Home | History | Annotate | Download | only in sys
      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. */
    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
    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
    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
    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
    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
    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
    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