Network Services API  2.50.00.07
slnetif.h
Go to the documentation of this file.
1 /*
2  * Copyright (c) 2017-2018, Texas Instruments Incorporated
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  *
9  * * Redistributions of source code must retain the above copyright
10  * notice, this list of conditions and the following disclaimer.
11  *
12  * * Redistributions in binary form must reproduce the above copyright
13  * notice, this list of conditions and the following disclaimer in the
14  * documentation and/or other materials provided with the distribution.
15  *
16  * * Neither the name of Texas Instruments Incorporated nor the names of
17  * its contributors may be used to endorse or promote products derived
18  * from this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
22  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
23  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
24  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
25  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
26  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
27  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
28  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
29  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
30  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31  */
32 
33 /*****************************************************************************/
34 /* Include files */
35 /*****************************************************************************/
36 
37 #ifndef __SL_NET_IF_H__
38 #define __SL_NET_IF_H__
39 
40 #include <stdint.h>
41 #include <stdbool.h>
42 
43 #include <ti/net/slnetsock.h>
44 
45 #ifdef __cplusplus
46 extern "C" {
47 #endif
48 
60 /*****************************************************************************/
61 /* Macro declarations */
62 /*****************************************************************************/
63 
64 /* Interface ID bit pool to be used in interface add and in socket creation */
65 #define SLNETIF_ID_1 (1 << 0)
66 #define SLNETIF_ID_2 (1 << 1)
67 #define SLNETIF_ID_3 (1 << 2)
68 #define SLNETIF_ID_4 (1 << 3)
69 #define SLNETIF_ID_5 (1 << 4)
70 #define SLNETIF_ID_6 (1 << 5)
71 #define SLNETIF_ID_7 (1 << 6)
72 #define SLNETIF_ID_8 (1 << 7)
73 #define SLNETIF_ID_9 (1 << 8)
74 #define SLNETIF_ID_10 (1 << 9)
75 #define SLNETIF_ID_11 (1 << 10)
76 #define SLNETIF_ID_12 (1 << 11)
77 #define SLNETIF_ID_13 (1 << 12)
78 #define SLNETIF_ID_14 (1 << 13)
79 #define SLNETIF_ID_15 (1 << 14)
80 #define SLNETIF_ID_16 (1 << 15)
82 #define SLNETIF_MAX_IF (16)
84 /* this macro returns 0 when only one bit is set and a number when it isn't */
85 #define ONLY_ONE_BIT_IS_SET(x) (((x > 0) && ((x & (x - 1)) == 0))?true:false)
86 
87 
88 /* Interface connection status bit pool to be used in set interface connection status function */
89 
90 #define SLNETIF_STATUS_DISCONNECTED (0)
91 #define SLNETIF_STATUS_CONNECTED (1)
92 
96 typedef enum
97 {
101 
105 typedef enum
106 {
111 
112 /* Address config return values that can be retrieved in get ip address function */
113 #define SLNETIF_ADDR_CFG_UNKNOWN (0)
114 #define SLNETIF_ADDR_CFG_DHCP (1)
115 #define SLNETIF_ADDR_CFG_DHCP_LLA (2)
116 #define SLNETIF_ADDR_CFG_STATIC (4)
117 #define SLNETIF_ADDR_CFG_STATELESS (5)
118 #define SLNETIF_ADDR_CFG_STATEFUL (6)
119 
120 /* Security object types for load Sec Obj function */
121 #define SLNETIF_SEC_OBJ_TYPE_RSA_PRIVATE_KEY (1)
122 #define SLNETIF_SEC_OBJ_TYPE_CERTIFICATE (2)
123 #define SLNETIF_SEC_OBJ_TYPE_DH_KEY (3)
124 
125 
131 #define SLNETIF_QUERY_IF_STATE_BIT (1 << 0)
132 
137 #define SLNETIF_QUERY_IF_CONNECTION_STATUS_BIT (1 << 1)
138 
144 #define SLNETIF_QUERY_IF_ALLOW_PARTIAL_MATCH_BIT (1 << 2)
145 
146 /*****************************************************************************/
147 /* Structure/Enum declarations */
148 /*****************************************************************************/
149 
160 typedef struct SlNetIf_Config_t
161 {
162  /* socket related API's */
163  int16_t (*sockCreate) (void *ifContext, int16_t domain, int16_t type, int16_t protocol, void **sdContext);
164  int32_t (*sockClose) (int16_t sd, void *sdContext);
165  int32_t (*sockShutdown) (int16_t sd, void *sdContext, int16_t how);
166  int16_t (*sockAccept) (int16_t sd, void *sdContext, SlNetSock_Addr_t *addr, SlNetSocklen_t *addrlen, uint8_t flags, void **acceptedSdContext);
167  int32_t (*sockBind) (int16_t sd, void *sdContext, const SlNetSock_Addr_t *addr, int16_t addrlen);
168  int32_t (*sockListen) (int16_t sd, void *sdContext, int16_t backlog);
169  int32_t (*sockConnect) (int16_t sd, void *sdContext, const SlNetSock_Addr_t *addr, SlNetSocklen_t addrlen, uint8_t flags);
170  int32_t (*sockGetPeerName) (int16_t sd, void *sdContext, SlNetSock_Addr_t *addr, SlNetSocklen_t *addrlen);
171  int32_t (*sockGetLocalName) (int16_t sd, void *sdContext, SlNetSock_Addr_t *addr, SlNetSocklen_t *addrlen);
172  int32_t (*sockSelect) (void *ifContext, int16_t nsds, SlNetSock_SdSet_t *readsds, SlNetSock_SdSet_t *writesds, SlNetSock_SdSet_t *exceptsds, SlNetSock_Timeval_t *timeout);
173  int32_t (*sockSetOpt) (int16_t sd, void *sdContext, int16_t level, int16_t optname, void *optval, SlNetSocklen_t optlen);
174  int32_t (*sockGetOpt) (int16_t sd, void *sdContext, int16_t level, int16_t optname, void *optval, SlNetSocklen_t *optlen);
175  int32_t (*sockRecv) (int16_t sd, void *sdContext, void *buf, uint32_t len, uint32_t flags);
176  int32_t (*sockRecvFrom) (int16_t sd, void *sdContext, void *buf, uint32_t len, uint32_t flags, SlNetSock_Addr_t *from, SlNetSocklen_t *fromlen);
177  int32_t (*sockSend) (int16_t sd, void *sdContext, const void *buf, uint32_t len, uint32_t flags);
178  int32_t (*sockSendTo) (int16_t sd, void *sdContext, const void *buf, uint32_t len, uint32_t flags, const SlNetSock_Addr_t *to, SlNetSocklen_t tolen);
179  int32_t (*sockstartSec) (int16_t sd, void *sdContext, SlNetSockSecAttrib_t *secAttrib, uint8_t flags);
181  /* util related API's */
182  int32_t (*utilGetHostByName) (void *ifContext, char *name, const uint16_t nameLen, uint32_t *ipAddr, uint16_t *ipAddrLen, const uint8_t family);
184  /* if related API's */
185  int32_t (*ifGetIPAddr) (void *ifContext, SlNetIfAddressType_e addrType, uint16_t *addrConfig, uint32_t *ipAddr);
186  int32_t (*ifGetConnectionStatus) (void *ifContext);
187  int32_t (*ifLoadSecObj) (void *ifContext, uint16_t objType, char *objName, int16_t objNameLen, uint8_t *objBuff, int16_t objBuffLen);
188  int32_t (*ifCreateContext) (uint16_t ifID, const char *ifName, void **ifContext);
191 
192 
197 typedef struct SlNetIf_t
198 {
199  uint32_t ifID;
200  char *ifName;
201  int32_t flags;
203  void *ifContext;
204 } SlNetIf_t;
205 
206 /*****************************************************************************/
207 /* Function prototypes */
208 /*****************************************************************************/
209 
223 int32_t SlNetIf_init(int32_t flags);
224 
255 int32_t SlNetIf_add(uint16_t ifID, char *ifName, const SlNetIf_Config_t *ifConf, uint8_t priority);
256 
257 
280 SlNetIf_t * SlNetIf_getIfByID(uint16_t ifID);
281 
282 
305 SlNetIf_t * SlNetIf_queryIf(uint32_t ifBitmap, uint32_t queryBitmap);
306 
307 
331 const char * SlNetIf_getNameByID(uint16_t ifID);
332 
333 
362 int32_t SlNetIf_getIDByName(char *ifName);
363 
364 
388 int32_t SlNetIf_getPriority(uint16_t ifID);
389 
390 
416 int32_t SlNetIf_setPriority(uint16_t ifID, uint8_t priority);
417 
418 
445 int32_t SlNetIf_setState(uint16_t ifID, SlNetIfState_e ifState);
446 
447 
470 int32_t SlNetIf_getState(uint16_t ifID);
471 
472 
493 int32_t SlNetIf_getConnectionStatus(uint16_t ifID);
494 
495 
530 int32_t SlNetIf_getIPAddr(uint16_t ifID, SlNetIfAddressType_e addrType, uint16_t *addrConfig, uint32_t *ipAddr);
531 
532 
575 int32_t SlNetIf_loadSecObj(uint16_t objType, char *objName, int16_t objNameLen, uint8_t *objBuff, int16_t objBuffLen, uint32_t ifBitmap);
576 
584 #ifdef __cplusplus
585 }
586 #endif /* __cplusplus */
587 
588 #endif /* __SL_NET_IF_H__ */
int32_t(* sockSend)(int16_t sd, void *sdContext, const void *buf, uint32_t len, uint32_t flags)
Definition: slnetif.h:177
int32_t(* sockShutdown)(int16_t sd, void *sdContext, int16_t how)
Definition: slnetif.h:165
const char * SlNetIf_getNameByID(uint16_t ifID)
Get interface Name from interface ID.
int16_t(* sockAccept)(int16_t sd, void *sdContext, SlNetSock_Addr_t *addr, SlNetSocklen_t *addrlen, uint8_t flags, void **acceptedSdContext)
Definition: slnetif.h:166
int32_t(* sockGetOpt)(int16_t sd, void *sdContext, int16_t level, int16_t optname, void *optval, SlNetSocklen_t *optlen)
Definition: slnetif.h:174
int32_t(* sockSetOpt)(int16_t sd, void *sdContext, int16_t level, int16_t optname, void *optval, SlNetSocklen_t optlen)
Definition: slnetif.h:173
int32_t SlNetIf_setPriority(uint16_t ifID, uint8_t priority)
Set interface priority.
SlNetIf_Config_t structure contains all the function callbacks that are expected to be filled by the ...
Definition: slnetif.h:160
int32_t(* ifGetIPAddr)(void *ifContext, SlNetIfAddressType_e addrType, uint16_t *addrConfig, uint32_t *ipAddr)
Definition: slnetif.h:185
int32_t(* sockConnect)(int16_t sd, void *sdContext, const SlNetSock_Addr_t *addr, SlNetSocklen_t addrlen, uint8_t flags)
Definition: slnetif.h:169
Definition: slnetif.h:98
Definition: slnetif.h:99
The SlNetIf_t structure holds the configuration of the interface Its ID, name, flags and the configur...
Definition: slnetif.h:197
SlNetIfAddressType_e
Address type enum to be used in get ip address function.
Definition: slnetif.h:105
uint16_t SlNetSocklen_t
The SlNetSocklen_t is used for declaring the socket length parameter.
Definition: slnetsock.h:641
int32_t SlNetIf_init(int32_t flags)
Initialize the SlNetIf module.
int32_t(* sockGetLocalName)(int16_t sd, void *sdContext, SlNetSock_Addr_t *addr, SlNetSocklen_t *addrlen)
Definition: slnetif.h:171
SlNetIf_t * SlNetIf_queryIf(uint32_t ifBitmap, uint32_t queryBitmap)
Query for the highest priority interface, given a list of interfaces and properties.
int32_t SlNetIf_getIPAddr(uint16_t ifID, SlNetIfAddressType_e addrType, uint16_t *addrConfig, uint32_t *ipAddr)
Get IP Address of specific interface.
int32_t flags
Definition: slnetif.h:201
IpV4 socket address.
Definition: slnetsock.h:646
struct SlNetIf_Config_t SlNetIf_Config_t
SlNetIf_Config_t structure contains all the function callbacks that are expected to be filled by the ...
int32_t(* sockBind)(int16_t sd, void *sdContext, const SlNetSock_Addr_t *addr, int16_t addrlen)
Definition: slnetif.h:167
int32_t(* ifLoadSecObj)(void *ifContext, uint16_t objType, char *objName, int16_t objNameLen, uint8_t *objBuff, int16_t objBuffLen)
Definition: slnetif.h:187
The SlNetSock_SdSet_t structure holds the sd array for SlNetSock_select function. ...
Definition: slnetsock.h:690
int32_t(* utilGetHostByName)(void *ifContext, char *name, const uint16_t nameLen, uint32_t *ipAddr, uint16_t *ipAddrLen, const uint8_t family)
Definition: slnetif.h:182
int32_t(* sockClose)(int16_t sd, void *sdContext)
Definition: slnetif.h:164
int32_t(* sockstartSec)(int16_t sd, void *sdContext, SlNetSockSecAttrib_t *secAttrib, uint8_t flags)
Definition: slnetif.h:179
int32_t(* ifGetConnectionStatus)(void *ifContext)
Definition: slnetif.h:186
Definition: slnetif.h:109
SlNetIfState_e
Interface state bit pool to be used in set interface state function.
Definition: slnetif.h:96
Secure socket attribute context.
Definition: slnetsock.h:564
int32_t SlNetIf_getPriority(uint16_t ifID)
Get interface priority.
int32_t SlNetIf_getConnectionStatus(uint16_t ifID)
Get the connection status of an interface.
struct SlNetIf_t SlNetIf_t
The SlNetIf_t structure holds the configuration of the interface Its ID, name, flags and the configur...
int16_t(* sockCreate)(void *ifContext, int16_t domain, int16_t type, int16_t protocol, void **sdContext)
Definition: slnetif.h:163
int32_t(* ifCreateContext)(uint16_t ifID, const char *ifName, void **ifContext)
Definition: slnetif.h:188
void * ifContext
Definition: slnetif.h:203
int32_t(* sockGetPeerName)(int16_t sd, void *sdContext, SlNetSock_Addr_t *addr, SlNetSocklen_t *addrlen)
Definition: slnetif.h:170
int32_t(* sockSelect)(void *ifContext, int16_t nsds, SlNetSock_SdSet_t *readsds, SlNetSock_SdSet_t *writesds, SlNetSock_SdSet_t *exceptsds, SlNetSock_Timeval_t *timeout)
Definition: slnetif.h:172
Definition: slnetif.h:107
int32_t(* sockSendTo)(int16_t sd, void *sdContext, const void *buf, uint32_t len, uint32_t flags, const SlNetSock_Addr_t *to, SlNetSocklen_t tolen)
Definition: slnetif.h:178
int32_t SlNetIf_add(uint16_t ifID, char *ifName, const SlNetIf_Config_t *ifConf, uint8_t priority)
Add a new SlNetIf-compatible interface to the system.
int32_t(* sockRecv)(int16_t sd, void *sdContext, void *buf, uint32_t len, uint32_t flags)
Definition: slnetif.h:175
SlNetIf_t * SlNetIf_getIfByID(uint16_t ifID)
Get interface configuration from interface ID.
int32_t(* sockRecvFrom)(int16_t sd, void *sdContext, void *buf, uint32_t len, uint32_t flags, SlNetSock_Addr_t *from, SlNetSocklen_t *fromlen)
Definition: slnetif.h:176
int32_t SlNetIf_getState(uint16_t ifID)
Get interface state.
char * ifName
Definition: slnetif.h:200
SlNetIf_Config_t * ifConf
Definition: slnetif.h:202
int32_t SlNetIf_getIDByName(char *ifName)
Get interface ID from interface name.
uint32_t ifID
Definition: slnetif.h:199
Definition: slnetif.h:108
struct timeval SlNetSock_Timeval_t
The SlNetSock_Timeval_t structure is used in SLNETSOCK_OPSOCK_RCV_TIMEO socket level option...
Definition: slnetsock.h:636
int32_t(* sockListen)(int16_t sd, void *sdContext, int16_t backlog)
Definition: slnetif.h:168
int32_t SlNetIf_loadSecObj(uint16_t objType, char *objName, int16_t objNameLen, uint8_t *objBuff, int16_t objBuffLen, uint32_t ifBitmap)
Load secured buffer to the network stack.
int32_t SlNetIf_setState(uint16_t ifID, SlNetIfState_e ifState)
Set interface state.
© Copyright 1995-2018, Texas Instruments Incorporated. All rights reserved.
Trademarks | Privacy policy | Terms of use | Terms of sale