diff options
author | David Gibson <david@gibson.dropbear.id.au> | 2022-09-24 19:08:18 +1000 |
---|---|---|
committer | Stefano Brivio <sbrivio@redhat.com> | 2022-09-24 14:48:35 +0200 |
commit | 1467a35b5af93a5f7c6678e1c6a8d9b4c191160c (patch) | |
tree | ba8dcf1b85c3becb08d9d66b64e79ff4eb7b120e /udp.c | |
parent | 163dc5f18899808e97b92ddae0314928c903bb4b (diff) | |
download | passt-1467a35b5af93a5f7c6678e1c6a8d9b4c191160c.tar passt-1467a35b5af93a5f7c6678e1c6a8d9b4c191160c.tar.gz passt-1467a35b5af93a5f7c6678e1c6a8d9b4c191160c.tar.bz2 passt-1467a35b5af93a5f7c6678e1c6a8d9b4c191160c.tar.lz passt-1467a35b5af93a5f7c6678e1c6a8d9b4c191160c.tar.xz passt-1467a35b5af93a5f7c6678e1c6a8d9b4c191160c.tar.zst passt-1467a35b5af93a5f7c6678e1c6a8d9b4c191160c.zip |
udp: Delay initialization of UDP reversed port mapping table
Because it's connectionless, when mapping UDP ports we need, in addition
to the table of deltas for destination ports needed by TCP, we need an
inverted table to translate the source ports on return packets.
Currently we fill out the inverted table at the same time we construct the
main table in udp_remap_to_tap() and udp_remap_to_init(). However, we
don't use either table until after we've initialized UDP, so we can delay
the construction of the reverse table to udp_init(). This makes the
configuration more symmetric between TCP and UDP which will enable further
cleanups.
Signed-off-by: David Gibson <david@gibson.dropbear.id.au>
Diffstat (limited to 'udp.c')
-rw-r--r-- | udp.c | 25 |
1 files changed, 22 insertions, 3 deletions
@@ -109,6 +109,7 @@ #include <sys/uio.h> #include <unistd.h> #include <time.h> +#include <assert.h> #include "checksum.h" #include "util.h" @@ -266,7 +267,6 @@ static struct mmsghdr udp_mmh_sendto [UDP_SPLICE_FRAMES]; void udp_remap_to_tap(struct ctx *c, in_port_t port, in_port_t delta) { c->udp.fwd_in.f.delta[port] = delta; - c->udp.fwd_in.rdelta[port + delta] = USHRT_MAX - delta; } /** @@ -278,7 +278,23 @@ void udp_remap_to_tap(struct ctx *c, in_port_t port, in_port_t delta) void udp_remap_to_init(struct ctx *c, in_port_t port, in_port_t delta) { c->udp.fwd_out.f.delta[port] = delta; - c->udp.fwd_out.rdelta[port + delta] = USHRT_MAX - delta; +} + +/** + * udp_invert_portmap() - Compute reverse port translations for return packets + * @fwd: Port forwarding configuration to compute reverse map for + */ +static void udp_invert_portmap(struct udp_port_fwd *fwd) +{ + int i; + + assert(ARRAY_SIZE(fwd->f.delta) == ARRAY_SIZE(fwd->rdelta)); + for (i = 0; i < ARRAY_SIZE(fwd->f.delta); i++) { + in_port_t delta = fwd->f.delta[i]; + + if (delta) + fwd->rdelta[(in_port_t)i + delta] = USHRT_MAX - delta; + } } /** @@ -1267,7 +1283,7 @@ static void udp_splice_iov_init(void) * * Return: 0 */ -int udp_init(const struct ctx *c) +int udp_init(struct ctx *c) { if (c->ifi4) udp_sock4_iov_init(); @@ -1275,6 +1291,9 @@ int udp_init(const struct ctx *c) if (c->ifi6) udp_sock6_iov_init(); + udp_invert_portmap(&c->udp.fwd_in); + udp_invert_portmap(&c->udp.fwd_out); + if (c->mode == MODE_PASTA) { udp_splice_iov_init(); NS_CALL(udp_sock_init_ns, c); |