net_sockets.c 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2015-02-17 Bernard First version
  9. * 2018-05-17 ChenYong Add socket abstraction layer
  10. */
  11. #include <dfs.h>
  12. #include <dfs_file.h>
  13. #include <poll.h>
  14. #include <dfs_net.h>
  15. #include <sys/errno.h>
  16. #include <sys/socket.h>
  17. int accept(int s, struct sockaddr *addr, socklen_t *addrlen)
  18. {
  19. int new_socket = -1;
  20. int socket = dfs_net_getsocket(s);
  21. new_socket = sal_accept(socket, addr, addrlen);
  22. if (new_socket != -1)
  23. {
  24. /* this is a new socket, create it in file system fd */
  25. int fd;
  26. struct dfs_file *d;
  27. /* allocate a fd */
  28. fd = fd_new();
  29. if (fd < 0)
  30. {
  31. rt_set_errno(-ENOMEM);
  32. sal_closesocket(new_socket);
  33. return -1;
  34. }
  35. d = fd_get(fd);
  36. if(d)
  37. {
  38. #ifdef RT_USING_DFS_V2
  39. d->fops = dfs_net_get_fops();
  40. #endif
  41. /* this is a socket fd */
  42. d->vnode = (struct dfs_vnode *)rt_malloc(sizeof(struct dfs_vnode));
  43. if (!d->vnode)
  44. {
  45. /* release fd */
  46. fd_release(fd);
  47. rt_set_errno(-ENOMEM);
  48. return -1;
  49. }
  50. dfs_vnode_init(d->vnode, FT_SOCKET, dfs_net_get_fops());
  51. d->flags = O_RDWR; /* set flags as read and write */
  52. /* set socket to the data of dfs_file */
  53. d->vnode->data = (void *)(size_t)new_socket;
  54. return fd;
  55. }
  56. rt_set_errno(-ENOMEM);
  57. sal_closesocket(new_socket);
  58. return -1;
  59. }
  60. return -1;
  61. }
  62. RTM_EXPORT(accept);
  63. int bind(int s, const struct sockaddr *name, socklen_t namelen)
  64. {
  65. int socket = dfs_net_getsocket(s);
  66. return sal_bind(socket, name, namelen);
  67. }
  68. RTM_EXPORT(bind);
  69. int shutdown(int s, int how)
  70. {
  71. int error = 0;
  72. int socket = -1;
  73. struct dfs_file *d;
  74. socket = dfs_net_getsocket(s);
  75. if (socket < 0)
  76. {
  77. rt_set_errno(-ENOTSOCK);
  78. return -1;
  79. }
  80. d = fd_get(s);
  81. if (d == NULL)
  82. {
  83. rt_set_errno(-EBADF);
  84. return -1;
  85. }
  86. if (sal_shutdown(socket, how) == 0)
  87. {
  88. error = 0;
  89. }
  90. else
  91. {
  92. rt_set_errno(-ENOTSOCK);
  93. error = -1;
  94. }
  95. return error;
  96. }
  97. RTM_EXPORT(shutdown);
  98. int getpeername(int s, struct sockaddr *name, socklen_t *namelen)
  99. {
  100. int socket = dfs_net_getsocket(s);
  101. return sal_getpeername(socket, name, namelen);
  102. }
  103. RTM_EXPORT(getpeername);
  104. int getsockname(int s, struct sockaddr *name, socklen_t *namelen)
  105. {
  106. int socket = dfs_net_getsocket(s);
  107. return sal_getsockname(socket, name, namelen);
  108. }
  109. RTM_EXPORT(getsockname);
  110. int getsockopt(int s, int level, int optname, void *optval, socklen_t *optlen)
  111. {
  112. int socket = dfs_net_getsocket(s);
  113. return sal_getsockopt(socket, level, optname, optval, optlen);
  114. }
  115. RTM_EXPORT(getsockopt);
  116. int setsockopt(int s, int level, int optname, const void *optval, socklen_t optlen)
  117. {
  118. int socket = dfs_net_getsocket(s);
  119. return sal_setsockopt(socket, level, optname, optval, optlen);
  120. }
  121. RTM_EXPORT(setsockopt);
  122. int connect(int s, const struct sockaddr *name, socklen_t namelen)
  123. {
  124. int socket = dfs_net_getsocket(s);
  125. return sal_connect(socket, name, namelen);
  126. }
  127. RTM_EXPORT(connect);
  128. int listen(int s, int backlog)
  129. {
  130. int socket = dfs_net_getsocket(s);
  131. return sal_listen(socket, backlog);
  132. }
  133. RTM_EXPORT(listen);
  134. int recv(int s, void *mem, size_t len, int flags)
  135. {
  136. int socket = dfs_net_getsocket(s);
  137. return sal_recvfrom(socket, mem, len, flags, NULL, NULL);
  138. }
  139. RTM_EXPORT(recv);
  140. int sendmsg(int s, const struct msghdr *message, int flags)
  141. {
  142. int socket = dfs_net_getsocket(s);
  143. return sal_sendmsg(socket, message, flags);
  144. }
  145. RTM_EXPORT(sendmsg);
  146. int recvmsg(int s, struct msghdr *message, int flags)
  147. {
  148. int socket = dfs_net_getsocket(s);
  149. return sal_recvmsg(socket, message, flags);
  150. }
  151. RTM_EXPORT(recvmsg);
  152. int recvfrom(int s, void *mem, size_t len, int flags,
  153. struct sockaddr *from, socklen_t *fromlen)
  154. {
  155. int socket = dfs_net_getsocket(s);
  156. return sal_recvfrom(socket, mem, len, flags, from, fromlen);
  157. }
  158. RTM_EXPORT(recvfrom);
  159. int send(int s, const void *dataptr, size_t size, int flags)
  160. {
  161. int socket = dfs_net_getsocket(s);
  162. return sal_sendto(socket, dataptr, size, flags, NULL, 0);
  163. }
  164. RTM_EXPORT(send);
  165. int sendto(int s, const void *dataptr, size_t size, int flags,
  166. const struct sockaddr *to, socklen_t tolen)
  167. {
  168. int socket = dfs_net_getsocket(s);
  169. return sal_sendto(socket, dataptr, size, flags, to, tolen);
  170. }
  171. RTM_EXPORT(sendto);
  172. int socket(int domain, int type, int protocol)
  173. {
  174. /* create a BSD socket */
  175. int fd;
  176. int socket;
  177. struct dfs_file *d;
  178. /* allocate a fd */
  179. fd = fd_new();
  180. if (fd < 0)
  181. {
  182. rt_set_errno(-ENOMEM);
  183. return -1;
  184. }
  185. d = fd_get(fd);
  186. #ifdef RT_USING_DFS_V2
  187. d->fops = dfs_net_get_fops();
  188. #endif
  189. d->vnode = (struct dfs_vnode *)rt_malloc(sizeof(struct dfs_vnode));
  190. if (!d->vnode)
  191. {
  192. /* release fd */
  193. fd_release(fd);
  194. rt_set_errno(-ENOMEM);
  195. return -1;
  196. }
  197. /* create socket and then put it to the dfs_file */
  198. socket = sal_socket(domain, type, protocol);
  199. if (socket >= 0)
  200. {
  201. dfs_vnode_init(d->vnode, FT_SOCKET, dfs_net_get_fops());
  202. d->flags = O_RDWR; /* set flags as read and write */
  203. /* set socket to the data of dfs_file */
  204. d->vnode->data = (void *)(size_t)socket;
  205. }
  206. else
  207. {
  208. /* release fd */
  209. fd_release(fd);
  210. rt_set_errno(-ENOMEM);
  211. return -1;
  212. }
  213. return fd;
  214. }
  215. RTM_EXPORT(socket);
  216. int closesocket(int s)
  217. {
  218. int error = 0;
  219. int socket = -1;
  220. struct dfs_file *d;
  221. socket = dfs_net_getsocket(s);
  222. if (socket < 0)
  223. {
  224. rt_set_errno(-ENOTSOCK);
  225. return -1;
  226. }
  227. d = fd_get(s);
  228. if (d == RT_NULL)
  229. {
  230. rt_set_errno(-EBADF);
  231. return -1;
  232. }
  233. if (!d->vnode)
  234. {
  235. rt_set_errno(-EBADF);
  236. return -1;
  237. }
  238. if (sal_closesocket(socket) == 0)
  239. {
  240. error = 0;
  241. }
  242. else
  243. {
  244. rt_set_errno(-ENOTSOCK);
  245. error = -1;
  246. }
  247. /* socket has been closed, delete it from file system fd */
  248. fd_release(s);
  249. return error;
  250. }
  251. RTM_EXPORT(closesocket);
  252. int socketpair(int domain, int type, int protocol, int *fds)
  253. {
  254. rt_err_t ret = 0;
  255. int sock_fds[2];
  256. fds[0] = socket(domain, type, protocol);
  257. if (fds[0] < 0)
  258. {
  259. fds[0] = 0;
  260. return -1;
  261. }
  262. fds[1] = socket(domain, type, protocol);
  263. if (fds[1] < 0)
  264. {
  265. closesocket(fds[0]);
  266. fds[0] = 0;
  267. fds[1] = 0;
  268. return -1;
  269. }
  270. sock_fds[0] = dfs_net_getsocket(fds[0]);
  271. sock_fds[1] = dfs_net_getsocket(fds[1]);
  272. ret = sal_socketpair(domain, type, protocol, sock_fds);
  273. if (ret < 0)
  274. {
  275. closesocket(fds[0]);
  276. closesocket(fds[1]);
  277. }
  278. return ret;
  279. }
  280. RTM_EXPORT(socketpair);
  281. int ioctlsocket(int s, long cmd, void *arg)
  282. {
  283. int socket = dfs_net_getsocket(s);
  284. return sal_ioctlsocket(socket, cmd, arg);
  285. }
  286. RTM_EXPORT(ioctlsocket);