net_sockets.c 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353
  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. /* LWIPPTP_SWREQ_0036 */
  141. int sendmsg(int s, const struct msghdr *message, int flags)
  142. {
  143. int socket = dfs_net_getsocket(s);
  144. return sal_sendmsg(socket, message, flags);
  145. }
  146. RTM_EXPORT(sendmsg);
  147. /* LWIPPTP_SWREQ_0036 */
  148. int recvmsg(int s, struct msghdr *message, int flags)
  149. {
  150. int socket = dfs_net_getsocket(s);
  151. return sal_recvmsg(socket, message, flags);
  152. }
  153. RTM_EXPORT(recvmsg);
  154. int recvfrom(int s, void *mem, size_t len, int flags,
  155. struct sockaddr *from, socklen_t *fromlen)
  156. {
  157. int socket = dfs_net_getsocket(s);
  158. return sal_recvfrom(socket, mem, len, flags, from, fromlen);
  159. }
  160. RTM_EXPORT(recvfrom);
  161. int send(int s, const void *dataptr, size_t size, int flags)
  162. {
  163. int socket = dfs_net_getsocket(s);
  164. return sal_sendto(socket, dataptr, size, flags, NULL, 0);
  165. }
  166. RTM_EXPORT(send);
  167. int sendto(int s, const void *dataptr, size_t size, int flags,
  168. const struct sockaddr *to, socklen_t tolen)
  169. {
  170. int socket = dfs_net_getsocket(s);
  171. return sal_sendto(socket, dataptr, size, flags, to, tolen);
  172. }
  173. RTM_EXPORT(sendto);
  174. int socket(int domain, int type, int protocol)
  175. {
  176. /* create a BSD socket */
  177. int fd;
  178. int socket;
  179. struct dfs_file *d;
  180. /* allocate a fd */
  181. fd = fd_new();
  182. if (fd < 0)
  183. {
  184. rt_set_errno(-ENOMEM);
  185. return -1;
  186. }
  187. d = fd_get(fd);
  188. #ifdef RT_USING_DFS_V2
  189. d->fops = dfs_net_get_fops();
  190. #endif
  191. d->vnode = (struct dfs_vnode *)rt_malloc(sizeof(struct dfs_vnode));
  192. if (!d->vnode)
  193. {
  194. /* release fd */
  195. fd_release(fd);
  196. rt_set_errno(-ENOMEM);
  197. return -1;
  198. }
  199. /* create socket and then put it to the dfs_file */
  200. socket = sal_socket(domain, type, protocol);
  201. if (socket >= 0)
  202. {
  203. dfs_vnode_init(d->vnode, FT_SOCKET, dfs_net_get_fops());
  204. d->flags = O_RDWR; /* set flags as read and write */
  205. /* set socket to the data of dfs_file */
  206. d->vnode->data = (void *)(size_t)socket;
  207. }
  208. else
  209. {
  210. /* release fd */
  211. fd_release(fd);
  212. rt_set_errno(-ENOMEM);
  213. return -1;
  214. }
  215. return fd;
  216. }
  217. RTM_EXPORT(socket);
  218. int closesocket(int s)
  219. {
  220. int error = 0;
  221. int socket = -1;
  222. struct dfs_file *d;
  223. socket = dfs_net_getsocket(s);
  224. if (socket < 0)
  225. {
  226. rt_set_errno(-ENOTSOCK);
  227. return -1;
  228. }
  229. d = fd_get(s);
  230. if (d == RT_NULL)
  231. {
  232. rt_set_errno(-EBADF);
  233. return -1;
  234. }
  235. if (!d->vnode)
  236. {
  237. rt_set_errno(-EBADF);
  238. return -1;
  239. }
  240. if (sal_closesocket(socket) == 0)
  241. {
  242. error = 0;
  243. }
  244. else
  245. {
  246. rt_set_errno(-ENOTSOCK);
  247. error = -1;
  248. }
  249. /* socket has been closed, delete it from file system fd */
  250. fd_release(s);
  251. return error;
  252. }
  253. RTM_EXPORT(closesocket);
  254. int socketpair(int domain, int type, int protocol, int *fds)
  255. {
  256. rt_err_t ret = 0;
  257. int sock_fds[2];
  258. fds[0] = socket(domain, type, protocol);
  259. if (fds[0] < 0)
  260. {
  261. fds[0] = 0;
  262. return -1;
  263. }
  264. fds[1] = socket(domain, type, protocol);
  265. if (fds[1] < 0)
  266. {
  267. closesocket(fds[0]);
  268. fds[0] = 0;
  269. fds[1] = 0;
  270. return -1;
  271. }
  272. sock_fds[0] = dfs_net_getsocket(fds[0]);
  273. sock_fds[1] = dfs_net_getsocket(fds[1]);
  274. ret = sal_socketpair(domain, type, protocol, sock_fds);
  275. if (ret < 0)
  276. {
  277. closesocket(fds[0]);
  278. closesocket(fds[1]);
  279. }
  280. return ret;
  281. }
  282. RTM_EXPORT(socketpair);
  283. int ioctlsocket(int s, long cmd, void *arg)
  284. {
  285. int socket = dfs_net_getsocket(s);
  286. return sal_ioctlsocket(socket, cmd, arg);
  287. }
  288. RTM_EXPORT(ioctlsocket);