X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?p=elogind.git;a=blobdiff_plain;f=src%2Fshared%2Fsocket-util.h;h=07d0aff72b3a95d7776781abc9c28d281fd3f998;hp=d42a2fee318d05e6a5050fa0bf95986ce89a0cdd;hb=f1e3bee216b9eac1d5b00415617cb2ff5e894c10;hpb=4d49b48c60a4ac66fa764fd7a6ae6d0bd0bd9c37 diff --git a/src/shared/socket-util.h b/src/shared/socket-util.h index d42a2fee3..07d0aff72 100644 --- a/src/shared/socket-util.h +++ b/src/shared/socket-util.h @@ -23,10 +23,11 @@ #include #include +#include #include -#include #include #include +#include #include "macro.h" #include "util.h" @@ -38,6 +39,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 +70,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 +85,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,8 +102,17 @@ 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_; int netlink_family_to_string_alloc(int b, char **s); int netlink_family_from_string(const char *s) _pure_; + +bool sockaddr_equal(const union sockaddr_union *a, const union sockaddr_union *b); + +#define ETHER_ADDR_TO_STRING_MAX (3*6) + +char* ether_addr_to_string(const struct ether_addr *addr, char buffer[ETHER_ADDR_TO_STRING_MAX]);