diff options
author | David Gibson <david@gibson.dropbear.id.au> | 2024-05-21 15:57:03 +1000 |
---|---|---|
committer | Stefano Brivio <sbrivio@redhat.com> | 2024-05-22 23:20:52 +0200 |
commit | 7a832a8a0edbdd5a705c1fe03fca0790a535ab11 (patch) | |
tree | 408f32fadc34b75ea9e7e166a5ba91880a4a1d73 /tcp_conn.h | |
parent | 1a20370b364ada675882e6a70d05b6e81418d64f (diff) | |
download | passt-7a832a8a0edbdd5a705c1fe03fca0790a535ab11.tar passt-7a832a8a0edbdd5a705c1fe03fca0790a535ab11.tar.gz passt-7a832a8a0edbdd5a705c1fe03fca0790a535ab11.tar.bz2 passt-7a832a8a0edbdd5a705c1fe03fca0790a535ab11.tar.lz passt-7a832a8a0edbdd5a705c1fe03fca0790a535ab11.tar.xz passt-7a832a8a0edbdd5a705c1fe03fca0790a535ab11.tar.zst passt-7a832a8a0edbdd5a705c1fe03fca0790a535ab11.zip |
flow: Properly type callbacks to protocol specific handlers
The flow dispatches deferred and timer handling for flows centrally, but
needs to call into protocol specific code for the handling of individual
flows. Currently this passes a general union flow *. It makes more sense
to pass the specific relevant flow type structure. That brings the check
on the flow type adjacent to casting to the union variant which it tags.
Arguably, this is a slight abstraction violation since it involves the
generic flow code using protocol specific types. It's already calling into
protocol specific functions, so I don't think this really makes any
difference.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: Stefano Brivio <sbrivio@redhat.com>
Diffstat (limited to 'tcp_conn.h')
-rw-r--r-- | tcp_conn.h | 6 |
1 files changed, 3 insertions, 3 deletions
@@ -155,9 +155,9 @@ struct tcp_splice_conn { extern int init_sock_pool4 [TCP_SOCK_POOL_SIZE]; extern int init_sock_pool6 [TCP_SOCK_POOL_SIZE]; -bool tcp_flow_defer(union flow *flow); -bool tcp_splice_flow_defer(union flow *flow); -void tcp_splice_timer(const struct ctx *c, union flow *flow); +bool tcp_flow_defer(const struct tcp_tap_conn *conn); +bool tcp_splice_flow_defer(struct tcp_splice_conn *conn); +void tcp_splice_timer(const struct ctx *c, struct tcp_splice_conn *conn); int tcp_conn_pool_sock(int pool[]); int tcp_conn_sock(const struct ctx *c, sa_family_t af); int tcp_sock_refill_pool(const struct ctx *c, int pool[], sa_family_t af); |