34 #ifndef LWIP_HDR_SOCKETS_H 35 #define LWIP_HDR_SOCKETS_H 53 #if !defined(sa_family_t) && !defined(SA_FAMILY_T_DEFINED) 54 typedef u8_t sa_family_t;
58 #if !defined(in_port_t) && !defined(IN_PORT_T_DEFINED) 59 typedef u16_t in_port_t;
66 sa_family_t sin_family;
69 #define SIN_ZERO_LEN 8 70 char sin_zero[SIN_ZERO_LEN];
77 sa_family_t sin6_family;
87 sa_family_t sa_family;
91 struct sockaddr_storage {
93 sa_family_t ss_family;
103 #if !defined(socklen_t) && !defined(SOCKLEN_T_DEFINED) 104 typedef u32_t socklen_t;
109 #if !LWIP_TCPIP_CORE_LOCKING 111 #define LWIP_SETGETSOCKOPT_MAXOPTLEN 16 115 struct lwip_setgetsockopt_data {
124 #if LWIP_MPU_COMPATIBLE 125 u8_t optval[LWIP_SETGETSOCKOPT_MAXOPTLEN];
150 socklen_t msg_namelen;
151 struct iovec *msg_iov;
154 socklen_t msg_controllen;
159 #define SOCK_STREAM 1 166 #define SO_REUSEADDR 0x0004 167 #define SO_KEEPALIVE 0x0008 168 #define SO_BROADCAST 0x0020 174 #define SO_DEBUG 0x0001 175 #define SO_ACCEPTCONN 0x0002 176 #define SO_DONTROUTE 0x0010 177 #define SO_USELOOPBACK 0x0040 178 #define SO_LINGER 0x0080 179 #define SO_DONTLINGER ((int)(~SO_LINGER)) 180 #define SO_OOBINLINE 0x0100 181 #define SO_REUSEPORT 0x0200 182 #define SO_SNDBUF 0x1001 183 #define SO_RCVBUF 0x1002 184 #define SO_SNDLOWAT 0x1003 185 #define SO_RCVLOWAT 0x1004 186 #define SO_SNDTIMEO 0x1005 187 #define SO_RCVTIMEO 0x1006 188 #define SO_ERROR 0x1007 189 #define SO_TYPE 0x1008 190 #define SO_CONTIMEO 0x1009 191 #define SO_NO_CHECK 0x100a 205 #define SOL_SOCKET 0xfff 213 #define AF_INET6 AF_UNSPEC 215 #define PF_INET AF_INET 216 #define PF_INET6 AF_INET6 217 #define PF_UNSPEC AF_UNSPEC 220 #define IPPROTO_ICMP 1 221 #define IPPROTO_TCP 6 222 #define IPPROTO_UDP 17 224 #define IPPROTO_IPV6 41 225 #define IPPROTO_ICMPV6 58 227 #define IPPROTO_UDPLITE 136 228 #define IPPROTO_RAW 255 231 #define MSG_PEEK 0x01 232 #define MSG_WAITALL 0x02 234 #define MSG_DONTWAIT 0x08 235 #define MSG_MORE 0x10 248 #define TCP_NODELAY 0x01 249 #define TCP_KEEPALIVE 0x02 250 #define TCP_KEEPIDLE 0x03 251 #define TCP_KEEPINTVL 0x04 252 #define TCP_KEEPCNT 0x05 259 #define IPV6_CHECKSUM 7 260 #define IPV6_V6ONLY 27 263 #if LWIP_UDP && LWIP_UDPLITE 267 #define UDPLITE_SEND_CSCOV 0x01 268 #define UDPLITE_RECV_CSCOV 0x02 272 #if LWIP_MULTICAST_TX_OPTIONS 276 #define IP_MULTICAST_TTL 5 277 #define IP_MULTICAST_IF 6 278 #define IP_MULTICAST_LOOP 7 285 #define IP_ADD_MEMBERSHIP 3 286 #define IP_DROP_MEMBERSHIP 4 288 typedef struct ip_mreq {
310 #define IPTOS_TOS_MASK 0x1E 311 #define IPTOS_TOS(tos) ((tos) & IPTOS_TOS_MASK) 312 #define IPTOS_LOWDELAY 0x10 313 #define IPTOS_THROUGHPUT 0x08 314 #define IPTOS_RELIABILITY 0x04 315 #define IPTOS_LOWCOST 0x02 316 #define IPTOS_MINCOST IPTOS_LOWCOST 327 #define IPTOS_PREC_MASK 0xe0 328 #define IPTOS_PREC(tos) ((tos) & IPTOS_PREC_MASK) 329 #define IPTOS_PREC_NETCONTROL 0xe0 330 #define IPTOS_PREC_INTERNETCONTROL 0xc0 331 #define IPTOS_PREC_CRITIC_ECP 0xa0 332 #define IPTOS_PREC_FLASHOVERRIDE 0x80 333 #define IPTOS_PREC_FLASH 0x60 334 #define IPTOS_PREC_IMMEDIATE 0x40 335 #define IPTOS_PREC_PRIORITY 0x20 336 #define IPTOS_PREC_ROUTINE 0x00 349 #if !defined(FIONREAD) || !defined(FIONBIO) 350 #define IOCPARM_MASK 0x7fU 351 #define IOC_VOID 0x20000000UL 352 #define IOC_OUT 0x40000000UL 353 #define IOC_IN 0x80000000UL 354 #define IOC_INOUT (IOC_IN|IOC_OUT) 357 #define _IO(x,y) (IOC_VOID|((x)<<8)|(y)) 359 #define _IOR(x,y,t) (IOC_OUT|(((long)sizeof(t)&IOCPARM_MASK)<<16)|((x)<<8)|(y)) 361 #define _IOW(x,y,t) (IOC_IN|(((long)sizeof(t)&IOCPARM_MASK)<<16)|((x)<<8)|(y)) 365 #define FIONREAD _IOR('f', 127, unsigned long) 368 #define FIONBIO _IOW('f', 126, unsigned long) 373 #define SIOCSHIWAT _IOW('s', 0, unsigned long) 374 #define SIOCGHIWAT _IOR('s', 1, unsigned long) 375 #define SIOCSLOWAT _IOW('s', 2, unsigned long) 376 #define SIOCGLOWAT _IOR('s', 3, unsigned long) 377 #define SIOCATMARK _IOR('s', 7, unsigned long) 407 #define FD_SETSIZE MEMP_NUM_NETCONN 408 #define FDSETSAFESET(n, code) do { \ 409 if (((n) - LWIP_SOCKET_OFFSET < MEMP_NUM_NETCONN) && (((int)(n) - LWIP_SOCKET_OFFSET) >= 0)) { \ 411 #define FDSETSAFEGET(n, code) (((n) - LWIP_SOCKET_OFFSET < MEMP_NUM_NETCONN) && (((int)(n) - LWIP_SOCKET_OFFSET) >= 0) ?\ 413 #define FD_SET(n, p) FDSETSAFESET(n, (p)->fd_bits[((n)-LWIP_SOCKET_OFFSET)/8] |= (1 << (((n)-LWIP_SOCKET_OFFSET) & 7))) 414 #define FD_CLR(n, p) FDSETSAFESET(n, (p)->fd_bits[((n)-LWIP_SOCKET_OFFSET)/8] &= ~(1 << (((n)-LWIP_SOCKET_OFFSET) & 7))) 415 #define FD_ISSET(n,p) FDSETSAFEGET(n, (p)->fd_bits[((n)-LWIP_SOCKET_OFFSET)/8] & (1 << (((n)-LWIP_SOCKET_OFFSET) & 7))) 416 #define FD_ZERO(p) memset((void*)(p), 0, sizeof(*(p))) 418 typedef struct fd_set
420 unsigned char fd_bits [(FD_SETSIZE+7)/8];
423 #elif LWIP_SOCKET_OFFSET 424 #error LWIP_SOCKET_OFFSET does not work with external FD_SET! 429 #ifndef LWIP_TIMEVAL_PRIVATE 430 #define LWIP_TIMEVAL_PRIVATE 1 433 #if LWIP_TIMEVAL_PRIVATE 440 #define lwip_socket_init() 441 void lwip_socket_thread_init(
void);
442 void lwip_socket_thread_cleanup(
void);
444 #if LWIP_COMPAT_SOCKETS == 2 446 #define lwip_accept accept 447 #define lwip_bind bind 448 #define lwip_shutdown shutdown 449 #define lwip_getpeername getpeername 450 #define lwip_getsockname getsockname 451 #define lwip_setsockopt setsockopt 452 #define lwip_getsockopt getsockopt 453 #define lwip_close closesocket 454 #define lwip_connect connect 455 #define lwip_listen listen 456 #define lwip_recv recv 457 #define lwip_recvfrom recvfrom 458 #define lwip_send send 459 #define lwip_sendmsg sendmsg 460 #define lwip_sendto sendto 461 #define lwip_socket socket 462 #define lwip_select select 463 #define lwip_ioctlsocket ioctl 465 #if LWIP_POSIX_SOCKETS_IO_NAMES 466 #define lwip_read read 467 #define lwip_write write 468 #define lwip_writev writev 470 #define lwip_close close 471 #define closesocket(s) close(s) 472 #define lwip_fcntl fcntl 473 #define lwip_ioctl ioctl 477 int lwip_accept(
int s,
struct sockaddr *addr, socklen_t *addrlen);
478 int lwip_bind(
int s,
const struct sockaddr *name, socklen_t namelen);
479 int lwip_shutdown(
int s,
int how);
480 int lwip_getpeername (
int s,
struct sockaddr *name, socklen_t *namelen);
481 int lwip_getsockname (
int s,
struct sockaddr *name, socklen_t *namelen);
482 int lwip_getsockopt (
int s,
int level,
int optname,
void *optval, socklen_t *optlen);
483 int lwip_setsockopt (
int s,
int level,
int optname,
const void *optval, socklen_t optlen);
484 int lwip_close(
int s);
485 int lwip_connect(
int s,
const struct sockaddr *name, socklen_t namelen);
486 int lwip_listen(
int s,
int backlog);
487 int lwip_recv(
int s,
void *
mem,
size_t len,
int flags);
488 int lwip_read(
int s,
void *
mem,
size_t len);
489 int lwip_recvfrom(
int s,
void *
mem,
size_t len,
int flags,
490 struct sockaddr *from, socklen_t *fromlen);
491 int lwip_send(
int s,
const void *dataptr,
size_t size,
int flags);
492 int lwip_sendmsg(
int s,
const struct msghdr *message,
int flags);
493 int lwip_sendto(
int s,
const void *dataptr,
size_t size,
int flags,
494 const struct sockaddr *to, socklen_t tolen);
495 int lwip_socket(
int domain,
int type,
int protocol);
496 int lwip_write(
int s,
const void *dataptr,
size_t size);
497 int lwip_writev(
int s,
const struct iovec *iov,
int iovcnt);
498 int lwip_select(
int maxfdp1, fd_set *readset, fd_set *writeset, fd_set *exceptset,
499 struct timeval *timeout);
500 int lwip_ioctl(
int s,
long cmd,
void *argp);
501 int lwip_fcntl(
int s,
int cmd,
int val);
503 #if LWIP_COMPAT_SOCKETS 504 #if LWIP_COMPAT_SOCKETS != 2 505 #define accept(s,addr,addrlen) lwip_accept(s,addr,addrlen) 506 #define bind(s,name,namelen) lwip_bind(s,name,namelen) 507 #define shutdown(s,how) lwip_shutdown(s,how) 508 #define getpeername(s,name,namelen) lwip_getpeername(s,name,namelen) 509 #define getsockname(s,name,namelen) lwip_getsockname(s,name,namelen) 510 #define setsockopt(s,level,optname,opval,optlen) lwip_setsockopt(s,level,optname,opval,optlen) 511 #define getsockopt(s,level,optname,opval,optlen) lwip_getsockopt(s,level,optname,opval,optlen) 512 #define closesocket(s) lwip_close(s) 513 #define connect(s,name,namelen) lwip_connect(s,name,namelen) 514 #define listen(s,backlog) lwip_listen(s,backlog) 515 #define recv(s,mem,len,flags) lwip_recv(s,mem,len,flags) 516 #define recvfrom(s,mem,len,flags,from,fromlen) lwip_recvfrom(s,mem,len,flags,from,fromlen) 517 #define send(s,dataptr,size,flags) lwip_send(s,dataptr,size,flags) 518 #define sendmsg(s,message,flags) lwip_sendmsg(s,message,flags) 519 #define sendto(s,dataptr,size,flags,to,tolen) lwip_sendto(s,dataptr,size,flags,to,tolen) 520 #define socket(domain,type,protocol) lwip_socket(domain,type,protocol) 521 #define select(maxfdp1,readset,writeset,exceptset,timeout) lwip_select(maxfdp1,readset,writeset,exceptset,timeout) 522 #define ioctlsocket(s,cmd,argp) lwip_ioctl(s,cmd,argp) 524 #if LWIP_POSIX_SOCKETS_IO_NAMES 525 #define read(s,mem,len) lwip_read(s,mem,len) 526 #define write(s,dataptr,len) lwip_write(s,dataptr,len) 527 #define writev(s,iov,iovcnt) lwip_writev(s,iov,iovcnt) 528 #define close(s) lwip_close(s) 529 #define fcntl(s,cmd,val) lwip_fcntl(s,cmd,val) 530 #define ioctl(s,cmd,argp) lwip_ioctl(s,cmd,argp) 534 #if LWIP_IPV4 && LWIP_IPV6 535 #define inet_ntop(af,src,dst,size) \ 536 (((af) == AF_INET6) ? ip6addr_ntoa_r((const ip6_addr_t*)(src),(dst),(size)) \ 537 : (((af) == AF_INET) ? ip4addr_ntoa_r((const ip4_addr_t*)(src),(dst),(size)) : NULL)) 538 #define inet_pton(af,src,dst) \ 539 (((af) == AF_INET6) ? ip6addr_aton((src),(ip6_addr_t*)(dst)) \ 540 : (((af) == AF_INET) ? ip4addr_aton((src),(ip4_addr_t*)(dst)) : 0)) 542 #define inet_ntop(af,src,dst,size) \ 543 (((af) == AF_INET) ? ip4addr_ntoa_r((const ip4_addr_t*)(src),(dst),(size)) : NULL) 544 #define inet_pton(af,src,dst) \ 545 (((af) == AF_INET) ? ip4addr_aton((src),(ip4_addr_t*)(dst)) : 0) 547 #define inet_ntop(af,src,dst,size) \ 548 (((af) == AF_INET6) ? ip6addr_ntoa_r((const ip6_addr_t*)(src),(dst),(size)) : NULL) 549 #define inet_pton(af,src,dst) \ 550 (((af) == AF_INET6) ? ip6addr_aton((src),(ip6_addr_t*)(dst)) : 0)