Zephyr Project API  3.1.0
A Scalable Open Source RTOS
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 <zephyr/net/net_ip.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
145#define TLS_CERT_NOCOPY 10
156#define TLS_NATIVE 11
161#define TLS_SESSION_CACHE 12
165#define TLS_SESSION_CACHE_PURGE 13
166
169/* Valid values for TLS_PEER_VERIFY option */
170#define TLS_PEER_VERIFY_NONE 0
171#define TLS_PEER_VERIFY_OPTIONAL 1
172#define TLS_PEER_VERIFY_REQUIRED 2
174/* Valid values for TLS_DTLS_ROLE option */
175#define TLS_DTLS_ROLE_CLIENT 0
176#define TLS_DTLS_ROLE_SERVER 1
178/* Valid values for TLS_CERT_NOCOPY option */
179#define TLS_CERT_NOCOPY_NONE 0
180#define TLS_CERT_NOCOPY_OPTIONAL 1
182/* Valid values for TLS_SESSION_CACHE option */
183#define TLS_SESSION_CACHE_DISABLED 0
184#define TLS_SESSION_CACHE_ENABLED 1
195
196 struct sockaddr _ai_addr;
197 char _ai_canonname[DNS_MAX_NAME_SIZE + 1];
198};
199
236__syscall void *zsock_get_context_object(int sock);
237
255__syscall int zsock_socket(int family, int type, int proto);
256
269__syscall int zsock_socketpair(int family, int type, int proto, int *sv);
270
282__syscall int zsock_close(int sock);
283
297__syscall int zsock_shutdown(int sock, int how);
298
311__syscall int zsock_bind(int sock, const struct sockaddr *addr,
312 socklen_t addrlen);
313
326__syscall int zsock_connect(int sock, const struct sockaddr *addr,
327 socklen_t addrlen);
328
341__syscall int zsock_listen(int sock, int backlog);
342
355__syscall int zsock_accept(int sock, struct sockaddr *addr, socklen_t *addrlen);
356
369__syscall ssize_t zsock_sendto(int sock, const void *buf, size_t len,
370 int flags, const struct sockaddr *dest_addr,
371 socklen_t addrlen);
372
385static inline ssize_t zsock_send(int sock, const void *buf, size_t len,
386 int flags)
387{
388 return zsock_sendto(sock, buf, len, flags, NULL, 0);
389}
390
403__syscall ssize_t zsock_sendmsg(int sock, const struct msghdr *msg,
404 int flags);
405
418__syscall ssize_t zsock_recvfrom(int sock, void *buf, size_t max_len,
419 int flags, struct sockaddr *src_addr,
420 socklen_t *addrlen);
421
434static inline ssize_t zsock_recv(int sock, void *buf, size_t max_len,
435 int flags)
436{
437 return zsock_recvfrom(sock, buf, max_len, flags, NULL, NULL);
438}
439
452__syscall int zsock_fcntl(int sock, int cmd, int flags);
453
468__syscall int zsock_poll(struct zsock_pollfd *fds, int nfds, int timeout);
469
485__syscall int zsock_getsockopt(int sock, int level, int optname,
486 void *optval, socklen_t *optlen);
487
503__syscall int zsock_setsockopt(int sock, int level, int optname,
504 const void *optval, socklen_t optlen);
505
518__syscall int zsock_getpeername(int sock, struct sockaddr *addr,
519 socklen_t *addrlen);
520
533__syscall int zsock_getsockname(int sock, struct sockaddr *addr,
534 socklen_t *addrlen);
535
548__syscall int zsock_gethostname(char *buf, size_t len);
549
562static inline char *zsock_inet_ntop(sa_family_t family, const void *src,
563 char *dst, size_t size)
564{
565 return net_addr_ntop(family, src, dst, size);
566}
567
580__syscall int zsock_inet_pton(sa_family_t family, const char *src, void *dst);
581
583__syscall int z_zsock_getaddrinfo_internal(const char *host,
584 const char *service,
585 const struct zsock_addrinfo *hints,
586 struct zsock_addrinfo *res);
589/* Flags for getaddrinfo() hints. */
590
592#define AI_PASSIVE 0x1
594#define AI_CANONNAME 0x2
596#define AI_NUMERICHOST 0x4
598#define AI_V4MAPPED 0x8
600#define AI_ALL 0x10
602#define AI_ADDRCONFIG 0x20
604#define AI_NUMERICSERV 0x400
605
618int zsock_getaddrinfo(const char *host, const char *service,
619 const struct zsock_addrinfo *hints,
620 struct zsock_addrinfo **res);
621
635
648const char *zsock_gai_strerror(int errcode);
649
651#define NI_NUMERICHOST 1
653#define NI_NUMERICSERV 2
655#define NI_NOFQDN 4
657#define NI_NAMEREQD 8
659#define NI_DGRAM 16
660
661/* POSIX extensions */
662
664#ifndef NI_MAXHOST
665#define NI_MAXHOST 64
666#endif
667
680int zsock_getnameinfo(const struct sockaddr *addr, socklen_t addrlen,
681 char *host, socklen_t hostlen,
682 char *serv, socklen_t servlen, int flags);
683
684#if defined(CONFIG_NET_SOCKETS_POSIX_NAMES)
685
686#define pollfd zsock_pollfd
687
688static inline int socket(int family, int type, int proto)
689{
690 return zsock_socket(family, type, proto);
691}
692
693static inline int socketpair(int family, int type, int proto, int sv[2])
694{
695 return zsock_socketpair(family, type, proto, sv);
696}
697
698static inline int close(int sock)
699{
700 return zsock_close(sock);
701}
702
703static inline int shutdown(int sock, int how)
704{
705 return zsock_shutdown(sock, how);
706}
707
708static inline int bind(int sock, const struct sockaddr *addr, socklen_t addrlen)
709{
710 return zsock_bind(sock, addr, addrlen);
711}
712
713static inline int connect(int sock, const struct sockaddr *addr,
714 socklen_t addrlen)
715{
716 return zsock_connect(sock, addr, addrlen);
717}
718
719static inline int listen(int sock, int backlog)
720{
721 return zsock_listen(sock, backlog);
722}
723
724static inline int accept(int sock, struct sockaddr *addr, socklen_t *addrlen)
725{
726 return zsock_accept(sock, addr, addrlen);
727}
728
729static inline ssize_t send(int sock, const void *buf, size_t len, int flags)
730{
731 return zsock_send(sock, buf, len, flags);
732}
733
734static inline ssize_t recv(int sock, void *buf, size_t max_len, int flags)
735{
736 return zsock_recv(sock, buf, max_len, flags);
737}
738
739/*
740 * Need this wrapper because newer GCC versions got too smart and "typecheck"
741 * even macros, so '#define fcntl zsock_fcntl' leads to error.
742 */
743static inline int zsock_fcntl_wrapper(int sock, int cmd, ...)
744{
745 va_list args;
746 int flags;
747
748 va_start(args, cmd);
749 flags = va_arg(args, int);
750 va_end(args);
751 return zsock_fcntl(sock, cmd, flags);
752}
753
754#define fcntl zsock_fcntl_wrapper
755
756static inline ssize_t sendto(int sock, const void *buf, size_t len, int flags,
757 const struct sockaddr *dest_addr,
758 socklen_t addrlen)
759{
760 return zsock_sendto(sock, buf, len, flags, dest_addr, addrlen);
761}
762
763static inline ssize_t sendmsg(int sock, const struct msghdr *message,
764 int flags)
765{
766 return zsock_sendmsg(sock, message, flags);
767}
768
769static inline ssize_t recvfrom(int sock, void *buf, size_t max_len, int flags,
770 struct sockaddr *src_addr, socklen_t *addrlen)
771{
772 return zsock_recvfrom(sock, buf, max_len, flags, src_addr, addrlen);
773}
774
775static inline int poll(struct zsock_pollfd *fds, int nfds, int timeout)
776{
777 return zsock_poll(fds, nfds, timeout);
778}
779
780static inline int getsockopt(int sock, int level, int optname,
781 void *optval, socklen_t *optlen)
782{
783 return zsock_getsockopt(sock, level, optname, optval, optlen);
784}
785
786static inline int setsockopt(int sock, int level, int optname,
787 const void *optval, socklen_t optlen)
788{
789 return zsock_setsockopt(sock, level, optname, optval, optlen);
790}
791
792static inline int getpeername(int sock, struct sockaddr *addr,
793 socklen_t *addrlen)
794{
795 return zsock_getpeername(sock, addr, addrlen);
796}
797
798static inline int getsockname(int sock, struct sockaddr *addr,
799 socklen_t *addrlen)
800{
801 return zsock_getsockname(sock, addr, addrlen);
802}
803
804static inline int getaddrinfo(const char *host, const char *service,
805 const struct zsock_addrinfo *hints,
806 struct zsock_addrinfo **res)
807{
808 return zsock_getaddrinfo(host, service, hints, res);
809}
810
811static inline void freeaddrinfo(struct zsock_addrinfo *ai)
812{
814}
815
816static inline const char *gai_strerror(int errcode)
817{
818 return zsock_gai_strerror(errcode);
819}
820
821static inline int getnameinfo(const struct sockaddr *addr, socklen_t addrlen,
822 char *host, socklen_t hostlen,
823 char *serv, socklen_t servlen, int flags)
824{
825 return zsock_getnameinfo(addr, addrlen, host, hostlen,
826 serv, servlen, flags);
827}
828
829#define addrinfo zsock_addrinfo
830
831static inline int gethostname(char *buf, size_t len)
832{
833 return zsock_gethostname(buf, len);
834}
835
836static inline int inet_pton(sa_family_t family, const char *src, void *dst)
837{
838 return zsock_inet_pton(family, src, dst);
839}
840
841static inline char *inet_ntop(sa_family_t family, const void *src, char *dst,
842 size_t size)
843{
844 return zsock_inet_ntop(family, src, dst, size);
845}
846
847#define POLLIN ZSOCK_POLLIN
848#define POLLOUT ZSOCK_POLLOUT
849#define POLLERR ZSOCK_POLLERR
850#define POLLHUP ZSOCK_POLLHUP
851#define POLLNVAL ZSOCK_POLLNVAL
852
853#define MSG_PEEK ZSOCK_MSG_PEEK
854#define MSG_TRUNC ZSOCK_MSG_TRUNC
855#define MSG_DONTWAIT ZSOCK_MSG_DONTWAIT
856#define MSG_WAITALL ZSOCK_MSG_WAITALL
857
858#define SHUT_RD ZSOCK_SHUT_RD
859#define SHUT_WR ZSOCK_SHUT_WR
860#define SHUT_RDWR ZSOCK_SHUT_RDWR
861
862#define EAI_BADFLAGS DNS_EAI_BADFLAGS
863#define EAI_NONAME DNS_EAI_NONAME
864#define EAI_AGAIN DNS_EAI_AGAIN
865#define EAI_FAIL DNS_EAI_FAIL
866#define EAI_NODATA DNS_EAI_NODATA
867#define EAI_MEMORY DNS_EAI_MEMORY
868#define EAI_SYSTEM DNS_EAI_SYSTEM
869#define EAI_SERVICE DNS_EAI_SERVICE
870#define EAI_SOCKTYPE DNS_EAI_SOCKTYPE
871#define EAI_FAMILY DNS_EAI_FAMILY
872#endif /* defined(CONFIG_NET_SOCKETS_POSIX_NAMES) */
873
874#define IFNAMSIZ Z_DEVICE_MAX_NAME_LEN
875
877struct ifreq {
878 char ifr_name[IFNAMSIZ]; /* Interface name */
879};
880
882#define SOL_SOCKET 1
883
884/* Socket options for SOL_SOCKET level */
885
887#define SO_DEBUG 1
889#define SO_REUSEADDR 2
891#define SO_TYPE 3
893#define SO_ERROR 4
895#define SO_DONTROUTE 5
897#define SO_BROADCAST 6
898
900#define SO_SNDBUF 7
902#define SO_RCVBUF 8
903
905#define SO_KEEPALIVE 9
907#define SO_OOBINLINE 10
909#define SO_REUSEPORT 15
910
915#define SO_RCVTIMEO 20
917#define SO_SNDTIMEO 21
918
920#define SO_BINDTODEVICE 25
921
923#define SO_ACCEPTCONN 30
924
926#define SO_TIMESTAMPING 37
928#define SO_PROTOCOL 38
929
931#define SO_DOMAIN 39
932
935/* Socket options for IPPROTO_TCP level */
937#define TCP_NODELAY 1
938
939/* Socket options for IPPROTO_IPV6 level */
941#define IPV6_V6ONLY 26
942
944#define SO_PRIORITY 12
945
947#define SO_TXTIME 61
948#define SCM_TXTIME SO_TXTIME
949
950/* Socket options for SOCKS5 proxy */
952#define SO_SOCKS5 60
953
958struct net_socket_register {
959 int family;
960 bool is_offloaded;
961 bool (*is_supported)(int family, int type, int proto);
962 int (*handler)(int family, int type, int proto);
963};
964
965#define NET_SOCKET_DEFAULT_PRIO CONFIG_NET_SOCKETS_PRIORITY_DEFAULT
966
967#define NET_SOCKET_GET_NAME(socket_name, prio) \
968 __net_socket_register_##prio##_##socket_name
969
970#define _NET_SOCKET_REGISTER(socket_name, prio, _family, _is_supported, _handler, _is_offloaded) \
971 static const STRUCT_SECTION_ITERABLE(net_socket_register, \
972 NET_SOCKET_GET_NAME(socket_name, prio)) = { \
973 .family = _family, \
974 .is_offloaded = _is_offloaded, \
975 .is_supported = _is_supported, \
976 .handler = _handler, \
977 }
978
979#define NET_SOCKET_REGISTER(socket_name, prio, _family, _is_supported, _handler) \
980 _NET_SOCKET_REGISTER(socket_name, prio, _family, _is_supported, _handler, false)
981
982#define NET_SOCKET_OFFLOAD_REGISTER(socket_name, prio, _family, _is_supported, _handler) \
983 _NET_SOCKET_REGISTER(socket_name, prio, _family, _is_supported, _handler, true)
984
987#ifdef __cplusplus
988}
989#endif
990
991#include <syscalls/socket.h>
992
997#endif /* ZEPHYR_INCLUDE_NET_SOCKET_H_ */
ZTEST_BMEM int timeout
Definition: main.c:31
DNS resolving library.
int zsock_getpeername(int sock, struct sockaddr *addr, socklen_t *addrlen)
Get peer name.
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:385
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:434
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:874
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:562
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 getpeername(int sock, struct sockaddr *addr, socklen_t *addrlen)
Definition: socket.h:102
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:108
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:877
char ifr_name[Z_DEVICE_MAX_NAME_LEN]
Definition: socket.h:878
Definition: net_ip.h:235
Definition: net_ip.h:341
Definition: socket.h:186
struct zsock_addrinfo * ai_next
Definition: socket.h:187
int ai_family
Definition: socket.h:189
int ai_flags
Definition: socket.h:188
char * ai_canonname
Definition: socket.h:194
int ai_protocol
Definition: socket.h:191
struct sockaddr * ai_addr
Definition: socket.h:193
int ai_socktype
Definition: socket.h:190
socklen_t ai_addrlen
Definition: socket.h:192
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