package tcpip
OCaml TCP/IP networking stack, used in MirageOS
Install
Dune Dependency
Authors
Maintainers
Sources
tcpip-9.0.1.tbz
sha256=fac07ce986811cf5e3d71373d92b631cc30fbef548d6da21b0917212dcf90b03
sha512=01de13f560d58b1524c39619e4e4cb6ebbf069155eb43d0f264aa12b00e0cc8c39792719e3ca46585dd596b692b8e1e3f8c132f005ed9e2d77747c0c158bf4d9
doc/src/tcpip.udp/udp.ml.html
Source file udp.ml
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101
(* * Copyright (c) 2010-2014 Anil Madhavapeddy <anil@recoil.org> * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. *) open Lwt.Infix let src = Logs.Src.create "udp" ~doc:"Mirage UDP" module Log = (val Logs.src_log src : Logs.LOG) module Make (Ip : Tcpip.Ip.S) = struct type ipaddr = Ip.ipaddr type callback = src:ipaddr -> dst:ipaddr -> src_port:int -> Cstruct.t -> unit Lwt.t type error = [ `Ip of Ip.error ] let pp_error ppf (`Ip e) = Ip.pp_error ppf e type t = { ip : Ip.t; listeners : (int, callback) Hashtbl.t; } let pp_ip = Ip.pp_ipaddr let listen t ~port callback = if port < 0 || port > 65535 then raise (Invalid_argument (Printf.sprintf "invalid port number (%d)" port)) else Hashtbl.replace t.listeners port callback let unlisten t ~port = Hashtbl.remove t.listeners port (* TODO: ought we to check to make sure the destination is relevant here? Currently we process all incoming packets without making sure they're either unicast for us or otherwise interesting. *) let input t ~src ~dst buf = match Udp_packet.Unmarshal.of_cstruct buf with | Error s -> Log.debug (fun f -> f "Discarding received UDP message: error parsing: %s" s); Lwt.return_unit | Ok ({ Udp_packet.src_port; dst_port}, payload) -> match Hashtbl.find_opt t.listeners dst_port with | None -> Lwt.return_unit | Some fn -> fn ~src ~dst ~src_port payload let writev ?src ?src_port ?ttl ~dst ~dst_port t bufs = let src_port = match src_port with | None -> Randomconv.int ~bound:65535 (fun x -> Mirage_crypto_rng.generate x) | Some p -> p in let fill_hdr buf = let payload_size = Cstruct.lenv bufs in let ph = Ip.pseudoheader t.ip ?src dst `UDP (payload_size + Udp_wire.sizeof_udp) in let udp_header = Udp_packet.({ src_port; dst_port; }) in match Udp_packet.Marshal.into_cstruct udp_header buf ~pseudoheader:ph ~payload:(Cstruct.concat bufs) with | Ok () -> 8 | Error msg -> Logs.err (fun m -> m "error while assembling udp header: %s, ignoring" msg); 8 in Ip.write t.ip ?src dst ?ttl `UDP ~size:8 fill_hdr bufs >|= function | Ok () -> Ok () | Error e -> Log.err (fun f -> f "IP module couldn't send UDP packet to %a: %a" pp_ip dst Ip.pp_error e); (* we're supposed to make our best effort, and we did *) Ok () let write ?src ?src_port ?ttl ~dst ~dst_port t buf = writev ?src ?src_port ?ttl ~dst ~dst_port t [buf] let connect ip = Log.info (fun f -> f "UDP layer connected on %a" Fmt.(list ~sep:(any ", ") Ip.pp_prefix) (Ip.configured_ips ip)); let t = { ip ; listeners = Hashtbl.create 7 } in Lwt.return t let disconnect t = Log.info (fun f -> f "UDP layer disconnected on %a" Fmt.(list ~sep:(any ", ") Ip.pp_prefix) (Ip.configured_ips t.ip)); Lwt.return_unit end
sectionYPositions = computeSectionYPositions($el), 10)"
x-init="setTimeout(() => sectionYPositions = computeSectionYPositions($el), 10)"
>