Zephyr API Documentation  3.0.0
A Scalable Open Source RTOS
3.0.0
All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Modules Pages
socket.h
Go to the documentation of this file.
1
8/*
9 * Copyright (c) 2017-2018 Linaro Limited
10 * Copyright (c) 2021 Nordic Semiconductor
11 *
12 * SPDX-License-Identifier: Apache-2.0
13 */
14
15#ifndef ZEPHYR_INCLUDE_NET_SOCKET_H_
16#define ZEPHYR_INCLUDE_NET_SOCKET_H_
17
25#include <sys/types.h>
26#include <zephyr/types.h>
27#include <net/net_ip.h>
28#include <net/dns_resolve.h>
29#include <net/socket_select.h>
30#include <stdlib.h>
31
32#ifdef __cplusplus
33extern "C" {
34#endif
35
37 int fd;
38 short events;
39 short revents;
40};
41
42/* ZSOCK_POLL* values are compatible with Linux */
44#define ZSOCK_POLLIN 1
46#define ZSOCK_POLLPRI 2
48#define ZSOCK_POLLOUT 4
50#define ZSOCK_POLLERR 8
52#define ZSOCK_POLLHUP 0x10
54#define ZSOCK_POLLNVAL 0x20
55
57#define ZSOCK_MSG_PEEK 0x02
61#define ZSOCK_MSG_TRUNC 0x20
63#define ZSOCK_MSG_DONTWAIT 0x40
65#define ZSOCK_MSG_WAITALL 0x100
66
67/* Well-known values, e.g. from Linux man 2 shutdown:
68 * "The constants SHUT_RD, SHUT_WR, SHUT_RDWR have the value 0, 1, 2,
69 * respectively". Some software uses numeric values.
70 */
72#define ZSOCK_SHUT_RD 0
74#define ZSOCK_SHUT_WR 1
76#define ZSOCK_SHUT_RDWR 2
77
81#define SOL_TLS 282
82
92#define TLS_SEC_TAG_LIST 1
97#define TLS_HOSTNAME 2
103#define TLS_CIPHERSUITE_LIST 3
108#define TLS_CIPHERSUITE_USED 4
119#define TLS_PEER_VERIFY 5
128#define TLS_DTLS_ROLE 6
134#define TLS_ALPN_LIST 7
139#define TLS_DTLS_HANDSHAKE_TIMEOUT_MIN 8
140#define TLS_DTLS_HANDSHAKE_TIMEOUT_MAX 9
141
146#define TLS_CERT_NOCOPY 10
147
150/* Valid values for TLS_PEER_VERIFY option */
151#define TLS_PEER_VERIFY_NONE 0
152#define TLS_PEER_VERIFY_OPTIONAL 1
153#define TLS_PEER_VERIFY_REQUIRED 2
155/* Valid values for TLS_DTLS_ROLE option */
156#define TLS_DTLS_ROLE_CLIENT 0
157#define TLS_DTLS_ROLE_SERVER 1
159/* Valid values for TLS_CERT_NOCOPY option */
160#define TLS_CERT_NOCOPY_NONE 0
161#define TLS_CERT_NOCOPY_OPTIONAL 1
172
173 struct sockaddr _ai_addr;
174 char _ai_canonname[DNS_MAX_NAME_SIZE + 1];
175};
176
213__syscall void *zsock_get_context_object(int sock);
214
232__syscall int zsock_socket(int family, int type, int proto);
233
246__syscall int zsock_socketpair(int family, int type, int proto, int *sv);
247
259__syscall int zsock_close(int sock);
260
274__syscall int zsock_shutdown(int sock, int how);
275
288__syscall int zsock_bind(int sock, const struct sockaddr *addr,
289 socklen_t addrlen);
290
303__syscall int zsock_connect(int sock, const struct sockaddr *addr,
304 socklen_t addrlen);
305
318__syscall int zsock_listen(int sock, int backlog);
319
332__syscall int zsock_accept(int sock, struct sockaddr *addr, socklen_t *addrlen);
333
346__syscall ssize_t zsock_sendto(int sock, const void *buf, size_t len,
347 int flags, const struct sockaddr *dest_addr,
348 socklen_t addrlen);
349
362static inline ssize_t zsock_send(int sock, const void *buf, size_t len,
363 int flags)
364{
365 return zsock_sendto(sock, buf, len, flags, NULL, 0);
366}
367
380__syscall ssize_t zsock_sendmsg(int sock, const struct msghdr *msg,
381 int flags);
382
395__syscall ssize_t zsock_recvfrom(int sock, void *buf, size_t max_len,
396 int flags, struct sockaddr *src_addr,
397 socklen_t *addrlen);
398
411static inline ssize_t zsock_recv(int sock, void *buf, size_t max_len,
412 int flags)
413{
414 return zsock_recvfrom(sock, buf, max_len, flags, NULL, NULL);
415}
416
429__syscall int zsock_fcntl(int sock, int cmd, int flags);
430
445__syscall int zsock_poll(struct zsock_pollfd *fds, int nfds, int timeout);
446
462__syscall int zsock_getsockopt(int sock, int level, int optname,
463 void *optval, socklen_t *optlen);
464
480__syscall int zsock_setsockopt(int sock, int level, int optname,
481 const void *optval, socklen_t optlen);
482
495__syscall int zsock_getsockname(int sock, struct sockaddr *addr,
496 socklen_t *addrlen);
497
510__syscall int zsock_gethostname(char *buf, size_t len);
511
524static inline char *zsock_inet_ntop(sa_family_t family, const void *src,
525 char *dst, size_t size)
526{
527 return net_addr_ntop(family, src, dst, size);
528}
529
542__syscall int zsock_inet_pton(sa_family_t family, const char *src, void *dst);
543
545__syscall int z_zsock_getaddrinfo_internal(const char *host,
546 const char *service,
547 const struct zsock_addrinfo *hints,
548 struct zsock_addrinfo *res);
551/* Flags for getaddrinfo() hints. */
552
554#define AI_PASSIVE 0x1
556#define AI_CANONNAME 0x2
558#define AI_NUMERICHOST 0x4
560#define AI_V4MAPPED 0x8
562#define AI_ALL 0x10
564#define AI_ADDRCONFIG 0x20
566#define AI_NUMERICSERV 0x400
567
580int zsock_getaddrinfo(const char *host, const char *service,
581 const struct zsock_addrinfo *hints,
582 struct zsock_addrinfo **res);
583
597
610const char *zsock_gai_strerror(int errcode);
611
613#define NI_NUMERICHOST 1
615#define NI_NUMERICSERV 2
617#define NI_NOFQDN 4
619#define NI_NAMEREQD 8
621#define NI_DGRAM 16
622
623/* POSIX extensions */
624
626#ifndef NI_MAXHOST
627#define NI_MAXHOST 64
628#endif
629
642int zsock_getnameinfo(const struct sockaddr *addr, socklen_t addrlen,
643 char *host, socklen_t hostlen,
644 char *serv, socklen_t servlen, int flags);
645
646#if defined(CONFIG_NET_SOCKETS_POSIX_NAMES)
647
648#define pollfd zsock_pollfd
649
650static inline int socket(int family, int type, int proto)
651{
652 return zsock_socket(family, type, proto);
653}
654
655static inline int socketpair(int family, int type, int proto, int sv[2])
656{
657 return zsock_socketpair(family, type, proto, sv);
658}
659
660static inline int close(int sock)
661{
662 return zsock_close(sock);
663}
664
665static inline int shutdown(int sock, int how)
666{
667 return zsock_shutdown(sock, how);
668}
669
670static inline int bind(int sock, const struct sockaddr *addr, socklen_t addrlen)
671{
672 return zsock_bind(sock, addr, addrlen);
673}
674
675static inline int connect(int sock, const struct sockaddr *addr,
676 socklen_t addrlen)
677{
678 return zsock_connect(sock, addr, addrlen);
679}
680
681static inline int listen(int sock, int backlog)
682{
683 return zsock_listen(sock, backlog);
684}
685
686static inline int accept(int sock, struct sockaddr *addr, socklen_t *addrlen)
687{
688 return zsock_accept(sock, addr, addrlen);
689}
690
691static inline ssize_t send(int sock, const void *buf, size_t len, int flags)
692{
693 return zsock_send(sock, buf, len, flags);
694}
695
696static inline ssize_t recv(int sock, void *buf, size_t max_len, int flags)
697{
698 return zsock_recv(sock, buf, max_len, flags);
699}
700
701/*
702 * Need this wrapper because newer GCC versions got too smart and "typecheck"
703 * even macros, so '#define fcntl zsock_fcntl' leads to error.
704 */
705static inline int zsock_fcntl_wrapper(int sock, int cmd, ...)
706{
707 va_list args;
708 int flags;
709
710 va_start(args, cmd);
711 flags = va_arg(args, int);
712 va_end(args);
713 return zsock_fcntl(sock, cmd, flags);
714}
715
716#define fcntl zsock_fcntl_wrapper
717
718static inline ssize_t sendto(int sock, const void *buf, size_t len, int flags,
719 const struct sockaddr *dest_addr,
720 socklen_t addrlen)
721{
722 return zsock_sendto(sock, buf, len, flags, dest_addr, addrlen);
723}
724
725static inline ssize_t sendmsg(int sock, const struct msghdr *message,
726 int flags)
727{
728 return zsock_sendmsg(sock, message, flags);
729}
730
731static inline ssize_t recvfrom(int sock, void *buf, size_t max_len, int flags,
732 struct sockaddr *src_addr, socklen_t *addrlen)
733{
734 return zsock_recvfrom(sock, buf, max_len, flags, src_addr, addrlen);
735}
736
737static inline int poll(struct zsock_pollfd *fds, int nfds, int timeout)
738{
739 return zsock_poll(fds, nfds, timeout);
740}
741
742static inline int getsockopt(int sock, int level, int optname,
743 void *optval, socklen_t *optlen)
744{
745 return zsock_getsockopt(sock, level, optname, optval, optlen);
746}
747
748static inline int setsockopt(int sock, int level, int optname,
749 const void *optval, socklen_t optlen)
750{
751 return zsock_setsockopt(sock, level, optname, optval, optlen);
752}
753
754static inline int getsockname(int sock, struct sockaddr *addr,
755 socklen_t *addrlen)
756{
757 return zsock_getsockname(sock, addr, addrlen);
758}
759
760static inline int getaddrinfo(const char *host, const char *service,
761 const struct zsock_addrinfo *hints,
762 struct zsock_addrinfo **res)
763{
764 return zsock_getaddrinfo(host, service, hints, res);
765}
766
767static inline void freeaddrinfo(struct zsock_addrinfo *ai)
768{
770}
771
772static inline const char *gai_strerror(int errcode)
773{
774 return zsock_gai_strerror(errcode);
775}
776
777static inline int getnameinfo(const struct sockaddr *addr, socklen_t addrlen,
778 char *host, socklen_t hostlen,
779 char *serv, socklen_t servlen, int flags)
780{
781 return zsock_getnameinfo(addr, addrlen, host, hostlen,
782 serv, servlen, flags);
783}
784
785#define addrinfo zsock_addrinfo
786
787static inline int gethostname(char *buf, size_t len)
788{
789 return zsock_gethostname(buf, len);
790}
791
792static inline int inet_pton(sa_family_t family, const char *src, void *dst)
793{
794 return zsock_inet_pton(family, src, dst);
795}
796
797static inline char *inet_ntop(sa_family_t family, const void *src, char *dst,
798 size_t size)
799{
800 return zsock_inet_ntop(family, src, dst, size);
801}
802
803#define POLLIN ZSOCK_POLLIN
804#define POLLOUT ZSOCK_POLLOUT
805#define POLLERR ZSOCK_POLLERR
806#define POLLHUP ZSOCK_POLLHUP
807#define POLLNVAL ZSOCK_POLLNVAL
808
809#define MSG_PEEK ZSOCK_MSG_PEEK
810#define MSG_TRUNC ZSOCK_MSG_TRUNC
811#define MSG_DONTWAIT ZSOCK_MSG_DONTWAIT
812#define MSG_WAITALL ZSOCK_MSG_WAITALL
813
814#define SHUT_RD ZSOCK_SHUT_RD
815#define SHUT_WR ZSOCK_SHUT_WR
816#define SHUT_RDWR ZSOCK_SHUT_RDWR
817
818#define EAI_BADFLAGS DNS_EAI_BADFLAGS
819#define EAI_NONAME DNS_EAI_NONAME
820#define EAI_AGAIN DNS_EAI_AGAIN
821#define EAI_FAIL DNS_EAI_FAIL
822#define EAI_NODATA DNS_EAI_NODATA
823#define EAI_MEMORY DNS_EAI_MEMORY
824#define EAI_SYSTEM DNS_EAI_SYSTEM
825#define EAI_SERVICE DNS_EAI_SERVICE
826#define EAI_SOCKTYPE DNS_EAI_SOCKTYPE
827#define EAI_FAMILY DNS_EAI_FAMILY
828#endif /* defined(CONFIG_NET_SOCKETS_POSIX_NAMES) */
829
830#define IFNAMSIZ Z_DEVICE_MAX_NAME_LEN
831
833struct ifreq {
834 char ifr_name[IFNAMSIZ]; /* Interface name */
835};
836
838#define SOL_SOCKET 1
839
840/* Socket options for SOL_SOCKET level */
841
843#define SO_DEBUG 1
845#define SO_REUSEADDR 2
847#define SO_TYPE 3
849#define SO_ERROR 4
851#define SO_DONTROUTE 5
853#define SO_BROADCAST 6
854
856#define SO_SNDBUF 7
857
859#define SO_KEEPALIVE 9
861#define SO_OOBINLINE 10
863#define SO_REUSEPORT 15
864
869#define SO_RCVTIMEO 20
871#define SO_SNDTIMEO 21
872
874#define SO_BINDTODEVICE 25
875
877#define SO_ACCEPTCONN 30
878
880#define SO_TIMESTAMPING 37
882#define SO_PROTOCOL 38
883
885#define SO_DOMAIN 39
886
889/* Socket options for IPPROTO_TCP level */
891#define TCP_NODELAY 1
892
893/* Socket options for IPPROTO_IPV6 level */
895#define IPV6_V6ONLY 26
896
898#define SO_PRIORITY 12
899
901#define SO_TXTIME 61
902#define SCM_TXTIME SO_TXTIME
903
904/* Socket options for SOCKS5 proxy */
906#define SO_SOCKS5 60
907
912struct net_socket_register {
913 int family;
914 bool (*is_supported)(int family, int type, int proto);
915 int (*handler)(int family, int type, int proto);
916};
917
918#define NET_SOCKET_DEFAULT_PRIO CONFIG_NET_SOCKETS_PRIORITY_DEFAULT
919
920#define NET_SOCKET_GET_NAME(socket_name, prio) \
921 (__net_socket_register_##prio##_##socket_name)
922
923#define NET_SOCKET_REGISTER(socket_name, prio, _family, _is_supported, _handler) \
924 static const STRUCT_SECTION_ITERABLE(net_socket_register, \
925 NET_SOCKET_GET_NAME(socket_name, prio)) = { \
926 .family = _family, \
927 .is_supported = _is_supported, \
928 .handler = _handler, \
929 }
930
933#ifdef __cplusplus
934}
935#endif
936
937#include <syscalls/socket.h>
938
943#endif /* ZEPHYR_INCLUDE_NET_SOCKET_H_ */
ZTEST_BMEM int timeout
Definition: main.c:31
DNS resolving library.
int zsock_fcntl(int sock, int cmd, int flags)
Control blocking/non-blocking mode of a socket.
ssize_t zsock_sendto(int sock, const void *buf, size_t len, int flags, const struct sockaddr *dest_addr, socklen_t addrlen)
Send data to an arbitrary network address.
int zsock_connect(int sock, const struct sockaddr *addr, socklen_t addrlen)
Connect a socket to a peer network address.
int zsock_socketpair(int family, int type, int proto, int *sv)
Create an unnamed pair of connected sockets.
void * zsock_get_context_object(int sock)
Obtain a file descriptor's associated net context.
int zsock_accept(int sock, struct sockaddr *addr, socklen_t *addrlen)
Accept a connection on listening socket.
static ssize_t zsock_send(int sock, const void *buf, size_t len, int flags)
Send data to a connected peer.
Definition: socket.h:362
int zsock_bind(int sock, const struct sockaddr *addr, socklen_t addrlen)
Bind a socket to a local network address.
int zsock_socket(int family, int type, int proto)
Create a network socket.
int zsock_getsockopt(int sock, int level, int optname, void *optval, socklen_t *optlen)
Get various socket options.
void zsock_freeaddrinfo(struct zsock_addrinfo *ai)
Free results returned by zsock_getaddrinfo()
static ssize_t zsock_recv(int sock, void *buf, size_t max_len, int flags)
Receive data from a connected peer.
Definition: socket.h:411
int zsock_gethostname(char *buf, size_t len)
Get local host name.
int zsock_getsockname(int sock, struct sockaddr *addr, socklen_t *addrlen)
Get socket name.
int zsock_poll(struct zsock_pollfd *fds, int nfds, int timeout)
Efficiently poll multiple sockets for events.
const char * zsock_gai_strerror(int errcode)
Convert zsock_getaddrinfo() error code to textual message.
int zsock_shutdown(int sock, int how)
Shutdown socket send/receive operations.
ssize_t zsock_recvfrom(int sock, void *buf, size_t max_len, int flags, struct sockaddr *src_addr, socklen_t *addrlen)
Receive data from an arbitrary network address.
#define IFNAMSIZ
Definition: socket.h:830
int zsock_setsockopt(int sock, int level, int optname, const void *optval, socklen_t optlen)
Set various socket options.
ssize_t zsock_sendmsg(int sock, const struct msghdr *msg, int flags)
Send data to an arbitrary network address.
static char * zsock_inet_ntop(sa_family_t family, const void *src, char *dst, size_t size)
Convert network address from internal to numeric ASCII form.
Definition: socket.h:524
int zsock_inet_pton(sa_family_t family, const char *src, void *dst)
Convert network address from numeric ASCII form to internal representation.
int zsock_close(int sock)
Close a network socket.
int zsock_listen(int sock, int backlog)
Set up a STREAM socket to accept peer connections.
int zsock_getnameinfo(const struct sockaddr *addr, socklen_t addrlen, char *host, socklen_t hostlen, char *serv, socklen_t servlen, int flags)
Resolve a network address to a domain name or ASCII address.
int zsock_getaddrinfo(const char *host, const char *service, const struct zsock_addrinfo *hints, struct zsock_addrinfo **res)
Resolve a domain name to one or more network addresses.
#define DNS_MAX_NAME_SIZE
Definition: dns_resolve.h:42
static void cmd(uint32_t command)
Execute a display list command by co-processor engine.
Definition: ft8xx_reference_api.h:153
unsigned short int sa_family_t
Definition: net_ip.h:164
char * net_addr_ntop(sa_family_t family, const void *src, char *dst, size_t size)
Convert IP address to string form.
size_t socklen_t
Definition: net_ip.h:167
flags
Definition: http_parser.h:131
static int inet_pton(sa_family_t family, const char *src, void *dst)
Definition: inet.h:21
static char * inet_ntop(sa_family_t family, const void *src, char *dst, size_t size)
Definition: inet.h:15
__SIZE_TYPE__ ssize_t
Definition: types.h:28
IPv6 and IPv4 definitions.
static int getaddrinfo(const char *host, const char *service, const struct zsock_addrinfo *hints, struct zsock_addrinfo **res)
Definition: netdb.h:17
static int getnameinfo(const struct sockaddr *addr, socklen_t addrlen, char *host, socklen_t hostlen, char *serv, socklen_t servlen, int flags)
Definition: netdb.h:34
static const char * gai_strerror(int errcode)
Definition: netdb.h:29
static void freeaddrinfo(struct zsock_addrinfo *ai)
Definition: netdb.h:24
static int poll(struct zsock_pollfd *fds, int nfds, int timeout)
Definition: poll.h:23
static int socket(int family, int type, int proto)
Definition: socket.h:16
static int bind(int sock, const struct sockaddr *addr, socklen_t addrlen)
Definition: socket.h:40
static ssize_t sendmsg(int sock, const struct msghdr *message, int flags)
Definition: socket.h:78
static ssize_t recvfrom(int sock, void *buf, size_t max_len, int flags, struct sockaddr *src_addr, socklen_t *addrlen)
Definition: socket.h:84
static int getsockopt(int sock, int level, int optname, void *optval, socklen_t *optlen)
Definition: socket.h:90
static int accept(int sock, struct sockaddr *addr, socklen_t *addrlen)
Definition: socket.h:56
static int listen(int sock, int backlog)
Definition: socket.h:51
static int setsockopt(int sock, int level, int optname, const void *optval, socklen_t optlen)
Definition: socket.h:96
static int getsockname(int sock, struct sockaddr *addr, socklen_t *addrlen)
Definition: socket.h:102
static ssize_t sendto(int sock, const void *buf, size_t len, int flags, const struct sockaddr *dest_addr, socklen_t addrlen)
Definition: socket.h:71
static ssize_t send(int sock, const void *buf, size_t len, int flags)
Definition: socket.h:61
static int socketpair(int family, int type, int proto, int sv[2])
Definition: socket.h:21
static int connect(int sock, const struct sockaddr *addr, socklen_t addrlen)
Definition: socket.h:45
static ssize_t recv(int sock, void *buf, size_t max_len, int flags)
Definition: socket.h:66
static int shutdown(int sock, int how)
Definition: socket.h:35
#define bool
Definition: stdbool.h:13
Definition: socket.h:833
char ifr_name[Z_DEVICE_MAX_NAME_LEN]
Definition: socket.h:834
Definition: net_ip.h:235
Definition: net_ip.h:341
Definition: socket.h:163
struct zsock_addrinfo * ai_next
Definition: socket.h:164
int ai_family
Definition: socket.h:166
int ai_flags
Definition: socket.h:165
char * ai_canonname
Definition: socket.h:171
int ai_protocol
Definition: socket.h:168
struct sockaddr * ai_addr
Definition: socket.h:170
int ai_socktype
Definition: socket.h:167
socklen_t ai_addrlen
Definition: socket.h:169
Definition: socket.h:36
short events
Definition: socket.h:38
int fd
Definition: socket.h:37
short revents
Definition: socket.h:39
static void msg(uint64_t c64)
Definition: main.c:17
static void handler(struct k_timer *timer)
Definition: main.c:19