dfs_net.c 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119
  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. * 2016-05-07 Bernard Rename dfs_lwip to dfs_net
  10. * 2018-03-09 Bernard Fix the last data issue in poll.
  11. * 2018-05-24 ChenYong Add socket abstraction layer
  12. */
  13. #include <rtthread.h>
  14. #include <dfs.h>
  15. #include <dfs_net.h>
  16. #include <sys/socket.h>
  17. int dfs_net_getsocket(int fd)
  18. {
  19. int socket;
  20. struct dfs_file *file;
  21. file = fd_get(fd);
  22. if (file == NULL) return -1;
  23. if (file->vnode->type != FT_SOCKET) socket = -1;
  24. else socket = (int)(size_t)file->vnode->data;
  25. return socket;
  26. }
  27. static int dfs_net_ioctl(struct dfs_file* file, int cmd, void* args)
  28. {
  29. int ret;
  30. int socket = (int)(size_t)file->vnode->data;
  31. ret = sal_ioctlsocket(socket, cmd, args);
  32. if (ret < 0)
  33. {
  34. ret = rt_get_errno();
  35. return (ret > 0) ? (-ret) : ret;
  36. }
  37. return ret;
  38. }
  39. #ifdef RT_USING_DFS_V2
  40. static ssize_t dfs_net_read(struct dfs_file* file, void *buf, size_t count, off_t *pos)
  41. #else
  42. static ssize_t dfs_net_read(struct dfs_file* file, void *buf, size_t count)
  43. #endif
  44. {
  45. int ret;
  46. int socket = (int)(size_t)file->vnode->data;
  47. ret = sal_recvfrom(socket, buf, count, 0, NULL, NULL);
  48. if (ret < 0)
  49. {
  50. ret = rt_get_errno();
  51. return (ret > 0) ? (-ret) : ret;
  52. }
  53. return ret;
  54. }
  55. #ifdef RT_USING_DFS_V2
  56. static ssize_t dfs_net_write(struct dfs_file *file, const void *buf, size_t count, off_t *pos)
  57. #else
  58. static ssize_t dfs_net_write(struct dfs_file *file, const void *buf, size_t count)
  59. #endif
  60. {
  61. int ret;
  62. int socket = (int)(size_t)file->vnode->data;
  63. ret = sal_sendto(socket, buf, count, 0, NULL, 0);
  64. if (ret < 0)
  65. {
  66. ret = rt_get_errno();
  67. return (ret > 0) ? (-ret) : ret;
  68. }
  69. return ret;
  70. }
  71. static int dfs_net_close(struct dfs_file* file)
  72. {
  73. int socket;
  74. int ret = 0;
  75. if (file->vnode->ref_count == 1)
  76. {
  77. socket = (int)(size_t)file->vnode->data;
  78. ret = sal_closesocket(socket);
  79. }
  80. return ret;
  81. }
  82. static int dfs_net_poll(struct dfs_file *file, struct rt_pollreq *req)
  83. {
  84. extern int sal_poll(struct dfs_file *file, struct rt_pollreq *req);
  85. return sal_poll(file, req);
  86. }
  87. const struct dfs_file_ops _net_fops =
  88. {
  89. .close = dfs_net_close,
  90. .ioctl = dfs_net_ioctl,
  91. .read = dfs_net_read,
  92. .write = dfs_net_write,
  93. .poll = dfs_net_poll,
  94. };
  95. const struct dfs_file_ops *dfs_net_get_fops(void)
  96. {
  97. return &_net_fops;
  98. }