package tcpip

  1. Overview
  2. Docs

Description

mirage-tcpip provides a networking stack for the Mirage operating system. It provides implementations for the following module types (which correspond with the similarly-named protocols):

  • IP (via the IPv4 and IPv6 modules)
  • ICMP
  • UDP
  • TCP

Tags

org:mirage

Published: 24 May 2022

README

mirage-tcpip - an OCaml TCP/IP networking stack

mirage-tcpip provides a networking stack for the Mirage operating system. It provides implementations for the following module types (which correspond with the similarly-named protocols):

  • IP (via the IPv4 and IPv6 modules)

  • ICMP

  • UDP

  • TCP

Implementations

There are two implementations of the IP, ICMP, UDP, and TCP module types - the socket stack, and the direct stack.

The socket stack

The socket stack uses socket calls to a traditional operating system to provide the functionality described in the module types.

See the src/stack-unix/ directory for the modules used as implementations of the socket stack.

The socket stack is used for testing or other applications which do not expect to run as unikernels.

The direct stack

The direct stack expects to write to a device implementing the NETIF module type defined for MirageOS.

See the src/ directory for the modules used as implementations of the direct stack, which is the expected stack for most MirageOS applications.

The direct stack is the only usable set of implementations for applications which will run as unikernels on a hypervisor target.

Community

License

mirage-tcpip is distributed under the ISC license.

Dependencies (25)

  1. metrics
  2. lru >= "0.3.0"
  3. mirage-flow >= "2.0.0" & < "4.0.0"
  4. arp >= "3.0.0"
  5. ethernet >= "3.0.0"
  6. randomconv < "0.2.0"
  7. duration
  8. logs >= "0.6.0"
  9. lwt-dllist
  10. lwt >= "4.0.0"
  11. fmt >= "0.8.7"
  12. mirage-profile >= "0.5"
  13. macaddr-cstruct
  14. macaddr >= "4.0.0"
  15. ipaddr >= "5.0.0"
  16. mirage-time >= "2.0.0"
  17. mirage-random >= "2.0.0" & < "4.0.0"
  18. mirage-clock >= "3.0.0"
  19. mirage-net >= "3.0.0"
  20. ppx_cstruct
  21. cstruct-lwt
  22. cstruct >= "6.0.0"
  23. ocaml >= "4.08.0"
  24. dune >= "2.7.0"
  25. conf-pkg-config build

Dev Dependencies (7)

  1. ipaddr-cstruct with-test
  2. mirage-random-test with-test & >= "0.1.0"
  3. mirage-clock-unix with-test & >= "3.0.0"
  4. pcap-format with-test
  5. alcotest with-test & >= "0.7.0"
  6. mirage-vnetif with-test & >= "0.5.0"
  7. bisect_ppx dev & >= "2.5.0"

Used by (45)

  1. arp < "0.2.0"
  2. caldav
  3. capnp-rpc-mirage >= "0.3.2" & < "0.6.0" | >= "0.9.0" & < "1.1" | >= "1.2.2"
  4. caqti-mirage
  5. charrua >= "1.5.0"
  6. charrua-client >= "1.4.0"
  7. charrua-client-lwt >= "0.11.1" & < "0.12.0"
  8. charrua-client-mirage >= "0.11.1" & < "0.12.0"
  9. charrua-core >= "0.11.2"
  10. charrua-server >= "1.4.0"
  11. charrua-unix >= "1.4.0"
  12. conduit = "0.10.0"
  13. conduit-mirage >= "2.3.0"
  14. dkim-mirage >= "0.4.0"
  15. dns-certify >= "6.1.3"
  16. dns-client >= "6.1.3" & < "7.0.0"
  17. dns-client-mirage
  18. dns-mirage >= "6.1.3"
  19. dns-resolver >= "6.1.3"
  20. dns-server >= "6.1.3"
  21. dns-stub >= "6.1.3"
  22. frenetic >= "5.0.0" & < "5.0.5"
  23. git-mirage >= "3.7.0"
  24. git-paf >= "3.7.0"
  25. git-unix >= "3.0.0"
  26. happy-eyeballs-mirage >= "0.1.2"
  27. http-mirage-client
  28. letsencrypt-mirage
  29. mirage-conduit >= "2.0.0" & < "2.2.0"
  30. mirage-dns < "2.6.0"
  31. mirage-monitoring
  32. mirage-nat >= "2.2.4" & < "3.0.2"
  33. mirage-protocols >= "8.0.0"
  34. mirage-qubes-ipv4 >= "0.8.3"
  35. mirage-stack >= "4.0.0"
  36. mirage-vnetif-stack
  37. mirage-www >= "1.1.0"
  38. packet >= "0.4.0"
  39. paf
  40. paf-cohttp
  41. paf-le >= "0.0.8"
  42. pgx_lwt_mirage >= "2.1"
  43. spoke
  44. tftp
  45. vpnkit >= "0.1.1"

Conflicts (3)

  1. result < "1.5"
  2. ocaml-freestanding < "0.4.1"
  3. mirage-xen < "6.0.0"