X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fshared%2Fsocket-util.h;h=9883ab0328276a85270b55bf5818a3dc0d676b16;hb=02dd6e189a6d2b7f3884ad4cdb3d8c85e009c565;hp=d42a2fee318d05e6a5050fa0bf95986ce89a0cdd;hpb=4d49b48c60a4ac66fa764fd7a6ae6d0bd0bd9c37;p=elogind.git diff --git a/src/shared/socket-util.h b/src/shared/socket-util.h index d42a2fee3..9883ab032 100644 --- a/src/shared/socket-util.h +++ b/src/shared/socket-util.h @@ -24,9 +24,9 @@ #include #include #include -#include #include #include +#include #include "macro.h" #include "util.h" @@ -38,6 +38,7 @@ union sockaddr_union { struct sockaddr_un un; struct sockaddr_nl nl; struct sockaddr_storage storage; + struct sockaddr_ll ll; }; typedef struct SocketAddress { @@ -68,6 +69,7 @@ int socket_address_parse(SocketAddress *a, const char *s); int socket_address_parse_netlink(SocketAddress *a, const char *s); int socket_address_print(const SocketAddress *a, char **p); int socket_address_verify(const SocketAddress *a) _pure_; +int socket_address_unlink(SocketAddress *a); bool socket_address_can_accept(const SocketAddress *a) _pure_; @@ -82,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); @@ -98,6 +101,9 @@ int sockaddr_pretty(const struct sockaddr *_sa, socklen_t salen, bool translate_ int getpeername_pretty(int fd, char **ret); int getsockname_pretty(int fd, char **ret); +int socknameinfo_pretty(union sockaddr_union *sa, socklen_t salen, char **_ret); +int getnameinfo_pretty(int fd, char **ret); + const char* socket_address_bind_ipv6_only_to_string(SocketAddressBindIPv6Only b) _const_; SocketAddressBindIPv6Only socket_address_bind_ipv6_only_from_string(const char *s) _pure_;