From e0aa3726103448097e5ad7cc6f427e142103a321 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Zbigniew=20J=C4=99drzejewski-Szmek?= Date: Sun, 9 Mar 2014 21:33:04 -0400 Subject: [PATCH] activate: export make_socket_fd Also improve logging to print out the parsed address on error. --- src/activate/activate.c | 21 +-------------------- src/shared/socket-label.c | 30 ++++++++++++++++++++++++++++++ src/shared/socket-util.h | 1 + 3 files changed, 32 insertions(+), 20 deletions(-) diff --git a/src/activate/activate.c b/src/activate/activate.c index 23c484ca9..8c5827399 100644 --- a/src/activate/activate.c +++ b/src/activate/activate.c @@ -59,25 +59,6 @@ static int add_epoll(int epoll_fd, int fd) { return 0; } -static int make_socket_fd(const char* address, int flags) { - SocketAddress a; - int fd, r; - - r = socket_address_parse(&a, address); - if (r < 0) { - log_error("Failed to parse socket: %s", strerror(-r)); - return r; - } - - fd = socket_address_listen(&a, flags, SOMAXCONN, SOCKET_ADDRESS_DEFAULT, NULL, false, false, 0755, 0644, NULL); - if (fd < 0) { - log_error("Failed to listen: %s", strerror(-r)); - return fd; - } - - return fd; -} - static int open_sockets(int *epoll_fd, bool accept) { char **address; int n, fd, r; @@ -119,7 +100,7 @@ static int open_sockets(int *epoll_fd, bool accept) { STRV_FOREACH(address, arg_listen) { - fd = make_socket_fd(*address, SOCK_STREAM | (arg_accept*SOCK_CLOEXEC)); + fd = make_socket_fd(LOG_DEBUG, *address, SOCK_STREAM | (arg_accept*SOCK_CLOEXEC)); if (fd < 0) { log_open(); log_error("Failed to open '%s': %s", *address, strerror(-fd)); diff --git a/src/shared/socket-label.c b/src/shared/socket-label.c index c8be17a1d..1e78dd256 100644 --- a/src/shared/socket-label.c +++ b/src/shared/socket-label.c @@ -143,3 +143,33 @@ int socket_address_listen( return r; } + +int make_socket_fd(int log_level, const char* address, int flags) { + SocketAddress a; + int fd, r; + + r = socket_address_parse(&a, address); + if (r < 0) { + log_error("Failed to parse socket: %s", strerror(-r)); + return r; + } + + fd = socket_address_listen(&a, flags, SOMAXCONN, SOCKET_ADDRESS_DEFAULT, + NULL, false, false, 0755, 0644, NULL); + if (fd < 0 || log_get_max_level() >= log_level) { + char _cleanup_free_ *p = NULL; + + r = socket_address_print(&a, &p); + if (r < 0) { + log_error("socket_address_print(): %s", strerror(-r)); + return r; + } + + if (fd < 0) + log_error("Failed to listen on %s: %s", p, strerror(-r)); + else + log_full(log_level, "Listening on %s", p); + } + + return fd; +} diff --git a/src/shared/socket-util.h b/src/shared/socket-util.h index 84ebc302f..efaaf82ab 100644 --- a/src/shared/socket-util.h +++ b/src/shared/socket-util.h @@ -84,6 +84,7 @@ int socket_address_listen( mode_t directory_mode, mode_t socket_mode, const char *label); +int make_socket_fd(int log_level, const char* address, int flags); bool socket_address_is(const SocketAddress *a, const char *s, int type); bool socket_address_is_netlink(const SocketAddress *a, const char *s); -- 2.30.2