RaspberrPi project source code
Guo Wenxue
6 days ago f7889e2ceddbc3e15ea4b5377d831f4432169f76
commit | author | age
29b331 1 /********************************************************************************
GW 2  *      Copyright:  (C) 2022 LingYun IoT System Studio
3  *                  All rights reserved.
4  *
5  *       Filename:  socket.h
6  *    Description:  This head file is for socket API functions
7  *
8  *        Version:  1.0.0(18/04/22)
9  *         Author:  Guo Wenxue <guowenxue@gmail.com>
10  *      ChangeLog:  1, Release initial version on "18/04/22 17:09:59"
11  *
12  ********************************************************************************/
13
14 #ifndef  _SOCKET_H_
15 #define  _SOCKET_H_
16
17 #define HOSTNAME_LEN          64
18
19 typedef struct socket_ctx_s
20 {
21     char        host[HOSTNAME_LEN]; /* CLIENT: Connect server hostname; SERVER: Unused */
22     int         port;               /* CLIENT: Connect server port;     SERVER: listen port */
23     int         fd;                 /* socket descriptor  */
b74ad5 24     int         connected;          /* socket connect status: 1->connected 0->disconnected  */
29b331 25 } socket_ctx_t;
GW 26
27 /*  description: initial socket context
28  *   input args:
29  *               $sock:  socket context pointer
30  *               $host:  connect server hostname for client mode, unused for server mode
31  *               $port:  connect server port for client mode or listen port for server mode
32  * return value: <0: failure   0:ok
33  */
34 extern int socket_init(socket_ctx_t *sock, char *host, int port);
35
36 /*  description: close socket
37  *   input args:
38  *               $sock:  socket context pointer
39  * return value: <0: failure   0:ok
40  */
41 extern int socket_term(socket_ctx_t *sock);
42
43 /*  description: socket server start listen
44  *   input args:
45  *               $sock:  socket context pointer
46  * return value: <0: failure   0:ok
47  */
48 extern int socket_listen(socket_ctx_t *sock);
b74ad5 49
GW 50 /*  description: check socket connect status
51  *   input args:
52  *               $sock:  socket context pointer
53  * return value: 1: connected   0:disconnected
54  */
55 extern int socket_connected(socket_ctx_t *sock);
29b331 56
GW 57 /*  description: socket client connect to server
58  *   input args:
59  *               $sock:  socket context pointer
60  * return value: <0: failure   0:ok
61  */
62 extern int socket_connect(socket_ctx_t *sock);
63
64 /*  description: send data from the socket
65  *   input args:
66  *               $sock :  socket context pointer
67  *               $data :  socket send data
68  *               $bytes:  socket send data bytes
69  * return value: <0: failure   0:ok
70  */
71 extern int socket_send(socket_ctx_t *sock, char *data, int bytes);
72
73 /*  description: receive data from the socket
74  *   input args:
75  *               $sock :  socket context pointer
76  *               $buf  :  socket receive data buffer
77  *               $size :  socket receive data buffer size
78  *               $timeout: receive data time, <=0 will don't timeout
79  * return value: <0: failure   0:ok
80  */
81 #define TIMEOUT_NONE       0
82 extern int socket_recv(socket_ctx_t *sock, char *buf, int size, int timeout);
83
84 /*+-------------------------------------------------------------------+
85  *|                socket utils function                              |
86  *+-------------------------------------------------------------------+*/
87
88 /* description: set socket listen port as reusable, fix port already used bug  */
89 extern int socket_set_reuseaddr(int sockfd);
90
91 /* set socket as non-block mode, common socket default work as block mode */
92 extern int socket_set_nonblock(int sockfd);
93
94 /* set socket receive and send buffer size in linux kernel space */
95 extern int socket_set_buffer(int sockfd, int rsize, int ssize);
96
97 /* set heartbeat keepalive  */
98 extern int socket_set_keepalive(int sockfd, int keepintvl, int keepcnt);
99
100 /*  Set open file description count to max */
101 extern void set_socket_rlimit(void);
102
103 #endif   /* ----- #ifndef _SOCKET_H_  ----- */
104