mirror of
https://github.com/mirage/qubes-mirage-firewall.git
synced 2025-01-19 02:51:30 -05:00
Handle errors writing to client
mirage-net-xen would report Netback_shutdown if we tried to write to a client after it had disconnected. Now we just log this and continue.
This commit is contained in:
parent
63cbb4bed0
commit
9c33da3bfd
@ -7,9 +7,19 @@ open Utils
|
|||||||
module Netback = Netchannel.Backend.Make(Netchannel.Xenstore.Make(OS.Xs))
|
module Netback = Netchannel.Backend.Make(Netchannel.Xenstore.Make(OS.Xs))
|
||||||
module ClientEth = Ethif.Make(Netback)
|
module ClientEth = Ethif.Make(Netback)
|
||||||
|
|
||||||
let src = Logs.Src.create "net" ~doc:"Client networking"
|
let src = Logs.Src.create "client_net" ~doc:"Client networking"
|
||||||
module Log = (val Logs.src_log src : Logs.LOG)
|
module Log = (val Logs.src_log src : Logs.LOG)
|
||||||
|
|
||||||
|
let writev eth data =
|
||||||
|
Lwt.catch
|
||||||
|
(fun () -> ClientEth.writev eth data)
|
||||||
|
(fun ex ->
|
||||||
|
(* Usually Netback_shutdown, because the client disconnected *)
|
||||||
|
Log.err (fun f -> f "uncaught exception trying to send to client:@\n@[<v2> %a@]@\nException: @[%s@]"
|
||||||
|
Cstruct.hexdump_pp (Cstruct.concat data) (Printexc.to_string ex));
|
||||||
|
Lwt.return ()
|
||||||
|
)
|
||||||
|
|
||||||
class client_iface eth ~gateway_ip ~client_ip client_mac : client_link = object
|
class client_iface eth ~gateway_ip ~client_ip client_mac : client_link = object
|
||||||
val queue = FrameQ.create (Ipaddr.V4.to_string client_ip)
|
val queue = FrameQ.create (Ipaddr.V4.to_string client_ip)
|
||||||
method my_mac = ClientEth.mac eth
|
method my_mac = ClientEth.mac eth
|
||||||
@ -19,7 +29,7 @@ class client_iface eth ~gateway_ip ~client_ip client_mac : client_link = object
|
|||||||
method writev ip =
|
method writev ip =
|
||||||
FrameQ.send queue (fun () ->
|
FrameQ.send queue (fun () ->
|
||||||
let eth_hdr = eth_header_ipv4 ~src:(ClientEth.mac eth) ~dst:client_mac in
|
let eth_hdr = eth_header_ipv4 ~src:(ClientEth.mac eth) ~dst:client_mac in
|
||||||
ClientEth.writev eth (fixup_checksums (Cstruct.concat (eth_hdr :: ip)))
|
writev eth (fixup_checksums (Cstruct.concat (eth_hdr :: ip)))
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -29,7 +39,7 @@ let clients : Cleanup.t IntMap.t ref = ref IntMap.empty
|
|||||||
let input_arp ~fixed_arp ~eth request =
|
let input_arp ~fixed_arp ~eth request =
|
||||||
match Client_eth.ARP.input fixed_arp request with
|
match Client_eth.ARP.input fixed_arp request with
|
||||||
| None -> return ()
|
| None -> return ()
|
||||||
| Some response -> ClientEth.write eth response
|
| Some response -> writev eth [response]
|
||||||
|
|
||||||
(** Handle an IPv4 packet from the client. *)
|
(** Handle an IPv4 packet from the client. *)
|
||||||
let input_ipv4 ~client_ip ~router frame packet =
|
let input_ipv4 ~client_ip ~router frame packet =
|
||||||
|
Loading…
Reference in New Issue
Block a user