X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fshared%2Fsocket-util.h;h=25c4a7e4f96a05e996c921e6af167fd7ec08610a;hb=30d7c9c472bd7be1b6a09d3bd5afd939988de990;hp=d42a2fee318d05e6a5050fa0bf95986ce89a0cdd;hpb=4d49b48c60a4ac66fa764fd7a6ae6d0bd0bd9c37;p=elogind.git diff --git a/src/shared/socket-util.h b/src/shared/socket-util.h index d42a2fee3..25c4a7e4f 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,12 @@ union sockaddr_union { struct sockaddr_un un; struct sockaddr_nl nl; struct sockaddr_storage storage; + struct sockaddr_ll ll; +}; + +union in_addr_union { + struct in_addr in; + struct in6_addr in6; }; typedef struct SocketAddress { @@ -68,6 +74,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 +89,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); @@ -103,3 +111,10 @@ SocketAddressBindIPv6Only socket_address_bind_ipv6_only_from_string(const char * int netlink_family_to_string_alloc(int b, char **s); int netlink_family_from_string(const char *s) _pure_; + +int in_addr_null(unsigned family, union in_addr_union *u); +int in_addr_equal(unsigned family, union in_addr_union *a, union in_addr_union *b); +int in_addr_prefix_intersect(unsigned family, const union in_addr_union *a, unsigned aprefixlen, const union in_addr_union *b, unsigned bprefixlen); +int in_addr_prefix_next(unsigned family, union in_addr_union *u, unsigned prefixlen); +int in_addr_to_string(unsigned family, const union in_addr_union *u, char **ret); +int in_addr_from_string(unsigned family, const char *s, union in_addr_union *ret);