xref: /nrf52832-nimble/rt-thread/components/net/sal_socket/dfs_net/dfs_net.c (revision 104654410c56c573564690304ae786df310c91fc)
1*10465441SEvalZero /*
2*10465441SEvalZero  * Copyright (c) 2006-2018, RT-Thread Development Team
3*10465441SEvalZero  *
4*10465441SEvalZero  * SPDX-License-Identifier: Apache-2.0
5*10465441SEvalZero  *
6*10465441SEvalZero  * Change Logs:
7*10465441SEvalZero  * Date           Author       Notes
8*10465441SEvalZero  * 2015-02-17     Bernard      First version
9*10465441SEvalZero  * 2016-05-07     Bernard      Rename dfs_lwip to dfs_net
10*10465441SEvalZero  * 2018-03-09     Bernard      Fix the last data issue in poll.
11*10465441SEvalZero  * 2018-05-24     ChenYong     Add socket abstraction layer
12*10465441SEvalZero  */
13*10465441SEvalZero 
14*10465441SEvalZero #include <rtthread.h>
15*10465441SEvalZero 
16*10465441SEvalZero #include <dfs.h>
17*10465441SEvalZero #include <dfs_net.h>
18*10465441SEvalZero 
19*10465441SEvalZero #include <sys/socket.h>
20*10465441SEvalZero 
dfs_net_getsocket(int fd)21*10465441SEvalZero int dfs_net_getsocket(int fd)
22*10465441SEvalZero {
23*10465441SEvalZero     int socket;
24*10465441SEvalZero     struct dfs_fd *_dfs_fd;
25*10465441SEvalZero 
26*10465441SEvalZero     _dfs_fd = fd_get(fd);
27*10465441SEvalZero     if (_dfs_fd == NULL) return -1;
28*10465441SEvalZero 
29*10465441SEvalZero     if (_dfs_fd->type != FT_SOCKET) socket = -1;
30*10465441SEvalZero     else socket = (int)_dfs_fd->data;
31*10465441SEvalZero 
32*10465441SEvalZero     fd_put(_dfs_fd); /* put this dfs fd */
33*10465441SEvalZero     return socket;
34*10465441SEvalZero }
35*10465441SEvalZero 
dfs_net_ioctl(struct dfs_fd * file,int cmd,void * args)36*10465441SEvalZero static int dfs_net_ioctl(struct dfs_fd* file, int cmd, void* args)
37*10465441SEvalZero {
38*10465441SEvalZero     return -EIO;
39*10465441SEvalZero }
40*10465441SEvalZero 
dfs_net_read(struct dfs_fd * file,void * buf,size_t count)41*10465441SEvalZero static int dfs_net_read(struct dfs_fd* file, void *buf, size_t count)
42*10465441SEvalZero {
43*10465441SEvalZero     int socket = (int) file->data;
44*10465441SEvalZero 
45*10465441SEvalZero     return sal_recvfrom(socket, buf, count, 0, NULL, NULL);
46*10465441SEvalZero }
47*10465441SEvalZero 
dfs_net_write(struct dfs_fd * file,const void * buf,size_t count)48*10465441SEvalZero static int dfs_net_write(struct dfs_fd *file, const void *buf, size_t count)
49*10465441SEvalZero {
50*10465441SEvalZero     int socket = (int) file->data;
51*10465441SEvalZero 
52*10465441SEvalZero     return sal_sendto(socket, buf, count, 0, NULL, 0);
53*10465441SEvalZero }
54*10465441SEvalZero 
dfs_net_close(struct dfs_fd * file)55*10465441SEvalZero static int dfs_net_close(struct dfs_fd* file)
56*10465441SEvalZero {
57*10465441SEvalZero     int socket = (int) file->data;
58*10465441SEvalZero 
59*10465441SEvalZero     return sal_closesocket(socket);
60*10465441SEvalZero }
61*10465441SEvalZero 
dfs_net_poll(struct dfs_fd * file,struct rt_pollreq * req)62*10465441SEvalZero static int dfs_net_poll(struct dfs_fd *file, struct rt_pollreq *req)
63*10465441SEvalZero {
64*10465441SEvalZero     extern int sal_poll(struct dfs_fd *file, struct rt_pollreq *req);
65*10465441SEvalZero 
66*10465441SEvalZero     return sal_poll(file, req);
67*10465441SEvalZero }
68*10465441SEvalZero 
69*10465441SEvalZero const struct dfs_file_ops _net_fops =
70*10465441SEvalZero {
71*10465441SEvalZero     NULL,    /* open     */
72*10465441SEvalZero     dfs_net_close,
73*10465441SEvalZero     dfs_net_ioctl,
74*10465441SEvalZero     dfs_net_read,
75*10465441SEvalZero     dfs_net_write,
76*10465441SEvalZero     NULL,
77*10465441SEvalZero     NULL,    /* lseek    */
78*10465441SEvalZero     NULL,    /* getdents */
79*10465441SEvalZero     dfs_net_poll,
80*10465441SEvalZero };
81*10465441SEvalZero 
dfs_net_get_fops(void)82*10465441SEvalZero const struct dfs_file_ops *dfs_net_get_fops(void)
83*10465441SEvalZero {
84*10465441SEvalZero     return &_net_fops;
85*10465441SEvalZero }
86