net_sockets.c 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340
  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_fd *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. /* this is a socket fd */
  39. d->vnode = (struct dfs_fnode *)rt_malloc(sizeof(struct dfs_fnode));
  40. if (!d->vnode)
  41. {
  42. /* release fd */
  43. fd_release(fd);
  44. rt_set_errno(-ENOMEM);
  45. return -1;
  46. }
  47. rt_memset(d->vnode, 0, sizeof(struct dfs_fnode));
  48. rt_list_init(&d->vnode->list);
  49. d->vnode->type = FT_SOCKET;
  50. d->vnode->path = NULL;
  51. d->vnode->fullpath = NULL;
  52. d->vnode->ref_count = 1;
  53. d->vnode->fops = dfs_net_get_fops();
  54. d->flags = O_RDWR; /* set flags as read and write */
  55. d->vnode->size = 0;
  56. d->pos = 0;
  57. /* set socket to the data of dfs_fd */
  58. d->vnode->data = (void *)(size_t)new_socket;
  59. return fd;
  60. }
  61. rt_set_errno(-ENOMEM);
  62. sal_closesocket(new_socket);
  63. return -1;
  64. }
  65. return -1;
  66. }
  67. RTM_EXPORT(accept);
  68. int bind(int s, const struct sockaddr *name, socklen_t namelen)
  69. {
  70. int socket = dfs_net_getsocket(s);
  71. #ifdef SAL_USING_AF_UNIX
  72. struct sockaddr_in server_addr = {0};
  73. if (name->sa_family == AF_UNIX)
  74. {
  75. server_addr.sin_family = AF_INET;
  76. server_addr.sin_port = htons(514);
  77. server_addr.sin_addr.s_addr = inet_addr("127.0.0.1");
  78. return sal_bind(socket, (struct sockaddr *)&server_addr, namelen);
  79. }
  80. #endif /* SAL_USING_AF_UNIX */
  81. return sal_bind(socket, name, namelen);
  82. }
  83. RTM_EXPORT(bind);
  84. int shutdown(int s, int how)
  85. {
  86. int error = 0;
  87. int socket = -1;
  88. struct dfs_fd *d;
  89. socket = dfs_net_getsocket(s);
  90. if (socket < 0)
  91. {
  92. rt_set_errno(-ENOTSOCK);
  93. return -1;
  94. }
  95. d = fd_get(s);
  96. if (d == NULL)
  97. {
  98. rt_set_errno(-EBADF);
  99. return -1;
  100. }
  101. if (sal_shutdown(socket, how) == 0)
  102. {
  103. error = 0;
  104. }
  105. else
  106. {
  107. rt_set_errno(-ENOTSOCK);
  108. error = -1;
  109. }
  110. return error;
  111. }
  112. RTM_EXPORT(shutdown);
  113. int getpeername(int s, struct sockaddr *name, socklen_t *namelen)
  114. {
  115. int socket = dfs_net_getsocket(s);
  116. return sal_getpeername(socket, name, namelen);
  117. }
  118. RTM_EXPORT(getpeername);
  119. int getsockname(int s, struct sockaddr *name, socklen_t *namelen)
  120. {
  121. int socket = dfs_net_getsocket(s);
  122. return sal_getsockname(socket, name, namelen);
  123. }
  124. RTM_EXPORT(getsockname);
  125. int getsockopt(int s, int level, int optname, void *optval, socklen_t *optlen)
  126. {
  127. int socket = dfs_net_getsocket(s);
  128. return sal_getsockopt(socket, level, optname, optval, optlen);
  129. }
  130. RTM_EXPORT(getsockopt);
  131. int setsockopt(int s, int level, int optname, const void *optval, socklen_t optlen)
  132. {
  133. int socket = dfs_net_getsocket(s);
  134. return sal_setsockopt(socket, level, optname, optval, optlen);
  135. }
  136. RTM_EXPORT(setsockopt);
  137. int connect(int s, const struct sockaddr *name, socklen_t namelen)
  138. {
  139. int socket = dfs_net_getsocket(s);
  140. #ifdef SAL_USING_AF_UNIX
  141. struct sockaddr_in server_addr = {0};
  142. if (name->sa_family == AF_UNIX)
  143. {
  144. server_addr.sin_family = AF_INET;
  145. server_addr.sin_port = htons(514);
  146. server_addr.sin_addr.s_addr = inet_addr("127.0.0.1");
  147. return sal_connect(socket, (struct sockaddr *)&server_addr, namelen);
  148. }
  149. #endif /* SAL_USING_AF_UNIX */
  150. return sal_connect(socket, name, namelen);
  151. }
  152. RTM_EXPORT(connect);
  153. int listen(int s, int backlog)
  154. {
  155. int socket = dfs_net_getsocket(s);
  156. return sal_listen(socket, backlog);
  157. }
  158. RTM_EXPORT(listen);
  159. int recv(int s, void *mem, size_t len, int flags)
  160. {
  161. int socket = dfs_net_getsocket(s);
  162. return sal_recvfrom(socket, mem, len, flags, NULL, NULL);
  163. }
  164. RTM_EXPORT(recv);
  165. int recvfrom(int s, void *mem, size_t len, int flags,
  166. struct sockaddr *from, socklen_t *fromlen)
  167. {
  168. int socket = dfs_net_getsocket(s);
  169. return sal_recvfrom(socket, mem, len, flags, from, fromlen);
  170. }
  171. RTM_EXPORT(recvfrom);
  172. int send(int s, const void *dataptr, size_t size, int flags)
  173. {
  174. int socket = dfs_net_getsocket(s);
  175. return sal_sendto(socket, dataptr, size, flags, NULL, 0);
  176. }
  177. RTM_EXPORT(send);
  178. int sendto(int s, const void *dataptr, size_t size, int flags,
  179. const struct sockaddr *to, socklen_t tolen)
  180. {
  181. int socket = dfs_net_getsocket(s);
  182. return sal_sendto(socket, dataptr, size, flags, to, tolen);
  183. }
  184. RTM_EXPORT(sendto);
  185. int socket(int domain, int type, int protocol)
  186. {
  187. /* create a BSD socket */
  188. int fd;
  189. int socket;
  190. struct dfs_fd *d;
  191. /* allocate a fd */
  192. fd = fd_new();
  193. if (fd < 0)
  194. {
  195. rt_set_errno(-ENOMEM);
  196. return -1;
  197. }
  198. d = fd_get(fd);
  199. d->vnode = (struct dfs_fnode *)rt_malloc(sizeof(struct dfs_fnode));
  200. if (!d->vnode)
  201. {
  202. /* release fd */
  203. fd_release(fd);
  204. rt_set_errno(-ENOMEM);
  205. return -1;
  206. }
  207. #ifdef SAL_USING_AF_UNIX
  208. if (domain == AF_UNIX)
  209. {
  210. domain = AF_INET;
  211. }
  212. #endif /* SAL_USING_AF_UNIX */
  213. /* create socket and then put it to the dfs_fd */
  214. socket = sal_socket(domain, type, protocol);
  215. if (socket >= 0)
  216. {
  217. rt_memset(d->vnode, 0, sizeof(struct dfs_fnode));
  218. rt_list_init(&d->vnode->list);
  219. /* this is a socket fd */
  220. d->vnode->type = FT_SOCKET;
  221. d->vnode->path = NULL;
  222. d->vnode->fullpath = NULL;
  223. d->vnode->ref_count = 1;
  224. d->vnode->fops = dfs_net_get_fops();
  225. d->flags = O_RDWR; /* set flags as read and write */
  226. d->vnode->size = 0;
  227. d->pos = 0;
  228. /* set socket to the data of dfs_fd */
  229. d->vnode->data = (void *)(size_t)socket;
  230. }
  231. else
  232. {
  233. rt_free(d->vnode);
  234. /* release fd */
  235. fd_release(fd);
  236. rt_set_errno(-ENOMEM);
  237. return -1;
  238. }
  239. return fd;
  240. }
  241. RTM_EXPORT(socket);
  242. int closesocket(int s)
  243. {
  244. int error = 0;
  245. int socket = -1;
  246. struct dfs_fd *d;
  247. socket = dfs_net_getsocket(s);
  248. if (socket < 0)
  249. {
  250. rt_set_errno(-ENOTSOCK);
  251. return -1;
  252. }
  253. d = fd_get(s);
  254. if (d == RT_NULL)
  255. {
  256. rt_set_errno(-EBADF);
  257. return -1;
  258. }
  259. if (!d->vnode)
  260. {
  261. rt_set_errno(-EBADF);
  262. return -1;
  263. }
  264. if (sal_closesocket(socket) == 0)
  265. {
  266. error = 0;
  267. }
  268. else
  269. {
  270. rt_set_errno(-ENOTSOCK);
  271. error = -1;
  272. }
  273. rt_free(d->vnode);
  274. /* socket has been closed, delete it from file system fd */
  275. fd_release(s);
  276. return error;
  277. }
  278. RTM_EXPORT(closesocket);
  279. int ioctlsocket(int s, long cmd, void *arg)
  280. {
  281. int socket = dfs_net_getsocket(s);
  282. return sal_ioctlsocket(socket, cmd, arg);
  283. }
  284. RTM_EXPORT(ioctlsocket);