1 /*
2  * Copyright (C) 2008 The Android Open Source Project
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *  * Redistributions of source code must retain the above copyright
9  *    notice, this list of conditions and the following disclaimer.
10  *  * Redistributions in binary form must reproduce the above copyright
11  *    notice, this list of conditions and the following disclaimer in
12  *    the documentation and/or other materials provided with the
13  *    distribution.
14  *
15  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
18  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22  * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
23  * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
25  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26  * SUCH DAMAGE.
27  */
28 
29 #ifndef _SYS_SOCKET_H_
30 #define _SYS_SOCKET_H_
31 
32 #include <sys/cdefs.h>
33 #include <sys/types.h>
34 #include <linux/socket.h>
35 
36 #include <asm/fcntl.h>
37 #include <asm/socket.h>
38 #include <linux/sockios.h>
39 #include <linux/uio.h>
40 #include <linux/types.h>
41 #include <linux/compiler.h>
42 
43 #include <bits/sa_family_t.h>
44 
45 __BEGIN_DECLS
46 
47 #define sockaddr_storage __kernel_sockaddr_storage
48 
49 struct timespec;
50 
51 #ifdef __mips__
52 #define SOCK_DGRAM      1
53 #define SOCK_STREAM     2
54 #else
55 #define SOCK_STREAM     1
56 #define SOCK_DGRAM      2
57 #endif
58 #define SOCK_RAW        3
59 #define SOCK_RDM        4
60 #define SOCK_SEQPACKET  5
61 #define SOCK_DCCP       6
62 #define SOCK_PACKET     10
63 
64 #define SOCK_CLOEXEC O_CLOEXEC
65 #define SOCK_NONBLOCK O_NONBLOCK
66 
67 enum {
68   SHUT_RD = 0,
69 #define SHUT_RD         SHUT_RD
70   SHUT_WR,
71 #define SHUT_WR         SHUT_WR
72   SHUT_RDWR
73 #define SHUT_RDWR       SHUT_RDWR
74 };
75 
76 struct sockaddr {
77   sa_family_t sa_family;
78   char sa_data[14];
79 };
80 
81 struct linger {
82   int l_onoff;
83   int l_linger;
84 };
85 
86 struct msghdr {
87   void* msg_name;
88   socklen_t msg_namelen;
89   struct iovec* msg_iov;
90   size_t msg_iovlen;
91   void* msg_control;
92   size_t msg_controllen;
93   int msg_flags;
94 };
95 
96 struct mmsghdr {
97   struct msghdr msg_hdr;
98   unsigned int msg_len;
99 };
100 
101 struct cmsghdr {
102   size_t cmsg_len;
103   int cmsg_level;
104   int cmsg_type;
105 };
106 
107 #define CMSG_NXTHDR(mhdr, cmsg) __cmsg_nxthdr((mhdr), (cmsg))
108 #define CMSG_ALIGN(len) ( ((len)+sizeof(long)-1) & ~(sizeof(long)-1) )
109 #define CMSG_DATA(cmsg) (((unsigned char*)(cmsg) + CMSG_ALIGN(sizeof(struct cmsghdr))))
110 #define CMSG_SPACE(len) (CMSG_ALIGN(sizeof(struct cmsghdr)) + CMSG_ALIGN(len))
111 #define CMSG_LEN(len) (CMSG_ALIGN(sizeof(struct cmsghdr)) + (len))
112 #define CMSG_FIRSTHDR(msg) \
113   ((msg)->msg_controllen >= sizeof(struct cmsghdr) \
114    ? (struct cmsghdr*) (msg)->msg_control : (struct cmsghdr*) NULL)
115 #define CMSG_OK(mhdr, cmsg) ((cmsg)->cmsg_len >= sizeof(struct cmsghdr) &&   (cmsg)->cmsg_len <= (unsigned long)   ((mhdr)->msg_controllen -   ((char*)(cmsg) - (char*)(mhdr)->msg_control)))
116 
117 #if __ANDROID_API__ >= __ANDROID_API_L__
118 struct cmsghdr* __cmsg_nxthdr(struct msghdr*, struct cmsghdr*) __INTRODUCED_IN(21);
119 #else
120 /* TODO(danalbert): Move this into libandroid_support. */
__cmsg_nxthdr(struct msghdr * msg,struct cmsghdr * cmsg)121 static inline struct cmsghdr* __cmsg_nxthdr(struct msghdr* msg, struct cmsghdr* cmsg) {
122   struct cmsghdr* ptr =
123       __BIONIC_CAST(reinterpret_cast, struct cmsghdr*,
124                     (__BIONIC_CAST(reinterpret_cast, char*, cmsg) + CMSG_ALIGN(cmsg->cmsg_len)));
125   size_t len = __BIONIC_CAST(reinterpret_cast, char*, ptr + 1) -
126                __BIONIC_CAST(reinterpret_cast, char*, msg->msg_control);
127   if (len > msg->msg_controllen) {
128     return NULL;
129   }
130   return ptr;
131 }
132 #endif /* __ANDROID_API__ >= __ANDROID_API_L__ */
133 
134 #define SCM_RIGHTS 0x01
135 #define SCM_CREDENTIALS 0x02
136 #define SCM_SECURITY 0x03
137 
138 struct ucred {
139   pid_t pid;
140   uid_t uid;
141   gid_t gid;
142 };
143 
144 #define AF_UNSPEC 0
145 #define AF_UNIX 1
146 #define AF_LOCAL 1
147 #define AF_INET 2
148 #define AF_AX25 3
149 #define AF_IPX 4
150 #define AF_APPLETALK 5
151 #define AF_NETROM 6
152 #define AF_BRIDGE 7
153 #define AF_ATMPVC 8
154 #define AF_X25 9
155 #define AF_INET6 10
156 #define AF_ROSE 11
157 #define AF_DECnet 12
158 #define AF_NETBEUI 13
159 #define AF_SECURITY 14
160 #define AF_KEY 15
161 #define AF_NETLINK 16
162 #define AF_ROUTE AF_NETLINK
163 #define AF_PACKET 17
164 #define AF_ASH 18
165 #define AF_ECONET 19
166 #define AF_ATMSVC 20
167 #define AF_RDS 21
168 #define AF_SNA 22
169 #define AF_IRDA 23
170 #define AF_PPPOX 24
171 #define AF_WANPIPE 25
172 #define AF_LLC 26
173 #define AF_CAN 29
174 #define AF_TIPC 30
175 #define AF_BLUETOOTH 31
176 #define AF_IUCV 32
177 #define AF_RXRPC 33
178 #define AF_ISDN 34
179 #define AF_PHONET 35
180 #define AF_IEEE802154 36
181 #define AF_CAIF 37
182 #define AF_ALG 38
183 #define AF_NFC 39
184 #define AF_VSOCK 40
185 #define AF_KCM 41
186 #define AF_QIPCRTR 42
187 #define AF_MAX 43
188 
189 #define PF_UNSPEC AF_UNSPEC
190 #define PF_UNIX AF_UNIX
191 #define PF_LOCAL AF_LOCAL
192 #define PF_INET AF_INET
193 #define PF_AX25 AF_AX25
194 #define PF_IPX AF_IPX
195 #define PF_APPLETALK AF_APPLETALK
196 #define PF_NETROM AF_NETROM
197 #define PF_BRIDGE AF_BRIDGE
198 #define PF_ATMPVC AF_ATMPVC
199 #define PF_X25 AF_X25
200 #define PF_INET6 AF_INET6
201 #define PF_ROSE AF_ROSE
202 #define PF_DECnet AF_DECnet
203 #define PF_NETBEUI AF_NETBEUI
204 #define PF_SECURITY AF_SECURITY
205 #define PF_KEY AF_KEY
206 #define PF_NETLINK AF_NETLINK
207 #define PF_ROUTE AF_ROUTE
208 #define PF_PACKET AF_PACKET
209 #define PF_ASH AF_ASH
210 #define PF_ECONET AF_ECONET
211 #define PF_ATMSVC AF_ATMSVC
212 #define PF_RDS AF_RDS
213 #define PF_SNA AF_SNA
214 #define PF_IRDA AF_IRDA
215 #define PF_PPPOX AF_PPPOX
216 #define PF_WANPIPE AF_WANPIPE
217 #define PF_LLC AF_LLC
218 #define PF_CAN AF_CAN
219 #define PF_TIPC AF_TIPC
220 #define PF_BLUETOOTH AF_BLUETOOTH
221 #define PF_IUCV AF_IUCV
222 #define PF_RXRPC AF_RXRPC
223 #define PF_ISDN AF_ISDN
224 #define PF_PHONET AF_PHONET
225 #define PF_IEEE802154 AF_IEEE802154
226 #define PF_CAIF AF_CAIF
227 #define PF_ALG AF_ALG
228 #define PF_NFC AF_NFC
229 #define PF_VSOCK AF_VSOCK
230 #define PF_KCM AF_KCM
231 #define PF_QIPCRTR AF_QIPCRTR
232 #define PF_MAX AF_MAX
233 
234 #define SOMAXCONN 128
235 
236 #define MSG_OOB 1
237 #define MSG_PEEK 2
238 #define MSG_DONTROUTE 4
239 #define MSG_TRYHARD 4
240 #define MSG_CTRUNC 8
241 #define MSG_PROBE 0x10
242 #define MSG_TRUNC 0x20
243 #define MSG_DONTWAIT 0x40
244 #define MSG_EOR 0x80
245 #define MSG_WAITALL 0x100
246 #define MSG_FIN 0x200
247 #define MSG_SYN 0x400
248 #define MSG_CONFIRM 0x800
249 #define MSG_RST 0x1000
250 #define MSG_ERRQUEUE 0x2000
251 #define MSG_NOSIGNAL 0x4000
252 #define MSG_MORE 0x8000
253 #define MSG_WAITFORONE 0x10000
254 #define MSG_BATCH 0x40000
255 #define MSG_FASTOPEN 0x20000000
256 #define MSG_CMSG_CLOEXEC 0x40000000
257 #define MSG_EOF MSG_FIN
258 #define MSG_CMSG_COMPAT 0
259 
260 #define SOL_IP 0
261 #define SOL_TCP 6
262 #define SOL_UDP 17
263 #define SOL_IPV6 41
264 #define SOL_ICMPV6 58
265 #define SOL_SCTP 132
266 #define SOL_RAW 255
267 #define SOL_IPX 256
268 #define SOL_AX25 257
269 #define SOL_ATALK 258
270 #define SOL_NETROM 259
271 #define SOL_ROSE 260
272 #define SOL_DECNET 261
273 #define SOL_X25 262
274 #define SOL_PACKET 263
275 #define SOL_ATM 264
276 #define SOL_AAL 265
277 #define SOL_IRDA 266
278 #define SOL_NETBEUI 267
279 #define SOL_LLC 268
280 #define SOL_DCCP 269
281 #define SOL_NETLINK 270
282 #define SOL_TIPC 271
283 #define SOL_RXRPC 272
284 #define SOL_PPPOL2TP 273
285 #define SOL_BLUETOOTH 274
286 #define SOL_PNPIPE 275
287 #define SOL_RDS 276
288 #define SOL_IUCV 277
289 #define SOL_CAIF 278
290 #define SOL_ALG 279
291 #define SOL_NFC 280
292 #define SOL_KCM 281
293 
294 #define IPX_TYPE 1
295 
296 #ifdef __i386__
297 # define __socketcall extern __attribute__((__cdecl__))
298 #else
299 # define __socketcall extern
300 #endif
301 
302 __socketcall int accept(int, struct sockaddr*, socklen_t*);
303 __socketcall int accept4(int, struct sockaddr*, socklen_t*, int) __INTRODUCED_IN(21);
304 __socketcall int bind(int, const struct sockaddr*, socklen_t);
305 __socketcall int connect(int, const struct sockaddr*, socklen_t);
306 __socketcall int getpeername(int, struct sockaddr*, socklen_t*);
307 __socketcall int getsockname(int, struct sockaddr*, socklen_t*);
308 __socketcall int getsockopt(int, int, int, void*, socklen_t*);
309 __socketcall int listen(int, int);
310 __socketcall int recvmmsg(int, struct mmsghdr*, unsigned int, int, const struct timespec*)
311   __INTRODUCED_IN(21);
312 __socketcall ssize_t recvmsg(int, struct msghdr*, int);
313 __socketcall int sendmmsg(int, const struct mmsghdr*, unsigned int, int) __INTRODUCED_IN(21);
314 __socketcall ssize_t sendmsg(int, const struct msghdr*, int);
315 __socketcall int setsockopt(int, int, int, const void*, socklen_t);
316 __socketcall int shutdown(int, int);
317 __socketcall int socket(int, int, int);
318 __socketcall int socketpair(int, int, int, int*);
319 
320 ssize_t recv(int, void*, size_t, int) __overloadable __RENAME_CLANG(recv);
321 ssize_t send(int, const void*, size_t, int) __overloadable __RENAME_CLANG(send);
322 
323 __socketcall ssize_t sendto(int, const void*, size_t, int, const struct sockaddr*, socklen_t)
324         __overloadable __RENAME_CLANG(sendto);
325 __socketcall ssize_t recvfrom(int, void*, size_t, int, struct sockaddr*,
326         socklen_t*) __overloadable __RENAME_CLANG(recvfrom);
327 
328 extern ssize_t __sendto_chk(int, const void*, size_t, size_t, int, const struct sockaddr*,
329         socklen_t) __INTRODUCED_IN(26);
330 ssize_t __recvfrom_chk(int, void*, size_t, size_t, int, struct sockaddr*,
331         socklen_t*) __INTRODUCED_IN(21);
332 
333 #if defined(__BIONIC_FORTIFY)
334 
335 #define __recvfrom_bad_size "recvfrom called with size bigger than buffer"
336 #define __sendto_bad_size "sendto called with size bigger than buffer"
337 #if defined(__clang__)
338 #if __ANDROID_API__ >= __ANDROID_API_N__
339 __BIONIC_ERROR_FUNCTION_VISIBILITY
340 ssize_t recvfrom(int fd, void* const buf __pass_object_size0, size_t len,
341                  int flags, struct sockaddr* src_addr, socklen_t* addr_len)
342         __overloadable
343         __enable_if(__bos(buf) != __BIONIC_FORTIFY_UNKNOWN_SIZE &&
344                     __bos(buf) < len, "selected when the buffer is too small")
345         __errorattr(__recvfrom_bad_size);
346 
347 __BIONIC_FORTIFY_INLINE
recvfrom(int fd,void * const buf __pass_object_size0,size_t len,int flags,struct sockaddr * src_addr,socklen_t * addr_len)348 ssize_t recvfrom(int fd, void* const buf __pass_object_size0, size_t len,
349                  int flags, struct sockaddr* src_addr, socklen_t* addr_len)
350       __overloadable {
351   size_t bos = __bos0(buf);
352 
353   if (bos == __BIONIC_FORTIFY_UNKNOWN_SIZE) {
354     return __call_bypassing_fortify(recvfrom)(fd, buf, len, flags, src_addr,
355               addr_len);
356   }
357 
358   return __recvfrom_chk(fd, buf, len, bos, flags, src_addr, addr_len);
359 }
360 #endif /* __ANDROID_API__ >= __ANDROID_API_N__ */
361 
362 #if __ANDROID_API__ >= __ANDROID_API_N_MR1__
363 __BIONIC_ERROR_FUNCTION_VISIBILITY
364 ssize_t sendto(int fd, const void* buf, size_t len, int flags,
365                const struct sockaddr* dest_addr, socklen_t addr_len)
366         __overloadable
367         __enable_if(__bos0(buf) != __BIONIC_FORTIFY_UNKNOWN_SIZE &&
368                     __bos0(buf) < len, "selected when the buffer is too small")
369         __errorattr(__sendto_bad_size);
370 
371 __BIONIC_FORTIFY_INLINE
sendto(int fd,const void * const buf __pass_object_size0,size_t len,int flags,const struct sockaddr * dest_addr,socklen_t addr_len)372 ssize_t sendto(int fd, const void* const buf __pass_object_size0, size_t len,
373                int flags, const struct sockaddr* dest_addr, socklen_t addr_len)
374       __overloadable {
375   size_t bos = __bos0(buf);
376 
377   if (bos == __BIONIC_FORTIFY_UNKNOWN_SIZE) {
378     return __call_bypassing_fortify(sendto)(fd, buf, len, flags, dest_addr,
379               addr_len);
380   }
381 
382   return __sendto_chk(fd, buf, len, bos, flags, dest_addr, addr_len);
383 }
384 
385 __BIONIC_ERROR_FUNCTION_VISIBILITY
386 ssize_t send(int socket, const void* buf, size_t len, int flags)
387         __overloadable
388         __enable_if(__bos0(buf) != __BIONIC_FORTIFY_UNKNOWN_SIZE &&
389                     __bos0(buf) < len, "selected when the buffer is too small")
390         __errorattr("send called with size bigger than buffer");
391 #endif /* __ANDROID_API__ >= __ANDROID_API_N_MR1__ */
392 
393 #else /* defined(__clang__) */
394 ssize_t __recvfrom_real(int, void*, size_t, int, struct sockaddr*, socklen_t*) __RENAME(recvfrom);
395 __errordecl(__recvfrom_error, __recvfrom_bad_size);
396 
397 extern ssize_t __sendto_real(int, const void*, size_t, int, const struct sockaddr*, socklen_t)
398         __RENAME(sendto);
399 __errordecl(__sendto_error, __sendto_bad_size);
400 
401 #if __ANDROID_API__ >= __ANDROID_API_N__
402 __BIONIC_FORTIFY_INLINE
recvfrom(int fd,void * buf,size_t len,int flags,struct sockaddr * src_addr,socklen_t * addr_len)403 ssize_t recvfrom(int fd, void* buf, size_t len, int flags,
404                  struct sockaddr* src_addr, socklen_t* addr_len) {
405   size_t bos = __bos0(buf);
406 
407   if (bos == __BIONIC_FORTIFY_UNKNOWN_SIZE) {
408     return __recvfrom_real(fd, buf, len, flags, src_addr, addr_len);
409   }
410 
411   if (__builtin_constant_p(len) && (len <= bos)) {
412     return __recvfrom_real(fd, buf, len, flags, src_addr, addr_len);
413   }
414 
415   if (__builtin_constant_p(len) && (len > bos)) {
416     __recvfrom_error();
417   }
418 
419   return __recvfrom_chk(fd, buf, len, bos, flags, src_addr, addr_len);
420 }
421 #endif /* __ANDROID_API__ >= __ANDROID_API_N__ */
422 
423 #if __ANDROID_API__ >= __ANDROID_API_N_MR1__
424 __BIONIC_FORTIFY_INLINE
sendto(int fd,const void * buf,size_t len,int flags,const struct sockaddr * dest_addr,socklen_t addr_len)425 ssize_t sendto(int fd, const void* buf, size_t len, int flags,
426                const struct sockaddr* dest_addr, socklen_t addr_len) {
427   size_t bos = __bos0(buf);
428 
429   if (bos == __BIONIC_FORTIFY_UNKNOWN_SIZE) {
430     return __sendto_real(fd, buf, len, flags, dest_addr, addr_len);
431   }
432 
433   if (__builtin_constant_p(len) && (len <= bos)) {
434     return __sendto_real(fd, buf, len, flags, dest_addr, addr_len);
435   }
436 
437   if (__builtin_constant_p(len) && (len > bos)) {
438     __sendto_error();
439   }
440 
441   return __sendto_chk(fd, buf, len, bos, flags, dest_addr, addr_len);
442 }
443 #endif /* __ANDROID_API__ >= __ANDROID_API_N_MR1__ */
444 
445 #endif /* defined(__clang__) */
446 #undef __recvfrom_bad_size
447 #undef __sendto_bad_size
448 
449 __BIONIC_FORTIFY_INLINE
recv(int socket,void * const buf __pass_object_size0,size_t len,int flags)450 ssize_t recv(int socket, void* const buf __pass_object_size0, size_t len,
451              int flags) __overloadable {
452   return recvfrom(socket, buf, len, flags, NULL, 0);
453 }
454 
455 __BIONIC_FORTIFY_INLINE
send(int socket,const void * const buf __pass_object_size0,size_t len,int flags)456 ssize_t send(int socket, const void* const buf __pass_object_size0, size_t len, int flags)
457         __overloadable {
458   return sendto(socket, buf, len, flags, NULL, 0);
459 }
460 
461 #endif /* __BIONIC_FORTIFY */
462 
463 #undef __socketcall
464 
465 __END_DECLS
466 
467 #endif /* _SYS_SOCKET_H */
468