mirror of
https://passt.top/passt
synced 2025-05-25 18:45:37 +02:00
icmp: Use 'flowside' epoll references for ping sockets
Currently ping sockets use a custom epoll reference type which includes the ICMP id. However, now that we have entries in the flow table for ping flows, finding that is sufficient to get everything else we want, including the id. Therefore remove the icmp_epoll_ref type and use the general 'flowside' field for ping sockets. Having done this we no longer need separate EPOLL_TYPE_ICMP and EPOLL_TYPE_ICMPV6 reference types, because we can easily determine which case we have from the flow type. Merge both types into EPOLL_TYPE_PING. Signed-off-by: David Gibson <david@gibson.dropbear.id.au> Signed-off-by: Stefano Brivio <sbrivio@redhat.com>
This commit is contained in:
parent
02cbdb0b86
commit
4779dfe12f
5 changed files with 24 additions and 44 deletions
7
passt.h
7
passt.h
|
@ -59,10 +59,8 @@ enum epoll_type {
|
|||
EPOLL_TYPE_TCP_TIMER,
|
||||
/* UDP sockets */
|
||||
EPOLL_TYPE_UDP,
|
||||
/* IPv4 ICMP sockets */
|
||||
EPOLL_TYPE_ICMP,
|
||||
/* ICMPv6 sockets */
|
||||
EPOLL_TYPE_ICMPV6,
|
||||
/* ICMP/ICMPv6 ping sockets */
|
||||
EPOLL_TYPE_PING,
|
||||
/* inotify fd watching for end of netns (pasta) */
|
||||
EPOLL_TYPE_NSQUIT_INOTIFY,
|
||||
/* timer fd watching for end of netns, fallback for inotify (pasta) */
|
||||
|
@ -100,7 +98,6 @@ union epoll_ref {
|
|||
flow_sidx_t flowside;
|
||||
union tcp_listen_epoll_ref tcp_listen;
|
||||
union udp_epoll_ref udp;
|
||||
union icmp_epoll_ref icmp;
|
||||
uint32_t data;
|
||||
int nsdir_fd;
|
||||
};
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue