diff options
author | David Gibson <david@gibson.dropbear.id.au> | 2023-11-07 12:40:16 +1100 |
---|---|---|
committer | Stefano Brivio <sbrivio@redhat.com> | 2023-11-07 09:53:45 +0100 |
commit | f6d8dc235553761a2541f7a6b782488160db03a7 (patch) | |
tree | bd91d104ba900c99cc9dbabdc277e95bf628d845 /tcp.c | |
parent | 732e24937618f5848e182dc8a38eb170cf079394 (diff) | |
download | passt-f6d8dc235553761a2541f7a6b782488160db03a7.tar passt-f6d8dc235553761a2541f7a6b782488160db03a7.tar.gz passt-f6d8dc235553761a2541f7a6b782488160db03a7.tar.bz2 passt-f6d8dc235553761a2541f7a6b782488160db03a7.tar.lz passt-f6d8dc235553761a2541f7a6b782488160db03a7.tar.xz passt-f6d8dc235553761a2541f7a6b782488160db03a7.tar.zst passt-f6d8dc235553761a2541f7a6b782488160db03a7.zip |
pif: Pass originating pif to tap handler functions
For now, packets passed to the various *_tap_handler() functions always
come from the single "tap" interface. We want to allow the possibility to
broaden that in future. As preparation for that, have the code in tap.c
pass the pif id of the originating interface to each of those handler
functions.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: Stefano Brivio <sbrivio@redhat.com>
Diffstat (limited to 'tcp.c')
-rw-r--r-- | tcp.c | 6 |
1 files changed, 5 insertions, 1 deletions
@@ -2562,6 +2562,7 @@ static void tcp_conn_from_sock_finish(struct ctx *c, struct tcp_tap_conn *conn, /** * tcp_tap_handler() - Handle packets from tap and state transitions * @c: Execution context + * @pif: pif on which the packet is arriving * @af: Address family, AF_INET or AF_INET6 * @saddr: Source address * @daddr: Destination address @@ -2571,7 +2572,8 @@ static void tcp_conn_from_sock_finish(struct ctx *c, struct tcp_tap_conn *conn, * * Return: count of consumed packets */ -int tcp_tap_handler(struct ctx *c, int af, const void *saddr, const void *daddr, +int tcp_tap_handler(struct ctx *c, uint8_t pif, int af, + const void *saddr, const void *daddr, const struct pool *p, int idx, const struct timespec *now) { struct tcp_tap_conn *conn; @@ -2581,6 +2583,8 @@ int tcp_tap_handler(struct ctx *c, int af, const void *saddr, const void *daddr, char *opts; int count; + (void)pif; + th = packet_get(p, idx, 0, sizeof(*th), &len); if (!th) return 1; |