mirror of
https://github.com/RGBCube/serenity
synced 2025-05-31 12:48:10 +00:00
IPv4: Support overriding the default TTL (64)
Made getsockopt() and setsockopt() virtual so we can handle them in the various Socket subclasses. The subclasses map kinda nicely to "levels". This will allow us to implement things like "traceroute", although.. I spent some time trying to do that, but then hit a wall when it turned out that the user-mode networking in QEMU doesn't preserve TTL in the ICMP packets passing through.
This commit is contained in:
parent
482d5295f1
commit
8cfb859368
11 changed files with 58 additions and 10 deletions
|
@ -77,7 +77,7 @@ int UDPSocket::protocol_send(const void* data, int data_length)
|
|||
local_port(),
|
||||
peer_address().to_string().characters(),
|
||||
peer_port());
|
||||
routing_decision.adapter->send_ipv4(routing_decision.next_hop, peer_address(), IPv4Protocol::UDP, buffer.data(), buffer.size());
|
||||
routing_decision.adapter->send_ipv4(routing_decision.next_hop, peer_address(), IPv4Protocol::UDP, buffer.data(), buffer.size(), ttl());
|
||||
return data_length;
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue