diff options
author | David Gibson <david@gibson.dropbear.id.au> | 2024-07-18 15:26:43 +1000 |
---|---|---|
committer | Stefano Brivio <sbrivio@redhat.com> | 2024-07-19 18:33:29 +0200 |
commit | 060f24e310b71f8813dbbc561a2e5a59d21feae0 (patch) | |
tree | 0b2d8532c057f97ec5f51840c1a4daeb12f79f23 /fwd.h | |
parent | 4cd753e65c591732b84c455b8eb9af44d09155cd (diff) | |
download | passt-060f24e310b71f8813dbbc561a2e5a59d21feae0.tar passt-060f24e310b71f8813dbbc561a2e5a59d21feae0.tar.gz passt-060f24e310b71f8813dbbc561a2e5a59d21feae0.tar.bz2 passt-060f24e310b71f8813dbbc561a2e5a59d21feae0.tar.lz passt-060f24e310b71f8813dbbc561a2e5a59d21feae0.tar.xz passt-060f24e310b71f8813dbbc561a2e5a59d21feae0.tar.zst passt-060f24e310b71f8813dbbc561a2e5a59d21feae0.zip |
flow, tcp: Flow based NAT and port forwarding for TCP
Currently the code to translate host side addresses and ports to guest side
addresses and ports, and vice versa, is scattered across the TCP code.
This includes both port redirection as controlled by the -t and -T options,
and our special case NAT controlled by the --no-map-gw option.
Gather this logic into fwd_nat_from_*() functions for each input
interface in fwd.c which take protocol and address information for the
initiating side and generates the pif and address information for the
forwarded side. This performs any NAT or port forwarding needed.
We create a flow_target() helper which applies those forwarding functions
as needed to automatically move a flow from INI to TGT state.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Signed-off-by: Stefano Brivio <sbrivio@redhat.com>
Diffstat (limited to 'fwd.h')
-rw-r--r-- | fwd.h | 9 |
1 files changed, 9 insertions, 0 deletions
@@ -7,6 +7,8 @@ #ifndef FWD_H #define FWD_H +struct flowside; + /* Number of ports for both TCP and UDP */ #define NUM_PORTS (1U << 16) @@ -42,4 +44,11 @@ void fwd_scan_ports_udp(struct fwd_ports *fwd, const struct fwd_ports *rev, const struct fwd_ports *tcp_rev); void fwd_scan_ports_init(struct ctx *c); +uint8_t fwd_nat_from_tap(const struct ctx *c, uint8_t proto, + const struct flowside *ini, struct flowside *tgt); +uint8_t fwd_nat_from_splice(const struct ctx *c, uint8_t proto, + const struct flowside *ini, struct flowside *tgt); +uint8_t fwd_nat_from_host(const struct ctx *c, uint8_t proto, + const struct flowside *ini, struct flowside *tgt); + #endif /* FWD_H */ |