From c3e5f78016f4319fb22126163d0ddbcac0bdeed5 Mon Sep 17 00:00:00 2001 From: Michael Adam Date: Tue, 16 Aug 2016 13:38:50 +0200 Subject: swrap: Optimization in (commented out) check_addr_port_in_use() Pair-Programmed-With: Stefan Metzmacher Signed-off-by: Michael Adam Signed-off-by: Stefan Metzmacher Reviewed-by: Andreas Schneider --- src/socket_wrapper.c | 6 ++++++ 1 file changed, 6 insertions(+) (limited to 'src') diff --git a/src/socket_wrapper.c b/src/socket_wrapper.c index b7de67c..51d22df 100644 --- a/src/socket_wrapper.c +++ b/src/socket_wrapper.c @@ -1403,6 +1403,7 @@ static struct socket_info *find_socket_info(int fd) static bool check_addr_port_in_use(const struct sockaddr *sa, socklen_t len) { struct socket_info_fd *f; + const struct socket_info *last_s = NULL; /* first catch invalid input */ switch (sa->sa_family) { @@ -1426,6 +1427,11 @@ static bool check_addr_port_in_use(const struct sockaddr *sa, socklen_t len) for (f = socket_fds; f; f = f->next) { struct socket_info *s = f->si; + if (s == last_s) { + continue; + } + last_s = s; + if (s->myname == NULL) { continue; } -- cgit