4 This file is part of systemd.
6 Copyright 2010 Lennart Poettering
8 systemd is free software; you can redistribute it and/or modify it
9 under the terms of the GNU Lesser General Public License as published by
10 the Free Software Foundation; either version 2.1 of the License, or
11 (at your option) any later version.
13 systemd is distributed in the hope that it will be useful, but
14 WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 Lesser General Public License for more details.
18 You should have received a copy of the GNU Lesser General Public License
19 along with systemd; If not, see <http://www.gnu.org/licenses/>.
22 #include <netinet/ether.h>
23 #include <netinet/in.h>
26 #include <sys/socket.h>
27 #include <sys/types.h>
29 #include <linux/netlink.h>
30 #include <linux/if_packet.h>
35 union sockaddr_union {
37 struct sockaddr_in in;
38 struct sockaddr_in6 in6;
39 struct sockaddr_un un;
40 struct sockaddr_nl nl;
41 struct sockaddr_storage storage;
42 struct sockaddr_ll ll;
45 #if 0 /// UNNEEDED by elogind
46 typedef struct SocketAddress {
47 union sockaddr_union sockaddr;
49 /* We store the size here explicitly due to the weird
50 * sockaddr_un semantics for abstract sockets */
53 /* Socket type, i.e. SOCK_STREAM, SOCK_DGRAM, ... */
56 /* Socket protocol, IPPROTO_xxx, usually 0, except for netlink */
60 typedef enum SocketAddressBindIPv6Only {
61 SOCKET_ADDRESS_DEFAULT,
63 SOCKET_ADDRESS_IPV6_ONLY,
64 _SOCKET_ADDRESS_BIND_IPV6_ONLY_MAX,
65 _SOCKET_ADDRESS_BIND_IPV6_ONLY_INVALID = -1
66 } SocketAddressBindIPv6Only;
68 #define socket_address_family(a) ((a)->sockaddr.sa.sa_family)
70 int socket_address_parse(SocketAddress *a, const char *s);
71 int socket_address_parse_and_warn(SocketAddress *a, const char *s);
72 int socket_address_parse_netlink(SocketAddress *a, const char *s);
73 int socket_address_print(const SocketAddress *a, char **p);
74 int socket_address_verify(const SocketAddress *a) _pure_;
75 int socket_address_unlink(SocketAddress *a);
77 bool socket_address_can_accept(const SocketAddress *a) _pure_;
79 int socket_address_listen(
80 const SocketAddress *a,
83 SocketAddressBindIPv6Only only,
84 const char *bind_to_device,
88 mode_t directory_mode,
91 int make_socket_fd(int log_level, const char* address, int type, int flags);
93 bool socket_address_is(const SocketAddress *a, const char *s, int type);
94 bool socket_address_is_netlink(const SocketAddress *a, const char *s);
96 bool socket_address_matches_fd(const SocketAddress *a, int fd);
98 bool socket_address_equal(const SocketAddress *a, const SocketAddress *b) _pure_;
100 const char* socket_address_get_path(const SocketAddress *a);
103 bool socket_ipv6_is_supported(void);
105 #if 0 /// UNNEEDED by elogind
106 int sockaddr_port(const struct sockaddr *_sa) _pure_;
108 int sockaddr_pretty(const struct sockaddr *_sa, socklen_t salen, bool translate_ipv6, bool include_port, char **ret);
109 int getpeername_pretty(int fd, bool include_port, char **ret);
110 int getsockname_pretty(int fd, char **ret);
112 int socknameinfo_pretty(union sockaddr_union *sa, socklen_t salen, char **_ret);
113 int getnameinfo_pretty(int fd, char **ret);
115 const char* socket_address_bind_ipv6_only_to_string(SocketAddressBindIPv6Only b) _const_;
116 SocketAddressBindIPv6Only socket_address_bind_ipv6_only_from_string(const char *s) _pure_;
118 int netlink_family_to_string_alloc(int b, char **s);
119 int netlink_family_from_string(const char *s) _pure_;
121 bool sockaddr_equal(const union sockaddr_union *a, const union sockaddr_union *b);
124 int fd_inc_sndbuf(int fd, size_t n);
125 int fd_inc_rcvbuf(int fd, size_t n);
126 #if 0 /// UNNEEDED by elogind
128 int ip_tos_to_string_alloc(int i, char **s);
129 int ip_tos_from_string(const char *s);
132 bool ifname_valid(const char *p);
134 int getpeercred(int fd, struct ucred *ucred);
135 int getpeersec(int fd, char **ret);
137 int send_one_fd_sa(int transport_fd,
139 const struct sockaddr *sa, socklen_t len,
141 #define send_one_fd(transport_fd, fd, flags) send_one_fd_sa(transport_fd, fd, NULL, 0, flags)
142 #if 0 /// UNNEEDED by elogind
143 int receive_one_fd(int transport_fd, int flags);
145 ssize_t next_datagram_size_fd(int fd);
147 int flush_accept(int fd);
150 #define CMSG_FOREACH(cmsg, mh) \
151 for ((cmsg) = CMSG_FIRSTHDR(mh); (cmsg); (cmsg) = CMSG_NXTHDR((mh), (cmsg)))
153 struct cmsghdr* cmsg_find(struct msghdr *mh, int level, int type, socklen_t length);
155 /* Covers only file system and abstract AF_UNIX socket addresses, but not unnamed socket addresses. */
156 #define SOCKADDR_UN_LEN(sa) \
158 const struct sockaddr_un *_sa = &(sa); \
159 assert(_sa->sun_family == AF_UNIX); \
160 offsetof(struct sockaddr_un, sun_path) + \
161 (_sa->sun_path[0] == 0 ? \
162 1 + strnlen(_sa->sun_path+1, sizeof(_sa->sun_path)-1) : \
163 strnlen(_sa->sun_path, sizeof(_sa->sun_path))); \