mirror of
https://passt.top/passt
synced 2025-05-22 09:15:34 +02:00
conf: Add command line switch to enable IP_FREEBIND socket option
In a couple of recent reports, we've seen that it can be useful for pasta to forward ports from addresses which are not currently configured on the host, but might be in future. That can be done with the sysctl net.ipv4.ip_nonlocal_bind, but that does require CAP_NET_ADMIN to set in the first place. We can allow the same thing on a per-socket basis with the IP_FREEBIND (or IPV6_FREEBIND) socket option. Add a --freebind command line argument to enable this socket option on all listening sockets. Link: https://bugs.passt.top/show_bug.cgi?id=101 Signed-off-by: David Gibson <david@gibson.dropbear.id.au> Signed-off-by: Stefano Brivio <sbrivio@redhat.com>
This commit is contained in:
parent
151dbe0d3d
commit
9d66df9a9a
4 changed files with 30 additions and 0 deletions
2
conf.c
2
conf.c
|
@ -836,6 +836,7 @@ static void usage(const char *name, FILE *f, int status)
|
|||
" --no-ndp Disable NDP responses\n"
|
||||
" --no-dhcpv6 Disable DHCPv6 server\n"
|
||||
" --no-ra Disable router advertisements\n"
|
||||
" --freebind Bind to any address for forwarding\n"
|
||||
" --no-map-gw Don't map gateway address to host\n"
|
||||
" -4, --ipv4-only Enable IPv4 operation only\n"
|
||||
" -6, --ipv6-only Enable IPv6 operation only\n");
|
||||
|
@ -1255,6 +1256,7 @@ void conf(struct ctx *c, int argc, char **argv)
|
|||
{"no-dhcpv6", no_argument, &c->no_dhcpv6, 1 },
|
||||
{"no-ndp", no_argument, &c->no_ndp, 1 },
|
||||
{"no-ra", no_argument, &c->no_ra, 1 },
|
||||
{"freebind", no_argument, &c->freebind, 1 },
|
||||
{"no-map-gw", no_argument, &no_map_gw, 1 },
|
||||
{"ipv4-only", no_argument, NULL, '4' },
|
||||
{"ipv6-only", no_argument, NULL, '6' },
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue