VSF Documented
socket.h
Go to the documentation of this file.
1#ifndef __VSF_LINUX_SYS_SOCKET_H__
2#define __VSF_LINUX_SYS_SOCKET_H__
3
5
6#if VSF_LINUX_CFG_RELATIVE_PATH == ENABLED
7# include "../sys/types.h"
8#else
9# include <sys/types.h>
10#endif
11// for stdint.h
13
14#ifdef __cplusplus
15extern "C" {
16#endif
17
18#define SOMAXCONN 256
19
20#define SCM_RIGHTS 0x01
21#define SCM_CREDENTIALS 0x02
22#define SCM_SECURITY 0x03
23
24// protocol families
25// refer: https://code.woboq.org/gtk/include/bits/socket.h.html
26#define PF_UNSPEC 0
27#define PF_LOCAL 1
28#define PF_UNIX PF_LOCAL
29#define PF_INET 2
30#define PF_INET6 10
31#define PF_NETLINK 16
32#define PF_PACKET 17
33#define PF_BLUETOOTH 31
34
35// standard address families
36#define AF_UNSPEC PF_UNSPEC
37#define AF_LOCAL PF_LOCAL
38#define AF_UNIX PF_UNIX
39#define AF_FILE PF_FILE
40#define AF_INET PF_INET
41#define AF_INET6 PF_INET6
42#define AF_NETLINK PF_NETLINK
43#define AF_PACKET PF_PACKET
44#define AF_BLUETOOTH PF_BLUETOOTH
45
46#define SOL_IP IPPROTO_IP
47#define SOL_TCP IPPROTO_TCP
48#define SOL_UDP IPPROTO_UDP
49
50#define IP_TOS 1
51#define IP_TTL 2
52#define IP_HDRINCL 3
53#define IP_OPTIONS 4
54
62};
63#define SOCK_MAX (SOCK_PACKET + 1)
64
65// flags for socket/socketpair/accept4
66#define SOCK_CLOEXEC O_CLOEXEC
67#define SOCK_NONBLOCK O_NONBLOCK
68
69#define INVALID_SOCKET -1
70#define SOCKET_ERROR -1
71
73#define __socklen_t_defined
74
76struct sockaddr {
78 char sa_data[32];
79};
82 // TODO: need to be larger?
83 char sa_data[32];
84};
85
86struct linger {
89};
90
91#if VSF_LINUX_SOCKET_CFG_WRAPPER == ENABLED
92#define VSF_LINUX_SOCKET_WRAPPER(__api) VSF_SHELL_WRAPPER(vsf_linux_socket, __api)
93
94#define setsockopt VSF_LINUX_SOCKET_WRAPPER(setsockopt)
95#define getsockopt VSF_LINUX_SOCKET_WRAPPER(getsockopt)
96
97#define getpeername VSF_LINUX_SOCKET_WRAPPER(getpeername)
98#define getsockname VSF_LINUX_SOCKET_WRAPPER(getsockname)
99
100#define accept VSF_LINUX_SOCKET_WRAPPER(accept)
101#define accept4 VSF_LINUX_SOCKET_WRAPPER(accept4)
102#define bind VSF_LINUX_SOCKET_WRAPPER(bind)
103#define connect VSF_LINUX_SOCKET_WRAPPER(connect)
104#define listen VSF_LINUX_SOCKET_WRAPPER(listen)
105#define recv VSF_LINUX_SOCKET_WRAPPER(recv)
106#define recvmsg VSF_LINUX_SOCKET_WRAPPER(recvmsg)
107#define recvfrom VSF_LINUX_SOCKET_WRAPPER(recvfrom)
108#define send VSF_LINUX_SOCKET_WRAPPER(send)
109#define sendmsg VSF_LINUX_SOCKET_WRAPPER(sendmsg)
110#define sendto VSF_LINUX_SOCKET_WRAPPER(sendto)
111#define shutdown VSF_LINUX_SOCKET_WRAPPER(shutdown)
112#define socket VSF_LINUX_SOCKET_WRAPPER(socket)
113#define socketpair VSF_LINUX_SOCKET_WRAPPER(socketpair)
114#endif
115
116// syscalls
117
118#define __NR_connect connect
119#define __NR_accept accept
120#define __NR_accept4 accept4
121#define __NR_bind bind
122
123// level for sockopt
124#define SOL_SOCKET 0xFFFF
125// sock options
126// refer: https://code.woboq.org/gtk/include/asm-generic/socket.h.html
127#define SO_DEBUG 1
128#define SO_REUSEADDR 2
129#define SO_TYPE 3
130#define SO_ERROR 4
131#define SO_DONTROUTE 5
132#define SO_BROADCAST 6
133#define SO_SNDBUF 7
134#define SO_RCVBUF 8
135#define SO_KEEPALIVE 9
136#define SO_OOBINLINE 10
137#define SO_NO_CHECK 11
138#define SO_PRIORITY 12
139#define SO_LINGER 13
140#define SO_BSDCOMPAT 14
141#define SO_REUSEPORT 15
142// struct ucred is not implemented
143//#define SO_PASSCRED 16
144//#define SO_PEERCRED 17
145#define SO_RCVLOWAT 18
146#define SO_SNDLOWAT 19
147#define SO_RCVTIMEO 20
148#define SO_SNDTIMEO 21
149#define SO_BINDTODEVICE 25
150#define SO_MAX_PACING_RATE 47
151#define SO_NONBLOCK 100
152
153// IP options
154#define IP_TOS 1
155#define IP_TTL 2
156#define IP_HDRINCL 3
157#define IP_OPTIONS 4
158#define IP_PKTINFO 8
159
160// multicast
161// in.h
162#define IP_MULTICAST_IF 32
163#define IP_MULTICAST_TTL 33
164#define IP_MULTICAST_LOOP 34
165#define IP_ADD_MEMBERSHIP 35
166#define IP_DROP_MEMBERSHIP 36
167#define IP_MULTICAST_ALL 49
168// in6.h
169#define IPV6_UNICAST_HOPS 16
170#define IPV6_MULTICAST_IF 17
171#define IPV6_MULTICAST_HOPS 18
172#define IPV6_MULTICAST_LOOP 19
173#define IPV6_JOIN_GROUP 20
174#define IPV6_ADD_MEMBERSHIP IPV6_JOIN_GROUP
175#define IPV6_LEAVE_GROUP 21
176#define IPV6_DROP_MEMBERSHIP IPV6_LEAVE_GROUP
177#define IPV6_V6ONLY 26
178
179// flags for send/recv
180enum {
181 MSG_OOB = 1 << 0,
182#define MSG_OOB MSG_OOB
183 MSG_PEEK = 1 << 1,
184#define MSG_PEEK MSG_PEEK
186#define MSG_DONTROUTE MSG_DONTROUTE
187 MSG_CTRUNC = 1 << 3,
188#define MSG_CTRUNC MSG_CTRUNC
189 MSG_TRUNC = 1 << 5,
190#define MSG_TRUNC MSG_TRUNC
191 MSG_DONTWAIT = 1 << 6,
192#define MSG_DONTWAIT MSG_DONTWAIT
193 MSG_WAITALL = 1 << 8,
194#define MSG_WAITALL MSG_WAITALL
195 MSG_NOSIGNAL = 1 << 14,
196#define MSG_NOSIGNAL MSG_NOSIGNAL
197};
198
199struct msghdr {
200 void *msg_name;
202 struct iovec *msg_iov;
207};
208
209#define CMSG_ALIGN(len) (((len)+sizeof(long)-1) & ~(sizeof(long)-1))
210#define CMSG_SPACE(len) (sizeof(struct cmsghdr) + CMSG_ALIGN(len))
211#define CMSG_LEN(len) (sizeof(struct cmsghdr) + (len))
212#define CMSG_DATA(cmsg) (void *)((uint8_t *)(cmsg) + sizeof(struct cmsghdr))
213#define CMSG_FIRSTHDR(msg) \
214 ((msg)->msg_controllen >= sizeof(struct cmsghdr) ? \
215 (struct cmsghdr *)(msg)->msg_control \
216 : (struct cmsghdr *)NULL)
217struct cmsghdr {
218 size_t cmsg_len;
221};
222
223#if __IS_COMPILER_GCC__
224# pragma GCC diagnostic push
225# pragma GCC diagnostic ignored "-Wcast-align"
226#elif __IS_COMPILER_LLVM__ || __IS_COMPILER_ARM_COMPILER_6__
227# pragma clang diagnostic push
228# pragma clang diagnostic ignored "-Wcast-align"
229#endif
230
231static inline struct cmsghdr * CMSG_NXTHDR(struct msghdr *__msg, struct cmsghdr *__cmsg)
232{
233 struct cmsghdr * __ptr;
234
235 __ptr = (struct cmsghdr*)(((unsigned char *) __cmsg) + CMSG_ALIGN(__cmsg->cmsg_len));
236 if ((unsigned long)((char*)(__ptr+1) - (char *)__msg->msg_control) > __msg->msg_controllen)
237 return (struct cmsghdr *)0;
238
239 return __ptr;
240}
241
242#if __IS_COMPILER_GCC__
243# pragma GCC diagnostic pop
244#elif __IS_COMPILER_LLVM__ || __IS_COMPILER_ARM_COMPILER_6__
245# pragma clang diagnostic pop
246#endif
247
248// how for shutdown
249enum {
250 SHUT_RD = 1 << 0,
251 SHUT_WR = 1 << 1,
253};
254
255#if VSF_LINUX_APPLET_USE_SYS_SOCKET == ENABLED
258
261
264
269
276
280
281 // in6addr_any and in6addr_loopback belongs to <netinet/in.h>, which has no vplt, so add to socket vplt
285# ifndef __VSF_APPLET__
287# endif
288#endif
289
290#if defined(__VSF_APPLET__) && (defined(__VSF_APPLET_LIB__) || defined(__VSF_APPLET_LINUX_SYS_SOCKET_LIB__))\
291 && VSF_APPLET_CFG_ABI_PATCH != ENABLED && VSF_LINUX_APPLET_USE_SYS_SOCKET == ENABLED
292
293#ifndef VSF_LINUX_APPLET_SYS_SOCKET_VPLT
294# if VSF_LINUX_USE_APPLET == ENABLED
295# define VSF_LINUX_APPLET_SYS_SOCKET_VPLT \
296 ((vsf_linux_sys_socket_vplt_t *)(VSF_LINUX_APPLET_VPLT->sys_socket_vplt))
297# else
298# define VSF_LINUX_APPLET_SYS_SOCKET_VPLT \
299 ((vsf_linux_sys_socket_vplt_t *)vsf_vplt((void *)0))
300# endif
301#endif
302
303#define VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(__NAME) \
304 VSF_APPLET_VPLT_ENTRY_FUNC_ENTRY(VSF_LINUX_APPLET_SYS_SOCKET_VPLT, __NAME)
305#define VSF_LINUX_APPLET_SYS_SOCKET_IMP(...) \
306 VSF_APPLET_VPLT_ENTRY_FUNC_IMP(VSF_LINUX_APPLET_SYS_SOCKET_VPLT, __VA_ARGS__)
307
308VSF_LINUX_APPLET_SYS_SOCKET_IMP(setsockopt, int, int sockfd, int level, int optname, const void *optval, socklen_t optlen) {
310 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(setsockopt)(sockfd, level, optname, optval, optlen);
311}
312VSF_LINUX_APPLET_SYS_SOCKET_IMP(getsockopt, int, int sockfd, int level, int optname, void *optval, socklen_t *optlen) {
314 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(getsockopt)(sockfd, level, optname, optval, optlen);
315}
316VSF_LINUX_APPLET_SYS_SOCKET_IMP(getpeername, int, int sockfd, struct sockaddr *addr, socklen_t *addrlen) {
318 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(getpeername)(sockfd, addr, addrlen);
319}
320VSF_LINUX_APPLET_SYS_SOCKET_IMP(getsockname, int, int sockfd, struct sockaddr *addr, socklen_t *addrlen) {
322 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(getsockname)(sockfd, addr, addrlen);
323}
324VSF_LINUX_APPLET_SYS_SOCKET_IMP(accept, int, int sockfd, struct sockaddr *addr, socklen_t *addrlen) {
326 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(accept)(sockfd, addr, addrlen);
327}
328VSF_LINUX_APPLET_SYS_SOCKET_IMP(bind, int, int sockfd, const struct sockaddr *addr, socklen_t addrlen) {
330 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(bind)(sockfd, addr, addrlen);
331}
332VSF_LINUX_APPLET_SYS_SOCKET_IMP(connect, int, int sockfd, const struct sockaddr *addr, socklen_t addrlen) {
334 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(connect)(sockfd, addr, addrlen);
335}
336VSF_LINUX_APPLET_SYS_SOCKET_IMP(listen, int, int sockfd, int backlog) {
338 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(listen)(sockfd, backlog);
339}
340VSF_LINUX_APPLET_SYS_SOCKET_IMP(recv, ssize_t, int sockfd, void *buffer, size_t length, int flags) {
342 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(recv)(sockfd, buffer, length, flags);
343}
344VSF_LINUX_APPLET_SYS_SOCKET_IMP(recvmsg, ssize_t, int sockfd, struct msghdr *msg, int flags) {
346 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(recvmsg)(sockfd, msg, flags);
347}
348VSF_LINUX_APPLET_SYS_SOCKET_IMP(recvfrom, ssize_t, int sockfd, void *buffer, size_t length, int flags, struct sockaddr *src_addr, socklen_t *addrlen) {
350 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(recvfrom)(sockfd, buffer, length, flags, src_addr, addrlen);
351}
352VSF_LINUX_APPLET_SYS_SOCKET_IMP(send, ssize_t, int sockfd, const void *buffer, size_t length, int flags) {
354 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(send)(sockfd, buffer, length, flags);
355}
356VSF_LINUX_APPLET_SYS_SOCKET_IMP(sendmsg, ssize_t, int sockfd, const struct msghdr *msg, int flags) {
358 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(sendmsg)(sockfd, msg, flags);
359}
360VSF_LINUX_APPLET_SYS_SOCKET_IMP(sendto, ssize_t, int sockfd, const void *buffer, size_t length, int flags, const struct sockaddr *dest_addr, socklen_t addrlen) {
362 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(sendto)(sockfd, buffer, length, flags, dest_addr, addrlen);
363}
364VSF_LINUX_APPLET_SYS_SOCKET_IMP(shutdown, int, int sockfd, int how) {
366 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(shutdown)(sockfd, how);
367}
368VSF_LINUX_APPLET_SYS_SOCKET_IMP(socket, int, int domain, int type, int protocol) {
370 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(socket)(domain, type, protocol);
371}
372VSF_LINUX_APPLET_SYS_SOCKET_IMP(socketpair, int, int domain, int type, int protocol, int socket_vector[2]) {
374 return VSF_LINUX_APPLET_SYS_SOCKET_ENTRY(socketpair)(domain, type, protocol, socket_vector);
375}
376
377#else // __VSF_APPLET__ && VSF_LINUX_APPLET_USE_SYS_SOCKET
378
379int setsockopt(int sockfd, int level, int optname, const void *optval,
380 socklen_t optlen);
381int getsockopt(int sockfd, int level, int optname, void *optval,
382 socklen_t *optlen);
383
384int getpeername(int sockfd, struct sockaddr *addr, socklen_t *addrlen);
385int getsockname(int sockfd, struct sockaddr *addr, socklen_t *addrlen);
386
387int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen);
388int accept4(int sockfd, struct sockaddr *addr, socklen_t *addrlen, int flags);
389int bind(int sockfd, const struct sockaddr *addr, socklen_t addrlen);
390int connect(int sockfd, const struct sockaddr *addr, socklen_t addrlen);
391int listen(int sockfd, int backlog);
392
393ssize_t recv(int sockfd, void *buffer, size_t length, int flags);
394ssize_t recvmsg(int sockfd, struct msghdr *msg, int flags);
395ssize_t recvfrom(int sockfd, void *buffer, size_t length, int flags,
396 struct sockaddr *src_addr, socklen_t *addrlen);
397ssize_t send(int sockfd, const void *buffer, size_t length, int flags);
398ssize_t sendmsg(int sockfd, const struct msghdr *msg, int flags);
399ssize_t sendto(int sockfd, const void *buffer, size_t length, int flags,
400 const struct sockaddr *dest_addr, socklen_t addrlen);
401
402int shutdown(int sockfd, int how);
403int socket(int domain, int type, int protocol);
404int socketpair(int domain, int type, int protocol, int socket_vector[2]);
405
406#endif // __VSF_APPLET__ && VSF_LINUX_APPLET_USE_SYS_SOCKET
407
408#ifdef __cplusplus
409}
410#endif
411
412#endif
const struct in6_addr in6addr_loopback
Definition vsf_linux_socket.c:70
const struct in6_addr in6addr_any
Definition vsf_linux_socket.c:68
int ssize_t
Definition types.h:71
sock_type
Definition socket.h:55
@ SOCK_DGRAM
Definition socket.h:57
@ SOCK_RDM
Definition socket.h:59
@ SOCK_SEQPACKET
Definition socket.h:60
@ SOCK_RAW
Definition socket.h:58
@ SOCK_PACKET
Definition socket.h:61
@ SOCK_STREAM
Definition socket.h:56
#define MSG_WAITALL
Definition socket.h:194
#define getpeername
Definition socket.h:97
uint16_t sa_family_t
Definition socket.h:75
#define listen
Definition socket.h:104
#define sendmsg
Definition socket.h:109
#define setsockopt
Definition socket.h:94
#define accept
Definition socket.h:100
#define recvfrom
Definition socket.h:107
uint32_t socklen_t
Definition socket.h:72
#define sendto
Definition socket.h:110
__VSF_VPLT_DECORATOR__ vsf_linux_sys_socket_vplt_t vsf_linux_sys_socket_vplt
Definition vsf_linux_socket.c:821
#define MSG_PEEK
Definition socket.h:184
#define recvmsg
Definition socket.h:106
#define MSG_TRUNC
Definition socket.h:190
#define getsockopt
Definition socket.h:95
#define accept4
Definition socket.h:101
@ SHUT_RD
Definition socket.h:250
@ SHUT_WR
Definition socket.h:251
@ SHUT_RDWR
Definition socket.h:252
#define CMSG_ALIGN(len)
Definition socket.h:209
#define MSG_DONTROUTE
Definition socket.h:186
#define MSG_OOB
Definition socket.h:182
#define MSG_NOSIGNAL
Definition socket.h:196
#define getsockname
Definition socket.h:98
#define MSG_CTRUNC
Definition socket.h:188
#define socket
Definition socket.h:112
#define MSG_DONTWAIT
Definition socket.h:192
#define socketpair
Definition socket.h:113
#define shutdown
Definition socket.h:111
#define connect
Definition socket.h:103
#define recv
Definition socket.h:105
#define bind
Definition socket.h:102
#define send
Definition socket.h:108
unsigned short uint16_t
Definition stdint.h:7
unsigned uint32_t
Definition stdint.h:9
Definition socket.h:217
int cmsg_type
Definition socket.h:220
size_t cmsg_len
Definition socket.h:218
int cmsg_level
Definition socket.h:219
Definition unistd.h:230
Definition socket.h:86
int l_linger
Definition socket.h:88
int l_onoff
Definition socket.h:87
Definition socket.h:199
struct iovec * msg_iov
Definition socket.h:202
socklen_t msg_namelen
Definition socket.h:201
void * msg_name
Definition socket.h:200
int msg_flags
Definition socket.h:206
size_t msg_controllen
Definition socket.h:205
size_t msg_iovlen
Definition socket.h:203
void * msg_control
Definition socket.h:204
Definition socket.h:80
sa_family_t ss_family
Definition socket.h:81
char sa_data[32]
Definition socket.h:83
Definition socket.h:76
char sa_data[32]
Definition socket.h:78
sa_family_t sa_family
Definition socket.h:77
Definition socket.h:256
VSF_APPLET_VPLT_ENTRY_FUNC_DEF(socketpair)
VSF_APPLET_VPLT_ENTRY_FUNC_DEF(setsockopt)
vsf_vplt_info_t info
Definition socket.h:257
VSF_APPLET_VPLT_ENTRY_FUNC_DEF(shutdown)
VSF_APPLET_VPLT_ENTRY_FUNC_DEF(getsockopt)
VSF_APPLET_VPLT_ENTRY_FUNC_DEF(getpeername)
VSF_APPLET_VPLT_ENTRY_FUNC_DEF(recvfrom)
VSF_APPLET_VPLT_ENTRY_VAR_DEF(in6addr_loopback)
VSF_APPLET_VPLT_ENTRY_FUNC_DEF(getsockname)
VSF_APPLET_VPLT_ENTRY_VAR_DEF(in6addr_any)
Definition vsf_cfg.h:95
vk_av_control_type_t type
Definition vsf_audio.h:170
#define __VSF_VPLT_DECORATOR__
Definition vsf_cfg.h:93
#define VSF_APPLET_VPLT_ENTRY_FUNC_TRACE()
Definition vsf_cfg.h:165
uint_fast8_t length
Definition vsf_pbuf.c:38
Generated from commit: vsfteam/vsf@1c19fdc