aboutgitcodebugslistschat
path: root/tcp.h
diff options
context:
space:
mode:
authorStefano Brivio <sbrivio@redhat.com>2023-02-16 01:29:55 +0100
committerStefano Brivio <sbrivio@redhat.com>2023-02-16 17:33:49 +0100
commit3d0de2c1d72757a7754532f788b53102420e987d (patch)
tree5df61a9982c1660a41d25555929cc1bc21ba1df9 /tcp.h
parentb4f13c2b189c24ae1ef7fee562d5be7147efd477 (diff)
downloadpasst-3d0de2c1d72757a7754532f788b53102420e987d.tar
passt-3d0de2c1d72757a7754532f788b53102420e987d.tar.gz
passt-3d0de2c1d72757a7754532f788b53102420e987d.tar.bz2
passt-3d0de2c1d72757a7754532f788b53102420e987d.tar.lz
passt-3d0de2c1d72757a7754532f788b53102420e987d.tar.xz
passt-3d0de2c1d72757a7754532f788b53102420e987d.tar.zst
passt-3d0de2c1d72757a7754532f788b53102420e987d.zip
conf, tcp, udp: Exit if we fail to bind sockets for all given ports
passt supports ranges of forwarded ports as well as 'all' for TCP and UDP, so it might be convenient to proceed if we fail to bind only some of the desired ports. But if we fail to bind even a single port for a given specification, we're clearly, unexpectedly, conflicting with another network service. In that case, report failure and exit. Reported-by: Yalan Zhang <yalzhang@redhat.com> Signed-off-by: Stefano Brivio <sbrivio@redhat.com> Reviewed-by: David Gibson <david@gibson.dropbear.id.au>
Diffstat (limited to 'tcp.h')
-rw-r--r--tcp.h4
1 files changed, 2 insertions, 2 deletions
diff --git a/tcp.h b/tcp.h
index 236038f..5527c5b 100644
--- a/tcp.h
+++ b/tcp.h
@@ -17,8 +17,8 @@ void tcp_sock_handler(struct ctx *c, union epoll_ref ref, uint32_t events,
const struct timespec *now);
int tcp_tap_handler(struct ctx *c, int af, const void *addr,
const struct pool *p, const struct timespec *now);
-void tcp_sock_init(const struct ctx *c, sa_family_t af, const void *addr,
- const char *ifname, in_port_t port);
+int tcp_sock_init(const struct ctx *c, sa_family_t af, const void *addr,
+ const char *ifname, in_port_t port);
int tcp_init(struct ctx *c);
void tcp_timer(struct ctx *c, const struct timespec *ts);
void tcp_defer_handler(struct ctx *c);