net_sockets.c 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311
  1. /*
  2. * Copyright (c) 2006-2018, 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 <dfs_poll.h>
  14. #include <dfs_net.h>
  15. #include <sys/socket.h>
  16. int accept(int s, struct sockaddr *addr, socklen_t *addrlen)
  17. {
  18. int new_socket = -1;
  19. int socket = dfs_net_getsocket(s);
  20. new_socket = sal_accept(socket, addr, addrlen);
  21. if (new_socket != -1)
  22. {
  23. /* this is a new socket, create it in file system fd */
  24. int fd;
  25. struct dfs_fd *d;
  26. /* allocate a fd */
  27. fd = fd_new();
  28. if (fd < 0)
  29. {
  30. rt_set_errno(-ENOMEM);
  31. sal_closesocket(new_socket);
  32. return -1;
  33. }
  34. d = fd_get(fd);
  35. if(d)
  36. {
  37. /* this is a socket fd */
  38. d->fnode = (struct dfs_fnode *)rt_malloc(sizeof(struct dfs_fnode));
  39. if (!d->fnode)
  40. {
  41. /* release fd */
  42. fd_release(fd);
  43. rt_set_errno(-ENOMEM);
  44. return -1;
  45. }
  46. rt_memset(d->fnode, 0, sizeof(struct dfs_fnode));
  47. rt_list_init(&d->fnode->list);
  48. d->fnode->type = FT_SOCKET;
  49. d->fnode->path = NULL;
  50. d->fnode->fullpath = NULL;
  51. d->fnode->ref_count = 1;
  52. d->fnode->fops = dfs_net_get_fops();
  53. d->flags = O_RDWR; /* set flags as read and write */
  54. d->fnode->size = 0;
  55. d->pos = 0;
  56. /* set socket to the data of dfs_fd */
  57. d->fnode->data = (void *) new_socket;
  58. return fd;
  59. }
  60. rt_set_errno(-ENOMEM);
  61. sal_closesocket(new_socket);
  62. return -1;
  63. }
  64. return -1;
  65. }
  66. RTM_EXPORT(accept);
  67. int bind(int s, const struct sockaddr *name, socklen_t namelen)
  68. {
  69. int socket = dfs_net_getsocket(s);
  70. return sal_bind(socket, name, namelen);
  71. }
  72. RTM_EXPORT(bind);
  73. int shutdown(int s, int how)
  74. {
  75. int error = 0;
  76. int socket = -1;
  77. struct dfs_fd *d;
  78. socket = dfs_net_getsocket(s);
  79. if (socket < 0)
  80. {
  81. rt_set_errno(-ENOTSOCK);
  82. return -1;
  83. }
  84. d = fd_get(s);
  85. if (d == NULL)
  86. {
  87. rt_set_errno(-EBADF);
  88. return -1;
  89. }
  90. if (sal_shutdown(socket, how) == 0)
  91. {
  92. error = 0;
  93. }
  94. else
  95. {
  96. rt_set_errno(-ENOTSOCK);
  97. error = -1;
  98. }
  99. return error;
  100. }
  101. RTM_EXPORT(shutdown);
  102. int getpeername(int s, struct sockaddr *name, socklen_t *namelen)
  103. {
  104. int socket = dfs_net_getsocket(s);
  105. return sal_getpeername(socket, name, namelen);
  106. }
  107. RTM_EXPORT(getpeername);
  108. int getsockname(int s, struct sockaddr *name, socklen_t *namelen)
  109. {
  110. int socket = dfs_net_getsocket(s);
  111. return sal_getsockname(socket, name, namelen);
  112. }
  113. RTM_EXPORT(getsockname);
  114. int getsockopt(int s, int level, int optname, void *optval, socklen_t *optlen)
  115. {
  116. int socket = dfs_net_getsocket(s);
  117. return sal_getsockopt(socket, level, optname, optval, optlen);
  118. }
  119. RTM_EXPORT(getsockopt);
  120. int setsockopt(int s, int level, int optname, const void *optval, socklen_t optlen)
  121. {
  122. int socket = dfs_net_getsocket(s);
  123. return sal_setsockopt(socket, level, optname, optval, optlen);
  124. }
  125. RTM_EXPORT(setsockopt);
  126. int connect(int s, const struct sockaddr *name, socklen_t namelen)
  127. {
  128. int socket = dfs_net_getsocket(s);
  129. return sal_connect(socket, name, namelen);
  130. }
  131. RTM_EXPORT(connect);
  132. int listen(int s, int backlog)
  133. {
  134. int socket = dfs_net_getsocket(s);
  135. return sal_listen(socket, backlog);
  136. }
  137. RTM_EXPORT(listen);
  138. int recv(int s, void *mem, size_t len, int flags)
  139. {
  140. int socket = dfs_net_getsocket(s);
  141. return sal_recvfrom(socket, mem, len, flags, NULL, NULL);
  142. }
  143. RTM_EXPORT(recv);
  144. int recvfrom(int s, void *mem, size_t len, int flags,
  145. struct sockaddr *from, socklen_t *fromlen)
  146. {
  147. int socket = dfs_net_getsocket(s);
  148. return sal_recvfrom(socket, mem, len, flags, from, fromlen);
  149. }
  150. RTM_EXPORT(recvfrom);
  151. int send(int s, const void *dataptr, size_t size, int flags)
  152. {
  153. int socket = dfs_net_getsocket(s);
  154. return sal_sendto(socket, dataptr, size, flags, NULL, 0);
  155. }
  156. RTM_EXPORT(send);
  157. int sendto(int s, const void *dataptr, size_t size, int flags,
  158. const struct sockaddr *to, socklen_t tolen)
  159. {
  160. int socket = dfs_net_getsocket(s);
  161. return sal_sendto(socket, dataptr, size, flags, to, tolen);
  162. }
  163. RTM_EXPORT(sendto);
  164. int socket(int domain, int type, int protocol)
  165. {
  166. /* create a BSD socket */
  167. int fd;
  168. int socket;
  169. struct dfs_fd *d;
  170. /* allocate a fd */
  171. fd = fd_new();
  172. if (fd < 0)
  173. {
  174. rt_set_errno(-ENOMEM);
  175. return -1;
  176. }
  177. d = fd_get(fd);
  178. d->fnode = (struct dfs_fnode *)rt_malloc(sizeof(struct dfs_fnode));
  179. if (!d->fnode)
  180. {
  181. /* release fd */
  182. fd_release(fd);
  183. rt_set_errno(-ENOMEM);
  184. return -1;
  185. }
  186. /* create socket and then put it to the dfs_fd */
  187. socket = sal_socket(domain, type, protocol);
  188. if (socket >= 0)
  189. {
  190. rt_memset(d->fnode, 0, sizeof(struct dfs_fnode));
  191. rt_list_init(&d->fnode->list);
  192. /* this is a socket fd */
  193. d->fnode->type = FT_SOCKET;
  194. d->fnode->path = NULL;
  195. d->fnode->fullpath = NULL;
  196. d->fnode->ref_count = 1;
  197. d->fnode->fops = dfs_net_get_fops();
  198. d->flags = O_RDWR; /* set flags as read and write */
  199. d->fnode->size = 0;
  200. d->pos = 0;
  201. /* set socket to the data of dfs_fd */
  202. d->fnode->data = (void *) socket;
  203. }
  204. else
  205. {
  206. rt_free(d->fnode);
  207. /* release fd */
  208. fd_release(fd);
  209. rt_set_errno(-ENOMEM);
  210. return -1;
  211. }
  212. return fd;
  213. }
  214. RTM_EXPORT(socket);
  215. int closesocket(int s)
  216. {
  217. int error = 0;
  218. int socket = -1;
  219. struct dfs_fd *d;
  220. socket = dfs_net_getsocket(s);
  221. if (socket < 0)
  222. {
  223. rt_set_errno(-ENOTSOCK);
  224. return -1;
  225. }
  226. d = fd_get(s);
  227. if (d == RT_NULL)
  228. {
  229. rt_set_errno(-EBADF);
  230. return -1;
  231. }
  232. if (!d->fnode)
  233. {
  234. rt_set_errno(-EBADF);
  235. return -1;
  236. }
  237. if (sal_closesocket(socket) == 0)
  238. {
  239. error = 0;
  240. }
  241. else
  242. {
  243. rt_set_errno(-ENOTSOCK);
  244. error = -1;
  245. }
  246. rt_free(d->fnode);
  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 ioctlsocket(int s, long cmd, void *arg)
  253. {
  254. int socket = dfs_net_getsocket(s);
  255. return sal_ioctlsocket(socket, cmd, arg);
  256. }
  257. RTM_EXPORT(ioctlsocket);