drivers: Update CC3100 driver library to SDK release version 1.1.0.

This commit is contained in:
danicampora 2015-03-15 11:45:01 +01:00
parent c292632b59
commit 2b8a718d73
21 changed files with 2317 additions and 1360 deletions

View File

@ -34,14 +34,16 @@
* *
*/ */
#ifndef __DEVICE_H__
#define __DEVICE_H__
/*****************************************************************************/ /*****************************************************************************/
/* Include files */ /* Include files */
/*****************************************************************************/ /*****************************************************************************/
#include "simplelink.h" #include "simplelink.h"
#ifndef __DEVICE_H__
#define __DEVICE_H__
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif #endif
@ -79,6 +81,10 @@ extern "C" {
/* User supplied invalid parameter */ /* User supplied invalid parameter */
#define SL_INVALPARAM (-2003) #define SL_INVALPARAM (-2003)
/* Failed to open interface */
#define SL_BAD_INTERFACE (-2004)
/* End of SL internal Error codes */ /* End of SL internal Error codes */
@ -171,6 +177,8 @@ typedef enum
#define SL_WLAN_CONNECTION_FAILED_EVENT (9) #define SL_WLAN_CONNECTION_FAILED_EVENT (9)
/* SL_EVENT_CLASS_DEVICE user events */ /* SL_EVENT_CLASS_DEVICE user events */
#define SL_DEVICE_FATAL_ERROR_EVENT (1) #define SL_DEVICE_FATAL_ERROR_EVENT (1)
#define SL_DEVICE_ABORT_ERROR_EVENT (2)
/* SL_EVENT_CLASS_BSD user events */ /* SL_EVENT_CLASS_BSD user events */
#define SL_SOCKET_TX_FAILED_EVENT (1) #define SL_SOCKET_TX_FAILED_EVENT (1)
#define SL_SOCKET_ASYNC_EVENT (2) #define SL_SOCKET_ASYNC_EVENT (2)
@ -228,6 +236,8 @@ typedef enum
/* Structure/Enum declarations */ /* Structure/Enum declarations */
/*****************************************************************************/ /*****************************************************************************/
#define ROLE_UNKNOWN_ERR (-1)
#ifdef SL_IF_TYPE_UART #ifdef SL_IF_TYPE_UART
typedef struct typedef struct
{ {
@ -252,6 +262,14 @@ typedef struct
_u16 Padding; _u16 Padding;
}SlVersionFull; }SlVersionFull;
typedef struct
{
_u32 AbortType;
_u32 AbortData;
}sl_DeviceReportAbort;
typedef struct typedef struct
{ {
_i8 status; _i8 status;
@ -261,6 +279,7 @@ typedef struct
typedef union typedef union
{ {
sl_DeviceReport deviceEvent; sl_DeviceReport deviceEvent;
sl_DeviceReportAbort deviceReport;
} _SlDeviceEventData_u; } _SlDeviceEventData_u;
typedef struct typedef struct
@ -376,7 +395,7 @@ _i16 sl_Start(const void* pIfHdl, _i8* pDevName, const P_INIT_CALLBACK pInitCal
\warning \warning
*/ */
#if _SL_INCLUDE_FUNC(sl_Stop) #if _SL_INCLUDE_FUNC(sl_Stop)
_i16 sl_Stop(_u16 timeout); _i16 sl_Stop(const _u16 timeout);
#endif #endif
@ -399,7 +418,7 @@ _i16 sl_Stop(_u16 timeout);
Setting device time and date example: Setting device time and date example:
SlDateTime_t dateTime= {0}; SlDateTime_t dateTime= {0};
dateTime.sl_tm_day = (_u32)23; // Day of month (DD format) range 1-13 dateTime.sl_tm_day = (_u32)23; // Day of month (DD format) range 1-31
dateTime.sl_tm_mon = (_u32)6; // Month (MM format) in the range of 1-12 dateTime.sl_tm_mon = (_u32)6; // Month (MM format) in the range of 1-12
dateTime.sl_tm_year = (_u32)2014; // Year (YYYY format) dateTime.sl_tm_year = (_u32)2014; // Year (YYYY format)
dateTime.sl_tm_hour = (_u32)17; // Hours in the range of 0-23 dateTime.sl_tm_hour = (_u32)17; // Hours in the range of 0-23
@ -413,7 +432,7 @@ _i16 sl_Stop(_u16 timeout);
\endcode \endcode
*/ */
#if _SL_INCLUDE_FUNC(sl_DevSet) #if _SL_INCLUDE_FUNC(sl_DevSet)
_i32 sl_DevSet(_u8 DeviceSetId ,_u8 Option,_u8 ConfigLen, _u8 *pValues); _i32 sl_DevSet(const _u8 DeviceSetId ,const _u8 Option,const _u8 ConfigLen,const _u8 *pValues);
#endif #endif
/*! /*!
@ -446,9 +465,11 @@ _i32 sl_DevSet(_u8 DeviceSetId ,_u8 Option,_u8 ConfigLen, _u8 *pValues);
_u8 pConfigOpt; _u8 pConfigOpt;
_u8 pConfigLen; _u8 pConfigLen;
pConfigOpt = SL_EVENT_CLASS_WLAN; pConfigOpt = SL_EVENT_CLASS_WLAN;
pConfigLen = sizeof(_u32);
sl_DevGet(SL_DEVICE_STATUS,&pConfigOpt,&pConfigLen,(_u8 *)(&statusWlan)); sl_DevGet(SL_DEVICE_STATUS,&pConfigOpt,&pConfigLen,(_u8 *)(&statusWlan));
Example for getting version: Example for getting version:
SlVersionFull ver; SlVersionFull ver;
pConfigLen = sizeof(ver);
pConfigOpt = SL_DEVICE_GENERAL_VERSION; pConfigOpt = SL_DEVICE_GENERAL_VERSION;
sl_DevGet(SL_DEVICE_GENERAL_CONFIGURATION,&pConfigOpt,&pConfigLen,(_u8 *)(&ver)); sl_DevGet(SL_DEVICE_GENERAL_CONFIGURATION,&pConfigOpt,&pConfigLen,(_u8 *)(&ver));
printf("CHIP %d\nMAC 31.%d.%d.%d.%d\nPHY %d.%d.%d.%d\nNWP %d.%d.%d.%d\nROM %d\nHOST %d.%d.%d.%d\n", printf("CHIP %d\nMAC 31.%d.%d.%d.%d\nPHY %d.%d.%d.%d\nNWP %d.%d.%d.%d\nROM %d\nHOST %d.%d.%d.%d\n",
@ -475,7 +496,7 @@ _i32 sl_DevSet(_u8 DeviceSetId ,_u8 Option,_u8 ConfigLen, _u8 *pValues);
\endcode \endcode
*/ */
#if _SL_INCLUDE_FUNC(sl_DevGet) #if _SL_INCLUDE_FUNC(sl_DevGet)
_i32 sl_DevGet(_u8 DeviceGetId, _u8 *pOption,_u8 *pConfigLen, _u8 *pValues); _i32 sl_DevGet(const _u8 DeviceGetId,_u8 *pOption,_u8 *pConfigLen, _u8 *pValues);
#endif #endif
@ -527,7 +548,7 @@ _i32 sl_DevGet(_u8 DeviceGetId, _u8 *pOption,_u8 *pConfigLen, _u8 *pValues);
\endcode \endcode
*/ */
#if _SL_INCLUDE_FUNC(sl_EventMaskSet) #if _SL_INCLUDE_FUNC(sl_EventMaskSet)
_i16 sl_EventMaskSet(_u8 EventClass , _u32 Mask); _i16 sl_EventMaskSet(const _u8 EventClass ,const _u32 Mask);
#endif #endif
/*! /*!
@ -567,7 +588,7 @@ _i16 sl_EventMaskSet(_u8 EventClass , _u32 Mask);
\endcode \endcode
*/ */
#if _SL_INCLUDE_FUNC(sl_EventMaskGet) #if _SL_INCLUDE_FUNC(sl_EventMaskGet)
_i16 sl_EventMaskGet(_u8 EventClass, _u32 *pMask); _i16 sl_EventMaskGet(const _u8 EventClass,_u32 *pMask);
#endif #endif

View File

@ -61,8 +61,8 @@ typedef struct
typedef struct typedef struct
{ {
_u16 TxPayloadLen; _u16 TxPayloadLen;
_u16 RxPayloadLen; _i16 RxPayloadLen;
_u16 ActualRxPayloadLen; _i16 ActualRxPayloadLen;
_u8 *pTxPayload; _u8 *pTxPayload;
_u8 *pRxPayload; _u8 *pRxPayload;
}_SlCmdExt_t; }_SlCmdExt_t;
@ -97,12 +97,20 @@ typedef enum
SOCKET_6, SOCKET_6,
SOCKET_7, SOCKET_7,
MAX_SOCKET_ENUM_IDX, MAX_SOCKET_ENUM_IDX,
#ifndef SL_TINY_EXT
ACCEPT_ID = MAX_SOCKET_ENUM_IDX, ACCEPT_ID = MAX_SOCKET_ENUM_IDX,
CONNECT_ID, CONNECT_ID,
#else
CONNECT_ID = MAX_SOCKET_ENUM_IDX,
#endif
#ifndef SL_TINY_EXT
SELECT_ID, SELECT_ID,
#endif
GETHOSYBYNAME_ID, GETHOSYBYNAME_ID,
#ifndef SL_TINY_EXT
GETHOSYBYSERVICE_ID, GETHOSYBYSERVICE_ID,
PING_ID, PING_ID,
#endif
START_STOP_ID, START_STOP_ID,
RECV_ID RECV_ID
}_SlActionID_e; }_SlActionID_e;
@ -166,21 +174,18 @@ typedef struct
_SlSyncObj_t CmdSyncObj; _SlSyncObj_t CmdSyncObj;
_u8 IsCmdRespWaited; _u8 IsCmdRespWaited;
_SlFlowContCB_t FlowContCB; _SlFlowContCB_t FlowContCB;
_u8 TxSeqNum; _u8 TxSeqNum;
_volatile _u8 RxIrqCnt;
_u8 RxDoneCnt; _u8 RxDoneCnt;
_u8 SocketNonBlocking; _u8 SocketNonBlocking;
_u8 SocketTXFailure; _u8 SocketTXFailure;
_u8 RelayFlagsViaRxPayload;
/* for stack reduction the parameters are globals */ /* for stack reduction the parameters are globals */
_SlFunctionParams_t FunctionParams; _SlFunctionParams_t FunctionParams;
_u8 ActionIndex;
}_SlDriverCb_t; }_SlDriverCb_t;
extern _volatile _u8 RxIrqCnt;
extern _SlDriverCb_t* g_pCB; extern _SlDriverCb_t* g_pCB;
extern P_SL_DEV_PING_CALLBACK pPingCallBackFunc; extern P_SL_DEV_PING_CALLBACK pPingCallBackFunc;
@ -195,25 +200,47 @@ extern _SlReturnVal_t _SlDrvCmdOp(_SlCmdCtrl_t *pCmdCtrl , void* pTxRxDescBuff
extern _SlReturnVal_t _SlDrvCmdSend(_SlCmdCtrl_t *pCmdCtrl , void* pTxRxDescBuff , _SlCmdExt_t* pCmdExt); extern _SlReturnVal_t _SlDrvCmdSend(_SlCmdCtrl_t *pCmdCtrl , void* pTxRxDescBuff , _SlCmdExt_t* pCmdExt);
extern _SlReturnVal_t _SlDrvDataReadOp(_SlSd_t Sd, _SlCmdCtrl_t *pCmdCtrl , void* pTxRxDescBuff , _SlCmdExt_t* pCmdExt); extern _SlReturnVal_t _SlDrvDataReadOp(_SlSd_t Sd, _SlCmdCtrl_t *pCmdCtrl , void* pTxRxDescBuff , _SlCmdExt_t* pCmdExt);
extern _SlReturnVal_t _SlDrvDataWriteOp(_SlSd_t Sd, _SlCmdCtrl_t *pCmdCtrl , void* pTxRxDescBuff , _SlCmdExt_t* pCmdExt); extern _SlReturnVal_t _SlDrvDataWriteOp(_SlSd_t Sd, _SlCmdCtrl_t *pCmdCtrl , void* pTxRxDescBuff , _SlCmdExt_t* pCmdExt);
extern _i16 _SlDrvBasicCmd(_SlOpcode_t Opcode);
extern void _sl_HandleAsync_InitComplete(void *pVoidBuf); extern void _sl_HandleAsync_InitComplete(void *pVoidBuf);
extern void _sl_HandleAsync_Connect(void *pVoidBuf); extern void _sl_HandleAsync_Connect(void *pVoidBuf);
#ifndef SL_TINY_EXT
extern _i16 _SlDrvBasicCmd(_SlOpcode_t Opcode);
extern void _sl_HandleAsync_Accept(void *pVoidBuf); extern void _sl_HandleAsync_Accept(void *pVoidBuf);
extern void _sl_HandleAsync_Select(void *pVoidBuf);
extern void _sl_HandleAsync_DnsGetHostByName(void *pVoidBuf);
extern void _sl_HandleAsync_DnsGetHostByService(void *pVoidBuf); extern void _sl_HandleAsync_DnsGetHostByService(void *pVoidBuf);
extern void _sl_HandleAsync_Select(void *pVoidBuf);
#endif
extern void _sl_HandleAsync_DnsGetHostByName(void *pVoidBuf);
extern void _sl_HandleAsync_DnsGetHostByAddr(void *pVoidBuf); extern void _sl_HandleAsync_DnsGetHostByAddr(void *pVoidBuf);
extern void _sl_HandleAsync_PingResponse(void *pVoidBuf); extern void _sl_HandleAsync_PingResponse(void *pVoidBuf);
extern void _SlDrvNetAppEventHandler(void *pArgs); extern void _SlDrvNetAppEventHandler(void* pArgs);
extern void _SlDrvDeviceEventHandler(void *pArgs); extern void _SlDrvDeviceEventHandler(void* pArgs);
extern void _sl_HandleAsync_Stop(void *pVoidBuf); extern void _sl_HandleAsync_Stop(void *pVoidBuf);
extern _i16 _SlDrvWaitForPoolObj(_u32 ActionID, _u8 SocketID); extern _u8 _SlDrvWaitForPoolObj(_u8 ActionID, _u8 SocketID);
extern void _SlDrvReleasePoolObj(_u8 pObj); extern void _SlDrvReleasePoolObj(_u8 pObj);
extern void _SlDrvObjInit(void); extern _u16 _SlDrvAlignSize(_u16 msgLen);
extern _u8 _SlDrvProtectAsyncRespSetting(_u8 *pAsyncRsp, _u8 ActionID, _u8 SocketID);
extern void _SlDrvSyncObjWaitForever(_SlSyncObj_t *pSyncObj);
extern void _SlDrvSyncObjSignal(_SlSyncObj_t *pSyncObj);
extern void _SlDrvObjLock(_SlLockObj_t *pLockObj, _SlTime_t Timeout);
extern void _SlDrvObjLockWaitForever(_SlLockObj_t *pLockObj);
extern void _SlDrvProtectionObjLockWaitForever();
extern void _SlDrvObjUnLock(_SlLockObj_t *pLockObj);
extern void _SlDrvProtectionObjUnLock();
extern void _SlDrvMemZero(void* Addr, _u16 size);
extern void _SlDrvResetCmdExt(_SlCmdExt_t* pCmdExt);
#define _SL_PROTOCOL_ALIGN_SIZE(msgLen) (((msgLen)+3) & (~3)) #define _SL_PROTOCOL_ALIGN_SIZE(msgLen) (((msgLen)+3) & (~3))
#define _SL_IS_PROTOCOL_ALIGNED_SIZE(msgLen) (!((msgLen) & 3)) #define _SL_IS_PROTOCOL_ALIGNED_SIZE(msgLen) (!((msgLen) & 3))
#define _SL_PROTOCOL_CALC_LEN(pCmdCtrl,pCmdExt) ((pCmdExt) ? \ #define _SL_PROTOCOL_CALC_LEN(pCmdCtrl,pCmdExt) ((pCmdExt) ? \
(_SL_PROTOCOL_ALIGN_SIZE(pCmdCtrl->TxDescLen) + _SL_PROTOCOL_ALIGN_SIZE(pCmdExt->TxPayloadLen)) : \ (_SL_PROTOCOL_ALIGN_SIZE(pCmdCtrl->TxDescLen) + _SL_PROTOCOL_ALIGN_SIZE(pCmdExt->TxPayloadLen)) : \
(_SL_PROTOCOL_ALIGN_SIZE(pCmdCtrl->TxDescLen))) (_SL_PROTOCOL_ALIGN_SIZE(pCmdCtrl->TxDescLen)))

View File

@ -34,15 +34,17 @@
* *
*/ */
#ifndef __FS_H__
#define __FS_H__
/*****************************************************************************/ /*****************************************************************************/
/* Include files */ /* Include files */
/*****************************************************************************/ /*****************************************************************************/
#include "simplelink.h" #include "simplelink.h"
#ifndef __FS_H__
#define __FS_H__
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif #endif
@ -180,7 +182,7 @@ typedef enum
_FS_FILE_OPEN_FLAG_NO_SIGNATURE_TEST = 0x4, /* Relevant to secure file only */ _FS_FILE_OPEN_FLAG_NO_SIGNATURE_TEST = 0x4, /* Relevant to secure file only */
_FS_FILE_OPEN_FLAG_STATIC = 0x8, /* Relevant to secure file only */ _FS_FILE_OPEN_FLAG_STATIC = 0x8, /* Relevant to secure file only */
_FS_FILE_OPEN_FLAG_VENDOR = 0x10, /* Relevant to secure file only */ _FS_FILE_OPEN_FLAG_VENDOR = 0x10, /* Relevant to secure file only */
_FS_FILE_PUBLIC_WRITE = 0x20, /* Relevant to secure file only, the file can be opened for write without Token */ _FS_FILE_PUBLIC_WRITE= 0x20, /* Relevant to secure file only, the file can be opened for write without Token */
_FS_FILE_PUBLIC_READ = 0x40 /* Relevant to secure file only, the file can be opened for read without Token */ _FS_FILE_PUBLIC_READ = 0x40 /* Relevant to secure file only, the file can be opened for read without Token */
}SlFileOpenFlags_e; }SlFileOpenFlags_e;
@ -256,7 +258,7 @@ _u32 _sl_GetCreateFsMode(_u32 maxSizeInBytes,_u32 accessFlags);
\endcode \endcode
*/ */
#if _SL_INCLUDE_FUNC(sl_FsOpen) #if _SL_INCLUDE_FUNC(sl_FsOpen)
_i32 sl_FsOpen(_u8 *pFileName,_u32 AccessModeAndMaxSize,_u32 *pToken,_i32 *pFileHandle); _i32 sl_FsOpen(const _u8 *pFileName,const _u32 AccessModeAndMaxSize,_u32 *pToken,_i32 *pFileHandle);
#endif #endif
/*! /*!
@ -279,7 +281,7 @@ _i32 sl_FsOpen(_u8 *pFileName,_u32 AccessModeAndMaxSize,_u32 *pToken,_i32 *pFile
\endcode \endcode
*/ */
#if _SL_INCLUDE_FUNC(sl_FsClose) #if _SL_INCLUDE_FUNC(sl_FsClose)
_i16 sl_FsClose(_i32 FileHdl,_u8* pCeritificateFileName,_u8* pSignature,_u32 SignatureLen); _i16 sl_FsClose(const _i32 FileHdl,const _u8* pCeritificateFileName,const _u8* pSignature,const _u32 SignatureLen);
#endif #endif
/*! /*!
@ -301,7 +303,7 @@ _i16 sl_FsClose(_i32 FileHdl,_u8* pCeritificateFileName,_u8* pSignature,_u32 Sig
\endcode \endcode
*/ */
#if _SL_INCLUDE_FUNC(sl_FsRead) #if _SL_INCLUDE_FUNC(sl_FsRead)
_i32 sl_FsRead(_i32 FileHdl,_u32 Offset ,_u8* pData,_u32 Len); _i32 sl_FsRead(const _i32 FileHdl,_u32 Offset ,_u8* pData,_u32 Len);
#endif #endif
/*! /*!
@ -323,7 +325,7 @@ _i32 sl_FsRead(_i32 FileHdl,_u32 Offset ,_u8* pData,_u32 Len);
\endcode \endcode
*/ */
#if _SL_INCLUDE_FUNC(sl_FsWrite) #if _SL_INCLUDE_FUNC(sl_FsWrite)
_i32 sl_FsWrite(_i32 FileHdl,_u32 Offset,_u8* pData,_u32 Len); _i32 sl_FsWrite(const _i32 FileHdl,_u32 Offset,_u8* pData,_u32 Len);
#endif #endif
/*! /*!
@ -344,7 +346,7 @@ _i32 sl_FsWrite(_i32 FileHdl,_u32 Offset,_u8* pData,_u32 Len);
\endcode \endcode
*/ */
#if _SL_INCLUDE_FUNC(sl_FsGetInfo) #if _SL_INCLUDE_FUNC(sl_FsGetInfo)
_i16 sl_FsGetInfo(_u8 *pFileName,_u32 Token,SlFsFileInfo_t* pFsFileInfo); _i16 sl_FsGetInfo(const _u8 *pFileName,const _u32 Token,SlFsFileInfo_t* pFsFileInfo);
#endif #endif
/*! /*!
@ -363,7 +365,7 @@ _i16 sl_FsGetInfo(_u8 *pFileName,_u32 Token,SlFsFileInfo_t* pFsFileInfo);
\endcode \endcode
*/ */
#if _SL_INCLUDE_FUNC(sl_FsDel) #if _SL_INCLUDE_FUNC(sl_FsDel)
_i16 sl_FsDel(_u8 *pFileName,_u32 Token); _i16 sl_FsDel(const _u8 *pFileName,const _u32 Token);
#endif #endif
/*! /*!

View File

@ -34,15 +34,17 @@
* *
*/ */
#ifndef __NETAPP_H__
#define __NETAPP_H__
/*****************************************************************************/ /*****************************************************************************/
/* Include files */ /* Include files */
/*****************************************************************************/ /*****************************************************************************/
#include "simplelink.h" #include "simplelink.h"
#ifndef __NETAPP_H__
#define __NETAPP_H__
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
@ -356,7 +358,7 @@ typedef void (*P_SL_DEV_PING_CALLBACK)(SlPingReport_t*);
\endcode \endcode
*/ */
#if _SL_INCLUDE_FUNC(sl_NetAppStart) #if _SL_INCLUDE_FUNC(sl_NetAppStart)
_i16 sl_NetAppStart(_u32 AppBitMap); _i16 sl_NetAppStart(const _u32 AppBitMap);
#endif #endif
/*! /*!
\brief Stops a network application \brief Stops a network application
@ -382,7 +384,7 @@ _i16 sl_NetAppStart(_u32 AppBitMap);
\endcode \endcode
*/ */
#if _SL_INCLUDE_FUNC(sl_NetAppStop) #if _SL_INCLUDE_FUNC(sl_NetAppStop)
_i16 sl_NetAppStop(_u32 AppBitMap); _i16 sl_NetAppStop(const _u32 AppBitMap);
#endif #endif
/*! /*!
@ -417,6 +419,8 @@ _i16 sl_NetAppStop(_u32 AppBitMap);
In this case, MAX_CONCURRENT_ACTIONS can be increased (result in memory increase) or try In this case, MAX_CONCURRENT_ACTIONS can be increased (result in memory increase) or try
again later to issue the command. again later to issue the command.
\warning \warning
In case an IP address in a string format is set as input, without any prefix (e.g. "1.2.3.4") the device will not
try to access the DNS and it will return the input address on the 'out_ip_addr' field
\par Example: \par Example:
\code \code
_u32 DestinationIP; _u32 DestinationIP;
@ -430,7 +434,7 @@ _i16 sl_NetAppStop(_u32 AppBitMap);
\endcode \endcode
*/ */
#if _SL_INCLUDE_FUNC(sl_NetAppDnsGetHostByName) #if _SL_INCLUDE_FUNC(sl_NetAppDnsGetHostByName)
_i16 sl_NetAppDnsGetHostByName(_i8 * hostname, _u16 usNameLen, _u32* out_ip_addr,_u8 family ); _i16 sl_NetAppDnsGetHostByName(_i8 * hostname,const _u16 usNameLen, _u32* out_ip_addr,const _u8 family );
#endif #endif
/*! /*!
@ -490,8 +494,8 @@ _i16 sl_NetAppDnsGetHostByName(_i8 * hostname, _u16 usNameLen, _u32* out_ip_add
*/ */
#if _SL_INCLUDE_FUNC(sl_NetAppDnsGetHostByService) #if _SL_INCLUDE_FUNC(sl_NetAppDnsGetHostByService)
_i32 sl_NetAppDnsGetHostByService(_i8 *pServiceName, /* string containing all (or only part): name + subtype + service */ _i32 sl_NetAppDnsGetHostByService(_i8 *pServiceName, /* string containing all (or only part): name + subtype + service */
_u8 ServiceLen, const _u8 ServiceLen,
_u8 Family, /* 4-IPv4 , 16-IPv6 */ const _u8 Family, /* 4-IPv4 , 16-IPv6 */
_u32 pAddr[], _u32 pAddr[],
_u32 *pPort, _u32 *pPort,
_u16 *pTextLen, /* in: max len , out: actual len */ _u16 *pTextLen, /* in: max len , out: actual len */
@ -549,11 +553,11 @@ _i32 sl_NetAppDnsGetHostByService(_i8 *pServiceName, /* string containing all
*/ */
#if _SL_INCLUDE_FUNC(sl_NetAppGetServiceList) #if _SL_INCLUDE_FUNC(sl_NetAppGetServiceList)
_i16 sl_NetAppGetServiceList(_u8 IndexOffest, _i16 sl_NetAppGetServiceList(const _u8 IndexOffest,
_u8 MaxServiceCount, const _u8 MaxServiceCount,
_u8 Flags, const _u8 Flags,
_i8 *pBuffer, _i8 *pBuffer,
_u32 RxBufferLength const _u32 RxBufferLength
); );
#endif #endif
@ -582,7 +586,7 @@ _i16 sl_NetAppGetServiceList(_u8 IndexOffest,
The size of the service length should be smaller than 255. The size of the service length should be smaller than 255.
*/ */
#if _SL_INCLUDE_FUNC(sl_NetAppMDNSUnRegisterService) #if _SL_INCLUDE_FUNC(sl_NetAppMDNSUnRegisterService)
_i16 sl_NetAppMDNSUnRegisterService(const _i8 *pServiceName,_u8 ServiceNameLen); _i16 sl_NetAppMDNSUnRegisterService(const _i8 *pServiceName,const _u8 ServiceNameLen);
#endif #endif
/*! /*!
@ -651,11 +655,11 @@ _i16 sl_NetAppMDNSUnRegisterService(const _i8 *pServiceName,_u8 ServiceNameLen);
*/ */
#if _SL_INCLUDE_FUNC(sl_NetAppMDNSRegisterService) #if _SL_INCLUDE_FUNC(sl_NetAppMDNSRegisterService)
_i16 sl_NetAppMDNSRegisterService( const _i8* pServiceName, _i16 sl_NetAppMDNSRegisterService( const _i8* pServiceName,
_u8 ServiceNameLen, const _u8 ServiceNameLen,
const _i8* pText, const _i8* pText,
_u8 TextLen, const _u8 TextLen,
_u16 Port, const _u16 Port,
_u32 TTL, const _u32 TTL,
_u32 Options); _u32 Options);
#endif #endif
@ -720,7 +724,7 @@ _i16 sl_NetAppMDNSRegisterService( const _i8* pServiceName,
\endcode \endcode
*/ */
#if _SL_INCLUDE_FUNC(sl_NetAppPingStart) #if _SL_INCLUDE_FUNC(sl_NetAppPingStart)
_i16 sl_NetAppPingStart(SlPingStartCommand_t* pPingParams,_u8 family,SlPingReport_t *pReport,const P_SL_DEV_PING_CALLBACK pPingCallback); _i16 sl_NetAppPingStart(const SlPingStartCommand_t* pPingParams,const _u8 family,SlPingReport_t *pReport,const P_SL_DEV_PING_CALLBACK pPingCallback);
#endif #endif
/*! /*!
@ -732,10 +736,27 @@ _i16 sl_NetAppPingStart(SlPingStartCommand_t* pPingParams,_u8 family,SlPingRepor
\param[in] AppId Application id, could be one of the following: \n \param[in] AppId Application id, could be one of the following: \n
- SL_NET_APP_HTTP_SERVER_ID - SL_NET_APP_HTTP_SERVER_ID
- SL_NET_APP_DHCP_SERVER_ID - SL_NET_APP_DHCP_SERVER_ID
- SL_NET_APP_DHCP_SERVER_ID - SL_NET_APP_MDNS_ID
- SL_NET_APP_DEVICE_CONFIG_ID
\param[in] SetOptions set option, could be one of the following: \n \param[in] SetOptions set option, could be one of the following: \n
NETAPP_SET_BASIC_OPT - SL_NET_APP_DHCP_SERVER_ID
- NETAPP_SET_DHCP_SRV_BASIC_OPT
- SL_NET_APP_HTTP_SERVER_ID
- NETAPP_SET_GET_HTTP_OPT_PORT_NUMBER
- NETAPP_SET_GET_HTTP_OPT_AUTH_CHECK
- NETAPP_SET_GET_HTTP_OPT_AUTH_NAME
- NETAPP_SET_GET_HTTP_OPT_AUTH_PASSWORD
- NETAPP_SET_GET_HTTP_OPT_AUTH_REALM
- NETAPP_SET_GET_HTTP_OPT_ROM_PAGES_ACCESS
- SL_NET_APP_MDNS_ID
- NETAPP_SET_GET_MDNS_CONT_QUERY_OPT
- NETAPP_SET_GET_MDNS_QEVETN_MASK_OPT
- NETAPP_SET_GET_MDNS_TIMING_PARAMS_OPT
- SL_NET_APP_DEVICE_CONFIG_ID
- NETAPP_SET_GET_DEV_CONF_OPT_DEVICE_URN
- NETAPP_SET_GET_DEV_CONF_OPT_DOMAIN_NAME
\param[in] OptionLen option structure length \param[in] OptionLen option structure length
@ -770,7 +791,7 @@ _i16 sl_NetAppPingStart(SlPingStartCommand_t* pPingParams,_u8 family,SlPingRepor
*/ */
#if _SL_INCLUDE_FUNC(sl_NetAppSet) #if _SL_INCLUDE_FUNC(sl_NetAppSet)
_i32 sl_NetAppSet(_u8 AppId ,_u8 Option,_u8 OptionLen, _u8 *pOptionValue); _i32 sl_NetAppSet(const _u8 AppId ,const _u8 Option,const _u8 OptionLen,const _u8 *pOptionValue);
#endif #endif
/*! /*!
@ -782,9 +803,27 @@ _i32 sl_NetAppSet(_u8 AppId ,_u8 Option,_u8 OptionLen, _u8 *pOptionValue);
\param[in] AppId Application id, could be one of the following: \n \param[in] AppId Application id, could be one of the following: \n
- SL_NET_APP_HTTP_SERVER_ID - SL_NET_APP_HTTP_SERVER_ID
- SL_NET_APP_DHCP_SERVER_ID - SL_NET_APP_DHCP_SERVER_ID
- SL_NET_APP_MDNS_ID
- SL_NET_APP_DEVICE_CONFIG_ID
\param[in] SetOptions set option, could be one of the following: \n
- SL_NET_APP_DHCP_SERVER_ID
- NETAPP_SET_DHCP_SRV_BASIC_OPT
- SL_NET_APP_HTTP_SERVER_ID
- NETAPP_SET_GET_HTTP_OPT_PORT_NUMBER
- NETAPP_SET_GET_HTTP_OPT_AUTH_CHECK
- NETAPP_SET_GET_HTTP_OPT_AUTH_NAME
- NETAPP_SET_GET_HTTP_OPT_AUTH_PASSWORD
- NETAPP_SET_GET_HTTP_OPT_AUTH_REALM
- NETAPP_SET_GET_HTTP_OPT_ROM_PAGES_ACCESS
- SL_NET_APP_MDNS_ID
- NETAPP_SET_GET_MDNS_CONT_QUERY_OPT
- NETAPP_SET_GET_MDNS_QEVETN_MASK_OPT
- NETAPP_SET_GET_MDNS_TIMING_PARAMS_OPT
- SL_NET_APP_DEVICE_CONFIG_ID
- NETAPP_SET_GET_DEV_CONF_OPT_DEVICE_URN
- NETAPP_SET_GET_DEV_CONF_OPT_DOMAIN_NAME
\param[in] Options Get option, could be one of the following: \n
NETAPP_SET_BASIC_OPT
\param[in] OptionLen The length of the allocated memory as input, when the \param[in] OptionLen The length of the allocated memory as input, when the
function complete, the value of this parameter would be function complete, the value of this parameter would be
@ -824,7 +863,7 @@ _i32 sl_NetAppSet(_u8 AppId ,_u8 Option,_u8 OptionLen, _u8 *pOptionValue);
\endcode \endcode
*/ */
#if _SL_INCLUDE_FUNC(sl_NetAppGet) #if _SL_INCLUDE_FUNC(sl_NetAppGet)
_i32 sl_NetAppGet(_u8 AppId, _u8 Option,_u8 *pOptionLen, _u8 *pOptionValue); _i32 sl_NetAppGet(const _u8 AppId,const _u8 Option,_u8 *pOptionLen, _u8 *pOptionValue);
#endif #endif

View File

@ -34,14 +34,16 @@
* *
*/ */
#ifndef __NETCFG_H__
#define __NETCFG_H__
/*****************************************************************************/ /*****************************************************************************/
/* Include files */ /* Include files */
/*****************************************************************************/ /*****************************************************************************/
#include "simplelink.h" #include "simplelink.h"
#ifndef __NETCFG_H__
#define __NETCFG_H__
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif #endif
@ -182,7 +184,7 @@ typedef struct
*/ */
#if _SL_INCLUDE_FUNC(sl_NetCfgSet) #if _SL_INCLUDE_FUNC(sl_NetCfgSet)
_i32 sl_NetCfgSet(_u8 ConfigId ,_u8 ConfigOpt, _u8 ConfigLen, _u8 *pValues); _i32 sl_NetCfgSet(const _u8 ConfigId,const _u8 ConfigOpt,const _u8 ConfigLen,const _u8 *pValues);
#endif #endif
@ -262,7 +264,7 @@ _i32 sl_NetCfgSet(_u8 ConfigId ,_u8 ConfigOpt, _u8 ConfigLen, _u8 *pValues);
*/ */
#if _SL_INCLUDE_FUNC(sl_NetCfgGet) #if _SL_INCLUDE_FUNC(sl_NetCfgGet)
_i32 sl_NetCfgGet(_u8 ConfigId ,_u8 *pConfigOpt, _u8 *pConfigLen, _u8 *pValues); _i32 sl_NetCfgGet(const _u8 ConfigId ,_u8 *pConfigOpt, _u8 *pConfigLen, _u8 *pValues);
#endif #endif
/*! /*!

View File

@ -55,7 +55,7 @@ extern "C" {
#define NONOS_WAIT_FOREVER 0xFF #define NONOS_WAIT_FOREVER 0xFF
#define NONOS_NO_WAIT 0x01 #define NONOS_NO_WAIT 0x00
#define NONOS_RET_OK (0) #define NONOS_RET_OK (0)
#define NONOS_RET_ERR (0xFF) #define NONOS_RET_ERR (0xFF)

View File

@ -168,25 +168,25 @@ extern "C" {
#define _SL_INCLUDE_FUNC(Name) (_SL_INC_##Name) #define _SL_INCLUDE_FUNC(Name) (_SL_INC_##Name)
/* Driver */ /* Driver */
#define _SL_INC_sl_NetAppStart __nap #define _SL_INC_sl_NetAppStart __nap__ext
#define _SL_INC_sl_NetAppStop __nap__ext
#define _SL_INC_sl_NetAppStop __nap
#define _SL_INC_sl_NetAppDnsGetHostByName __nap__clt #define _SL_INC_sl_NetAppDnsGetHostByName __nap__clt
#define _SL_INC_sl_NetAppDnsGetHostByService __nap__clt #define _SL_INC_sl_NetAppDnsGetHostByService __nap__ext
#define _SL_INC_sl_NetAppMDNSRegisterService __nap__clt #define _SL_INC_sl_NetAppMDNSRegisterService __nap__ext
#define _SL_INC_sl_NetAppMDNSUnRegisterService __nap__clt #define _SL_INC_sl_NetAppMDNSUnRegisterService __nap__ext
#define _SL_INC_sl_NetAppMDNSRegisterUnregisterService __nap__clt #define _SL_INC_sl_NetAppMDNSRegisterUnregisterService __nap__ext
#define _SL_INC_sl_NetAppGetServiceList __nap__clt #define _SL_INC_sl_NetAppGetServiceList __nap__ext
#define _SL_INC_sl_DnsGetHostByAddr __nap__ext #define _SL_INC_sl_DnsGetHostByAddr __nap__ext
#define _SL_INC_sl_NetAppPingStart __nap__ext
#define _SL_INC_sl_NetAppPingReport __nap__ext
#define _SL_INC_sl_NetAppSet __nap__ext
#define _SL_INC_sl_NetAppGet __nap__ext
#define _SL_INC_sl_NetAppPingStart __nap
#define _SL_INC_sl_NetAppPingReport __nap
/* FS */ /* FS */
#define _SL_INC_sl_FsOpen __nvm #define _SL_INC_sl_FsOpen __nvm
@ -210,14 +210,11 @@ extern "C" {
#define _SL_INC_sl_NetCfgSet __ncg #define _SL_INC_sl_NetCfgSet __ncg
#define _SL_INC_sl_NetAppSet __nap
#define _SL_INC_sl_NetAppGet __nap
/* socket */ /* socket */
#define _SL_INC_sl_Socket __sck #define _SL_INC_sl_Socket __sck
#define _SL_INC_sl_Close __sck__ext #define _SL_INC_sl_Close __sck
#define _SL_INC_sl_Accept __sck__srv #define _SL_INC_sl_Accept __sck__srv
@ -306,7 +303,7 @@ extern "C" {
#define _SL_INC_sl_StatusGet __dev #define _SL_INC_sl_StatusGet __dev
#ifdef SL_IF_TYPE_UART #ifdef SL_IF_TYPE_UART
#define _SL_INC_sl_UartSetMode __dev #define _SL_INC_sl_UartSetMode __dev__ext
#endif #endif
#define _SL_INC_sl_EventMaskGet __dev__ext #define _SL_INC_sl_EventMaskGet __dev__ext

View File

@ -149,6 +149,7 @@ typedef struct
#define SL_FLAGS_MASK (0xF) #define SL_FLAGS_MASK (0xF)
#define SL_OPCODE_DEVICE_INITCOMPLETE 0x0008 #define SL_OPCODE_DEVICE_INITCOMPLETE 0x0008
#define SL_OPCODE_DEVICE_ABORT 0x000C
#define SL_OPCODE_DEVICE_STOP_COMMAND 0x8473 #define SL_OPCODE_DEVICE_STOP_COMMAND 0x8473
#define SL_OPCODE_DEVICE_STOP_RESPONSE 0x0473 #define SL_OPCODE_DEVICE_STOP_RESPONSE 0x0473
#define SL_OPCODE_DEVICE_STOP_ASYNC_RESPONSE 0x0073 #define SL_OPCODE_DEVICE_STOP_ASYNC_RESPONSE 0x0073
@ -351,9 +352,6 @@ typedef struct
#define SL_OPCODE_WLAN_SMARTCONFIGOPTGET 0x8C8E #define SL_OPCODE_WLAN_SMARTCONFIGOPTGET 0x8C8E
#define SL_OPCODE_WLAN_SMARTCONFIGOPTGETRESPONSE 0x0C8E #define SL_OPCODE_WLAN_SMARTCONFIGOPTGETRESPONSE 0x0C8E
#define SL_OPCODE_FREE_BSD_RECV_BUFFER 0xCCCB
#define SL_OPCODE_FREE_NON_BSD_READ_BUFFER 0xCCCD
/* Rx Filters opcodes */ /* Rx Filters opcodes */
#define SL_OPCODE_WLAN_WLANRXFILTERADDCOMMAND 0x8C6C #define SL_OPCODE_WLAN_WLANRXFILTERADDCOMMAND 0x8C6C
@ -1032,6 +1030,7 @@ typedef struct
_u16 rxKbitsSec; _u16 rxKbitsSec;
_u32 outOfOrderPackets; _u32 outOfOrderPackets;
_u32 missedPackets; _u32 missedPackets;
_i16 token;
}_CtestAsyncResponse_t; }_CtestAsyncResponse_t;
typedef struct typedef struct
@ -1162,8 +1161,15 @@ typedef _BasicResponse_t _FsWriteResponse_t;
/* Set Max Async Payload length depending on flavor (Tiny, Small, etc.) */ /* TODO: Set MAx Async Payload length depending on flavor (Tiny, Small, etc.) */
#ifdef SL_TINY_EXT
#define SL_ASYNC_MAX_PAYLOAD_LEN 120 /* size must be aligned to 4 */
#else
#define SL_ASYNC_MAX_PAYLOAD_LEN 160 /* size must be aligned to 4 */ #define SL_ASYNC_MAX_PAYLOAD_LEN 160 /* size must be aligned to 4 */
#endif
#define SL_ASYNC_MAX_MSG_LEN (_SL_RESP_HDR_SIZE + SL_ASYNC_MAX_PAYLOAD_LEN) #define SL_ASYNC_MAX_MSG_LEN (_SL_RESP_HDR_SIZE + SL_ASYNC_MAX_PAYLOAD_LEN)
#define RECV_ARGS_SIZE (sizeof(_SocketResponse_t)) #define RECV_ARGS_SIZE (sizeof(_SocketResponse_t))

View File

@ -58,7 +58,7 @@
Listed below are the various modules in the SimpleLink CC31xx/CC32xx driver: Listed below are the various modules in the SimpleLink CC31xx/CC32xx driver:
-# \ref device - controls the behaviour of the CC31xx/CC32xx device (start/stop, events masking and obtaining specific device status) -# \ref device - controls the behaviour of the CC31xx/CC32xx device (start/stop, events masking and obtaining specific device status)
-# \ref wlan - controls the use of the WiFi WLAN module including: -# \ref wlan - controls the use of the WiFi WLAN module including:
- Connection features, such as: profiles, policies, SmartConfig - Connection features, such as: profiles, policies, SmartConfig<EFBFBD>
- Advanced WLAN features, such as: scans, rx filters and rx statistics collection - Advanced WLAN features, such as: scans, rx filters and rx statistics collection
-# \ref socket - controls standard client/server sockets programming options and capabilities -# \ref socket - controls standard client/server sockets programming options and capabilities
-# \ref netapp - activates networking applications, such as: HTTP Server, DHCP Server, Ping, DNS and mDNS. -# \ref netapp - activates networking applications, such as: HTTP Server, DHCP Server, Ping, DNS and mDNS.
@ -250,11 +250,11 @@ extern "C"
/*****************************************************************************/ /*****************************************************************************/
/* Macro declarations for Host Driver version */ /* Macro declarations for Host Driver version */
/*****************************************************************************/ /*****************************************************************************/
#define SL_DRIVER_VERSION "1.0.0.1" #define SL_DRIVER_VERSION "1.0.0.10"
#define SL_MAJOR_VERSION_NUM 1L #define SL_MAJOR_VERSION_NUM 1L
#define SL_MINOR_VERSION_NUM 0L #define SL_MINOR_VERSION_NUM 0L
#define SL_VERSION_NUM 0L #define SL_VERSION_NUM 0L
#define SL_SUB_VERSION_NUM 1L #define SL_SUB_VERSION_NUM 10L
/*****************************************************************************/ /*****************************************************************************/
@ -264,15 +264,17 @@ extern "C"
#ifdef SL_TINY #ifdef SL_TINY
#undef SL_INC_ARG_CHECK #undef SL_INC_ARG_CHECK
#undef SL_INC_EXT_API #undef SL_INC_EXT_API
#undef SL_INC_SOCK_CLIENT_SIDE_API #undef SL_INC_SOCK_SERVER_SIDE_API
#undef SL_INC_SOCK_SEND_API
#undef SL_INC_WLAN_PKG #undef SL_INC_WLAN_PKG
#undef SL_INC_NET_APP_PKG
#undef SL_INC_NET_CFG_PKG #undef SL_INC_NET_CFG_PKG
#undef SL_INC_FS_PKG #undef SL_INC_FS_PKG
#define SL_INC_SOCK_SERVER_SIDE_API #undef SL_INC_SET_UART_MODE
#define SL_INC_SOCK_RECV_API #undef SL_INC_STD_BSD_API_NAMING
#define SL_INC_SOCKET_PKG #undef SL_INC_SOCK_CLIENT_SIDE_API
#undef SL_INC_NET_APP_PKG
#undef SL_INC_SOCK_RECV_API
#undef SL_INC_SOCK_SEND_API
#undef SL_INC_SOCKET_PKG
#endif #endif
#ifdef SL_SMALL #ifdef SL_SMALL
@ -287,6 +289,7 @@ extern "C"
#define SL_INC_SOCK_SERVER_SIDE_API #define SL_INC_SOCK_SERVER_SIDE_API
#define SL_INC_SOCK_RECV_API #define SL_INC_SOCK_RECV_API
#define SL_INC_SOCK_SEND_API #define SL_INC_SOCK_SEND_API
#define SL_INC_SET_UART_MODE
#endif #endif
#ifdef SL_FULL #ifdef SL_FULL
@ -301,6 +304,7 @@ extern "C"
#define SL_INC_SOCK_SERVER_SIDE_API #define SL_INC_SOCK_SERVER_SIDE_API
#define SL_INC_SOCK_RECV_API #define SL_INC_SOCK_RECV_API
#define SL_INC_SOCK_SEND_API #define SL_INC_SOCK_SEND_API
#define SL_INC_SET_UART_MODE
#endif #endif
#define SL_RET_CODE_OK (0) #define SL_RET_CODE_OK (0)
@ -314,7 +318,11 @@ extern "C"
#define sl_SyncObjClear(pObj) sl_SyncObjWait(pObj,SL_OS_NO_WAIT) #define sl_SyncObjClear(pObj) sl_SyncObjWait(pObj,SL_OS_NO_WAIT)
#ifndef SL_TINY_EXT
#define SL_MAX_SOCKETS (8) #define SL_MAX_SOCKETS (8)
#else
#define SL_MAX_SOCKETS (2)
#endif
/*****************************************************************************/ /*****************************************************************************/
@ -339,14 +347,14 @@ typedef void (*_SlSpawnEntryFunc_t)(void* pValue);
#endif #endif
#ifndef _SL_USER_TYPES #ifndef _SL_USER_TYPES
#define _u8 unsigned char typedef unsigned char _u8;
#define _i8 signed char typedef signed char _i8;
#define _u16 unsigned short typedef unsigned short _u16;
#define _i16 signed short typedef signed short _i16;
#define _u32 unsigned long typedef unsigned long _u32;
#define _i32 signed long typedef signed long _i32;
#define _volatile volatile #define _volatile volatile
#define _const const #define _const const
#endif #endif
@ -362,6 +370,23 @@ typedef _i16 _SlReturnVal_t;
/*
* This event status used to block or continue the event propagation
* through all the registered external libs/user application
*
*/
typedef enum {
EVENT_PROPAGATION_BLOCK = 0,
EVENT_PROPAGATION_CONTINUE
} _SlEventPropogationStatus_e;
/*****************************************************************************/ /*****************************************************************************/
/* Include files */ /* Include files */
/*****************************************************************************/ /*****************************************************************************/
@ -389,6 +414,323 @@ typedef _i16 _SlReturnVal_t;
#include "wlan_rx_filters.h" #include "wlan_rx_filters.h"
/* The general events dispatcher which is
* initialized to the user handler */
#ifdef sl_GeneralEvtHdlr
#define _SlDrvHandleGeneralEvents sl_GeneralEvtHdlr
#endif
/* The wlan events dispatcher which is
* initialized to the user handler */
#ifdef sl_WlanEvtHdlr
#define _SlDrvHandleWlanEvents sl_WlanEvtHdlr
#endif
/* The NetApp events dispatcher which is
* initialized to the user handler */
#ifdef sl_NetAppEvtHdlr
#define _SlDrvHandleNetAppEvents sl_NetAppEvtHdlr
#endif
/* The http server events dispatcher which is
* initialized to the user handler if exists */
#ifdef sl_HttpServerCallback
#define _SlDrvHandleHttpServerEvents sl_HttpServerCallback
#endif
/* The socket events dispatcher which is
* initialized to the user handler */
#ifdef sl_SockEvtHdlr
#define _SlDrvHandleSockEvents sl_SockEvtHdlr
#endif
#ifndef __CONCAT
#define __CONCAT(x,y) x ## y
#endif
#define __CONCAT2(x,y) __CONCAT(x,y)
/*
* The section below handles the external lib event registration
* according to the desired events it specified in its API header file.
* The external lib should be first installed by the user (see user.h)
*/
#ifdef SL_EXT_LIB_1
/* General Event Registration */
#if __CONCAT2(SL_EXT_LIB_1, _NOTIFY_GENERAL_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_1, _GeneralEventHdl) (SlDeviceEvent_t *);
#define SlExtLib1GeneralEventHandler __CONCAT2(SL_EXT_LIB_1, _GeneralEventHdl)
#undef EXT_LIB_REGISTERED_GENERAL_EVENTS
#define EXT_LIB_REGISTERED_GENERAL_EVENTS
#endif
/* Wlan Event Registration */
#if __CONCAT2(SL_EXT_LIB_1, _NOTIFY_WLAN_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_1, _WlanEventHdl) (SlWlanEvent_t *);
#define SlExtLib1WlanEventHandler __CONCAT2(SL_EXT_LIB_1, _WlanEventHdl)
#undef EXT_LIB_REGISTERED_WLAN_EVENTS
#define EXT_LIB_REGISTERED_WLAN_EVENTS
#endif
/* NetApp Event Registration */
#if __CONCAT2(SL_EXT_LIB_1, _NOTIFY_NETAPP_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_1, _NetAppEventHdl) (SlNetAppEvent_t *);
#define SlExtLib1NetAppEventHandler __CONCAT2(SL_EXT_LIB_1, _NetAppEventHdl)
#undef EXT_LIB_REGISTERED_NETAPP_EVENTS
#define EXT_LIB_REGISTERED_NETAPP_EVENTS
#endif
/* Http Server Event Registration */
#if __CONCAT2(SL_EXT_LIB_1, _NOTIFY_HTTP_SERVER_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_1, _HttpServerEventHdl) (SlHttpServerEvent_t* , SlHttpServerResponse_t*);
#define SlExtLib1HttpServerEventHandler __CONCAT2(SL_EXT_LIB_1, _HttpServerEventHdl)
#undef EXT_LIB_REGISTERED_HTTP_SERVER_EVENTS
#define EXT_LIB_REGISTERED_HTTP_SERVER_EVENTS
#endif
/* Socket Event Registration */
#if __CONCAT2(SL_EXT_LIB_1, _NOTIFY_SOCK_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_1, _SockEventHdl) (SlSockEvent_t *);
#define SlExtLib1SockEventHandler __CONCAT2(SL_EXT_LIB_1, _SockEventHdl)
#undef EXT_LIB_REGISTERED_SOCK_EVENTS
#define EXT_LIB_REGISTERED_SOCK_EVENTS
#endif
#endif
#ifdef SL_EXT_LIB_2
/* General Event Registration */
#if __CONCAT2(SL_EXT_LIB_2, _NOTIFY_GENERAL_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_2, _GeneralEventHdl) (SlDeviceEvent_t *);
#define SlExtLib2GeneralEventHandler __CONCAT2(SL_EXT_LIB_2, _GeneralEventHdl)
#undef EXT_LIB_REGISTERED_GENERAL_EVENTS
#define EXT_LIB_REGISTERED_GENERAL_EVENTS
#endif
/* Wlan Event Registration */
#if __CONCAT2(SL_EXT_LIB_2, _NOTIFY_WLAN_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_2, _WlanEventHdl) (SlWlanEvent_t *);
#define SlExtLib2WlanEventHandler __CONCAT2(SL_EXT_LIB_2, _WlanEventHdl)
#undef EXT_LIB_REGISTERED_WLAN_EVENTS
#define EXT_LIB_REGISTERED_WLAN_EVENTS
#endif
/* NetApp Event Registration */
#if __CONCAT2(SL_EXT_LIB_2, _NOTIFY_NETAPP_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_2, _NetAppEventHdl) (SlNetAppEvent_t *);
#define SlExtLib2NetAppEventHandler __CONCAT2(SL_EXT_LIB_2, _NetAppEventHdl)
#undef EXT_LIB_REGISTERED_NETAPP_EVENTS
#define EXT_LIB_REGISTERED_NETAPP_EVENTS
#endif
/* Http Server Event Registration */
#if __CONCAT2(SL_EXT_LIB_2, _NOTIFY_HTTP_SERVER_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_2, _HttpServerEventHdl) (SlHttpServerEvent_t* , SlHttpServerResponse_t*);
#define SlExtLib2HttpServerEventHandler __CONCAT2(SL_EXT_LIB_2, _HttpServerEventHdl)
#undef EXT_LIB_REGISTERED_HTTP_SERVER_EVENTS
#define EXT_LIB_REGISTERED_HTTP_SERVER_EVENTS
#endif
/* Socket Event Registration */
#if __CONCAT2(SL_EXT_LIB_2, _NOTIFY_SOCK_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_2, _SockEventHdl) (SlSockEvent_t *);
#define SlExtLib2SockEventHandler __CONCAT2(SL_EXT_LIB_2, _SockEventHdl)
#undef EXT_LIB_REGISTERED_SOCK_EVENTS
#define EXT_LIB_REGISTERED_SOCK_EVENTS
#endif
#endif
#ifdef SL_EXT_LIB_3
/* General Event Registration */
#if __CONCAT2(SL_EXT_LIB_3, _NOTIFY_GENERAL_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_3, _GeneralEventHdl) (SlDeviceEvent_t *);
#define SlExtLib3GeneralEventHandler __CONCAT2(SL_EXT_LIB_3, _GeneralEventHdl)
#undef EXT_LIB_REGISTERED_GENERAL_EVENTS
#define EXT_LIB_REGISTERED_GENERAL_EVENTS
#endif
/* Wlan Event Registration */
#if __CONCAT2(SL_EXT_LIB_3, _NOTIFY_WLAN_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_3, _WlanEventHdl) (SlWlanEvent_t *);
#define SlExtLib3WlanEventHandler __CONCAT2(SL_EXT_LIB_3, _WlanEventHdl)
#undef EXT_LIB_REGISTERED_WLAN_EVENTS
#define EXT_LIB_REGISTERED_WLAN_EVENTS
#endif
/* NetApp Event Registration */
#if __CONCAT2(SL_EXT_LIB_3, _NOTIFY_NETAPP_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_3, _NetAppEventHdl) (SlNetAppEvent_t *);
#define SlExtLib3NetAppEventHandler __CONCAT2(SL_EXT_LIB_3, _NetAppEventHdl)
#undef EXT_LIB_REGISTERED_NETAPP_EVENTS
#define EXT_LIB_REGISTERED_NETAPP_EVENTS
#endif
/* Http Server Event Registration */
#if __CONCAT2(SL_EXT_LIB_3, _NOTIFY_HTTP_SERVER_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_3, _HttpServerEventHdl) (SlHttpServerEvent_t* , SlHttpServerResponse_t*);
#define SlExtLib3HttpServerEventHandler __CONCAT2(SL_EXT_LIB_3, _HttpServerEventHdl)
#undef EXT_LIB_REGISTERED_HTTP_SERVER_EVENTS
#define EXT_LIB_REGISTERED_HTTP_SERVER_EVENTS
#endif
/* Socket Event Registration */
#if __CONCAT2(SL_EXT_LIB_3, _NOTIFY_SOCK_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_3, _SockEventHdl) (SlSockEvent_t *);
#define SlExtLib3SockEventHandler __CONCAT2(SL_EXT_LIB_3, _SockEventHdl)
#undef EXT_LIB_REGISTERED_SOCK_EVENTS
#define EXT_LIB_REGISTERED_SOCK_EVENTS
#endif
#endif
#ifdef SL_EXT_LIB_4
/* General Event Registration */
#if __CONCAT2(SL_EXT_LIB_4, _NOTIFY_GENERAL_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_4, _GeneralEventHdl) (SlDeviceEvent_t *);
#define SlExtLib4GeneralEventHandler __CONCAT2(SL_EXT_LIB_4, _GeneralEventHdl)
#undef EXT_LIB_REGISTERED_GENERAL_EVENTS
#define EXT_LIB_REGISTERED_GENERAL_EVENTS
#endif
/* Wlan Event Registration */
#if __CONCAT2(SL_EXT_LIB_4, _NOTIFY_WLAN_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_4, _WlanEventHdl) (SlWlanEvent_t *);
#define SlExtLib4WlanEventHandler __CONCAT2(SL_EXT_LIB_4, _WlanEventHdl)
#undef EXT_LIB_REGISTERED_WLAN_EVENTS
#define EXT_LIB_REGISTERED_WLAN_EVENTS
#endif
/* NetApp Event Registration */
#if __CONCAT2(SL_EXT_LIB_4, _NOTIFY_NETAPP_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_4, _NetAppEventHdl) (SlNetAppEvent_t *);
#define SlExtLib4NetAppEventHandler __CONCAT2(SL_EXT_LIB_4, _NetAppEventHdl)
#undef EXT_LIB_REGISTERED_NETAPP_EVENTS
#define EXT_LIB_REGISTERED_NETAPP_EVENTS
#endif
/* Http Server Event Registration */
#if __CONCAT2(SL_EXT_LIB_4, _NOTIFY_HTTP_SERVER_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_4, _HttpServerEventHdl) (SlHttpServerEvent_t* , SlHttpServerResponse_t*);
#define SlExtLib4HttpServerEventHandler __CONCAT2(SL_EXT_LIB_4, _HttpServerEventHdl)
#undef EXT_LIB_REGISTERED_HTTP_SERVER_EVENTS
#define EXT_LIB_REGISTERED_HTTP_SERVER_EVENTS
#endif
/* Socket Event Registration */
#if __CONCAT2(SL_EXT_LIB_4, _NOTIFY_SOCK_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_4, _SockEventHdl) (SlSockEvent_t *);
#define SlExtLib4SockEventHandler __CONCAT2(SL_EXT_LIB_4, _SockEventHdl)
#undef EXT_LIB_REGISTERED_SOCK_EVENTS
#define EXT_LIB_REGISTERED_SOCK_EVENTS
#endif
#endif
#ifdef SL_EXT_LIB_5
/* General Event Registration */
#if __CONCAT2(SL_EXT_LIB_5, _NOTIFY_GENERAL_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_5, _GeneralEventHdl) (SlDeviceEvent_t *);
#define SlExtLib5GeneralEventHandler __CONCAT2(SL_EXT_LIB_5, _GeneralEventHdl)
#undef EXT_LIB_REGISTERED_GENERAL_EVENTS
#define EXT_LIB_REGISTERED_GENERAL_EVENTS
#endif
/* Wlan Event Registration */
#if __CONCAT2(SL_EXT_LIB_5, _NOTIFY_WLAN_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_5, _WlanEventHdl) (SlWlanEvent_t *);
#define SlExtLib5WlanEventHandler __CONCAT2(SL_EXT_LIB_5, _WlanEventHdl)
#undef EXT_LIB_REGISTERED_WLAN_EVENTS
#define EXT_LIB_REGISTERED_WLAN_EVENTS
#endif
/* NetApp Event Registration */
#if __CONCAT2(SL_EXT_LIB_5, _NOTIFY_NETAPP_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_5, _NetAppEventHdl) (SlNetAppEvent_t *);
#define SlExtLib5NetAppEventHandler __CONCAT2(SL_EXT_LIB_5, _NetAppEventHdl)
#undef EXT_LIB_REGISTERED_NETAPP_EVENTS
#define EXT_LIB_REGISTERED_NETAPP_EVENTS
#endif
/* Http Server Event Registration */
#if __CONCAT2(SL_EXT_LIB_5, _NOTIFY_HTTP_SERVER_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_5, _HttpServerEventHdl) (SlHttpServerEvent_t* , SlHttpServerResponse_t*);
#define SlExtLib5HttpServerEventHandler __CONCAT2(SL_EXT_LIB_5, _HttpServerEventHdl)
#undef EXT_LIB_REGISTERED_HTTP_SERVER_EVENTS
#define EXT_LIB_REGISTERED_HTTP_SERVER_EVENTS
#endif
/* Socket Event Registration */
#if __CONCAT2(SL_EXT_LIB_5, _NOTIFY_SOCK_EVENT)
extern _SlEventPropogationStatus_e __CONCAT2(SL_EXT_LIB_5, _SockEventHdl) (SlSockEvent_t *);
#define SlExtLib5SockEventHandler __CONCAT2(SL_EXT_LIB_5, _SockEventHdl)
#undef EXT_LIB_REGISTERED_SOCK_EVENTS
#define EXT_LIB_REGISTERED_SOCK_EVENTS
#endif
#endif
#if defined(EXT_LIB_REGISTERED_GENERAL_EVENTS)
extern void _SlDrvHandleGeneralEvents(SlDeviceEvent_t *slGeneralEvent);
#endif
#if defined(EXT_LIB_REGISTERED_WLAN_EVENTS)
extern void _SlDrvHandleWlanEvents(SlWlanEvent_t *slWlanEvent);
#endif
#if defined (EXT_LIB_REGISTERED_NETAPP_EVENTS)
extern void _SlDrvHandleNetAppEvents(SlNetAppEvent_t *slNetAppEvent);
#endif
#if defined(EXT_LIB_REGISTERED_HTTP_SERVER_EVENTS)
extern void _SlDrvHandleHttpServerEvents(SlHttpServerEvent_t *slHttpServerEvent, SlHttpServerResponse_t *slHttpServerResponse);
#endif
#if defined(EXT_LIB_REGISTERED_SOCK_EVENTS)
extern void _SlDrvHandleSockEvents(SlSockEvent_t *slSockEvent);
#endif
typedef void (*_SlSpawnEntryFunc_t)(void* pValue);
/* Async functions description*/ /* Async functions description*/
@ -399,17 +741,31 @@ typedef _i16 _SlReturnVal_t;
\par \par
Parameters: \n Parameters: \n
<b>pSlDeviceEvent->Event = SL_DEVICE_FATAL_ERROR_EVENT </b> - <b>pSlDeviceEvent->Event = SL_DEVICE_FATAL_ERROR_EVENT </b>
- pSlDeviceEvent->EventData.deviceEvent fields: - pSlDeviceEvent->EventData.deviceEvent fields:
- status: An error code indication from the device - status: An error code indication from the device
- sender: The sender originator which is based on SlErrorSender_e enum - sender: The sender originator which is based on SlErrorSender_e enum
\par Example: - <b>pSlDeviceEvent->Event = SL_DEVICE_ABORT_ERROR_EVENT </b>
Indicates a severe error occured and the device stopped
- pSlDeviceEvent->EventData.deviceReport fields:
- AbortType: An idication of the event type
- AbortData: Additional info about the data error
\par Example for fatal error:
\code \code
printf(General Event Handler - ID=%d Sender=%d\n\n", printf(General Event Handler - ID=%d Sender=%d\n\n",
pSlDeviceEvent->EventData.deviceEvent.status, // status of the general event pSlDeviceEvent->EventData.deviceEvent.status, // status of the general event
pSlDeviceEvent->EventData.deviceEvent.sender); // sender type pSlDeviceEvent->EventData.deviceEvent.sender); // sender type
\endcode \endcode
\par Example for abort request:
\code
printf(Abort type =%d Abort Data=%d\n\n",
pSlDeviceEvent->EventData.deviceReport.AbortType,
pSlDeviceEvent->EventData.deviceReport.AbortData);
\endcode
*/ */
#if (defined(sl_GeneralEvtHdlr)) #if (defined(sl_GeneralEvtHdlr))
extern void sl_GeneralEvtHdlr(SlDeviceEvent_t *pSlDeviceEvent); extern void sl_GeneralEvtHdlr(SlDeviceEvent_t *pSlDeviceEvent);
@ -490,7 +846,7 @@ extern void sl_GeneralEvtHdlr(SlDeviceEvent_t *pSlDeviceEvent);
- status - status
*/ */
#if (defined(sl_WlanEvtHdlr)) #if (defined(sl_WlanEvtHdlr))
extern void sl_WlanEvtHdlr(SlWlanEvent_t *pSlWlanEvent); extern void sl_WlanEvtHdlr(SlWlanEvent_t* pSlWlanEvent);
#endif #endif
@ -501,27 +857,27 @@ extern void sl_WlanEvtHdlr(SlWlanEvent_t *pSlWlanEvent);
\par \par
Parameters: Parameters:
- <b>pSlWlanEvent->Event = SL_NETAPP_IPV4_IPACQUIRED_EVENT</b>, IPV4 acquired event - <b>pSlNetApp->Event = SL_NETAPP_IPV4_IPACQUIRED_EVENT</b>, IPV4 acquired event
- pSlWlanEvent->EventData.ipAcquiredV4 fields: - pSlNetApp->EventData.ipAcquiredV4 fields:
- ip - ip
- gateway - gateway
- dns - dns
- <b>pSlWlanEvent->Event = SL_NETAPP_IP_LEASED_EVENT</b>, AP or P2P go dhcp lease event - <b>pSlNetApp->Event = SL_NETAPP_IP_LEASED_EVENT</b>, AP or P2P go dhcp lease event
- pSlWlanEvent->EventData.ipLeased fields: - pSlNetApp->EventData.ipLeased fields:
- ip_address - ip_address
- lease_time - lease_time
- mac - mac
- <b>pSlWlanEvent->Event = SL_NETAPP_IP_RELEASED_EVENT</b>, AP or P2P go dhcp ip release event - <b>pSlNetApp->Event = SL_NETAPP_IP_RELEASED_EVENT</b>, AP or P2P go dhcp ip release event
- pSlWlanEvent->EventData.ipReleased fields - pSlNetApp->EventData.ipReleased fields
- ip_address - ip_address
- mac - mac
- reason - reason
*/ */
#if (defined(sl_NetAppEvtHdlr)) #if (defined(sl_NetAppEvtHdlr))
extern void sl_NetAppEvtHdlr(SlNetAppEvent_t *pSlNetApp); extern void sl_NetAppEvtHdlr(SlNetAppEvent_t* pSlNetApp);
#endif #endif
/*! /*!
@ -532,18 +888,18 @@ extern void sl_NetAppEvtHdlr(SlNetAppEvent_t *pSlNetApp);
\par \par
Parameters:\n Parameters:\n
- <b>pSlSockEvent->Event = SL_SOCKET_TX_FAILED_EVENT</b> - <b>pSlSockEvent->Event = SL_SOCKET_TX_FAILED_EVENT</b>
- pSlSockEvent->EventData fields: - pSlSockEvent->SockTxFailData fields:
- sd - sd
- status - status
- <b>pSlSockEvent->Event = SL_SOCKET_ASYNC_EVENT</b> - <b>pSlSockEvent->Event = SL_SOCKET_ASYNC_EVENT</b>
- pSlSockEvent->EventData fields: - pSlSockEvent->SockAsyncData fields:
- sd - sd
- type: SSL_ACCEPT or RX_FRAGMENTATION_TOO_BIG or OTHER_SIDE_CLOSE_SSL_DATA_NOT_ENCRYPTED - type: SSL_ACCEPT or RX_FRAGMENTATION_TOO_BIG or OTHER_SIDE_CLOSE_SSL_DATA_NOT_ENCRYPTED
- val - val
*/ */
#if (defined(sl_SockEvtHdlr)) #if (defined(sl_SockEvtHdlr))
extern void sl_SockEvtHdlr(SlSockEvent_t *pSlSockEvent); extern void sl_SockEvtHdlr(SlSockEvent_t* pSlSockEvent);
#endif #endif
/*! /*!

View File

@ -34,14 +34,16 @@
* *
*/ */
#ifndef __SL_SOCKET_H__
#define __SL_SOCKET_H__
/*****************************************************************************/ /*****************************************************************************/
/* Include files */ /* Include files */
/*****************************************************************************/ /*****************************************************************************/
#include "simplelink.h" #include "simplelink.h"
#ifndef __SL_SOCKET_H__
#define __SL_SOCKET_H__
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
@ -155,6 +157,60 @@ extern "C" {
#define SL_ESEC_ALT_NAME_E (-177) /* alt name size problem, too big */ #define SL_ESEC_ALT_NAME_E (-177) /* alt name size problem, too big */
#define SL_ESEC_AES_GCM_AUTH_E (-180) /* AES-GCM Authentication check failure */ #define SL_ESEC_AES_GCM_AUTH_E (-180) /* AES-GCM Authentication check failure */
#define SL_ESEC_AES_CCM_AUTH_E (-181) /* AES-CCM Authentication check failure */ #define SL_ESEC_AES_CCM_AUTH_E (-181) /* AES-CCM Authentication check failure */
#define SL_SOCKET_ERROR_E (-208) /* Error state on socket */
#define SL_ESEC_MEMORY_ERROR (-203) /* out of memory */
#define SL_ESEC_VERIFY_FINISHED_ERROR (-204) /* verify problem on finished */
#define SL_ESEC_VERIFY_MAC_ERROR (-205) /* verify mac problem */
#define SL_ESEC_UNKNOWN_HANDSHAKE_TYPE (-207) /* weird handshake type */
#define SL_ESEC_SOCKET_ERROR_E (-208) /* error state on socket */
#define SL_ESEC_SOCKET_NODATA (-209) /* expected data, not there */
#define SL_ESEC_INCOMPLETE_DATA (-210) /* don't have enough data to complete task */
#define SL_ESEC_UNKNOWN_RECORD_TYPE (-211) /* unknown type in record hdr */
#define SL_ESEC_FATAL_ERROR (-213) /* recvd alert fatal error */
#define SL_ESEC_ENCRYPT_ERROR (-214) /* error during encryption */
#define SL_ESEC_NO_PEER_KEY (-216) /* need peer's key */
#define SL_ESEC_NO_PRIVATE_KEY (-217) /* need the private key */
#define SL_ESEC_RSA_PRIVATE_ERROR (-218) /* error during rsa priv op */
#define SL_ESEC_NO_DH_PARAMS (-219) /* server missing DH params */
#define SL_ESEC_BUILD_MSG_ERROR (-220) /* build message failure */
#define SL_ESEC_BAD_HELLO (-221) /* client hello malformed */
#define SL_ESEC_DOMAIN_NAME_MISMATCH (-222) /* peer subject name mismatch */
#define SL_ESEC_WANT_READ (-223) /* want read, call again */
#define SL_ESEC_NOT_READY_ERROR (-224) /* handshake layer not ready */
#define SL_ESEC_PMS_VERSION_ERROR (-225) /* pre m secret version error */
#define SL_ESEC_VERSION_ERROR (-226) /* record layer version error */
#define SL_ESEC_WANT_WRITE (-227) /* want write, call again */
#define SL_ESEC_BUFFER_ERROR (-228) /* malformed buffer input */
#define SL_ESEC_VERIFY_CERT_ERROR (-229) /* verify cert error */
#define SL_ESEC_VERIFY_SIGN_ERROR (-230) /* verify sign error */
#define SL_ESEC_LENGTH_ERROR (-241) /* record layer length error */
#define SL_ESEC_PEER_KEY_ERROR (-242) /* can't decode peer key */
#define SL_ESEC_ZERO_RETURN (-243) /* peer sent close notify */
#define SL_ESEC_SIDE_ERROR (-244) /* wrong client/server type */
#define SL_ESEC_NO_PEER_CERT (-245) /* peer didn't send key */
#define SL_ESEC_ECC_CURVETYPE_ERROR (-250) /* Bad ECC Curve Type */
#define SL_ESEC_ECC_CURVE_ERROR (-251) /* Bad ECC Curve */
#define SL_ESEC_ECC_PEERKEY_ERROR (-252) /* Bad Peer ECC Key */
#define SL_ESEC_ECC_MAKEKEY_ERROR (-253) /* Bad Make ECC Key */
#define SL_ESEC_ECC_EXPORT_ERROR (-254) /* Bad ECC Export Key */
#define SL_ESEC_ECC_SHARED_ERROR (-255) /* Bad ECC Shared Secret */
#define SL_ESEC_NOT_CA_ERROR (-257) /* Not a CA cert error */
#define SL_ESEC_BAD_PATH_ERROR (-258) /* Bad path for opendir */
#define SL_ESEC_BAD_CERT_MANAGER_ERROR (-259) /* Bad Cert Manager */
#define SL_ESEC_MAX_CHAIN_ERROR (-268) /* max chain depth exceeded */
#define SL_ESEC_SUITES_ERROR (-271) /* suites pointer error */
#define SL_ESEC_SSL_NO_PEM_HEADER (-272) /* no PEM header found */
#define SL_ESEC_OUT_OF_ORDER_E (-273) /* out of order message */
#define SL_ESEC_SANITY_CIPHER_E (-275) /* sanity check on cipher error */
#define SL_ESEC_GEN_COOKIE_E (-277) /* Generate Cookie Error */
#define SL_ESEC_NO_PEER_VERIFY (-278) /* Need peer cert verify Error */
#define SL_ESEC_UNKNOWN_SNI_HOST_NAME_E (-281) /* Unrecognized host name Error */
/* begin negotiation parameter errors */
#define SL_ESEC_UNSUPPORTED_SUITE (-290) /* unsupported cipher suite */
#define SL_ESEC_MATCH_SUITE_ERROR (-291 ) /* can't match cipher suite */
/* ssl tls security start with -300 offset */ /* ssl tls security start with -300 offset */
#define SL_ESEC_CLOSE_NOTIFY (-300) /* ssl/tls alerts */ #define SL_ESEC_CLOSE_NOTIFY (-300) /* ssl/tls alerts */
#define SL_ESEC_UNEXPECTED_MESSAGE (-310) /* ssl/tls alerts */ #define SL_ESEC_UNEXPECTED_MESSAGE (-310) /* ssl/tls alerts */
@ -262,7 +318,13 @@ extern "C" {
#define SL_SEC_MASK_TLS_DHE_RSA_WITH_AES_256_CBC_SHA (1 << 3) #define SL_SEC_MASK_TLS_DHE_RSA_WITH_AES_256_CBC_SHA (1 << 3)
#define SL_SEC_MASK_TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA (1 << 4) #define SL_SEC_MASK_TLS_ECDHE_RSA_WITH_AES_256_CBC_SHA (1 << 4)
#define SL_SEC_MASK_TLS_ECDHE_RSA_WITH_RC4_128_SHA (1 << 5) #define SL_SEC_MASK_TLS_ECDHE_RSA_WITH_RC4_128_SHA (1 << 5)
#define SL_SEC_MASK_SECURE_DEFAULT ((SEC_MASK_TLS_ECDHE_RSA_WITH_RC4_128_SHA << 1) - 1) #define SL_SEC_MASK_TLS_RSA_WITH_AES_128_CBC_SHA256 (1 << 6)
#define SL_SEC_MASK_TLS_RSA_WITH_AES_256_CBC_SHA256 (1 << 7)
#define SL_SEC_MASK_TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256 (1 << 8)
#define SL_SEC_MASK_TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256 (1 << 9)
#define SL_SEC_MASK_SECURE_DEFAULT ((SL_SEC_MASK_TLS_ECDHE_ECDSA_WITH_AES_128_CBC_SHA256 << 1) - 1)
#define SL_MSG_DONTWAIT (0x00000008) /* Nonblocking IO */ #define SL_MSG_DONTWAIT (0x00000008) /* Nonblocking IO */
@ -415,28 +477,41 @@ typedef struct
_u32 NonblockingEnabled;/* 0 = disabled;1 = enabled;default = 1*/ _u32 NonblockingEnabled;/* 0 = disabled;1 = enabled;default = 1*/
}SlSockNonblocking_t; }SlSockNonblocking_t;
typedef struct typedef struct
{ {
_u8 sd; _u8 sd;
_u8 type; _u8 type;
_u16 val; _i16 val;
_u8* pExtraInfo;
} SlSocketAsyncEvent_t; } SlSocketAsyncEvent_t;
typedef struct typedef struct
{ {
_i16 status; _i16 status;
_u16 sd; _u8 sd;
SlSocketAsyncEvent_t socketAsyncEvent; _u8 padding;
} SlSockEventData_t; } SlSockTxFailEventData_t;
typedef union
{
SlSockTxFailEventData_t SockTxFailData;
SlSocketAsyncEvent_t SockAsyncData;
} SlSockEventData_u;
typedef struct typedef struct
{ {
_u32 Event; _u32 Event;
SlSockEventData_t EventData; SlSockEventData_u socketAsyncEvent;
} SlSockEvent_t; } SlSockEvent_t;
typedef struct typedef struct
{ {
_u32 secureMask; _u32 secureMask;
@ -819,7 +894,7 @@ _i16 sl_Connect(_i16 sd, const SlSockAddr_t *addr, _i16 addrlen);
\param[in] nfds the highest-numbered file descriptor in any of the \param[in] nfds the highest-numbered file descriptor in any of the
three sets, plus 1. three sets, plus 1.
\param[out] readsds socket descriptors list for read monitoring and accept monitoring \param[out] readsds socket descriptors list for read monitoring and accept monitoring
\param[out] writesds socket descriptors list for connect monitoring only, write monitoring is not supported \param[out] writesds socket descriptors list for connect monitoring only, write monitoring is not supported, non blocking connect is supported
\param[out] exceptsds socket descriptors list for exception monitoring, not supported. \param[out] exceptsds socket descriptors list for exception monitoring, not supported.
\param[in] timeout is an upper bound on the amount of time elapsed \param[in] timeout is an upper bound on the amount of time elapsed
before select() returns. Null or above 0xffff seconds means before select() returns. Null or above 0xffff seconds means

View File

@ -34,14 +34,16 @@
* *
*/ */
#ifndef __WLAN_H__
#define __WLAN_H__
/*****************************************************************************/ /*****************************************************************************/
/* Include files */ /* Include files */
/*****************************************************************************/ /*****************************************************************************/
#include "simplelink.h" #include "simplelink.h"
#ifndef __WLAN_H__
#define __WLAN_H__
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
@ -98,32 +100,6 @@ extern "C" {
#define SL_DISCONNECT_RESERVED_6 (29) #define SL_DISCONNECT_RESERVED_6 (29)
#define SL_DISCONNECT_RESERVED_7 (30) #define SL_DISCONNECT_RESERVED_7 (30)
#define SL_DISCONNECT_RESERVED_8 (31) #define SL_DISCONNECT_RESERVED_8 (31)
#define SL_DISASSOCIATED_FOR_UNSPECIFIED_QOS_RELATED_REASON (32)
#define SL_DISASSOCIATED_BECAUSE_QAP_LACKS_SUFFICIENT_BANDWIDTH_FOR_THIS_QSTA (33)
#define SL_DISASSOCIATED_BECAUSE_EXCESSIVE_NUMBER_OF_FRAMES_NEED_TO_BE_ACKNOWLEDGED (34)
#define SL_DISASSOCIATED_BECAUSE_QSTA_IS_TRANSMITTING_OUTSIDE_THE_LIMITS_OF_ITS_TXOPS (35)
#define SL_REQUESTED_FROM_PEER_QSTA_AS_THE_QSTA_IS_LEAVING_THE_QBSS (36)
#define SL_REQUESTED_FROM_PEER_QSTA_AS_IT_DOES_NO_WANT_TO_USE_THE_MECHANISM (37)
#define SL_REQUESTED_FROM_PEER_QSTA_AS_THE_QSTA_RECEIVED_FRAMES_SETUP_IS_REQUIRED (38)
#define SL_REQUESTED_FROM_PEER_QSTA_DUE_TO_TIMEOUT (39)
#define SL_PEER_QSTA_DOES_NOT_SUPPORT_THE_REQUESTED_CIPHER_SUITE (40)
#define SL_CISCO_DEFINED (98)
#define SL_CISCO_DEFINED_1 (99)
#define SL_ROAMING_TRIGGER_NONE (100)
#define SL_ROAMING_TRIGGER_LOW_QUALITY_FOR_BG_SCAN (101)
#define SL_ROAMING_TRIGGER_HIGH_QUALITY_FOR_BG_SCAN (102)
#define SL_ROAMING_TRIGGER_NORMAL_QUALITY_FOR_BG_SCAN (103)
#define SL_ROAMING_TRIGGER_LOW_TX_RATE (104)
#define SL_ROAMING_TRIGGER_LOW_SNR (105)
#define SL_ROAMING_TRIGGER_LOW_QUALITY (106)
#define SL_ROAMING_TRIGGER_TSPEC_REJECTED (107)
#define SL_ROAMING_TRIGGER_MAX_TX_RETRIES (108)
#define SL_ROAMING_TRIGGER_BSS_LOSS (109)
#define SL_ROAMING_TRIGGER_BSS_LOSS_DUE_TO_MAX_TX_RETRY (110)
#define SL_ROAMING_TRIGGER_SWITCH_CHANNEL (111)
#define SL_ROAMING_TRIGGER_AP_DISCONNECT (112)
#define SL_ROAMING_TRIGGER_SECURITY_ATTACK (113)
#define SL_ROAMING_TRIGGER_MAX (114)
#define SL_USER_INITIATED_DISCONNECTION (200) #define SL_USER_INITIATED_DISCONNECTION (200)
/* Wlan error codes */ /* Wlan error codes */
@ -417,7 +393,7 @@ typedef struct
{ {
_u32 ReceivedValidPacketsNumber; /* sum of the packets that been received OK (include filtered) */ _u32 ReceivedValidPacketsNumber; /* sum of the packets that been received OK (include filtered) */
_u32 ReceivedFcsErrorPacketsNumber; /* sum of the packets that been dropped due to FCS error */ _u32 ReceivedFcsErrorPacketsNumber; /* sum of the packets that been dropped due to FCS error */
_u32 ReceivedPlcpErrorPacketsNumber; /* sum of the packets that been dropped due to PLCP error */ _u32 ReceivedAddressMismatchPacketsNumber; /* sum of the packets that been received but filtered out by one of the HW filters */
_i16 AvarageDataCtrlRssi; /* average RSSI for all valid data packets received */ _i16 AvarageDataCtrlRssi; /* average RSSI for all valid data packets received */
_i16 AvarageMgMntRssi; /* average RSSI for all valid management packets received */ _i16 AvarageMgMntRssi; /* average RSSI for all valid management packets received */
_u16 RateHistogram[NUM_OF_RATE_INDEXES]; /* rate histogram for all valid packets received */ _u16 RateHistogram[NUM_OF_RATE_INDEXES]; /* rate histogram for all valid packets received */
@ -461,7 +437,7 @@ typedef struct
_u8 UserLen; _u8 UserLen;
_i8 AnonUser[32]; _i8 AnonUser[32];
_u8 AnonUserLen; _u8 AnonUserLen;
_u8 CertIndex; //not supported _u8 CertIndex; /* not supported */
_u32 EapMethod; _u32 EapMethod;
}SlGetSecParamsExt_t; }SlGetSecParamsExt_t;
@ -506,7 +482,11 @@ typedef struct
/*! /*!
\brief Connect to wlan network as a station \brief Connect to wlan network as a station
\param[in] sec_type security types options: \n \param[in] pName up to 32 bytes in case of STA the name is the SSID of the Access Point
\param[in] NameLen name length
\param[in] pMacAddr 6 bytes for MAC address
\param[in] pSecParams Security parameters (use NULL key for SL_SEC_TYPE_OPEN)
Security types options: \n
- SL_SEC_TYPE_OPEN - SL_SEC_TYPE_OPEN
- SL_SEC_TYPE_WEP - SL_SEC_TYPE_WEP
- SL_SEC_TYPE_WPA_WPA2 - SL_SEC_TYPE_WPA_WPA2
@ -514,10 +494,6 @@ typedef struct
- SL_SEC_TYPE_WPS_PBC - SL_SEC_TYPE_WPS_PBC
- SL_SEC_TYPE_WPS_PIN - SL_SEC_TYPE_WPS_PIN
\param[in] pName up to 32 bytes in case of STA the name is the SSID of the Access Point
\param[in] NameLen name length
\param[in] pMacAddr 6 bytes for MAC address
\param[in] pSecParams Security parameters (use NULL key for SL_SEC_TYPE_OPEN)
\param[in] pSecExtParams Enterprise parameters (set NULL in case Enterprise parameters is not in use) \param[in] pSecExtParams Enterprise parameters (set NULL in case Enterprise parameters is not in use)
\return On success, zero is returned. On error, negative is returned \return On success, zero is returned. On error, negative is returned
@ -529,7 +505,7 @@ typedef struct
SL_SEC_TYPE_WPA is a deprecated definition, the new definition is SL_SEC_TYPE_WPA_WPA2 SL_SEC_TYPE_WPA is a deprecated definition, the new definition is SL_SEC_TYPE_WPA_WPA2
*/ */
#if _SL_INCLUDE_FUNC(sl_WlanConnect) #if _SL_INCLUDE_FUNC(sl_WlanConnect)
_i16 sl_WlanConnect(_i8* pName, _i16 NameLen, _u8 *pMacAddr, SlSecParams_t* pSecParams , SlSecParamsExt_t* pSecExtParams); _i16 sl_WlanConnect(const _i8* pName,const _i16 NameLen,const _u8 *pMacAddr,const SlSecParams_t* pSecParams ,const SlSecParamsExt_t* pSecExtParams);
#endif #endif
/*! /*!
@ -586,7 +562,7 @@ _i16 sl_WlanDisconnect(void);
*/ */
#if _SL_INCLUDE_FUNC(sl_WlanProfileAdd) #if _SL_INCLUDE_FUNC(sl_WlanProfileAdd)
_i16 sl_WlanProfileAdd(_i8* pName, _i16 NameLen, _u8 *pMacAddr, SlSecParams_t* pSecParams , SlSecParamsExt_t* pSecExtParams, _u32 Priority, _u32 Options); _i16 sl_WlanProfileAdd(const _i8* pName,const _i16 NameLen,const _u8 *pMacAddr,const SlSecParams_t* pSecParams ,const SlSecParamsExt_t* pSecExtParams,const _u32 Priority,const _u32 Options);
#endif #endif
/*! /*!
@ -601,8 +577,8 @@ _i16 sl_WlanProfileAdd(_i8* pName, _i16 NameLen, _u8 *pMacAddr, SlSecParams_t*
\param[out] pNameLen name length \param[out] pNameLen name length
\param[out] pMacAddr 6 bytes for MAC address \param[out] pMacAddr 6 bytes for MAC address
\param[out] pSecParams security parameters - security type \param[out] pSecParams security parameters - security type
(LAN_SEC_UNSEC, WLAN_SEC_WEP, WLAN_SEC_WPA or (SL_SEC_TYPE_OPEN, SL_SEC_TYPE_WEP, SL_SEC_TYPE_WPA_WPA2 or
WLAN_SEC_WPA2, WLAN_SEC_P2P_PBC, WLAN_SEC_P2P_PIN_KEYPAD or WLAN_SEC_P2P_DISPLAY), key and key length are not SL_SEC_TYPE_WPS_PBC, SL_SEC_TYPE_WPS_PIN, SL_SEC_TYPE_WPA_ENT,SL_SEC_TYPE_P2P_PBC,SL_SEC_TYPE_P2P_PIN_KEYPAD or SL_SEC_TYPE_P2P_PIN_DISPLAY), key and key length are not
in case of p2p security type pin the key refers to pin code in case of p2p security type pin the key refers to pin code
return due to security reasons. return due to security reasons.
\param[out] pSecExtParams enterprise parameters - identity, identity \param[out] pSecExtParams enterprise parameters - identity, identity
@ -618,7 +594,7 @@ _i16 sl_WlanProfileAdd(_i8* pName, _i16 NameLen, _u8 *pMacAddr, SlSecParams_t*
\warning \warning
*/ */
#if _SL_INCLUDE_FUNC(sl_WlanProfileGet) #if _SL_INCLUDE_FUNC(sl_WlanProfileGet)
_i16 sl_WlanProfileGet(_i16 Index,_i8* pName, _i16 *pNameLen, _u8 *pMacAddr, SlSecParams_t* pSecParams, SlGetSecParamsExt_t* pSecExtParams, _u32 *pPriority); _i16 sl_WlanProfileGet(const _i16 Index,_i8* pName, _i16 *pNameLen, _u8 *pMacAddr, SlSecParams_t* pSecParams, SlGetSecParamsExt_t* pSecExtParams, _u32 *pPriority);
#endif #endif
/*! /*!
@ -637,7 +613,7 @@ _i16 sl_WlanProfileGet(_i16 Index,_i8* pName, _i16 *pNameLen, _u8 *pMacAddr, Sl
\warning \warning
*/ */
#if _SL_INCLUDE_FUNC(sl_WlanProfileDel) #if _SL_INCLUDE_FUNC(sl_WlanProfileDel)
_i16 sl_WlanProfileDel(_i16 Index); _i16 sl_WlanProfileDel(const _i16 Index);
#endif #endif
/*! /*!
@ -672,7 +648,7 @@ _i16 sl_WlanProfileDel(_i16 Index);
<b> sl_WlanPolicySet(SL_POLICY_CONNECTION,SL_CONNECTION_POLICY(0,0,0,0,1),NULL,0) </b> \n <b> sl_WlanPolicySet(SL_POLICY_CONNECTION,SL_CONNECTION_POLICY(0,0,0,0,1),NULL,0) </b> \n
The options above could be combined to a single action, if more than one action is required. \n The options above could be combined to a single action, if more than one action is required. \n
\par \par
SL_POLICY_SCAN defines system scan time interval in case there is no connection. Default interval is 10 minutes. \n SL_POLICY_SCAN defines system scan time interval.Default interval is 10 minutes. \n
After settings scan interval, an immediate scan is activated. The next scan will be based on the interval settings. \n After settings scan interval, an immediate scan is activated. The next scan will be based on the interval settings. \n
- For example, setting scan interval to 1 minute interval use: \n - For example, setting scan interval to 1 minute interval use: \n
_u32 intervalInSeconds = 60; \n _u32 intervalInSeconds = 60; \n
@ -706,7 +682,7 @@ _i16 sl_WlanProfileDel(_i16 Index);
*/ */
#if _SL_INCLUDE_FUNC(sl_WlanPolicySet) #if _SL_INCLUDE_FUNC(sl_WlanPolicySet)
_i16 sl_WlanPolicySet(_u8 Type , const _u8 Policy, _u8 *pVal,_u8 ValLen); _i16 sl_WlanPolicySet(const _u8 Type , const _u8 Policy, _u8 *pVal,const _u8 ValLen);
#endif #endif
/*! /*!
\brief get policy values \brief get policy values
@ -729,7 +705,7 @@ _i16 sl_WlanPolicySet(_u8 Type , const _u8 Policy, _u8 *pVal,_u8 ValLen);
*/ */
#if _SL_INCLUDE_FUNC(sl_WlanPolicyGet) #if _SL_INCLUDE_FUNC(sl_WlanPolicyGet)
_i16 sl_WlanPolicyGet(_u8 Type , _u8 Policy,_u8 *pVal,_u8 *pValLen); _i16 sl_WlanPolicyGet(const _u8 Type , _u8 Policy,_u8 *pVal,_u8 *pValLen);
#endif #endif
/*! /*!
\brief Gets the WLAN scan operation results \brief Gets the WLAN scan operation results
@ -760,7 +736,7 @@ _i16 sl_WlanPolicyGet(_u8 Type , _u8 Policy,_u8 *pVal,_u8 *pValLen);
\endcode \endcode
*/ */
#if _SL_INCLUDE_FUNC(sl_WlanGetNetworkList) #if _SL_INCLUDE_FUNC(sl_WlanGetNetworkList)
_i16 sl_WlanGetNetworkList(_u8 Index, _u8 Count, Sl_WlanNetworkEntry_t *pEntries); _i16 sl_WlanGetNetworkList(const _u8 Index,const _u8 Count, Sl_WlanNetworkEntry_t *pEntries);
#endif #endif
/*! /*!
@ -770,7 +746,7 @@ _i16 sl_WlanGetNetworkList(_u8 Index, _u8 Count, Sl_WlanNetworkEntry_t *pEntries
\sa sl_WlanRxStatStop sl_WlanRxStatGet \sa sl_WlanRxStatStop sl_WlanRxStatGet
\note belongs to \ref ext_api \note belongs to \ref ext_api
\warning This API is deprecated and should be removed for next release \warning
\par Example: \par Example:
\code Getting wlan RX statistics: \code Getting wlan RX statistics:
@ -810,7 +786,7 @@ _i16 sl_WlanRxStatStart(void);
\sa sl_WlanRxStatStart sl_WlanRxStatGet \sa sl_WlanRxStatStart sl_WlanRxStatGet
\note belongs to \ref ext_api \note belongs to \ref ext_api
\warning This API is deprecated and should be removed for next release \warning
*/ */
#if _SL_INCLUDE_FUNC(sl_WlanRxStatStop) #if _SL_INCLUDE_FUNC(sl_WlanRxStatStop)
_i16 sl_WlanRxStatStop(void); _i16 sl_WlanRxStatStop(void);
@ -829,7 +805,7 @@ _i16 sl_WlanRxStatStop(void);
\warning \warning
*/ */
#if _SL_INCLUDE_FUNC(sl_WlanRxStatGet) #if _SL_INCLUDE_FUNC(sl_WlanRxStatGet)
_i16 sl_WlanRxStatGet(SlGetRxStatResponse_t *pRxStat,_u32 Flags); _i16 sl_WlanRxStatGet(SlGetRxStatResponse_t *pRxStat,const _u32 Flags);
#endif #endif
@ -844,7 +820,7 @@ _i16 sl_WlanRxStatGet(SlGetRxStatResponse_t *pRxStat,_u32 Flags);
\sa sl_WlanSmartConfigStart \sa sl_WlanSmartConfigStart
\note belongs to \ref ext_api \note belongs to \ref ext_api
\warning This API is deprecated and should be removed for next release \warning
*/ */
#if _SL_INCLUDE_FUNC(sl_WlanSmartConfigStop) #if _SL_INCLUDE_FUNC(sl_WlanSmartConfigStop)
@ -980,6 +956,9 @@ _i16 sl_WlanSetMode(const _u8 mode);
for WEP: 5 / 13 characters (ascii) \n for WEP: 5 / 13 characters (ascii) \n
This options takes <b>_u8</b> buffer as parameter This options takes <b>_u8</b> buffer as parameter
- <b>SL_WLAN_CFG_GENERAL_PARAM_ID</b> - <b>SL_WLAN_CFG_GENERAL_PARAM_ID</b>
- <b> WLAN_GENERAL_PARAM_OPT_SCAN_PARAMS </b> \n
Set scan parameters.
This option uses slWlanScanParamCommand_t as parameter
- <b>WLAN_GENERAL_PARAM_OPT_COUNTRY_CODE</b> \n - <b>WLAN_GENERAL_PARAM_OPT_COUNTRY_CODE</b> \n
Set Country Code for AP mode \n Set Country Code for AP mode \n
This options takes <b>_u8</b> 2 bytes buffer as parameter This options takes <b>_u8</b> 2 bytes buffer as parameter
@ -1065,6 +1044,15 @@ _i16 sl_WlanSetMode(const _u8 mode);
_u8 stapower=(_u8)power; _u8 stapower=(_u8)power;
sl_WlanSet(SL_WLAN_CFG_GENERAL_PARAM_ID, WLAN_GENERAL_PARAM_OPT_STA_TX_POWER,1,(_u8 *)&stapower); sl_WlanSet(SL_WLAN_CFG_GENERAL_PARAM_ID, WLAN_GENERAL_PARAM_OPT_STA_TX_POWER,1,(_u8 *)&stapower);
\endcode \endcode
\par
<b> WLAN_GENERAL_PARAM_OPT_SCAN_PARAMS: </b>
\code
slWlanScanParamCommand_t ScanParamConfig;
ScanParamConfig.G_Channels_mask = 0x01; // bit mask for channels:1 means channel 1 is enabled, 3 means channels 1 + 2 are enabled
ScanParamConfig.rssiThershold = -70; // only for RSSI level which is higher than -70
sl_WlanSet(SL_WLAN_CFG_GENERAL_PARAM_ID ,WLAN_GENERAL_PARAM_OPT_SCAN_PARAMS,sizeof(slWlanScanParamCommand_t),(_u8*)&ScanParamConfig);
\endcode
\par \par
<b> WLAN_GENERAL_PARAM_OPT_COUNTRY_CODE: </b> <b> WLAN_GENERAL_PARAM_OPT_COUNTRY_CODE: </b>
\code \code
@ -1119,7 +1107,7 @@ _i16 sl_WlanSetMode(const _u8 mode);
*/ */
#if _SL_INCLUDE_FUNC(sl_WlanSet) #if _SL_INCLUDE_FUNC(sl_WlanSet)
_i16 sl_WlanSet(_u16 ConfigId ,_u16 ConfigOpt,_u16 ConfigLen, _u8 *pValues); _i16 sl_WlanSet(const _u16 ConfigId ,const _u16 ConfigOpt,const _u16 ConfigLen,const _u8 *pValues);
#endif #endif
/*! /*!
@ -1214,17 +1202,17 @@ _i16 sl_WlanSet(_u16 ConfigId ,_u16 ConfigOpt,_u16 ConfigLen, _u8 *pValues);
\par \par
<b> WLAN_GENERAL_PARAM_OPT_AP_TX_POWER: </b> <b> WLAN_GENERAL_PARAM_OPT_AP_TX_POWER: </b>
\code \code
_i16 TXPower = 0; _i8 TXPower = 0;
_u16 Option = WLAN_GENERAL_PARAM_OPT_AP_TX_POWER; _u16 Option = WLAN_GENERAL_PARAM_OPT_AP_TX_POWER;
_u16 OptionLen = sizeof(_i16); _u16 OptionLen = sizeof(_i8);
sl_WlanGet(SL_WLAN_CFG_GENERAL_PARAM_ID ,&Option,&OptionLen,(_u8 *)&TXPower); sl_WlanGet(SL_WLAN_CFG_GENERAL_PARAM_ID ,&Option,&OptionLen,(_u8 *)&TXPower);
\endcode \endcode
\par \par
<b> WLAN_GENERAL_PARAM_OPT_STA_TX_POWER: </b> <b> WLAN_GENERAL_PARAM_OPT_STA_TX_POWER: </b>
\code \code
_i16 TXPower = 0; _i8 TXPower = 0;
_u16 Option = WLAN_GENERAL_PARAM_OPT_STA_TX_POWER; _u16 Option = WLAN_GENERAL_PARAM_OPT_STA_TX_POWER;
_u16 OptionLen = sizeof(_i16); _u16 OptionLen = sizeof(_i8);
sl_WlanGet(SL_WLAN_CFG_GENERAL_PARAM_ID ,&Option,&OptionLen,(_u8 *)&TXPower); sl_WlanGet(SL_WLAN_CFG_GENERAL_PARAM_ID ,&Option,&OptionLen,(_u8 *)&TXPower);
\endcode \endcode
@ -1302,7 +1290,7 @@ _i16 sl_WlanSet(_u16 ConfigId ,_u16 ConfigOpt,_u16 ConfigLen, _u8 *pValues);
*/ */
#if _SL_INCLUDE_FUNC(sl_WlanGet) #if _SL_INCLUDE_FUNC(sl_WlanGet)
_i16 sl_WlanGet(_u16 ConfigId, _u16 *pConfigOpt,_u16 *pConfigLen, _u8 *pValues); _i16 sl_WlanGet(const _u16 ConfigId, _u16 *pConfigOpt,_u16 *pConfigLen, _u8 *pValues);
#endif #endif
/*! /*!

View File

@ -34,15 +34,17 @@
* *
*/ */
#ifndef RX_FILTERS_PREPROCESSOR_CLI_IF_H_
#define RX_FILTERS_PREPROCESSOR_CLI_IF_H_
/*****************************************************************************/ /*****************************************************************************/
/* Include files */ /* Include files */
/*****************************************************************************/ /*****************************************************************************/
#include "simplelink.h" #include "simplelink.h"
#ifndef RX_FILTERS_PREPROCESSOR_CLI_IF_H_
#define RX_FILTERS_PREPROCESSOR_CLI_IF_H_
#ifdef __cplusplus #ifdef __cplusplus
extern "C" { extern "C" {
#endif #endif

View File

@ -49,25 +49,23 @@
/* Internal functions */ /* Internal functions */
/*****************************************************************************/ /*****************************************************************************/
const _i8 StartResponseLUT[8] =
{
ROLE_UNKNOWN_ERR,
ROLE_STA,
ROLE_STA_ERR,
ROLE_AP,
ROLE_AP_ERR,
ROLE_P2P,
ROLE_P2P_ERR,
ROLE_UNKNOWN_ERR
};
_i16 _sl_GetStartResponseConvert(_u32 Status) _i16 _sl_GetStartResponseConvert(_u32 Status)
{ {
switch(Status) return (_i16)StartResponseLUT[Status & 0x7];
{
case INIT_STA_OK:
return ROLE_STA;
case INIT_STA_ERR:
return ROLE_STA_ERR;
case INIT_AP_OK:
return ROLE_AP;
case INIT_AP_ERR:
return ROLE_AP_ERR;
case INIT_P2P_OK:
return ROLE_P2P;
case INIT_P2P_ERR:
return ROLE_P2P_ERR;
default:
return (_i16)Status;
}
} }
/*****************************************************************************/ /*****************************************************************************/
@ -112,39 +110,37 @@ _i16 sl_Start(const void* pIfHdl, _i8* pDevName, const P_INIT_CALLBACK pInitCal
{ {
g_pCB->FD = (_SlFd_t)pIfHdl; g_pCB->FD = (_SlFd_t)pIfHdl;
} }
/* Use Obj to issue the command, if not available try later */
ObjIdx = _SlDrvWaitForPoolObj(START_STOP_ID,SL_MAX_SOCKETS); ObjIdx = _SlDrvProtectAsyncRespSetting((_u8 *)&AsyncRsp, START_STOP_ID, SL_MAX_SOCKETS);
if (MAX_CONCURRENT_ACTIONS == ObjIdx) if (MAX_CONCURRENT_ACTIONS == ObjIdx)
{ {
return SL_POOL_IS_EMPTY; return SL_POOL_IS_EMPTY;
} }
OSI_RET_OK_CHECK(sl_LockObjLock(&g_pCB->ProtectionLockObj, SL_OS_WAIT_FOREVER));
g_pCB->ObjPool[ObjIdx].pRespArgs = (_u8 *)&AsyncRsp;
OSI_RET_OK_CHECK(sl_LockObjUnlock(&g_pCB->ProtectionLockObj));
if( g_pCB->FD >= 0) if( g_pCB->FD >= (_SlFd_t)0)
{ {
sl_DeviceDisable(); sl_DeviceDisable();
sl_IfRegIntHdlr((SL_P_EVENT_HANDLER)_SlDrvRxIrqHandler, NULL); sl_IfRegIntHdlr((SL_P_EVENT_HANDLER)_SlDrvRxIrqHandler, NULL);
if(NULL != pInitCallBack)
{
g_pCB->pInitCallback = pInitCallBack; g_pCB->pInitCallback = pInitCallBack;
}
sl_DeviceEnable(); sl_DeviceEnable();
if (NULL == pInitCallBack) if (NULL == pInitCallBack)
{ {
OSI_RET_OK_CHECK(sl_SyncObjWait(&g_pCB->ObjPool[ObjIdx].SyncObj, SL_OS_WAIT_FOREVER)); _SlDrvSyncObjWaitForever(&g_pCB->ObjPool[ObjIdx].SyncObj);
/*release Pool Object*/
/* release Pool Object */
_SlDrvReleasePoolObj(g_pCB->FunctionParams.AsyncExt.ActionIndex); _SlDrvReleasePoolObj(g_pCB->FunctionParams.AsyncExt.ActionIndex);
return _sl_GetStartResponseConvert(AsyncRsp.Status); return _sl_GetStartResponseConvert(AsyncRsp.Status);
} }
else
{
return SL_RET_CODE_OK;
} }
}
return (_i16)g_pCB->FD; return SL_BAD_INTERFACE;
} }
#endif #endif
@ -156,7 +152,7 @@ void _sl_HandleAsync_InitComplete(void *pVoidBuf)
{ {
InitComplete_t *pMsgArgs = (InitComplete_t *)_SL_RESP_ARGS_START(pVoidBuf); InitComplete_t *pMsgArgs = (InitComplete_t *)_SL_RESP_ARGS_START(pVoidBuf);
OSI_RET_OK_CHECK(sl_LockObjLock(&g_pCB->ProtectionLockObj, SL_OS_WAIT_FOREVER)); _SlDrvProtectionObjLockWaitForever();
if(g_pCB->pInitCallback) if(g_pCB->pInitCallback)
{ {
@ -165,9 +161,10 @@ void _sl_HandleAsync_InitComplete(void *pVoidBuf)
else else
{ {
sl_Memcpy(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs, pMsgArgs, sizeof(InitComplete_t)); sl_Memcpy(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs, pMsgArgs, sizeof(InitComplete_t));
OSI_RET_OK_CHECK(sl_SyncObjSignal(&g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].SyncObj)); _SlDrvSyncObjSignal(&g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].SyncObj);
} }
OSI_RET_OK_CHECK(sl_LockObjUnlock(&g_pCB->ProtectionLockObj));
_SlDrvProtectionObjUnLock();
if(g_pCB->pInitCallback) if(g_pCB->pInitCallback)
{ {
@ -186,11 +183,13 @@ void _sl_HandleAsync_Stop(void *pVoidBuf)
VERIFY_SOCKET_CB(NULL != g_pCB->StopCB.pAsyncRsp); VERIFY_SOCKET_CB(NULL != g_pCB->StopCB.pAsyncRsp);
OSI_RET_OK_CHECK(sl_LockObjLock(&g_pCB->ProtectionLockObj, SL_OS_WAIT_FOREVER)); _SlDrvProtectionObjLockWaitForever();
sl_Memcpy(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs, pMsgArgs, sizeof(_BasicResponse_t)); sl_Memcpy(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs, pMsgArgs, sizeof(_BasicResponse_t));
OSI_RET_OK_CHECK(sl_SyncObjSignal(&g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].SyncObj));
OSI_RET_OK_CHECK(sl_LockObjUnlock(&g_pCB->ProtectionLockObj)); _SlDrvSyncObjSignal(&g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].SyncObj);
_SlDrvProtectionObjUnLock();
return; return;
} }
@ -212,12 +211,12 @@ const _SlCmdCtrl_t _SlStopCmdCtrl =
}; };
#if _SL_INCLUDE_FUNC(sl_Stop) #if _SL_INCLUDE_FUNC(sl_Stop)
_i16 sl_Stop(_u16 timeout) _i16 sl_Stop(const _u16 timeout)
{ {
_i16 RetVal=0; _i16 RetVal=0;
_SlStopMsg_u Msg; _SlStopMsg_u Msg;
_BasicResponse_t AsyncRsp; _BasicResponse_t AsyncRsp;
_i16 ObjIdx = MAX_CONCURRENT_ACTIONS; _i8 ObjIdx = MAX_CONCURRENT_ACTIONS;
/* if timeout is 0 the shutdown is forced immediately */ /* if timeout is 0 the shutdown is forced immediately */
if( 0 == timeout ) if( 0 == timeout )
{ {
@ -230,29 +229,23 @@ _i16 sl_Stop(_u16 timeout)
{ {
/* let the device make the shutdown using the defined timeout */ /* let the device make the shutdown using the defined timeout */
Msg.Cmd.Timeout = timeout; Msg.Cmd.Timeout = timeout;
/* Use Obj to issue the command, if not available try later */
ObjIdx = _SlDrvWaitForPoolObj(START_STOP_ID,SL_MAX_SOCKETS); ObjIdx = _SlDrvProtectAsyncRespSetting((_u8 *)&AsyncRsp, START_STOP_ID, SL_MAX_SOCKETS);
if (MAX_CONCURRENT_ACTIONS == ObjIdx) if (MAX_CONCURRENT_ACTIONS == ObjIdx)
{ {
return SL_POOL_IS_EMPTY; return SL_POOL_IS_EMPTY;
} }
OSI_RET_OK_CHECK(sl_LockObjLock(&g_pCB->ProtectionLockObj, SL_OS_WAIT_FOREVER));
g_pCB->ObjPool[ObjIdx].pRespArgs = (_u8 *)&AsyncRsp;
OSI_RET_OK_CHECK(sl_LockObjUnlock(&g_pCB->ProtectionLockObj));
VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&_SlStopCmdCtrl, &Msg, NULL)); VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&_SlStopCmdCtrl, &Msg, NULL));
if(SL_OS_RET_CODE_OK == (_i16)Msg.Rsp.status) if(SL_OS_RET_CODE_OK == (_i16)Msg.Rsp.status)
{ {
OSI_RET_OK_CHECK(sl_SyncObjWait(&g_pCB->ObjPool[ObjIdx].SyncObj, SL_OS_WAIT_FOREVER)); _SlDrvSyncObjWaitForever(&g_pCB->ObjPool[ObjIdx].SyncObj);
Msg.Rsp.status = AsyncRsp.status; Msg.Rsp.status = AsyncRsp.status;
RetVal = Msg.Rsp.status; RetVal = Msg.Rsp.status;
} }
_SlDrvReleasePoolObj((_u8)ObjIdx); _SlDrvReleasePoolObj(ObjIdx);
sl_IfRegIntHdlr(NULL, NULL); sl_IfRegIntHdlr(NULL, NULL);
sl_DeviceDisable(); sl_DeviceDisable();
sl_IfClose(g_pCB->FD); sl_IfClose(g_pCB->FD);
@ -273,6 +266,11 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlEventMaskSetMsg_u; }_SlEventMaskSetMsg_u;
#if _SL_INCLUDE_FUNC(sl_EventMaskSet)
const _SlCmdCtrl_t _SlEventMaskSetCmdCtrl = const _SlCmdCtrl_t _SlEventMaskSetCmdCtrl =
{ {
SL_OPCODE_DEVICE_EVENTMASKSET, SL_OPCODE_DEVICE_EVENTMASKSET,
@ -280,8 +278,8 @@ const _SlCmdCtrl_t _SlEventMaskSetCmdCtrl =
sizeof(_BasicResponse_t) sizeof(_BasicResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_EventMaskSet)
_i16 sl_EventMaskSet(_u8 EventClass , _u32 Mask) _i16 sl_EventMaskSet(const _u8 EventClass ,const _u32 Mask)
{ {
_SlEventMaskSetMsg_u Msg; _SlEventMaskSetMsg_u Msg;
@ -303,6 +301,10 @@ typedef union
_DevMaskEventGetResponse_t Rsp; _DevMaskEventGetResponse_t Rsp;
}_SlEventMaskGetMsg_u; }_SlEventMaskGetMsg_u;
#if _SL_INCLUDE_FUNC(sl_EventMaskGet)
const _SlCmdCtrl_t _SlEventMaskGetCmdCtrl = const _SlCmdCtrl_t _SlEventMaskGetCmdCtrl =
{ {
SL_OPCODE_DEVICE_EVENTMASKGET, SL_OPCODE_DEVICE_EVENTMASKGET,
@ -310,8 +312,8 @@ const _SlCmdCtrl_t _SlEventMaskGetCmdCtrl =
sizeof(_DevMaskEventGetResponse_t) sizeof(_DevMaskEventGetResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_EventMaskGet)
_i16 sl_EventMaskGet(_u8 EventClass, _u32 *pMask) _i16 sl_EventMaskGet(const _u8 EventClass,_u32 *pMask)
{ {
_SlEventMaskGetMsg_u Msg; _SlEventMaskGetMsg_u Msg;
@ -336,6 +338,10 @@ typedef union
_DeviceSetGet_t Rsp; _DeviceSetGet_t Rsp;
}_SlDeviceMsgGet_u; }_SlDeviceMsgGet_u;
#if _SL_INCLUDE_FUNC(sl_DevGet)
const _SlCmdCtrl_t _SlDeviceGetCmdCtrl = const _SlCmdCtrl_t _SlDeviceGetCmdCtrl =
{ {
SL_OPCODE_DEVICE_DEVICEGET, SL_OPCODE_DEVICE_DEVICEGET,
@ -343,8 +349,7 @@ const _SlCmdCtrl_t _SlDeviceGetCmdCtrl =
sizeof(_DeviceSetGet_t) sizeof(_DeviceSetGet_t)
}; };
#if _SL_INCLUDE_FUNC(sl_DevGet) _i32 sl_DevGet(const _u8 DeviceGetId,_u8 *pOption,_u8 *pConfigLen, _u8 *pValues)
_i32 sl_DevGet(_u8 DeviceGetId, _u8 *pOption,_u8 *pConfigLen, _u8 *pValues)
{ {
_SlDeviceMsgGet_u Msg; _SlDeviceMsgGet_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
@ -356,11 +361,10 @@ _i32 sl_DevGet(_u8 DeviceGetId, _u8 *pOption,_u8 *pConfigLen, _u8 *pValues)
if( pOption ) if( pOption )
{ {
CmdExt.TxPayloadLen = 0;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.RxPayloadLen = *pConfigLen; CmdExt.RxPayloadLen = *pConfigLen;
CmdExt.pTxPayload = NULL;
CmdExt.pRxPayload = (_u8 *)pValues; CmdExt.pRxPayload = (_u8 *)pValues;
CmdExt.ActualRxPayloadLen = 0;
Msg.Cmd.DeviceSetId = DeviceGetId; Msg.Cmd.DeviceSetId = DeviceGetId;
@ -401,6 +405,10 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlDeviceMsgSet_u; }_SlDeviceMsgSet_u;
#if _SL_INCLUDE_FUNC(sl_DevSet)
const _SlCmdCtrl_t _SlDeviceSetCmdCtrl = const _SlCmdCtrl_t _SlDeviceSetCmdCtrl =
{ {
SL_OPCODE_DEVICE_DEVICESET, SL_OPCODE_DEVICE_DEVICESET,
@ -408,17 +416,16 @@ const _SlCmdCtrl_t _SlDeviceSetCmdCtrl =
sizeof(_BasicResponse_t) sizeof(_BasicResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_DevSet) _i32 sl_DevSet(const _u8 DeviceSetId ,const _u8 Option,const _u8 ConfigLen,const _u8 *pValues)
_i32 sl_DevSet(_u8 DeviceSetId ,_u8 Option,_u8 ConfigLen, _u8 *pValues)
{ {
_SlDeviceMsgSet_u Msg; _SlDeviceMsgSet_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
CmdExt.TxPayloadLen = (ConfigLen+3) & (~3);
CmdExt.RxPayloadLen = 0;
CmdExt.pTxPayload = (_u8 *)pValues;
CmdExt.pRxPayload = NULL;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.TxPayloadLen = (ConfigLen+3) & (~3);
CmdExt.pTxPayload = (_u8 *)pValues;
Msg.Cmd.DeviceSetId = DeviceSetId; Msg.Cmd.DeviceSetId = DeviceSetId;
Msg.Cmd.ConfigLen = ConfigLen; Msg.Cmd.ConfigLen = ConfigLen;
@ -434,7 +441,7 @@ _i32 sl_DevSet(_u8 DeviceSetId ,_u8 Option,_u8 ConfigLen, _u8 *pValues)
/****************************************************************************** /******************************************************************************
_SlDrvDeviceEventHandler - handles internally device async events _SlDrvDeviceEventHandler - handles internally device async events
******************************************************************************/ ******************************************************************************/
void _SlDrvDeviceEventHandler(void *pArgs) void _SlDrvDeviceEventHandler(void* pArgs)
{ {
_SlResponseHeader_t *pHdr = (_SlResponseHeader_t *)pArgs; _SlResponseHeader_t *pHdr = (_SlResponseHeader_t *)pArgs;
@ -446,21 +453,34 @@ void _SlDrvDeviceEventHandler(void *pArgs)
case SL_OPCODE_DEVICE_STOP_ASYNC_RESPONSE: case SL_OPCODE_DEVICE_STOP_ASYNC_RESPONSE:
_sl_HandleAsync_Stop(pHdr); _sl_HandleAsync_Stop(pHdr);
break; break;
case SL_OPCODE_DEVICE_ABORT:
{
#if defined (sl_GeneralEvtHdlr) || defined(EXT_LIB_REGISTERED_GENERAL_EVENTS)
SlDeviceEvent_t devHandler;
devHandler.Event = SL_DEVICE_ABORT_ERROR_EVENT;
devHandler.EventData.deviceReport.AbortType = *((_u32*)pArgs + 2);
devHandler.EventData.deviceReport.AbortData = *((_u32*)pArgs + 3);
_SlDrvHandleGeneralEvents(&devHandler);
#endif
}
break;
case SL_OPCODE_DEVICE_DEVICEASYNCFATALERROR: case SL_OPCODE_DEVICE_DEVICEASYNCFATALERROR:
#ifdef sl_GeneralEvtHdlr #if defined (sl_GeneralEvtHdlr) || defined(EXT_LIB_REGISTERED_GENERAL_EVENTS)
{ {
_BasicResponse_t *pMsgArgs = (_BasicResponse_t *)_SL_RESP_ARGS_START(pHdr); _BasicResponse_t *pMsgArgs = (_BasicResponse_t *)_SL_RESP_ARGS_START(pHdr);
SlDeviceEvent_t devHandler; SlDeviceEvent_t devHandler;
devHandler.Event = SL_DEVICE_FATAL_ERROR_EVENT; devHandler.Event = SL_DEVICE_FATAL_ERROR_EVENT;
devHandler.EventData.deviceEvent.status = pMsgArgs->status & 0xFF; devHandler.EventData.deviceEvent.status = pMsgArgs->status & 0xFF;
devHandler.EventData.deviceEvent.sender = (SlErrorSender_e)((pMsgArgs->status >> 8) & 0xFF); devHandler.EventData.deviceEvent.sender = (SlErrorSender_e)((pMsgArgs->status >> 8) & 0xFF);
sl_GeneralEvtHdlr(&devHandler); _SlDrvHandleGeneralEvents(&devHandler);
} }
#endif #endif
break; break;
default: default:
SL_ERROR_TRACE1(MSG_306, "ASSERT: _SlDrvDeviceEventHandler : invalid opcode = 0x%x", pHdr->GenHeader.Opcode); SL_ERROR_TRACE2(MSG_306, "ASSERT: _SlDrvDeviceEventHandler : invalid opcode = 0x%x = %1", pHdr->GenHeader.Opcode, pHdr->GenHeader.Opcode);
VERIFY_PROTOCOL(0);
} }
} }
@ -475,6 +495,10 @@ typedef union
_DevUartSetModeResponse_t Rsp; _DevUartSetModeResponse_t Rsp;
}_SlUartSetModeMsg_u; }_SlUartSetModeMsg_u;
#if _SL_INCLUDE_FUNC(sl_UartSetMode)
const _SlCmdCtrl_t _SlUartSetModeCmdCtrl = const _SlCmdCtrl_t _SlUartSetModeCmdCtrl =
{ {
SL_OPCODE_DEVICE_SETUARTMODECOMMAND, SL_OPCODE_DEVICE_SETUARTMODECOMMAND,
@ -482,8 +506,6 @@ const _SlCmdCtrl_t _SlUartSetModeCmdCtrl =
sizeof(_DevUartSetModeResponse_t) sizeof(_DevUartSetModeResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_UartSetMode)
_i16 sl_UartSetMode(const SlUartIfParams_t* pUartParams) _i16 sl_UartSetMode(const SlUartIfParams_t* pUartParams)
{ {
_SlUartSetModeMsg_u Msg; _SlUartSetModeMsg_u Msg;

File diff suppressed because it is too large Load Diff

View File

@ -53,7 +53,6 @@
/* Internal functions */ /* Internal functions */
/*****************************************************************************/ /*****************************************************************************/
/*****************************************************************************/ /*****************************************************************************/
/* _sl_Strlen */ /* _sl_Strlen */
/*****************************************************************************/ /*****************************************************************************/
@ -87,7 +86,6 @@ _u32 _sl_GetCreateFsMode(_u32 maxSizeInBytes,_u32 accessFlags)
return _FS_MODE(_FS_MODE_OPEN_WRITE_CREATE_IF_NOT_EXIST, granIdx, granNum, accessFlags); return _FS_MODE(_FS_MODE_OPEN_WRITE_CREATE_IF_NOT_EXIST, granIdx, granNum, accessFlags);
} }
/*****************************************************************************/ /*****************************************************************************/
/* API functions */ /* API functions */
/*****************************************************************************/ /*****************************************************************************/
@ -101,6 +99,9 @@ typedef union
_FsOpenResponse_t Rsp; _FsOpenResponse_t Rsp;
}_SlFsOpenMsg_u; }_SlFsOpenMsg_u;
#if _SL_INCLUDE_FUNC(sl_FsOpen)
const _SlCmdCtrl_t _SlFsOpenCmdCtrl = const _SlCmdCtrl_t _SlFsOpenCmdCtrl =
{ {
SL_OPCODE_NVMEM_FILEOPEN, SL_OPCODE_NVMEM_FILEOPEN,
@ -108,16 +109,15 @@ const _SlCmdCtrl_t _SlFsOpenCmdCtrl =
sizeof(_FsOpenResponse_t) sizeof(_FsOpenResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_FsOpen) _i32 sl_FsOpen(const _u8 *pFileName,const _u32 AccessModeAndMaxSize, _u32 *pToken,_i32 *pFileHandle)
_i32 sl_FsOpen(_u8 *pFileName,_u32 AccessModeAndMaxSize, _u32 *pToken,_i32 *pFileHandle)
{ {
_SlReturnVal_t RetVal; _SlReturnVal_t RetVal;
_SlFsOpenMsg_u Msg; _SlFsOpenMsg_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
CmdExt.TxPayloadLen = (_sl_Strlen(pFileName)+4) & (~3); // add 4: 1 for NULL and the 3 for align CmdExt.TxPayloadLen = (_sl_Strlen(pFileName)+4) & (~3); /* add 4: 1 for NULL and the 3 for align */
CmdExt.RxPayloadLen = 0; CmdExt.RxPayloadLen = 0;
CmdExt.pTxPayload = pFileName; CmdExt.pTxPayload = (_u8*)pFileName;
CmdExt.pRxPayload = NULL; CmdExt.pRxPayload = NULL;
Msg.Cmd.Mode = AccessModeAndMaxSize; Msg.Cmd.Mode = AccessModeAndMaxSize;
@ -156,6 +156,9 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlFsCloseMsg_u; }_SlFsCloseMsg_u;
#if _SL_INCLUDE_FUNC(sl_FsClose)
const _SlCmdCtrl_t _SlFsCloseCmdCtrl = const _SlCmdCtrl_t _SlFsCloseCmdCtrl =
{ {
SL_OPCODE_NVMEM_FILECLOSE, SL_OPCODE_NVMEM_FILECLOSE,
@ -163,10 +166,9 @@ const _SlCmdCtrl_t _SlFsCloseCmdCtrl =
sizeof(_FsCloseResponse_t) sizeof(_FsCloseResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_FsClose) _i16 sl_FsClose(const _i32 FileHdl, const _u8* pCeritificateFileName,const _u8* pSignature ,const _u32 SignatureLen)
_i16 sl_FsClose(_i32 FileHdl, _u8* pCeritificateFileName,_u8* pSignature ,_u32 SignatureLen)
{ {
_SlFsCloseMsg_u Msg = {.Cmd = {0, 0, 0}, .Rsp = {0, 0}}; _SlFsCloseMsg_u Msg = {{0, 0}};
_SlCmdExt_t ExtCtrl; _SlCmdExt_t ExtCtrl;
Msg.Cmd.FileHandle = FileHdl; Msg.Cmd.FileHandle = FileHdl;
@ -177,13 +179,13 @@ _i16 sl_FsClose(_i32 FileHdl, _u8* pCeritificateFileName,_u8* pSignature ,_u32
Msg.Cmd.SignatureLen = SignatureLen; Msg.Cmd.SignatureLen = SignatureLen;
ExtCtrl.TxPayloadLen = ((SignatureLen+3) & (~3)); /* align */ ExtCtrl.TxPayloadLen = ((SignatureLen+3) & (~3)); /* align */
ExtCtrl.pTxPayload = pSignature; ExtCtrl.pTxPayload = (_u8*)pSignature;
ExtCtrl.RxPayloadLen = (_u16)Msg.Cmd.CertificFileNameLength; ExtCtrl.RxPayloadLen = (_i16)Msg.Cmd.CertificFileNameLength;
ExtCtrl.pRxPayload = pCeritificateFileName; /* Add signature */ ExtCtrl.pRxPayload = (_u8*)pCeritificateFileName; /* Add signature */
if(ExtCtrl.pRxPayload != NULL && ExtCtrl.RxPayloadLen != 0) if(ExtCtrl.pRxPayload != NULL && ExtCtrl.RxPayloadLen != 0)
{ {
g_pCB->RelayFlagsViaRxPayload = TRUE; ExtCtrl.RxPayloadLen = ExtCtrl.RxPayloadLen * (-1);
} }
VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&_SlFsCloseCmdCtrl, &Msg, &ExtCtrl)); VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&_SlFsCloseCmdCtrl, &Msg, &ExtCtrl));
@ -202,6 +204,9 @@ typedef union
_FsReadResponse_t Rsp; _FsReadResponse_t Rsp;
}_SlFsReadMsg_u; }_SlFsReadMsg_u;
#if _SL_INCLUDE_FUNC(sl_FsRead)
const _SlCmdCtrl_t _SlFsReadCmdCtrl = const _SlCmdCtrl_t _SlFsReadCmdCtrl =
{ {
SL_OPCODE_NVMEM_FILEREADCOMMAND, SL_OPCODE_NVMEM_FILEREADCOMMAND,
@ -209,9 +214,7 @@ const _SlCmdCtrl_t _SlFsReadCmdCtrl =
sizeof(_FsReadResponse_t) sizeof(_FsReadResponse_t)
}; };
_i32 sl_FsRead(const _i32 FileHdl,_u32 Offset, _u8* pData,_u32 Len)
#if _SL_INCLUDE_FUNC(sl_FsRead)
_i32 sl_FsRead(_i32 FileHdl, _u32 Offset, _u8* pData, _u32 Len)
{ {
_SlFsReadMsg_u Msg; _SlFsReadMsg_u Msg;
_SlCmdExt_t ExtCtrl; _SlCmdExt_t ExtCtrl;
@ -273,6 +276,9 @@ typedef union
_FsWriteResponse_t Rsp; _FsWriteResponse_t Rsp;
}_SlFsWriteMsg_u; }_SlFsWriteMsg_u;
#if _SL_INCLUDE_FUNC(sl_FsWrite)
const _SlCmdCtrl_t _SlFsWriteCmdCtrl = const _SlCmdCtrl_t _SlFsWriteCmdCtrl =
{ {
SL_OPCODE_NVMEM_FILEWRITECOMMAND, SL_OPCODE_NVMEM_FILEWRITECOMMAND,
@ -280,9 +286,7 @@ const _SlCmdCtrl_t _SlFsWriteCmdCtrl =
sizeof(_FsWriteResponse_t) sizeof(_FsWriteResponse_t)
}; };
_i32 sl_FsWrite(const _i32 FileHdl,_u32 Offset, _u8* pData,_u32 Len)
#if _SL_INCLUDE_FUNC(sl_FsWrite)
_i32 sl_FsWrite(_i32 FileHdl, _u32 Offset, _u8* pData, _u32 Len)
{ {
_SlFsWriteMsg_u Msg; _SlFsWriteMsg_u Msg;
_SlCmdExt_t ExtCtrl; _SlCmdExt_t ExtCtrl;
@ -347,6 +351,10 @@ typedef union
_FsGetInfoResponse_t Rsp; _FsGetInfoResponse_t Rsp;
}_SlFsGetInfoMsg_u; }_SlFsGetInfoMsg_u;
#if _SL_INCLUDE_FUNC(sl_FsGetInfo)
const _SlCmdCtrl_t _SlFsGetInfoCmdCtrl = const _SlCmdCtrl_t _SlFsGetInfoCmdCtrl =
{ {
SL_OPCODE_NVMEM_FILEGETINFOCOMMAND, SL_OPCODE_NVMEM_FILEGETINFOCOMMAND,
@ -354,15 +362,14 @@ const _SlCmdCtrl_t _SlFsGetInfoCmdCtrl =
sizeof(_FsGetInfoResponse_t) sizeof(_FsGetInfoResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_FsGetInfo) _i16 sl_FsGetInfo(const _u8 *pFileName,const _u32 Token,SlFsFileInfo_t* pFsFileInfo)
_i16 sl_FsGetInfo(_u8 *pFileName,_u32 Token,SlFsFileInfo_t* pFsFileInfo)
{ {
_SlFsGetInfoMsg_u Msg; _SlFsGetInfoMsg_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
CmdExt.TxPayloadLen = (_sl_Strlen(pFileName)+4) & (~3); /* add 4: 1 for NULL and the 3 for align */ CmdExt.TxPayloadLen = (_sl_Strlen(pFileName)+4) & (~3); /* add 4: 1 for NULL and the 3 for align */
CmdExt.RxPayloadLen = 0; CmdExt.RxPayloadLen = 0;
CmdExt.pTxPayload = pFileName; CmdExt.pTxPayload = (_u8*)pFileName;
CmdExt.pRxPayload = NULL; CmdExt.pRxPayload = NULL;
Msg.Cmd.Token = Token; Msg.Cmd.Token = Token;
@ -388,6 +395,9 @@ typedef union
_FsDeleteResponse_t Rsp; _FsDeleteResponse_t Rsp;
}_SlFsDeleteMsg_u; }_SlFsDeleteMsg_u;
#if _SL_INCLUDE_FUNC(sl_FsDel)
const _SlCmdCtrl_t _SlFsDeleteCmdCtrl = const _SlCmdCtrl_t _SlFsDeleteCmdCtrl =
{ {
SL_OPCODE_NVMEM_FILEDELCOMMAND, SL_OPCODE_NVMEM_FILEDELCOMMAND,
@ -395,15 +405,14 @@ const _SlCmdCtrl_t _SlFsDeleteCmdCtrl =
sizeof(_FsDeleteResponse_t) sizeof(_FsDeleteResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_FsDel) _i16 sl_FsDel(const _u8 *pFileName,const _u32 Token)
_i16 sl_FsDel(_u8 *pFileName,_u32 Token)
{ {
_SlFsDeleteMsg_u Msg; _SlFsDeleteMsg_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
CmdExt.TxPayloadLen = (_sl_Strlen(pFileName)+4) & (~3); /* add 4: 1 for NULL and the 3 for align */ CmdExt.TxPayloadLen = (_sl_Strlen(pFileName)+4) & (~3); /* add 4: 1 for NULL and the 3 for align */
CmdExt.RxPayloadLen = 0; CmdExt.RxPayloadLen = 0;
CmdExt.pTxPayload = pFileName; CmdExt.pTxPayload = (_u8*)pFileName;
CmdExt.pRxPayload = NULL; CmdExt.pRxPayload = NULL;
Msg.Cmd.Token = Token; Msg.Cmd.Token = Token;

View File

@ -59,32 +59,33 @@
/* Functions prototypes */ /* Functions prototypes */
/*****************************************************************************/ /*****************************************************************************/
void _sl_HandleAsync_DnsGetHostByName(void *pVoidBuf); void _sl_HandleAsync_DnsGetHostByName(void *pVoidBuf);
#ifndef SL_TINY_EXT
void _sl_HandleAsync_DnsGetHostByService(void *pVoidBuf); void _sl_HandleAsync_DnsGetHostByService(void *pVoidBuf);
void _sl_HandleAsync_PingResponse(void *pVoidBuf); void _sl_HandleAsync_PingResponse(void *pVoidBuf);
#endif
void CopyPingResultsToReport(_PingReportResponse_t *pResults,SlPingReport_t *pReport); void CopyPingResultsToReport(_PingReportResponse_t *pResults,SlPingReport_t *pReport);
_u16 sl_NetAppSendTokenValue(slHttpServerData_t * Token);
_i16 sl_NetAppMDNSRegisterUnregisterService(const _i8* pServiceName, _i16 sl_NetAppMDNSRegisterUnregisterService(const _i8* pServiceName,
_u8 ServiceNameLen, const _u8 ServiceNameLen,
const _i8* pText, const _i8* pText,
_u8 TextLen, const _u8 TextLen,
_u16 Port, const _u16 Port,
_u32 TTL, const _u32 TTL,
_u32 Options); const _u32 Options);
#if defined(sl_HttpServerCallback) || defined(EXT_LIB_REGISTERED_HTTP_SERVER_EVENTS)
/*****************************************************************************/ _u16 _sl_NetAppSendTokenValue(slHttpServerData_t * Token);
/* API functions */ #endif
/*****************************************************************************/
/*****************************************************************************
sl_NetAppStart
*****************************************************************************/
typedef union typedef union
{ {
_NetAppStartStopCommand_t Cmd; _NetAppStartStopCommand_t Cmd;
_NetAppStartStopResponse_t Rsp; _NetAppStartStopResponse_t Rsp;
}_SlNetAppStartStopMsg_u; }_SlNetAppStartStopMsg_u;
#if _SL_INCLUDE_FUNC(sl_NetAppStart)
const _SlCmdCtrl_t _SlNetAppStartCtrl = const _SlCmdCtrl_t _SlNetAppStartCtrl =
{ {
SL_OPCODE_NETAPP_START_COMMAND, SL_OPCODE_NETAPP_START_COMMAND,
@ -92,15 +93,7 @@ const _SlCmdCtrl_t _SlNetAppStartCtrl =
sizeof(_NetAppStartStopResponse_t) sizeof(_NetAppStartStopResponse_t)
}; };
const _SlCmdCtrl_t _SlNetAppStopCtrl = _i16 sl_NetAppStart(const _u32 AppBitMap)
{
SL_OPCODE_NETAPP_STOP_COMMAND,
sizeof(_NetAppStartStopCommand_t),
sizeof(_NetAppStartStopResponse_t)
};
#if _SL_INCLUDE_FUNC(sl_NetAppStart)
_i16 sl_NetAppStart(_u32 AppBitMap)
{ {
_SlNetAppStartStopMsg_u Msg; _SlNetAppStartStopMsg_u Msg;
Msg.Cmd.appId = AppBitMap; Msg.Cmd.appId = AppBitMap;
@ -114,7 +107,18 @@ _i16 sl_NetAppStart(_u32 AppBitMap)
sl_NetAppStop sl_NetAppStop
*****************************************************************************/ *****************************************************************************/
#if _SL_INCLUDE_FUNC(sl_NetAppStop) #if _SL_INCLUDE_FUNC(sl_NetAppStop)
_i16 sl_NetAppStop(_u32 AppBitMap)
const _SlCmdCtrl_t _SlNetAppStopCtrl =
{
SL_OPCODE_NETAPP_STOP_COMMAND,
sizeof(_NetAppStartStopCommand_t),
sizeof(_NetAppStartStopResponse_t)
};
_i16 sl_NetAppStop(const _u32 AppBitMap)
{ {
_SlNetAppStartStopMsg_u Msg; _SlNetAppStartStopMsg_u Msg;
Msg.Cmd.appId = AppBitMap; Msg.Cmd.appId = AppBitMap;
@ -142,6 +146,9 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlNetappGetServiceListMsg_u; }_SlNetappGetServiceListMsg_u;
#if _SL_INCLUDE_FUNC(sl_NetAppGetServiceList)
const _SlCmdCtrl_t _SlGetServiceListeCtrl = const _SlCmdCtrl_t _SlGetServiceListeCtrl =
{ {
SL_OPCODE_NETAPP_NETAPP_MDNS_LOOKUP_SERVICE, SL_OPCODE_NETAPP_NETAPP_MDNS_LOOKUP_SERVICE,
@ -149,13 +156,11 @@ const _SlCmdCtrl_t _SlGetServiceListeCtrl =
sizeof(_BasicResponse_t) sizeof(_BasicResponse_t)
}; };
_i16 sl_NetAppGetServiceList(const _u8 IndexOffest,
#if _SL_INCLUDE_FUNC(sl_NetAppGetServiceList) const _u8 MaxServiceCount,
_i16 sl_NetAppGetServiceList(_u8 IndexOffest, const _u8 Flags,
_u8 MaxServiceCount,
_u8 Flags,
_i8 *pBuffer, _i8 *pBuffer,
_u32 RxBufferLength const _u32 RxBufferLength
) )
{ {
@ -201,9 +206,8 @@ _i16 sl_NetAppGetServiceList(_u8 IndexOffest,
return SL_ERROR_NETAPP_RX_BUFFER_LENGTH_ERROR; return SL_ERROR_NETAPP_RX_BUFFER_LENGTH_ERROR;
} }
CmdExt.TxPayloadLen = 0; _SlDrvResetCmdExt(&CmdExt);
CmdExt.RxPayloadLen = BufferSize; CmdExt.RxPayloadLen = BufferSize;
CmdExt.pTxPayload = NULL;
CmdExt.pRxPayload = (_u8 *)pBuffer; CmdExt.pRxPayload = (_u8 *)pBuffer;
Msg.Cmd.IndexOffest = IndexOffest; Msg.Cmd.IndexOffest = IndexOffest;
@ -257,6 +261,9 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlNetappMdnsRegisterServiceMsg_u; }_SlNetappMdnsRegisterServiceMsg_u;
#if _SL_INCLUDE_FUNC(sl_NetAppMDNSRegisterUnregisterService)
const _SlCmdCtrl_t _SlRegisterServiceCtrl = const _SlCmdCtrl_t _SlRegisterServiceCtrl =
{ {
SL_OPCODE_NETAPP_MDNSREGISTERSERVICE, SL_OPCODE_NETAPP_MDNSREGISTERSERVICE,
@ -264,7 +271,6 @@ const _SlCmdCtrl_t _SlRegisterServiceCtrl =
sizeof(_BasicResponse_t) sizeof(_BasicResponse_t)
}; };
/****************************************************************************** /******************************************************************************
sl_NetAppMDNSRegisterService sl_NetAppMDNSRegisterService
@ -339,15 +345,13 @@ const _SlCmdCtrl_t _SlRegisterServiceCtrl =
******************************************************************************/ ******************************************************************************/
#if _SL_INCLUDE_FUNC(sl_NetAppMDNSRegisterUnregisterService)
_i16 sl_NetAppMDNSRegisterUnregisterService( const _i8* pServiceName, _i16 sl_NetAppMDNSRegisterUnregisterService( const _i8* pServiceName,
_u8 ServiceNameLen, const _u8 ServiceNameLen,
const _i8* pText, const _i8* pText,
_u8 TextLen, const _u8 TextLen,
_u16 Port, const _u16 Port,
_u32 TTL, const _u32 TTL,
_u32 Options) const _u32 Options)
{ {
_SlNetappMdnsRegisterServiceMsg_u Msg; _SlNetappMdnsRegisterServiceMsg_u Msg;
@ -390,7 +394,7 @@ _i16 sl_NetAppMDNSRegisterUnregisterService( const _i8* pServiceName,
return -1; return -1;
} }
sl_Memset(ServiceNameAndTextBuffer,0,NETAPP_MDNS_MAX_SERVICE_NAME_AND_TEXT_LENGTH); _SlDrvMemZero(ServiceNameAndTextBuffer, NETAPP_MDNS_MAX_SERVICE_NAME_AND_TEXT_LENGTH);
/*Copy the service name*/ /*Copy the service name*/
@ -410,10 +414,9 @@ _i16 sl_NetAppMDNSRegisterUnregisterService( const _i8* pServiceName,
} }
_SlDrvResetCmdExt(&CmdExt);
CmdExt.TxPayloadLen = (TextLen + ServiceNameLen); CmdExt.TxPayloadLen = (TextLen + ServiceNameLen);
CmdExt.RxPayloadLen = 0;
CmdExt.pTxPayload = (_u8 *)ServiceNameAndTextBuffer; CmdExt.pTxPayload = (_u8 *)ServiceNameAndTextBuffer;
CmdExt.pRxPayload = NULL;
VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&_SlRegisterServiceCtrl, &Msg, &CmdExt)); VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&_SlRegisterServiceCtrl, &Msg, &CmdExt));
@ -428,11 +431,11 @@ _i16 sl_NetAppMDNSRegisterUnregisterService( const _i8* pServiceName,
#if _SL_INCLUDE_FUNC(sl_NetAppMDNSRegisterService) #if _SL_INCLUDE_FUNC(sl_NetAppMDNSRegisterService)
_i16 sl_NetAppMDNSRegisterService( const _i8* pServiceName, _i16 sl_NetAppMDNSRegisterService( const _i8* pServiceName,
_u8 ServiceNameLen, const _u8 ServiceNameLen,
const _i8* pText, const _i8* pText,
_u8 TextLen, const _u8 TextLen,
_u16 Port, const _u16 Port,
_u32 TTL, const _u32 TTL,
_u32 Options) _u32 Options)
{ {
@ -478,7 +481,7 @@ _i16 sl_NetAppMDNSRegisterService( const _i8* pServiceName,
#if _SL_INCLUDE_FUNC(sl_NetAppMDNSUnRegisterService) #if _SL_INCLUDE_FUNC(sl_NetAppMDNSUnRegisterService)
_i16 sl_NetAppMDNSUnRegisterService( const _i8* pServiceName, _i16 sl_NetAppMDNSUnRegisterService( const _i8* pServiceName,
_u8 ServiceNameLen) const _u8 ServiceNameLen)
{ {
@ -585,7 +588,7 @@ typedef struct
_i16 Status; _i16 Status;
_u32 *out_pAddr; _u32 *out_pAddr;
_u32 *out_pPort; _u32 *out_pPort;
_u16 *inout_TextLen; // in: max len , out: actual len _u16 *inout_TextLen; /* in: max len , out: actual len */
_i8 *out_pText; _i8 *out_pText;
}_GetHostByServiceAsyncResponse_t; }_GetHostByServiceAsyncResponse_t;
@ -596,6 +599,9 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlGetHostByServiceMsg_u; }_SlGetHostByServiceMsg_u;
#if _SL_INCLUDE_FUNC(sl_NetAppDnsGetHostByService)
const _SlCmdCtrl_t _SlGetHostByServiceCtrl = const _SlCmdCtrl_t _SlGetHostByServiceCtrl =
{ {
SL_OPCODE_NETAPP_MDNSGETHOSTBYSERVICE, SL_OPCODE_NETAPP_MDNSGETHOSTBYSERVICE,
@ -603,14 +609,11 @@ const _SlCmdCtrl_t _SlGetHostByServiceCtrl =
sizeof(_BasicResponse_t) sizeof(_BasicResponse_t)
}; };
/******************************************************************************/ /******************************************************************************/
#if _SL_INCLUDE_FUNC(sl_NetAppDnsGetHostByService)
_i32 sl_NetAppDnsGetHostByService(_i8 *pServiceName, /* string containing all (or only part): name + subtype + service */ _i32 sl_NetAppDnsGetHostByService(_i8 *pServiceName, /* string containing all (or only part): name + subtype + service */
_u8 ServiceLen, const _u8 ServiceLen,
_u8 Family, /* 4-IPv4 , 16-IPv6 */ const _u8 Family, /* 4-IPv4 , 16-IPv6 */
_u32 pAddr[], _u32 pAddr[],
_u32 *pPort, _u32 *pPort,
_u16 *pTextLen, /* in: max len , out: actual len */ _u16 *pTextLen, /* in: max len , out: actual len */
@ -647,10 +650,10 @@ _i32 sl_NetAppDnsGetHostByService(_i8 *pServiceName, /* string containing all
/*Build the payload part of the command /*Build the payload part of the command
Copy the service name and text to one buffer.*/ Copy the service name and text to one buffer.*/
_SlDrvResetCmdExt(&CmdExt);
CmdExt.TxPayloadLen = ServiceLen; CmdExt.TxPayloadLen = ServiceLen;
CmdExt.RxPayloadLen = 0;
CmdExt.pTxPayload = (_u8 *)pServiceName; CmdExt.pTxPayload = (_u8 *)pServiceName;
CmdExt.pRxPayload = NULL;
/*set pointers to the output parameters (the returned parameters). /*set pointers to the output parameters (the returned parameters).
This pointers are belonged to local struct that is set to global Async response parameter. This pointers are belonged to local struct that is set to global Async response parameter.
@ -662,20 +665,14 @@ _i32 sl_NetAppDnsGetHostByService(_i8 *pServiceName, /* string containing all
AsyncRsp.out_pAddr = (_u32 *)pAddr; AsyncRsp.out_pAddr = (_u32 *)pAddr;
/*Use Obj to issue the command, if not available try later */ ObjIdx = _SlDrvProtectAsyncRespSetting((_u8*)&AsyncRsp, GETHOSYBYSERVICE_ID, SL_MAX_SOCKETS);
ObjIdx = (_u8)_SlDrvWaitForPoolObj(GETHOSYBYSERVICE_ID,SL_MAX_SOCKETS);
if (MAX_CONCURRENT_ACTIONS == ObjIdx) if (MAX_CONCURRENT_ACTIONS == ObjIdx)
{ {
return SL_POOL_IS_EMPTY; return SL_POOL_IS_EMPTY;
} }
OSI_RET_OK_CHECK(sl_LockObjLock(&g_pCB->ProtectionLockObj, SL_OS_WAIT_FOREVER));
g_pCB->ObjPool[ObjIdx].pRespArgs = (void *)&AsyncRsp;
OSI_RET_OK_CHECK(sl_LockObjUnlock(&g_pCB->ProtectionLockObj));
/* set bit to indicate IPv6 address is expected */
if (SL_AF_INET6 == Family) if (SL_AF_INET6 == Family)
{ {
g_pCB->ObjPool[ObjIdx].AdditionalData |= SL_NETAPP_FAMILY_MASK; g_pCB->ObjPool[ObjIdx].AdditionalData |= SL_NETAPP_FAMILY_MASK;
@ -688,7 +685,7 @@ _i32 sl_NetAppDnsGetHostByService(_i8 *pServiceName, /* string containing all
/* If the immediate reponse is O.K. than wait for aSYNC event response. */ /* If the immediate reponse is O.K. than wait for aSYNC event response. */
if(SL_RET_CODE_OK == Msg.Rsp.status) if(SL_RET_CODE_OK == Msg.Rsp.status)
{ {
OSI_RET_OK_CHECK(sl_SyncObjWait(&g_pCB->ObjPool[ObjIdx].SyncObj, SL_OS_WAIT_FOREVER)); _SlDrvSyncObjWaitForever(&g_pCB->ObjPool[ObjIdx].SyncObj);
/* If we are - it means that Async event was sent. /* If we are - it means that Async event was sent.
The results are copied in the Async handle return functions */ The results are copied in the Async handle return functions */
@ -700,6 +697,7 @@ _i32 sl_NetAppDnsGetHostByService(_i8 *pServiceName, /* string containing all
return Msg.Rsp.status; return Msg.Rsp.status;
} }
#endif #endif
/******************************************************************************/ /******************************************************************************/
/****************************************************************************** /******************************************************************************
@ -758,6 +756,7 @@ _i32 sl_NetAppDnsGetHostByService(_i8 *pServiceName, /* string containing all
******************************************************************************/ ******************************************************************************/
#ifndef SL_TINY_EXT
void _sl_HandleAsync_DnsGetHostByService(void *pVoidBuf) void _sl_HandleAsync_DnsGetHostByService(void *pVoidBuf)
{ {
@ -819,13 +818,11 @@ void _sl_HandleAsync_DnsGetHostByService(void *pVoidBuf)
/**************************************************************************************************/ /**************************************************************************************************/
OSI_RET_OK_CHECK(sl_SyncObjSignal(&g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].SyncObj)); _SlDrvSyncObjSignal(&g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].SyncObj);
return; return;
} }
} }
/*****************************************************************************/ /*****************************************************************************/
/* _sl_HandleAsync_DnsGetHostByAddr */ /* _sl_HandleAsync_DnsGetHostByAddr */
/*****************************************************************************/ /*****************************************************************************/
@ -834,6 +831,7 @@ void _sl_HandleAsync_DnsGetHostByAddr(void *pVoidBuf)
SL_TRACE0(DBG_MSG, MSG_303, "STUB: _sl_HandleAsync_DnsGetHostByAddr not implemented yet!"); SL_TRACE0(DBG_MSG, MSG_303, "STUB: _sl_HandleAsync_DnsGetHostByAddr not implemented yet!");
return; return;
} }
#endif
/*****************************************************************************/ /*****************************************************************************/
/* sl_DnsGetHostByName */ /* sl_DnsGetHostByName */
@ -850,24 +848,26 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlGetHostByNameMsg_u; }_SlGetHostByNameMsg_u;
#if _SL_INCLUDE_FUNC(sl_NetAppDnsGetHostByName)
const _SlCmdCtrl_t _SlGetHostByNameCtrl = const _SlCmdCtrl_t _SlGetHostByNameCtrl =
{ {
SL_OPCODE_NETAPP_DNSGETHOSTBYNAME, SL_OPCODE_NETAPP_DNSGETHOSTBYNAME,
sizeof(_GetHostByNameCommand_t), sizeof(_GetHostByNameCommand_t),
sizeof(_BasicResponse_t) sizeof(_BasicResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_NetAppDnsGetHostByName)
_i16 sl_NetAppDnsGetHostByName(_i8 * hostname, _u16 usNameLen, _u32* out_ip_addr,_u8 family) _i16 sl_NetAppDnsGetHostByName(_i8 * hostname,const _u16 usNameLen, _u32* out_ip_addr,const _u8 family)
{ {
_SlGetHostByNameMsg_u Msg; _SlGetHostByNameMsg_u Msg;
_SlCmdExt_t ExtCtrl; _SlCmdExt_t ExtCtrl;
_GetHostByNameAsyncResponse_u AsyncRsp; _GetHostByNameAsyncResponse_u AsyncRsp;
_u8 ObjIdx = MAX_CONCURRENT_ACTIONS; _u8 ObjIdx = MAX_CONCURRENT_ACTIONS;
_SlDrvResetCmdExt(&ExtCtrl);
ExtCtrl.TxPayloadLen = usNameLen; ExtCtrl.TxPayloadLen = usNameLen;
ExtCtrl.RxPayloadLen = 0;
ExtCtrl.pTxPayload = (_u8 *)hostname; ExtCtrl.pTxPayload = (_u8 *)hostname;
ExtCtrl.pRxPayload = 0;
Msg.Cmd.Len = usNameLen; Msg.Cmd.Len = usNameLen;
Msg.Cmd.family = family; Msg.Cmd.family = family;
@ -878,7 +878,8 @@ _i16 sl_NetAppDnsGetHostByName(_i8 * hostname, _u16 usNameLen, _u32* out_ip_add
{ {
return SL_POOL_IS_EMPTY; return SL_POOL_IS_EMPTY;
} }
OSI_RET_OK_CHECK(sl_LockObjLock(&g_pCB->ProtectionLockObj, SL_OS_WAIT_FOREVER));
_SlDrvProtectionObjLockWaitForever();
g_pCB->ObjPool[ObjIdx].pRespArgs = (_u8 *)&AsyncRsp; g_pCB->ObjPool[ObjIdx].pRespArgs = (_u8 *)&AsyncRsp;
/*set bit to indicate IPv6 address is expected */ /*set bit to indicate IPv6 address is expected */
@ -887,13 +888,14 @@ _i16 sl_NetAppDnsGetHostByName(_i8 * hostname, _u16 usNameLen, _u32* out_ip_add
g_pCB->ObjPool[ObjIdx].AdditionalData |= SL_NETAPP_FAMILY_MASK; g_pCB->ObjPool[ObjIdx].AdditionalData |= SL_NETAPP_FAMILY_MASK;
} }
OSI_RET_OK_CHECK(sl_LockObjUnlock(&g_pCB->ProtectionLockObj)); _SlDrvProtectionObjUnLock();
VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&_SlGetHostByNameCtrl, &Msg, &ExtCtrl)); VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&_SlGetHostByNameCtrl, &Msg, &ExtCtrl));
if(SL_RET_CODE_OK == Msg.Rsp.status) if(SL_RET_CODE_OK == Msg.Rsp.status)
{ {
OSI_RET_OK_CHECK(sl_SyncObjWait(&g_pCB->ObjPool[ObjIdx].SyncObj, SL_OS_WAIT_FOREVER)); _SlDrvSyncObjWaitForever(&g_pCB->ObjPool[ObjIdx].SyncObj);
Msg.Rsp.status = AsyncRsp.IpV4.status; Msg.Rsp.status = AsyncRsp.IpV4.status;
if(SL_OS_RET_CODE_OK == (_i16)Msg.Rsp.status) if(SL_OS_RET_CODE_OK == (_i16)Msg.Rsp.status)
@ -907,6 +909,8 @@ _i16 sl_NetAppDnsGetHostByName(_i8 * hostname, _u16 usNameLen, _u32* out_ip_add
return Msg.Rsp.status; return Msg.Rsp.status;
} }
#endif #endif
/******************************************************************************/ /******************************************************************************/
/* _sl_HandleAsync_DnsGetHostByName */ /* _sl_HandleAsync_DnsGetHostByName */
/******************************************************************************/ /******************************************************************************/
@ -914,7 +918,7 @@ void _sl_HandleAsync_DnsGetHostByName(void *pVoidBuf)
{ {
_GetHostByNameIPv4AsyncResponse_t *pMsgArgs = (_GetHostByNameIPv4AsyncResponse_t *)_SL_RESP_ARGS_START(pVoidBuf); _GetHostByNameIPv4AsyncResponse_t *pMsgArgs = (_GetHostByNameIPv4AsyncResponse_t *)_SL_RESP_ARGS_START(pVoidBuf);
OSI_RET_OK_CHECK(sl_LockObjLock(&g_pCB->ProtectionLockObj, SL_OS_WAIT_FOREVER)); _SlDrvProtectionObjLockWaitForever();
VERIFY_SOCKET_CB(NULL != g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs); VERIFY_SOCKET_CB(NULL != g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs);
@ -928,13 +932,13 @@ void _sl_HandleAsync_DnsGetHostByName(void *pVoidBuf)
{ {
sl_Memcpy(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs, pMsgArgs, sizeof(_GetHostByNameIPv4AsyncResponse_t)); sl_Memcpy(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs, pMsgArgs, sizeof(_GetHostByNameIPv4AsyncResponse_t));
} }
OSI_RET_OK_CHECK(sl_SyncObjSignal(&(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].SyncObj))); _SlDrvSyncObjSignal(&g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].SyncObj);
_SlDrvProtectionObjUnLock();
OSI_RET_OK_CHECK(sl_LockObjUnlock(&g_pCB->ProtectionLockObj));
return; return;
} }
#ifndef SL_TINY_EXT
void CopyPingResultsToReport(_PingReportResponse_t *pResults,SlPingReport_t *pReport) void CopyPingResultsToReport(_PingReportResponse_t *pResults,SlPingReport_t *pReport)
{ {
pReport->PacketsSent = pResults->numSendsPings; pReport->PacketsSent = pResults->numSendsPings;
@ -945,7 +949,6 @@ void CopyPingResultsToReport(_PingReportResponse_t *pResults,SlPingReport_t *pRe
pReport->TestTime = pResults->testTime; pReport->TestTime = pResults->testTime;
} }
/*****************************************************************************/ /*****************************************************************************/
/* _sl_HandleAsync_PingResponse */ /* _sl_HandleAsync_PingResponse */
/*****************************************************************************/ /*****************************************************************************/
@ -962,19 +965,20 @@ void _sl_HandleAsync_PingResponse(void *pVoidBuf)
else else
{ {
OSI_RET_OK_CHECK(sl_LockObjLock(&g_pCB->ProtectionLockObj, SL_OS_WAIT_FOREVER)); _SlDrvProtectionObjLockWaitForever();
VERIFY_SOCKET_CB(NULL != g_pCB->PingCB.PingAsync.pAsyncRsp); VERIFY_SOCKET_CB(NULL != g_pCB->PingCB.PingAsync.pAsyncRsp);
if (NULL != g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs) if (NULL != g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs)
{ {
sl_Memcpy(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs, pMsgArgs, sizeof(_PingReportResponse_t)); sl_Memcpy(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs, pMsgArgs, sizeof(_PingReportResponse_t));
OSI_RET_OK_CHECK(sl_SyncObjSignal(&g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].SyncObj)); _SlDrvSyncObjSignal(&g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].SyncObj);
} }
OSI_RET_OK_CHECK(sl_LockObjUnlock(&g_pCB->ProtectionLockObj)); _SlDrvProtectionObjUnLock();
} }
return; return;
} }
#endif
/*****************************************************************************/ /*****************************************************************************/
/* sl_PingStart */ /* sl_PingStart */
@ -994,15 +998,15 @@ typedef enum
#if _SL_INCLUDE_FUNC(sl_NetAppPingStart) #if _SL_INCLUDE_FUNC(sl_NetAppPingStart)
_i16 sl_NetAppPingStart(SlPingStartCommand_t* pPingParams,_u8 family,SlPingReport_t *pReport,const P_SL_DEV_PING_CALLBACK pPingCallback) _i16 sl_NetAppPingStart(const SlPingStartCommand_t* pPingParams,const _u8 family,SlPingReport_t *pReport,const P_SL_DEV_PING_CALLBACK pPingCallback)
{ {
_SlCmdCtrl_t CmdCtrl = {0, sizeof(_PingStartCommand_t), sizeof(_BasicResponse_t)}; _SlCmdCtrl_t CmdCtrl = {0, sizeof(_PingStartCommand_t), sizeof(_BasicResponse_t)};
_SlPingStartMsg_u Msg; _SlPingStartMsg_u Msg;
_PingReportResponse_t PingRsp; _PingReportResponse_t PingRsp;
_u8 ObjIdx = MAX_CONCURRENT_ACTIONS; _u8 ObjIdx = MAX_CONCURRENT_ACTIONS;
if( 0 == pPingParams->Ip ) // stop any ongoing ping if( 0 == pPingParams->Ip )
{ {/* stop any ongoing ping */
return _SlDrvBasicCmd(SL_OPCODE_NETAPP_PINGSTOP); return _SlDrvBasicCmd(SL_OPCODE_NETAPP_PINGSTOP);
} }
@ -1023,6 +1027,7 @@ _i16 sl_NetAppPingStart(SlPingStartCommand_t* pPingParams,_u8 family,SlPingRepor
Msg.Cmd.totalNumberOfAttempts = pPingParams->TotalNumberOfAttempts; Msg.Cmd.totalNumberOfAttempts = pPingParams->TotalNumberOfAttempts;
Msg.Cmd.flags = pPingParams->Flags; Msg.Cmd.flags = pPingParams->Flags;
if( pPingCallback ) if( pPingCallback )
{ {
pPingCallBackFunc = pPingCallback; pPingCallBackFunc = pPingCallback;
@ -1050,7 +1055,8 @@ _i16 sl_NetAppPingStart(SlPingStartCommand_t* pPingParams,_u8 family,SlPingRepor
/* block waiting for results if no callback function is used */ /* block waiting for results if no callback function is used */
if( NULL == pPingCallback ) if( NULL == pPingCallback )
{ {
OSI_RET_OK_CHECK(sl_SyncObjWait(&g_pCB->ObjPool[ObjIdx].SyncObj, SL_OS_WAIT_FOREVER)); _SlDrvSyncObjWaitForever(&g_pCB->ObjPool[ObjIdx].SyncObj);
if( SL_OS_RET_CODE_OK == (_i16)PingRsp.status ) if( SL_OS_RET_CODE_OK == (_i16)PingRsp.status )
{ {
CopyPingResultsToReport(&PingRsp,pReport); CopyPingResultsToReport(&PingRsp,pReport);
@ -1079,6 +1085,9 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlNetAppMsgSet_u; }_SlNetAppMsgSet_u;
#if _SL_INCLUDE_FUNC(sl_NetAppSet)
const _SlCmdCtrl_t _SlNetAppSetCmdCtrl = const _SlCmdCtrl_t _SlNetAppSetCmdCtrl =
{ {
SL_OPCODE_NETAPP_NETAPPSET, SL_OPCODE_NETAPP_NETAPPSET,
@ -1086,16 +1095,15 @@ const _SlCmdCtrl_t _SlNetAppSetCmdCtrl =
sizeof(_BasicResponse_t) sizeof(_BasicResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_NetAppSet) _i32 sl_NetAppSet(const _u8 AppId ,const _u8 Option,const _u8 OptionLen,const _u8 *pOptionValue)
_i32 sl_NetAppSet(_u8 AppId ,_u8 Option,_u8 OptionLen, _u8 *pOptionValue)
{ {
_SlNetAppMsgSet_u Msg; _SlNetAppMsgSet_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.TxPayloadLen = (OptionLen+3) & (~3); CmdExt.TxPayloadLen = (OptionLen+3) & (~3);
CmdExt.RxPayloadLen = 0;
CmdExt.pTxPayload = (_u8 *)pOptionValue; CmdExt.pTxPayload = (_u8 *)pOptionValue;
CmdExt.pRxPayload = NULL;
Msg.Cmd.AppId = AppId; Msg.Cmd.AppId = AppId;
@ -1117,6 +1125,9 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlNetAppMsgSendTokenValue_u; }_SlNetAppMsgSendTokenValue_u;
#if defined(sl_HttpServerCallback) || defined(EXT_LIB_REGISTERED_HTTP_SERVER_EVENTS)
const _SlCmdCtrl_t _SlNetAppSendTokenValueCmdCtrl = const _SlCmdCtrl_t _SlNetAppSendTokenValueCmdCtrl =
{ {
SL_OPCODE_NETAPP_HTTPSENDTOKENVALUE, SL_OPCODE_NETAPP_HTTPSENDTOKENVALUE,
@ -1124,7 +1135,7 @@ const _SlCmdCtrl_t _SlNetAppSendTokenValueCmdCtrl =
sizeof(_BasicResponse_t) sizeof(_BasicResponse_t)
}; };
_u16 sl_NetAppSendTokenValue(slHttpServerData_t * Token_value) _u16 _sl_NetAppSendTokenValue(slHttpServerData_t * Token_value)
{ {
_SlNetAppMsgSendTokenValue_u Msg; _SlNetAppMsgSendTokenValue_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
@ -1143,6 +1154,8 @@ _u16 sl_NetAppSendTokenValue(slHttpServerData_t * Token_value)
return Msg.Rsp.status; return Msg.Rsp.status;
} }
#endif
/*****************************************************************************/ /*****************************************************************************/
/* sl_NetAppGet */ /* sl_NetAppGet */
@ -1153,6 +1166,8 @@ typedef union
_NetAppSetGet_t Rsp; _NetAppSetGet_t Rsp;
}_SlNetAppMsgGet_u; }_SlNetAppMsgGet_u;
#if _SL_INCLUDE_FUNC(sl_NetAppGet)
const _SlCmdCtrl_t _SlNetAppGetCmdCtrl = const _SlCmdCtrl_t _SlNetAppGetCmdCtrl =
{ {
SL_OPCODE_NETAPP_NETAPPGET, SL_OPCODE_NETAPP_NETAPPGET,
@ -1160,8 +1175,7 @@ const _SlCmdCtrl_t _SlNetAppGetCmdCtrl =
sizeof(_NetAppSetGet_t) sizeof(_NetAppSetGet_t)
}; };
#if _SL_INCLUDE_FUNC(sl_NetAppGet) _i32 sl_NetAppGet(const _u8 AppId,const _u8 Option,_u8 *pOptionLen, _u8 *pOptionValue)
_i32 sl_NetAppGet(_u8 AppId, _u8 Option,_u8 *pOptionLen, _u8 *pOptionValue)
{ {
_SlNetAppMsgGet_u Msg; _SlNetAppMsgGet_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
@ -1170,11 +1184,10 @@ _i32 sl_NetAppGet(_u8 AppId, _u8 Option,_u8 *pOptionLen, _u8 *pOptionValue)
{ {
return SL_EZEROLEN; return SL_EZEROLEN;
} }
CmdExt.TxPayloadLen = 0;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.RxPayloadLen = *pOptionLen; CmdExt.RxPayloadLen = *pOptionLen;
CmdExt.pTxPayload = NULL;
CmdExt.pRxPayload = (_u8 *)pOptionValue; CmdExt.pRxPayload = (_u8 *)pOptionValue;
CmdExt.ActualRxPayloadLen = 0;
Msg.Cmd.AppId = AppId; Msg.Cmd.AppId = AppId;
Msg.Cmd.ConfigOpt = Option; Msg.Cmd.ConfigOpt = Option;
@ -1199,19 +1212,21 @@ _i32 sl_NetAppGet(_u8 AppId, _u8 Option,_u8 *pOptionLen, _u8 *pOptionValue)
/*****************************************************************************/ /*****************************************************************************/
/* _SlDrvNetAppEventHandler */ /* _SlDrvNetAppEventHandler */
/*****************************************************************************/ /*****************************************************************************/
void _SlDrvNetAppEventHandler(void *pArgs) void _SlDrvNetAppEventHandler(void* pArgs)
{ {
_SlResponseHeader_t *pHdr = (_SlResponseHeader_t *)pArgs; _SlResponseHeader_t *pHdr = (_SlResponseHeader_t *)pArgs;
#ifdef sl_HttpServerCallback #if defined(sl_HttpServerCallback) || defined(EXT_LIB_REGISTERED_HTTP_SERVER_EVENTS)
SlHttpServerEvent_t httpServerEvent; SlHttpServerEvent_t httpServerEvent;
SlHttpServerResponse_t httpServerResponse; SlHttpServerResponse_t httpServerResponse;
#endif #endif
switch(pHdr->GenHeader.Opcode) switch(pHdr->GenHeader.Opcode)
{ {
case SL_OPCODE_NETAPP_DNSGETHOSTBYNAMEASYNCRESPONSE: case SL_OPCODE_NETAPP_DNSGETHOSTBYNAMEASYNCRESPONSE:
case SL_OPCODE_NETAPP_DNSGETHOSTBYNAMEASYNCRESPONSE_V6: case SL_OPCODE_NETAPP_DNSGETHOSTBYNAMEASYNCRESPONSE_V6:
_sl_HandleAsync_DnsGetHostByName(pArgs); _sl_HandleAsync_DnsGetHostByName(pArgs);
break; break;
#ifndef SL_TINY_EXT
case SL_OPCODE_NETAPP_MDNSGETHOSTBYSERVICEASYNCRESPONSE: case SL_OPCODE_NETAPP_MDNSGETHOSTBYSERVICEASYNCRESPONSE:
case SL_OPCODE_NETAPP_MDNSGETHOSTBYSERVICEASYNCRESPONSE_V6: case SL_OPCODE_NETAPP_MDNSGETHOSTBYSERVICEASYNCRESPONSE_V6:
_sl_HandleAsync_DnsGetHostByService(pArgs); _sl_HandleAsync_DnsGetHostByService(pArgs);
@ -1219,9 +1234,11 @@ void _SlDrvNetAppEventHandler(void *pArgs)
case SL_OPCODE_NETAPP_PINGREPORTREQUESTRESPONSE: case SL_OPCODE_NETAPP_PINGREPORTREQUESTRESPONSE:
_sl_HandleAsync_PingResponse(pArgs); _sl_HandleAsync_PingResponse(pArgs);
break; break;
#endif
#if defined(sl_HttpServerCallback) || defined(EXT_LIB_REGISTERED_HTTP_SERVER_EVENTS)
case SL_OPCODE_NETAPP_HTTPGETTOKENVALUE: case SL_OPCODE_NETAPP_HTTPGETTOKENVALUE:
{ {
#ifdef sl_HttpServerCallback
_u8 *pTokenName; _u8 *pTokenName;
slHttpServerData_t Token_value; slHttpServerData_t Token_value;
sl_NetAppHttpServerGetToken_t *httpGetToken = (sl_NetAppHttpServerGetToken_t *)_SL_RESP_ARGS_START(pHdr); sl_NetAppHttpServerGetToken_t *httpGetToken = (sl_NetAppHttpServerGetToken_t *)_SL_RESP_ARGS_START(pHdr);
@ -1229,7 +1246,9 @@ void _SlDrvNetAppEventHandler(void *pArgs)
httpServerResponse.Response = SL_NETAPP_HTTPSETTOKENVALUE; httpServerResponse.Response = SL_NETAPP_HTTPSETTOKENVALUE;
httpServerResponse.ResponseData.token_value.len = MAX_TOKEN_VALUE_LEN; httpServerResponse.ResponseData.token_value.len = MAX_TOKEN_VALUE_LEN;
httpServerResponse.ResponseData.token_value.data = (_u8 *)_SL_RESP_ARGS_START(pHdr) + MAX_TOKEN_NAME_LEN; //Reuse the async buffer for getting the token value response from the user
/* Reuse the async buffer for getting the token value response from the user */
httpServerResponse.ResponseData.token_value.data = (_u8 *)_SL_RESP_ARGS_START(pHdr) + MAX_TOKEN_NAME_LEN;
httpServerEvent.Event = SL_NETAPP_HTTPGETTOKENVALUE_EVENT; httpServerEvent.Event = SL_NETAPP_HTTPGETTOKENVALUE_EVENT;
httpServerEvent.EventData.httpTokenName.len = httpGetToken->token_name_len; httpServerEvent.EventData.httpTokenName.len = httpGetToken->token_name_len;
@ -1237,22 +1256,19 @@ void _SlDrvNetAppEventHandler(void *pArgs)
Token_value.token_name = pTokenName; Token_value.token_name = pTokenName;
sl_HttpServerCallback (&httpServerEvent, &httpServerResponse); _SlDrvHandleHttpServerEvents (&httpServerEvent, &httpServerResponse);
Token_value.value_len = httpServerResponse.ResponseData.token_value.len; Token_value.value_len = httpServerResponse.ResponseData.token_value.len;
Token_value.name_len = httpServerEvent.EventData.httpTokenName.len; Token_value.name_len = httpServerEvent.EventData.httpTokenName.len;
Token_value.token_value = httpServerResponse.ResponseData.token_value.data; Token_value.token_value = httpServerResponse.ResponseData.token_value.data;
sl_NetAppSendTokenValue(&Token_value); _sl_NetAppSendTokenValue(&Token_value);
#endif
} }
break; break;
case SL_OPCODE_NETAPP_HTTPPOSTTOKENVALUE: case SL_OPCODE_NETAPP_HTTPPOSTTOKENVALUE:
{ {
#ifdef sl_HttpServerCallback
_u8 *pPostParams; _u8 *pPostParams;
sl_NetAppHttpServerPostToken_t *httpPostTokenArgs = (sl_NetAppHttpServerPostToken_t *)_SL_RESP_ARGS_START(pHdr); sl_NetAppHttpServerPostToken_t *httpPostTokenArgs = (sl_NetAppHttpServerPostToken_t *)_SL_RESP_ARGS_START(pHdr);
@ -1273,13 +1289,16 @@ void _SlDrvNetAppEventHandler(void *pArgs)
httpServerResponse.Response = SL_NETAPP_RESPONSE_NONE; httpServerResponse.Response = SL_NETAPP_RESPONSE_NONE;
_SlDrvHandleHttpServerEvents (&httpServerEvent, &httpServerResponse);
sl_HttpServerCallback (&httpServerEvent, &httpServerResponse);
#endif
} }
break; break;
#endif
default: default:
SL_ERROR_TRACE1(MSG_305, "ASSERT: _SlDrvNetAppEventHandler : invalid opcode = 0x%x", pHdr->GenHeader.Opcode); SL_ERROR_TRACE2(MSG_305, "ASSERT: _SlDrvNetAppEventHandler : invalid opcode = 0x%x = %1", pHdr->GenHeader.Opcode, pHdr->GenHeader.Opcode);
VERIFY_PROTOCOL(0); VERIFY_PROTOCOL(0);
} }
} }

View File

@ -52,6 +52,8 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlNetCfgMsgSet_u; }_SlNetCfgMsgSet_u;
#if _SL_INCLUDE_FUNC(sl_NetCfgSet)
const _SlCmdCtrl_t _SlNetCfgSetCmdCtrl = const _SlCmdCtrl_t _SlNetCfgSetCmdCtrl =
{ {
SL_OPCODE_DEVICE_NETCFG_SET_COMMAND, SL_OPCODE_DEVICE_NETCFG_SET_COMMAND,
@ -59,16 +61,15 @@ const _SlCmdCtrl_t _SlNetCfgSetCmdCtrl =
sizeof(_BasicResponse_t) sizeof(_BasicResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_NetCfgSet) _i32 sl_NetCfgSet(const _u8 ConfigId ,const _u8 ConfigOpt,const _u8 ConfigLen,const _u8 *pValues)
_i32 sl_NetCfgSet(_u8 ConfigId ,_u8 ConfigOpt,_u8 ConfigLen, _u8 *pValues)
{ {
_SlNetCfgMsgSet_u Msg; _SlNetCfgMsgSet_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.TxPayloadLen = (ConfigLen+3) & (~3); CmdExt.TxPayloadLen = (ConfigLen+3) & (~3);
CmdExt.RxPayloadLen = 0;
CmdExt.pTxPayload = (_u8 *)pValues; CmdExt.pTxPayload = (_u8 *)pValues;
CmdExt.pRxPayload = NULL;
Msg.Cmd.ConfigId = ConfigId; Msg.Cmd.ConfigId = ConfigId;
@ -91,6 +92,8 @@ typedef union
_NetCfgSetGet_t Rsp; _NetCfgSetGet_t Rsp;
}_SlNetCfgMsgGet_u; }_SlNetCfgMsgGet_u;
#if _SL_INCLUDE_FUNC(sl_NetCfgGet)
const _SlCmdCtrl_t _SlNetCfgGetCmdCtrl = const _SlCmdCtrl_t _SlNetCfgGetCmdCtrl =
{ {
SL_OPCODE_DEVICE_NETCFG_GET_COMMAND, SL_OPCODE_DEVICE_NETCFG_GET_COMMAND,
@ -98,8 +101,7 @@ const _SlCmdCtrl_t _SlNetCfgGetCmdCtrl =
sizeof(_NetCfgSetGet_t) sizeof(_NetCfgSetGet_t)
}; };
#if _SL_INCLUDE_FUNC(sl_NetCfgGet) _i32 sl_NetCfgGet(const _u8 ConfigId, _u8 *pConfigOpt,_u8 *pConfigLen, _u8 *pValues)
_i32 sl_NetCfgGet(_u8 ConfigId, _u8 *pConfigOpt,_u8 *pConfigLen, _u8 *pValues)
{ {
_SlNetCfgMsgGet_u Msg; _SlNetCfgMsgGet_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
@ -108,11 +110,10 @@ _i32 sl_NetCfgGet(_u8 ConfigId, _u8 *pConfigOpt,_u8 *pConfigLen, _u8 *pValues)
{ {
return SL_EZEROLEN; return SL_EZEROLEN;
} }
CmdExt.TxPayloadLen = 0;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.RxPayloadLen = *pConfigLen; CmdExt.RxPayloadLen = *pConfigLen;
CmdExt.pTxPayload = NULL;
CmdExt.pRxPayload = (_u8 *)pValues; CmdExt.pRxPayload = (_u8 *)pValues;
CmdExt.ActualRxPayloadLen = 0;
Msg.Cmd.ConfigLen = *pConfigLen; Msg.Cmd.ConfigLen = *pConfigLen;
Msg.Cmd.ConfigId = ConfigId; Msg.Cmd.ConfigId = ConfigId;
@ -129,8 +130,15 @@ _i32 sl_NetCfgGet(_u8 ConfigId, _u8 *pConfigOpt,_u8 *pConfigLen, _u8 *pValues)
if (CmdExt.RxPayloadLen < CmdExt.ActualRxPayloadLen) if (CmdExt.RxPayloadLen < CmdExt.ActualRxPayloadLen)
{ {
*pConfigLen = (_u8)CmdExt.RxPayloadLen; *pConfigLen = (_u8)CmdExt.RxPayloadLen;
if( SL_MAC_ADDRESS_GET == ConfigId )
{
return SL_RET_CODE_OK; /* sp fix */
}
else
{
return SL_ESMALLBUF; return SL_ESMALLBUF;
} }
}
else else
{ {
*pConfigLen = (_u8)CmdExt.ActualRxPayloadLen; *pConfigLen = (_u8)CmdExt.ActualRxPayloadLen;

View File

@ -47,7 +47,12 @@
#include "nonos.h" #include "nonos.h"
#ifndef SL_TINY_EXT
#define NONOS_MAX_SPAWN_ENTRIES 5 #define NONOS_MAX_SPAWN_ENTRIES 5
#else
#define NONOS_MAX_SPAWN_ENTRIES 1
#endif
typedef struct typedef struct
{ {
@ -71,6 +76,9 @@ _SlNonOsRetVal_t _SlNonOsSemSet(_SlNonOsSemObj_t* pSemObj , _SlNonOsSemObj_t Val
_SlNonOsRetVal_t _SlNonOsSemGet(_SlNonOsSemObj_t* pSyncObj, _SlNonOsSemObj_t WaitValue, _SlNonOsSemObj_t SetValue, _SlNonOsTime_t Timeout) _SlNonOsRetVal_t _SlNonOsSemGet(_SlNonOsSemObj_t* pSyncObj, _SlNonOsSemObj_t WaitValue, _SlNonOsSemObj_t SetValue, _SlNonOsTime_t Timeout)
{ {
#ifdef _SlSyncWaitLoopCallback
_SlNonOsTime_t timeOutRequest = Timeout;
#endif
while (Timeout>0) while (Timeout>0)
{ {
if (WaitValue == *pSyncObj) if (WaitValue == *pSyncObj)
@ -84,7 +92,7 @@ _SlNonOsRetVal_t _SlNonOsSemGet(_SlNonOsSemObj_t* pSyncObj, _SlNonOsSemObj_t Wai
} }
_SlNonOsMainLoopTask(); _SlNonOsMainLoopTask();
#ifdef _SlSyncWaitLoopCallback #ifdef _SlSyncWaitLoopCallback
if( __NON_OS_SYNC_OBJ_SIGNAL_VALUE == WaitValue ) if( (__NON_OS_SYNC_OBJ_SIGNAL_VALUE == WaitValue) && (timeOutRequest != NONOS_NO_WAIT) )
{ {
if (WaitValue == *pSyncObj) if (WaitValue == *pSyncObj)
{ {
@ -109,9 +117,11 @@ _SlNonOsRetVal_t _SlNonOsSemGet(_SlNonOsSemObj_t* pSyncObj, _SlNonOsSemObj_t Wai
_SlNonOsRetVal_t _SlNonOsSpawn(_SlSpawnEntryFunc_t pEntry , void* pValue , _u32 flags) _SlNonOsRetVal_t _SlNonOsSpawn(_SlSpawnEntryFunc_t pEntry , void* pValue , _u32 flags)
{ {
_i16 i; _i8 i = 0;
#ifndef SL_TINY_EXT
for (i=0 ; i<NONOS_MAX_SPAWN_ENTRIES ; i++) for (i=0 ; i<NONOS_MAX_SPAWN_ENTRIES ; i++)
#endif
{ {
_SlNonOsSpawnEntry_t* pE = &g__SlNonOsCB.SpawnEntries[i]; _SlNonOsSpawnEntry_t* pE = &g__SlNonOsCB.SpawnEntries[i];
@ -119,29 +129,36 @@ _SlNonOsRetVal_t _SlNonOsSpawn(_SlSpawnEntryFunc_t pEntry , void* pValue , _u32
{ {
pE->pValue = pValue; pE->pValue = pValue;
pE->pEntry = pEntry; pE->pEntry = pEntry;
#ifndef SL_TINY_EXT
break; break;
#endif
} }
} }
return NONOS_RET_OK; return NONOS_RET_OK;
} }
_SlNonOsRetVal_t _SlNonOsMainLoopTask(void) _SlNonOsRetVal_t _SlNonOsMainLoopTask(void)
{ {
_i16 i; _i8 i=0;
#ifndef SL_TINY_EXT
for (i=0 ; i<NONOS_MAX_SPAWN_ENTRIES ; i++) for (i=0 ; i<NONOS_MAX_SPAWN_ENTRIES ; i++)
#endif
{ {
_SlNonOsSpawnEntry_t* pE = &g__SlNonOsCB.SpawnEntries[i]; _SlNonOsSpawnEntry_t* pE = &g__SlNonOsCB.SpawnEntries[i];
_SlSpawnEntryFunc_t pF = pE->pEntry; _SlSpawnEntryFunc_t pF = pE->pEntry;
if (NULL != pF) if (NULL != pF)
{ {
if((g_pCB)->RxIrqCnt != (g_pCB)->RxDoneCnt) if(RxIrqCnt != (g_pCB)->RxDoneCnt)
{ {
pF(0);/*(pValue);*/ pF(0); /* (pValue) */
} }
pE->pEntry = NULL; pE->pEntry = NULL;
pE->pValue = NULL; pE->pValue = NULL;
} }
@ -150,4 +167,5 @@ _SlNonOsRetVal_t _SlNonOsMainLoopTask(void)
return NONOS_RET_OK; return NONOS_RET_OK;
} }
#endif /*(SL_PLATFORM != SL_PLATFORM_NON_OS)*/ #endif /*(SL_PLATFORM != SL_PLATFORM_NON_OS)*/

View File

@ -45,29 +45,57 @@
#include "driver.h" #include "driver.h"
/*******************************************************************************/ void _sl_BuildAddress(const SlSockAddr_t *addr, _SocketAddrCommand_u *pCmd);
/* Functions prototypes */
/*******************************************************************************/
void _sl_BuildAddress(const SlSockAddr_t *addr, _i16 addrlen, _SocketAddrCommand_u *pCmd);
void _sl_ParseAddress(_SocketAddrResponse_u *pRsp, SlSockAddr_t *addr, SlSocklen_t *addrlen);
void _sl_HandleAsync_Connect(void *pVoidBuf); void _sl_HandleAsync_Connect(void *pVoidBuf);
#ifndef SL_TINY_EXT
void _sl_ParseAddress(_SocketAddrResponse_u *pRsp, SlSockAddr_t *addr, SlSocklen_t *addrlen);
void _sl_HandleAsync_Accept(void *pVoidBuf); void _sl_HandleAsync_Accept(void *pVoidBuf);
void _sl_HandleAsync_Select(void *pVoidBuf); void _sl_HandleAsync_Select(void *pVoidBuf);
_u16 _sl_TruncatePayloadByProtocol(const _i16 pSd,const _u16 length); #endif
_u16 _sl_TruncatePayloadByProtocol(const _i16 pSd, const _u16 length);
/*******************************************************************************/ /*******************************************************************************/
/* Functions */ /* Functions */
/*******************************************************************************/ /*******************************************************************************/
/* ******************************************************************************/
/* _sl_BuildAddress */
/* ******************************************************************************/
void _sl_BuildAddress(const SlSockAddr_t *addr, _i16 addrlen, _SocketAddrCommand_u *pCmd)
{
/* Note: parsing of family and port in the generic way for all IPV4, IPV6 and EUI48 */ /* Note: parsing of family and port in the generic way for all IPV4, IPV6 and EUI48 */
/* is possible as _i32 as these parameters are in the same offset and size for these */ /* is possible as _i32 as these parameters are in the same offset and size for these */
/* three families. */ /* three families. */
#define SL_SOCKET_PAYLOAD_BASE (1350)
const _u8 _SlPayloadByProtocolLUT[16] =
{
(1472 - SL_SOCKET_PAYLOAD_BASE), /* SL_SOCKET_PAYLOAD_TYPE_UDP_IPV4 */
(1460 - SL_SOCKET_PAYLOAD_BASE), /* SL_SOCKET_PAYLOAD_TYPE_TCP_IPV4 */
(1452 - SL_SOCKET_PAYLOAD_BASE), /* SL_SOCKET_PAYLOAD_TYPE_UDP_IPV6 */
(1440 - SL_SOCKET_PAYLOAD_BASE), /* SL_SOCKET_PAYLOAD_TYPE_TCP_IPV6 */
(1386 - SL_SOCKET_PAYLOAD_BASE), /* SL_SOCKET_PAYLOAD_TYPE_TCP_IPV4_SECURE */
(1386 - SL_SOCKET_PAYLOAD_BASE), /* SL_SOCKET_PAYLOAD_TYPE_UDP_IPV4_SECURE */
(1396 - SL_SOCKET_PAYLOAD_BASE), /* SL_SOCKET_PAYLOAD_TYPE_UDP_IPV6_SECURE */
(1396 - SL_SOCKET_PAYLOAD_BASE), /* SL_SOCKET_PAYLOAD_TYPE_TCP_IPV6_SECURE */
(1476 - SL_SOCKET_PAYLOAD_BASE), /* SL_SOCKET_PAYLOAD_TYPE_RAW_TRANCEIVER */
(1514 - SL_SOCKET_PAYLOAD_BASE), /* SL_SOCKET_PAYLOAD_TYPE_RAW_PACKET */
(1480 - SL_SOCKET_PAYLOAD_BASE), /* SL_SOCKET_PAYLOAD_TYPE_RAW_IP4 */
(1480 - SL_SOCKET_PAYLOAD_BASE), /* SL_SOCKET_PAYLOAD_TYPE_RAW_IP6 */
(1440 - SL_SOCKET_PAYLOAD_BASE), /* Default */
(1440 - SL_SOCKET_PAYLOAD_BASE), /* Default */
(1440 - SL_SOCKET_PAYLOAD_BASE), /* Default */
(1440 - SL_SOCKET_PAYLOAD_BASE) /* Default */
};
/* ******************************************************************************/
/* _sl_BuildAddress */
/* ******************************************************************************/
void _sl_BuildAddress(const SlSockAddr_t *addr, _SocketAddrCommand_u *pCmd)
{
/* Note: parsing of family and port in the generic way for all IPV4, IPV6 and EUI48
is possible as long as these parameters are in the same offset and size for these
three families. */
pCmd->IpV4.FamilyAndFlags = (addr->sa_family << 4) & 0xF0; pCmd->IpV4.FamilyAndFlags = (addr->sa_family << 4) & 0xF0;
pCmd->IpV4.port = ((SlSockAddrIn_t *)addr)->sin_port; pCmd->IpV4.port = ((SlSockAddrIn_t *)addr)->sin_port;
@ -87,51 +115,18 @@ void _sl_BuildAddress(const SlSockAddr_t *addr, _i16 addrlen, _SocketAddrCommand
#endif #endif
} }
/* ******************************************************************************/
/* _sl_TruncatePayloadByProtocol */ /*****************************************************************************
/* ******************************************************************************/ _sl_TruncatePayloadByProtocol
_u16 _sl_TruncatePayloadByProtocol(const _i16 sd,const _u16 length) *****************************************************************************/
_u16 _sl_TruncatePayloadByProtocol(const _i16 sd, const _u16 length)
{ {
_u16 maxLength; unsigned int maxLength;
switch(sd & SL_SOCKET_PAYLOAD_TYPE_MASK)
{
case SL_SOCKET_PAYLOAD_TYPE_UDP_IPV4:
maxLength = 1472;
break;
case SL_SOCKET_PAYLOAD_TYPE_TCP_IPV4: maxLength = SL_SOCKET_PAYLOAD_BASE + _SlPayloadByProtocolLUT[((sd & SL_SOCKET_PAYLOAD_TYPE_MASK) >> 4)];
maxLength = 1460;
break;
case SL_SOCKET_PAYLOAD_TYPE_UDP_IPV6:
maxLength = 1452;
break;
case SL_SOCKET_PAYLOAD_TYPE_TCP_IPV6:
maxLength = 1440;
break;
case SL_SOCKET_PAYLOAD_TYPE_TCP_IPV4_SECURE:
case SL_SOCKET_PAYLOAD_TYPE_UDP_IPV4_SECURE:
maxLength = 1402;
break;
case SL_SOCKET_PAYLOAD_TYPE_UDP_IPV6_SECURE:
case SL_SOCKET_PAYLOAD_TYPE_TCP_IPV6_SECURE:
maxLength = 1396;
break;
case SL_SOCKET_PAYLOAD_TYPE_RAW_TRANCEIVER:
maxLength = 1476;
break;
case SL_SOCKET_PAYLOAD_TYPE_RAW_PACKET:
maxLength = 1514;
break;
case SL_SOCKET_PAYLOAD_TYPE_RAW_IP4:
maxLength = 1480;
break;
default:
maxLength = 1440;
break;
}
if( length > maxLength ) if( length > maxLength )
{ {
@ -146,6 +141,8 @@ _u16 _sl_TruncatePayloadByProtocol(const _i16 sd,const _u16 length)
/*******************************************************************************/ /*******************************************************************************/
/* _sl_ParseAddress */ /* _sl_ParseAddress */
/*******************************************************************************/ /*******************************************************************************/
#ifndef SL_TINY_EXT
void _sl_ParseAddress(_SocketAddrResponse_u *pRsp, SlSockAddr_t *addr, SlSocklen_t *addrlen) void _sl_ParseAddress(_SocketAddrResponse_u *pRsp, SlSockAddr_t *addr, SlSocklen_t *addrlen)
{ {
/* Note: parsing of family and port in the generic way for all IPV4, IPV6 and EUI48 */ /* Note: parsing of family and port in the generic way for all IPV4, IPV6 and EUI48 */
@ -172,6 +169,8 @@ void _sl_ParseAddress(_SocketAddrResponse_u *pRsp, SlSockAddr_t *addr, SlSock
#endif #endif
} }
#endif
/*******************************************************************************/ /*******************************************************************************/
/* sl_Socket */ /* sl_Socket */
/*******************************************************************************/ /*******************************************************************************/
@ -182,6 +181,10 @@ typedef union
_SocketResponse_t Rsp; _SocketResponse_t Rsp;
}_SlSockSocketMsg_u; }_SlSockSocketMsg_u;
#if _SL_INCLUDE_FUNC(sl_Socket)
const _SlCmdCtrl_t _SlSockSocketCmdCtrl = const _SlCmdCtrl_t _SlSockSocketCmdCtrl =
{ {
SL_OPCODE_SOCKET_SOCKET, SL_OPCODE_SOCKET_SOCKET,
@ -189,7 +192,6 @@ const _SlCmdCtrl_t _SlSockSocketCmdCtrl =
sizeof(_SocketResponse_t) sizeof(_SocketResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_Socket)
_i16 sl_Socket(_i16 Domain, _i16 Type, _i16 Protocol) _i16 sl_Socket(_i16 Domain, _i16 Type, _i16 Protocol)
{ {
_SlSockSocketMsg_u Msg; _SlSockSocketMsg_u Msg;
@ -220,6 +222,9 @@ typedef union
_SocketResponse_t Rsp; _SocketResponse_t Rsp;
}_SlSockCloseMsg_u; }_SlSockCloseMsg_u;
#if _SL_INCLUDE_FUNC(sl_Close)
const _SlCmdCtrl_t _SlSockCloseCmdCtrl = const _SlCmdCtrl_t _SlSockCloseCmdCtrl =
{ {
SL_OPCODE_SOCKET_CLOSE, SL_OPCODE_SOCKET_CLOSE,
@ -227,7 +232,6 @@ const _SlCmdCtrl_t _SlSockCloseCmdCtrl =
sizeof(_SocketResponse_t) sizeof(_SocketResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_Close)
_i16 sl_Close(_i16 sd) _i16 sl_Close(_i16 sd)
{ {
_SlSockCloseMsg_u Msg; _SlSockCloseMsg_u Msg;
@ -261,16 +265,21 @@ _i16 sl_Bind(_i16 sd, const SlSockAddr_t *addr, _i16 addrlen)
CmdCtrl.Opcode = SL_OPCODE_SOCKET_BIND; CmdCtrl.Opcode = SL_OPCODE_SOCKET_BIND;
CmdCtrl.TxDescLen = sizeof(_SocketAddrIPv4Command_t); CmdCtrl.TxDescLen = sizeof(_SocketAddrIPv4Command_t);
break; break;
#ifndef SL_TINY_EXT
case SL_AF_INET6_EUI_48: case SL_AF_INET6_EUI_48:
CmdCtrl.Opcode = SL_OPCODE_SOCKET_BIND_V6; CmdCtrl.Opcode = SL_OPCODE_SOCKET_BIND_V6;
CmdCtrl.TxDescLen = sizeof(_SocketAddrIPv6EUI48Command_t); CmdCtrl.TxDescLen = sizeof(_SocketAddrIPv6EUI48Command_t);
break; break;
#ifdef SL_SUPPORT_IPV6 #ifdef SL_SUPPORT_IPV6
case AF_INET6: case AF_INET6:
CmdCtrl.Opcode = SL_OPCODE_SOCKET_BIND_V6; CmdCtrl.Opcode = SL_OPCODE_SOCKET_BIND_V6;
CmdCtrl.TxDescLen = sizeof(_SocketAddrIPv6Command_t); CmdCtrl.TxDescLen = sizeof(_SocketAddrIPv6Command_t);
break; break;
#endif #endif
#endif
case SL_AF_RF : case SL_AF_RF :
default: default:
return SL_RET_CODE_INVALID_INPUT; return SL_RET_CODE_INVALID_INPUT;
@ -279,7 +288,7 @@ _i16 sl_Bind(_i16 sd, const SlSockAddr_t *addr, _i16 addrlen)
Msg.Cmd.IpV4.lenOrPadding = 0; Msg.Cmd.IpV4.lenOrPadding = 0;
Msg.Cmd.IpV4.sd = (_u8)sd; Msg.Cmd.IpV4.sd = (_u8)sd;
_sl_BuildAddress(addr, addrlen, &Msg.Cmd); _sl_BuildAddress(addr, &Msg.Cmd);
VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&CmdCtrl, &Msg, NULL)); VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&CmdCtrl, &Msg, NULL));
@ -305,11 +314,9 @@ _i16 sl_SendTo(_i16 sd, const void *pBuf, _i16 Len, _i16 flags, const SlSockAddr
_u16 ChunkLen; _u16 ChunkLen;
_i16 RetVal; _i16 RetVal;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.TxPayloadLen = (_u16)Len; CmdExt.TxPayloadLen = (_u16)Len;
CmdExt.RxPayloadLen = 0;
CmdExt.pTxPayload = (_u8 *)pBuf; CmdExt.pTxPayload = (_u8 *)pBuf;
CmdExt.pRxPayload = NULL;
switch(to->sa_family) switch(to->sa_family)
{ {
@ -317,6 +324,7 @@ _i16 sl_SendTo(_i16 sd, const void *pBuf, _i16 Len, _i16 flags, const SlSockAddr
CmdCtrl.Opcode = SL_OPCODE_SOCKET_SENDTO; CmdCtrl.Opcode = SL_OPCODE_SOCKET_SENDTO;
CmdCtrl.TxDescLen = sizeof(_SocketAddrIPv4Command_t); CmdCtrl.TxDescLen = sizeof(_SocketAddrIPv4Command_t);
break; break;
#ifndef SL_TINY_EXT
case SL_AF_INET6_EUI_48: case SL_AF_INET6_EUI_48:
CmdCtrl.Opcode = SL_OPCODE_SOCKET_BIND_V6; CmdCtrl.Opcode = SL_OPCODE_SOCKET_BIND_V6;
CmdCtrl.TxDescLen = sizeof(_SocketAddrIPv6EUI48Command_t); CmdCtrl.TxDescLen = sizeof(_SocketAddrIPv6EUI48Command_t);
@ -326,6 +334,7 @@ _i16 sl_SendTo(_i16 sd, const void *pBuf, _i16 Len, _i16 flags, const SlSockAddr
CmdCtrl.Opcode = SL_OPCODE_SOCKET_SENDTO_V6; CmdCtrl.Opcode = SL_OPCODE_SOCKET_SENDTO_V6;
CmdCtrl.TxDescLen = sizeof(_SocketAddrIPv6Command_t); CmdCtrl.TxDescLen = sizeof(_SocketAddrIPv6Command_t);
break; break;
#endif
#endif #endif
case SL_AF_RF: case SL_AF_RF:
default: default:
@ -338,7 +347,7 @@ _i16 sl_SendTo(_i16 sd, const void *pBuf, _i16 Len, _i16 flags, const SlSockAddr
Msg.Cmd.IpV4.sd = (_u8)sd; Msg.Cmd.IpV4.sd = (_u8)sd;
_sl_BuildAddress(to, tolen, &Msg.Cmd); _sl_BuildAddress(to, &Msg.Cmd);
Msg.Cmd.IpV4.FamilyAndFlags |= flags & 0x0F; Msg.Cmd.IpV4.FamilyAndFlags |= flags & 0x0F;
@ -380,6 +389,8 @@ const _SlCmdCtrl_t _SlRecvfomCmdCtrl =
sizeof(_SocketAddrResponse_u) sizeof(_SocketAddrResponse_u)
}; };
#if _SL_INCLUDE_FUNC(sl_RecvFrom) #if _SL_INCLUDE_FUNC(sl_RecvFrom)
_i16 sl_RecvFrom(_i16 sd, void *buf, _i16 Len, _i16 flags, SlSockAddr_t *from, SlSocklen_t *fromlen) _i16 sl_RecvFrom(_i16 sd, void *buf, _i16 Len, _i16 flags, SlSockAddr_t *from, SlSocklen_t *fromlen)
{ {
@ -387,33 +398,33 @@ _i16 sl_RecvFrom(_i16 sd, void *buf, _i16 Len, _i16 flags, SlSockAddr_t *from, S
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
_i16 RetVal; _i16 RetVal;
CmdExt.TxPayloadLen = 0;
CmdExt.RxPayloadLen = Len;
CmdExt.pTxPayload = NULL;
CmdExt.pRxPayload = (_u8 *)buf;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.RxPayloadLen = Len;
CmdExt.pRxPayload = (_u8 *)buf;
Msg.Cmd.sd = (_u8)sd; Msg.Cmd.sd = (_u8)sd;
Msg.Cmd.StatusOrLen = Len; Msg.Cmd.StatusOrLen = Len;
/* no size truncation in recv path */ /* no size truncation in recv path */
CmdExt.RxPayloadLen = Msg.Cmd.StatusOrLen; CmdExt.RxPayloadLen = Msg.Cmd.StatusOrLen;
Msg.Cmd.FamilyAndFlags = flags & 0x0F;
if(sizeof(SlSockAddrIn_t) == *fromlen) if(sizeof(SlSockAddrIn_t) == *fromlen)
{ {
Msg.Cmd.FamilyAndFlags = SL_AF_INET; Msg.Cmd.FamilyAndFlags |= (SL_AF_INET << 4);
} }
else if (sizeof(SlSockAddrIn6_t) == *fromlen) else if (sizeof(SlSockAddrIn6_t) == *fromlen)
{ {
Msg.Cmd.FamilyAndFlags = SL_AF_INET6; Msg.Cmd.FamilyAndFlags |= (SL_AF_INET6 << 4);
} }
else else
{ {
return SL_RET_CODE_INVALID_INPUT; return SL_RET_CODE_INVALID_INPUT;
} }
Msg.Cmd.FamilyAndFlags = (Msg.Cmd.FamilyAndFlags << 4) & 0xF0;
Msg.Cmd.FamilyAndFlags |= flags & 0x0F;
RetVal = _SlDrvDataReadOp((_SlSd_t)sd, (_SlCmdCtrl_t *)&_SlRecvfomCmdCtrl, &Msg, &CmdExt); RetVal = _SlDrvDataReadOp((_SlSd_t)sd, (_SlCmdCtrl_t *)&_SlRecvfomCmdCtrl, &Msg, &CmdExt);
if( RetVal != SL_OS_RET_CODE_OK ) if( RetVal != SL_OS_RET_CODE_OK )
{ {
@ -481,6 +492,7 @@ _i16 sl_Connect(_i16 sd, const SlSockAddr_t *addr, _i16 addrlen)
case SL_AF_INET : case SL_AF_INET :
CmdCtrl.Opcode = SL_OPCODE_SOCKET_CONNECT; CmdCtrl.Opcode = SL_OPCODE_SOCKET_CONNECT;
CmdCtrl.TxDescLen = sizeof(_SocketAddrIPv4Command_t); CmdCtrl.TxDescLen = sizeof(_SocketAddrIPv4Command_t);
/* Do nothing - cmd already initialized to this type */
break; break;
case SL_AF_INET6_EUI_48: case SL_AF_INET6_EUI_48:
CmdCtrl.Opcode = SL_OPCODE_SOCKET_CONNECT_V6; CmdCtrl.Opcode = SL_OPCODE_SOCKET_CONNECT_V6;
@ -492,7 +504,7 @@ _i16 sl_Connect(_i16 sd, const SlSockAddr_t *addr, _i16 addrlen)
CmdCtrl.TxDescLen = sizeof(_SocketAddrIPv6Command_t); CmdCtrl.TxDescLen = sizeof(_SocketAddrIPv6Command_t);
break; break;
#endif #endif
case SL_AF_RF : case SL_AF_RF:
default: default:
return SL_RET_CODE_INVALID_INPUT; return SL_RET_CODE_INVALID_INPUT;
} }
@ -500,20 +512,15 @@ _i16 sl_Connect(_i16 sd, const SlSockAddr_t *addr, _i16 addrlen)
Msg.Cmd.IpV4.lenOrPadding = 0; Msg.Cmd.IpV4.lenOrPadding = 0;
Msg.Cmd.IpV4.sd = (_u8)sd; Msg.Cmd.IpV4.sd = (_u8)sd;
_sl_BuildAddress(addr, addrlen, &Msg.Cmd); _sl_BuildAddress(addr, &Msg.Cmd);
/* Use Obj to issue the command, if not available try later */
ObjIdx = (_u8)_SlDrvWaitForPoolObj(CONNECT_ID, (_u8)(sd & BSD_SOCKET_ID_MASK)); ObjIdx = _SlDrvProtectAsyncRespSetting((_u8*)&AsyncRsp, CONNECT_ID, sd & BSD_SOCKET_ID_MASK);
if (MAX_CONCURRENT_ACTIONS == ObjIdx) if (MAX_CONCURRENT_ACTIONS == ObjIdx)
{ {
return SL_POOL_IS_EMPTY; return SL_POOL_IS_EMPTY;
} }
OSI_RET_OK_CHECK(sl_LockObjLock(&g_pCB->ProtectionLockObj, SL_OS_WAIT_FOREVER));
g_pCB->ObjPool[ObjIdx].pRespArgs = (_u8 *)&AsyncRsp;
OSI_RET_OK_CHECK(sl_LockObjUnlock(&g_pCB->ProtectionLockObj));
/* send the command */ /* send the command */
VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&CmdCtrl, &Msg, NULL)); VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&CmdCtrl, &Msg, NULL));
@ -524,17 +531,22 @@ _i16 sl_Connect(_i16 sd, const SlSockAddr_t *addr, _i16 addrlen)
if(SL_RET_CODE_OK == RetVal) if(SL_RET_CODE_OK == RetVal)
{ {
/* wait for async and get Data Read parameters */ /* wait for async and get Data Read parameters */
OSI_RET_OK_CHECK(sl_SyncObjWait(&g_pCB->ObjPool[ObjIdx].SyncObj, SL_OS_WAIT_FOREVER)); _SlDrvSyncObjWaitForever(&g_pCB->ObjPool[ObjIdx].SyncObj);
VERIFY_PROTOCOL(AsyncRsp.sd == sd); VERIFY_PROTOCOL(AsyncRsp.sd == sd);
RetVal = AsyncRsp.statusOrLen; RetVal = AsyncRsp.statusOrLen;
} }
_SlDrvReleasePoolObj(ObjIdx); _SlDrvReleasePoolObj(ObjIdx);
return RetVal; return RetVal;
} }
#endif #endif
/*******************************************************************************/ /*******************************************************************************/
/* _sl_HandleAsync_Connect */ /* _sl_HandleAsync_Connect */
/*******************************************************************************/ /*******************************************************************************/
@ -542,16 +554,18 @@ void _sl_HandleAsync_Connect(void *pVoidBuf)
{ {
_SocketResponse_t *pMsgArgs = (_SocketResponse_t *)_SL_RESP_ARGS_START(pVoidBuf); _SocketResponse_t *pMsgArgs = (_SocketResponse_t *)_SL_RESP_ARGS_START(pVoidBuf);
OSI_RET_OK_CHECK(sl_LockObjLock(&g_pCB->ProtectionLockObj, SL_OS_WAIT_FOREVER)); _SlDrvProtectionObjLockWaitForever();
VERIFY_PROTOCOL((pMsgArgs->sd & BSD_SOCKET_ID_MASK) <= SL_MAX_SOCKETS); VERIFY_PROTOCOL((pMsgArgs->sd & BSD_SOCKET_ID_MASK) <= SL_MAX_SOCKETS);
VERIFY_SOCKET_CB(NULL != g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs); VERIFY_SOCKET_CB(NULL != g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs);
((_SocketResponse_t *)(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs))->sd = pMsgArgs->sd; ((_SocketResponse_t *)(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs))->sd = pMsgArgs->sd;
((_SocketResponse_t *)(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs))->statusOrLen = pMsgArgs->statusOrLen; ((_SocketResponse_t *)(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs))->statusOrLen = pMsgArgs->statusOrLen;
OSI_RET_OK_CHECK(sl_SyncObjSignal(&g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].SyncObj));
OSI_RET_OK_CHECK(sl_LockObjUnlock(&g_pCB->ProtectionLockObj)); _SlDrvSyncObjSignal(&g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].SyncObj);
_SlDrvProtectionObjUnLock();
return; return;
} }
@ -581,8 +595,8 @@ _i16 sl_Send(_i16 sd, const void *pBuf, _i16 Len, _i16 flags)
_u32 tempVal; _u32 tempVal;
_u8 runSingleChunk = FALSE; _u8 runSingleChunk = FALSE;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.TxPayloadLen = Len; CmdExt.TxPayloadLen = Len;
CmdExt.RxPayloadLen = 0;
CmdExt.pTxPayload = (_u8 *)pBuf; CmdExt.pTxPayload = (_u8 *)pBuf;
/* Only for RAW transceiver type socket, relay the flags parameter in the 2 bytes (4 byte aligned) before the actual payload */ /* Only for RAW transceiver type socket, relay the flags parameter in the 2 bytes (4 byte aligned) before the actual payload */
@ -590,8 +604,7 @@ _i16 sl_Send(_i16 sd, const void *pBuf, _i16 Len, _i16 flags)
{ {
tempVal = flags; tempVal = flags;
CmdExt.pRxPayload = (_u8 *)&tempVal; CmdExt.pRxPayload = (_u8 *)&tempVal;
CmdExt.RxPayloadLen = 4; CmdExt.RxPayloadLen = -4; /* mark as Rx data to send */
g_pCB->RelayFlagsViaRxPayload = TRUE;
runSingleChunk = TRUE; runSingleChunk = TRUE;
} }
else else
@ -601,7 +614,6 @@ _i16 sl_Send(_i16 sd, const void *pBuf, _i16 Len, _i16 flags)
ChunkLen = _sl_TruncatePayloadByProtocol(sd,Len); ChunkLen = _sl_TruncatePayloadByProtocol(sd,Len);
CmdExt.TxPayloadLen = ChunkLen; CmdExt.TxPayloadLen = ChunkLen;
Msg.Cmd.StatusOrLen = ChunkLen; Msg.Cmd.StatusOrLen = ChunkLen;
Msg.Cmd.sd = (_u8)sd; Msg.Cmd.sd = (_u8)sd;
Msg.Cmd.FamilyAndFlags |= flags & 0x0F; Msg.Cmd.FamilyAndFlags |= flags & 0x0F;
@ -636,6 +648,10 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlListenMsg_u; }_SlListenMsg_u;
#if _SL_INCLUDE_FUNC(sl_Listen)
const _SlCmdCtrl_t _SlListenCmdCtrl = const _SlCmdCtrl_t _SlListenCmdCtrl =
{ {
SL_OPCODE_SOCKET_LISTEN, SL_OPCODE_SOCKET_LISTEN,
@ -643,7 +659,6 @@ const _SlCmdCtrl_t _SlListenCmdCtrl =
sizeof(_BasicResponse_t), sizeof(_BasicResponse_t),
}; };
#if _SL_INCLUDE_FUNC(sl_Listen)
_i16 sl_Listen(_i16 sd, _i16 backlog) _i16 sl_Listen(_i16 sd, _i16 backlog)
{ {
_SlListenMsg_u Msg; _SlListenMsg_u Msg;
@ -666,6 +681,10 @@ typedef union
_SocketResponse_t Rsp; _SocketResponse_t Rsp;
}_SlSockAcceptMsg_u; }_SlSockAcceptMsg_u;
#if _SL_INCLUDE_FUNC(sl_Accept)
const _SlCmdCtrl_t _SlAcceptCmdCtrl = const _SlCmdCtrl_t _SlAcceptCmdCtrl =
{ {
SL_OPCODE_SOCKET_ACCEPT, SL_OPCODE_SOCKET_ACCEPT,
@ -673,7 +692,6 @@ const _SlCmdCtrl_t _SlAcceptCmdCtrl =
sizeof(_BasicResponse_t), sizeof(_BasicResponse_t),
}; };
#if _SL_INCLUDE_FUNC(sl_Accept)
_i16 sl_Accept(_i16 sd, SlSockAddr_t *addr, SlSocklen_t *addrlen) _i16 sl_Accept(_i16 sd, SlSockAddr_t *addr, SlSocklen_t *addrlen)
{ {
_SlSockAcceptMsg_u Msg; _SlSockAcceptMsg_u Msg;
@ -686,19 +704,14 @@ _i16 sl_Accept(_i16 sd, SlSockAddr_t *addr, SlSocklen_t *addrlen)
Msg.Cmd.sd = (_u8)sd; Msg.Cmd.sd = (_u8)sd;
Msg.Cmd.family = (sizeof(SlSockAddrIn_t) == *addrlen) ? SL_AF_INET : SL_AF_INET6; Msg.Cmd.family = (sizeof(SlSockAddrIn_t) == *addrlen) ? SL_AF_INET : SL_AF_INET6;
/* Use Obj to issue the command, if not available try later */
ObjIdx = (_u8)_SlDrvWaitForPoolObj(ACCEPT_ID, (_u8)(sd & BSD_SOCKET_ID_MASK)); ObjIdx = _SlDrvProtectAsyncRespSetting((_u8*)&AsyncRsp, ACCEPT_ID, sd & BSD_SOCKET_ID_MASK );
if (MAX_CONCURRENT_ACTIONS == ObjIdx) if (MAX_CONCURRENT_ACTIONS == ObjIdx)
{ {
return SL_POOL_IS_EMPTY; return SL_POOL_IS_EMPTY;
} }
OSI_RET_OK_CHECK(sl_LockObjLock(&g_pCB->ProtectionLockObj, SL_OS_WAIT_FOREVER));
g_pCB->ObjPool[ObjIdx].pRespArgs = (_u8 *)&AsyncRsp;
OSI_RET_OK_CHECK(sl_LockObjUnlock(&g_pCB->ProtectionLockObj));
/* send the command */ /* send the command */
VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&_SlAcceptCmdCtrl, &Msg, NULL)); VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&_SlAcceptCmdCtrl, &Msg, NULL));
VERIFY_PROTOCOL(Msg.Rsp.sd == sd); VERIFY_PROTOCOL(Msg.Rsp.sd == sd);
@ -708,7 +721,7 @@ _i16 sl_Accept(_i16 sd, SlSockAddr_t *addr, SlSocklen_t *addrlen)
if(SL_OS_RET_CODE_OK == RetVal) if(SL_OS_RET_CODE_OK == RetVal)
{ {
/* wait for async and get Data Read parameters */ /* wait for async and get Data Read parameters */
OSI_RET_OK_CHECK(sl_SyncObjWait(&g_pCB->ObjPool[ObjIdx].SyncObj, SL_OS_WAIT_FOREVER)); _SlDrvSyncObjWaitForever(&g_pCB->ObjPool[ObjIdx].SyncObj);
VERIFY_PROTOCOL(AsyncRsp.IpV4.sd == sd); VERIFY_PROTOCOL(AsyncRsp.IpV4.sd == sd);
@ -812,22 +825,44 @@ _u16 sl_Htons( _u16 val )
/*******************************************************************************/ /*******************************************************************************/
/* _sl_HandleAsync_Accept */ /* _sl_HandleAsync_Accept */
/*******************************************************************************/ /*******************************************************************************/
#ifndef SL_TINY_EXT
void _sl_HandleAsync_Accept(void *pVoidBuf) void _sl_HandleAsync_Accept(void *pVoidBuf)
{ {
_SocketAddrResponse_u *pMsgArgs = (_SocketAddrResponse_u *)_SL_RESP_ARGS_START(pVoidBuf); _SocketAddrResponse_u *pMsgArgs = (_SocketAddrResponse_u *)_SL_RESP_ARGS_START(pVoidBuf);
OSI_RET_OK_CHECK(sl_LockObjLock(&g_pCB->ProtectionLockObj, SL_OS_WAIT_FOREVER)); _SlDrvProtectionObjLockWaitForever();
VERIFY_PROTOCOL(( pMsgArgs->IpV4.sd & BSD_SOCKET_ID_MASK) <= SL_MAX_SOCKETS); VERIFY_PROTOCOL(( pMsgArgs->IpV4.sd & BSD_SOCKET_ID_MASK) <= SL_MAX_SOCKETS);
VERIFY_SOCKET_CB(NULL != g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs); VERIFY_SOCKET_CB(NULL != g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs);
sl_Memcpy(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs, pMsgArgs,sizeof(_SocketAddrResponse_u)); sl_Memcpy(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs, pMsgArgs,sizeof(_SocketAddrResponse_u));
OSI_RET_OK_CHECK(sl_SyncObjSignal(&g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].SyncObj)); _SlDrvSyncObjSignal(&g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].SyncObj);
OSI_RET_OK_CHECK(sl_LockObjUnlock(&g_pCB->ProtectionLockObj)); _SlDrvProtectionObjUnLock();
return; return;
} }
/*******************************************************************************/
/* _sl_HandleAsync_Select */
/*******************************************************************************/
void _sl_HandleAsync_Select(void *pVoidBuf)
{
_SelectAsyncResponse_t *pMsgArgs = (_SelectAsyncResponse_t *)_SL_RESP_ARGS_START(pVoidBuf);
_SlDrvProtectionObjLockWaitForever();
VERIFY_SOCKET_CB(NULL != g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs);
sl_Memcpy(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs, pMsgArgs, sizeof(_SelectAsyncResponse_t));
_SlDrvSyncObjSignal(&g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].SyncObj);
_SlDrvProtectionObjUnLock();
return;
}
#endif
/*******************************************************************************/ /*******************************************************************************/
/* sl_Recv */ /* sl_Recv */
/*******************************************************************************/ /*******************************************************************************/
@ -837,6 +872,9 @@ typedef union
_SocketResponse_t Rsp; _SocketResponse_t Rsp;
}_SlRecvMsg_u; }_SlRecvMsg_u;
#if _SL_INCLUDE_FUNC(sl_Recv)
const _SlCmdCtrl_t _SlRecvCmdCtrl = const _SlCmdCtrl_t _SlRecvCmdCtrl =
{ {
SL_OPCODE_SOCKET_RECV, SL_OPCODE_SOCKET_RECV,
@ -844,16 +882,15 @@ const _SlCmdCtrl_t _SlRecvCmdCtrl =
sizeof(_SocketResponse_t) sizeof(_SocketResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_Recv)
_i16 sl_Recv(_i16 sd, void *pBuf, _i16 Len, _i16 flags) _i16 sl_Recv(_i16 sd, void *pBuf, _i16 Len, _i16 flags)
{ {
_SlRecvMsg_u Msg; _SlRecvMsg_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
_SlReturnVal_t status; _SlReturnVal_t status;
CmdExt.TxPayloadLen = 0; _SlDrvResetCmdExt(&CmdExt);
CmdExt.RxPayloadLen = Len; CmdExt.RxPayloadLen = Len;
CmdExt.pTxPayload = NULL;
CmdExt.pRxPayload = (_u8 *)pBuf; CmdExt.pRxPayload = (_u8 *)pBuf;
Msg.Cmd.sd = (_u8)sd; Msg.Cmd.sd = (_u8)sd;
@ -898,10 +935,10 @@ _i16 sl_SetSockOpt(_i16 sd, _i16 level, _i16 optname, const void *optval, SlSock
_SlSetSockOptMsg_u Msg; _SlSetSockOptMsg_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.TxPayloadLen = optlen; CmdExt.TxPayloadLen = optlen;
CmdExt.RxPayloadLen = 0;
CmdExt.pTxPayload = (_u8 *)optval; CmdExt.pTxPayload = (_u8 *)optval;
CmdExt.pRxPayload = NULL;
Msg.Cmd.sd = (_u8)sd; Msg.Cmd.sd = (_u8)sd;
Msg.Cmd.level = (_u8)level; Msg.Cmd.level = (_u8)level;
@ -923,6 +960,9 @@ typedef union
_getSockOptResponse_t Rsp; _getSockOptResponse_t Rsp;
}_SlGetSockOptMsg_u; }_SlGetSockOptMsg_u;
#if _SL_INCLUDE_FUNC(sl_GetSockOpt)
const _SlCmdCtrl_t _SlGetSockOptCmdCtrl = const _SlCmdCtrl_t _SlGetSockOptCmdCtrl =
{ {
SL_OPCODE_SOCKET_GETSOCKOPT, SL_OPCODE_SOCKET_GETSOCKOPT,
@ -930,7 +970,6 @@ const _SlCmdCtrl_t _SlGetSockOptCmdCtrl =
sizeof(_getSockOptResponse_t) sizeof(_getSockOptResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_GetSockOpt)
_i16 sl_GetSockOpt(_i16 sd, _i16 level, _i16 optname, void *optval, SlSocklen_t *optlen) _i16 sl_GetSockOpt(_i16 sd, _i16 level, _i16 optname, void *optval, SlSocklen_t *optlen)
{ {
_SlGetSockOptMsg_u Msg; _SlGetSockOptMsg_u Msg;
@ -940,11 +979,10 @@ _i16 sl_GetSockOpt(_i16 sd, _i16 level, _i16 optname, void *optval, SlSocklen_t
{ {
return SL_EZEROLEN; return SL_EZEROLEN;
} }
CmdExt.TxPayloadLen = 0;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.RxPayloadLen = *optlen; CmdExt.RxPayloadLen = *optlen;
CmdExt.pTxPayload = NULL;
CmdExt.pRxPayload = optval; CmdExt.pRxPayload = optval;
CmdExt.ActualRxPayloadLen = 0;
Msg.Cmd.sd = (_u8)sd; Msg.Cmd.sd = (_u8)sd;
Msg.Cmd.level = (_u8)level; Msg.Cmd.level = (_u8)level;
@ -975,6 +1013,11 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlSelectMsg_u; }_SlSelectMsg_u;
#ifndef SL_TINY_EXT
#if _SL_INCLUDE_FUNC(sl_Select)
const _SlCmdCtrl_t _SlSelectCmdCtrl = const _SlCmdCtrl_t _SlSelectCmdCtrl =
{ {
SL_OPCODE_SOCKET_SELECT, SL_OPCODE_SOCKET_SELECT,
@ -982,7 +1025,7 @@ const _SlCmdCtrl_t _SlSelectCmdCtrl =
sizeof(_BasicResponse_t) sizeof(_BasicResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_Select)
_i16 sl_Select(_i16 nfds, SlFdSet_t *readsds, SlFdSet_t *writesds, SlFdSet_t *exceptsds, struct SlTimeval_t *timeout) _i16 sl_Select(_i16 nfds, SlFdSet_t *readsds, SlFdSet_t *writesds, SlFdSet_t *exceptsds, struct SlTimeval_t *timeout)
{ {
_SlSelectMsg_u Msg; _SlSelectMsg_u Msg;
@ -996,6 +1039,7 @@ _i16 sl_Select(_i16 nfds, SlFdSet_t *readsds, SlFdSet_t *writesds, SlFdSet_t *ex
Msg.Cmd.readFds = 0; Msg.Cmd.readFds = 0;
Msg.Cmd.writeFds = 0; Msg.Cmd.writeFds = 0;
if( readsds ) if( readsds )
{ {
Msg.Cmd.readFds = (_u16)readsds->fd_array[0]; Msg.Cmd.readFds = (_u16)readsds->fd_array[0];
@ -1031,23 +1075,21 @@ _i16 sl_Select(_i16 nfds, SlFdSet_t *readsds, SlFdSet_t *writesds, SlFdSet_t *ex
} }
/* Use Obj to issue the command, if not available try later */ /* Use Obj to issue the command, if not available try later */
ObjIdx = (_u8)_SlDrvWaitForPoolObj(SELECT_ID, SL_MAX_SOCKETS); ObjIdx = _SlDrvProtectAsyncRespSetting((_u8*)&AsyncRsp, SELECT_ID, SL_MAX_SOCKETS);
if (MAX_CONCURRENT_ACTIONS == ObjIdx) if (MAX_CONCURRENT_ACTIONS == ObjIdx)
{ {
return SL_POOL_IS_EMPTY; return SL_POOL_IS_EMPTY;
} }
OSI_RET_OK_CHECK(sl_LockObjLock(&g_pCB->ProtectionLockObj, SL_OS_WAIT_FOREVER));
g_pCB->ObjPool[ObjIdx].pRespArgs = (_u8 *)&AsyncRsp;
OSI_RET_OK_CHECK(sl_LockObjUnlock(&g_pCB->ProtectionLockObj));
/* send the command */ /* send the command */
VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&_SlSelectCmdCtrl, &Msg, NULL)); VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&_SlSelectCmdCtrl, &Msg, NULL));
if(SL_OS_RET_CODE_OK == (_i16)Msg.Rsp.status) if(SL_OS_RET_CODE_OK == (_i16)Msg.Rsp.status)
{ {
OSI_RET_OK_CHECK(sl_SyncObjWait(&g_pCB->ObjPool[ObjIdx].SyncObj, SL_OS_WAIT_FOREVER)); _SlDrvSyncObjWaitForever(&g_pCB->ObjPool[ObjIdx].SyncObj);
Msg.Rsp.status = AsyncRsp.status; Msg.Rsp.status = AsyncRsp.status;
if( ((_i16)Msg.Rsp.status) >= 0 ) if( ((_i16)Msg.Rsp.status) >= 0 )
@ -1102,22 +1144,7 @@ void SL_FD_ZERO(SlFdSet_t *fdset)
} }
#endif #endif
#endif
/*******************************************************************************/
/* _sl_HandleAsync_Select */
/*******************************************************************************/
void _sl_HandleAsync_Select(void *pVoidBuf)
{
_SelectAsyncResponse_t *pMsgArgs = (_SelectAsyncResponse_t *)_SL_RESP_ARGS_START(pVoidBuf);
OSI_RET_OK_CHECK(sl_LockObjLock(&g_pCB->ProtectionLockObj, SL_OS_WAIT_FOREVER));
VERIFY_SOCKET_CB(NULL != g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs);
sl_Memcpy(g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].pRespArgs, pMsgArgs, sizeof(_SelectAsyncResponse_t));
OSI_RET_OK_CHECK(sl_SyncObjSignal(&g_pCB->ObjPool[g_pCB->FunctionParams.AsyncExt.ActionIndex].SyncObj));
OSI_RET_OK_CHECK(sl_LockObjUnlock(&g_pCB->ProtectionLockObj));
return;
}

View File

@ -93,8 +93,7 @@ void _SlInternalSpawnTaskEntry()
} }
g_SlInternalSpawnCB.SpawnEntries[i].pNext = NULL; g_SlInternalSpawnCB.SpawnEntries[i].pNext = NULL;
sl_LockObjUnlock(&g_SlInternalSpawnCB.LockObj); _SlDrvObjUnLock(&g_SlInternalSpawnCB.LockObj);
/* here we ready to execute entries */ /* here we ready to execute entries */
@ -106,12 +105,12 @@ void _SlInternalSpawnTaskEntry()
do do
{ {
/* get entry to execute */ /* get entry to execute */
sl_LockObjLock(&g_SlInternalSpawnCB.LockObj,SL_OS_WAIT_FOREVER); _SlDrvObjLockWaitForever(&g_SlInternalSpawnCB.LockObj);
pEntry = g_SlInternalSpawnCB.pWaitForExe; pEntry = g_SlInternalSpawnCB.pWaitForExe;
if ( NULL == pEntry ) if ( NULL == pEntry )
{ {
sl_LockObjUnlock(&g_SlInternalSpawnCB.LockObj); _SlDrvObjUnLock(&g_SlInternalSpawnCB.LockObj);
break; break;
} }
g_SlInternalSpawnCB.pWaitForExe = pEntry->pNext; g_SlInternalSpawnCB.pWaitForExe = pEntry->pNext;
@ -121,8 +120,7 @@ void _SlInternalSpawnTaskEntry()
LastEntry = TRUE; LastEntry = TRUE;
} }
sl_LockObjUnlock(&g_SlInternalSpawnCB.LockObj); _SlDrvObjUnLock(&g_SlInternalSpawnCB.LockObj);
/* pEntry could be null in case that the sync was already set by some /* pEntry could be null in case that the sync was already set by some
of the entries during execution of earlier entry */ of the entries during execution of earlier entry */
@ -130,7 +128,8 @@ void _SlInternalSpawnTaskEntry()
{ {
pEntry->pEntry(pEntry->pValue); pEntry->pEntry(pEntry->pValue);
/* free the entry */ /* free the entry */
sl_LockObjLock(&g_SlInternalSpawnCB.LockObj,SL_OS_WAIT_FOREVER);
_SlDrvObjLockWaitForever(&g_SlInternalSpawnCB.LockObj);
pEntry->pNext = g_SlInternalSpawnCB.pFree; pEntry->pNext = g_SlInternalSpawnCB.pFree;
g_SlInternalSpawnCB.pFree = pEntry; g_SlInternalSpawnCB.pFree = pEntry;
@ -142,7 +141,7 @@ void _SlInternalSpawnTaskEntry()
LastEntry = FALSE; LastEntry = FALSE;
} }
sl_LockObjUnlock(&g_SlInternalSpawnCB.LockObj); _SlDrvObjUnLock(&g_SlInternalSpawnCB.LockObj);
} }
@ -162,7 +161,7 @@ _i16 _SlInternalSpawn(_SlSpawnEntryFunc_t pEntry , void* pValue , _u32 flags)
} }
else else
{ {
sl_LockObjLock(&g_SlInternalSpawnCB.LockObj,SL_OS_WAIT_FOREVER); _SlDrvObjLockWaitForever(&g_SlInternalSpawnCB.LockObj);
pSpawnEntry = g_SlInternalSpawnCB.pFree; pSpawnEntry = g_SlInternalSpawnCB.pFree;
g_SlInternalSpawnCB.pFree = pSpawnEntry->pNext; g_SlInternalSpawnCB.pFree = pSpawnEntry->pNext;
@ -182,9 +181,10 @@ _i16 _SlInternalSpawn(_SlSpawnEntryFunc_t pEntry , void* pValue , _u32 flags)
g_SlInternalSpawnCB.pLastInWaitList = pSpawnEntry; g_SlInternalSpawnCB.pLastInWaitList = pSpawnEntry;
} }
sl_LockObjUnlock(&g_SlInternalSpawnCB.LockObj); _SlDrvObjUnLock(&g_SlInternalSpawnCB.LockObj);
/* this sync is called after releasing the lock object to avoid unnecessary context switches */ /* this sync is called after releasing the lock object to avoid unnecessary context switches */
sl_SyncObjSignal(&g_SlInternalSpawnCB.SyncObj); _SlDrvSyncObjSignal(&g_SlInternalSpawnCB.SyncObj);
} }
return Res; return Res;

View File

@ -70,7 +70,7 @@ typedef union
#if _SL_INCLUDE_FUNC(sl_WlanConnect) #if _SL_INCLUDE_FUNC(sl_WlanConnect)
_i16 sl_WlanConnect(_i8* pName, _i16 NameLen, _u8 *pMacAddr, SlSecParams_t* pSecParams , SlSecParamsExt_t* pSecExtParams) _i16 sl_WlanConnect(const _i8* pName,const _i16 NameLen,const _u8 *pMacAddr,const SlSecParams_t* pSecParams ,const SlSecParamsExt_t* pSecExtParams)
{ {
_SlWlanConnectMsg_u Msg; _SlWlanConnectMsg_u Msg;
_SlCmdCtrl_t CmdCtrl; _SlCmdCtrl_t CmdCtrl;
@ -82,6 +82,11 @@ _i16 sl_WlanConnect(_i8* pName, _i16 NameLen, _u8 *pMacAddr, SlSecParams_t* pSe
/* verify SSID length */ /* verify SSID length */
VERIFY_PROTOCOL(NameLen <= MAX_SSID_LEN); VERIFY_PROTOCOL(NameLen <= MAX_SSID_LEN);
/* verify SSID is not NULL */
if( NULL == pName )
{
return SL_INVALPARAM;
}
/* update SSID length */ /* update SSID length */
Msg.Cmd.Args.Common.SsidLen = (_u8)NameLen; Msg.Cmd.Args.Common.SsidLen = (_u8)NameLen;
@ -191,7 +196,7 @@ _i16 sl_WlanConnect(_i8* pName, _i16 NameLen, _u8 *pMacAddr, SlSecParams_t* pSe
} }
else else
{ {
sl_Memset(Msg.Cmd.Args.Common.Bssid, 0, sizeof(Msg.Cmd.Args.Common.Bssid)); _SlDrvMemZero(Msg.Cmd.Args.Common.Bssid, sizeof(Msg.Cmd.Args.Common.Bssid));
} }
@ -220,6 +225,8 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlPolicyMsg_u; }_SlPolicyMsg_u;
#if _SL_INCLUDE_FUNC(sl_WlanPolicySet)
const _SlCmdCtrl_t _SlPolicySetCmdCtrl = const _SlCmdCtrl_t _SlPolicySetCmdCtrl =
{ {
SL_OPCODE_WLAN_POLICYSETCOMMAND, SL_OPCODE_WLAN_POLICYSETCOMMAND,
@ -227,16 +234,15 @@ const _SlCmdCtrl_t _SlPolicySetCmdCtrl =
sizeof(_BasicResponse_t) sizeof(_BasicResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_WlanPolicySet) _i16 sl_WlanPolicySet(const _u8 Type , const _u8 Policy, _u8 *pVal,const _u8 ValLen)
_i16 sl_WlanPolicySet(_u8 Type , const _u8 Policy, _u8 *pVal,_u8 ValLen)
{ {
_SlPolicyMsg_u Msg; _SlPolicyMsg_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.TxPayloadLen = ValLen; CmdExt.TxPayloadLen = ValLen;
CmdExt.RxPayloadLen = 0;
CmdExt.pTxPayload = (_u8 *)pVal; CmdExt.pTxPayload = (_u8 *)pVal;
CmdExt.pRxPayload = NULL;
Msg.Cmd.PolicyType = Type; Msg.Cmd.PolicyType = Type;
@ -259,6 +265,8 @@ typedef union
_WlanPoliciySetGet_t Rsp; _WlanPoliciySetGet_t Rsp;
}_SlPolicyGetMsg_u; }_SlPolicyGetMsg_u;
#if _SL_INCLUDE_FUNC(sl_WlanPolicyGet)
const _SlCmdCtrl_t _SlPolicyGetCmdCtrl = const _SlCmdCtrl_t _SlPolicyGetCmdCtrl =
{ {
SL_OPCODE_WLAN_POLICYGETCOMMAND, SL_OPCODE_WLAN_POLICYGETCOMMAND,
@ -266,8 +274,7 @@ const _SlCmdCtrl_t _SlPolicyGetCmdCtrl =
sizeof(_WlanPoliciySetGet_t) sizeof(_WlanPoliciySetGet_t)
}; };
#if _SL_INCLUDE_FUNC(sl_WlanPolicyGet) _i16 sl_WlanPolicyGet(const _u8 Type ,_u8 Policy,_u8 *pVal,_u8 *pValLen)
_i16 sl_WlanPolicyGet(_u8 Type , _u8 Policy,_u8 *pVal,_u8 *pValLen)
{ {
_SlPolicyGetMsg_u Msg; _SlPolicyGetMsg_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
@ -276,12 +283,10 @@ _i16 sl_WlanPolicyGet(_u8 Type , _u8 Policy,_u8 *pVal,_u8 *pValLen)
{ {
return SL_EZEROLEN; return SL_EZEROLEN;
} }
CmdExt.TxPayloadLen = 0;
CmdExt.RxPayloadLen = *pValLen;
CmdExt.pTxPayload = NULL;
CmdExt.pRxPayload = pVal;
CmdExt.ActualRxPayloadLen = 0;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.RxPayloadLen = *pValLen;
CmdExt.pRxPayload = pVal;
Msg.Cmd.PolicyType = Type; Msg.Cmd.PolicyType = Type;
Msg.Cmd.PolicyOption = Policy; Msg.Cmd.PolicyOption = Policy;
@ -326,7 +331,7 @@ typedef union
#if _SL_INCLUDE_FUNC(sl_WlanProfileAdd) #if _SL_INCLUDE_FUNC(sl_WlanProfileAdd)
_i16 sl_WlanProfileAdd(_i8* pName, _i16 NameLen, _u8 *pMacAddr, SlSecParams_t* pSecParams , SlSecParamsExt_t* pSecExtParams, _u32 Priority, _u32 Options) _i16 sl_WlanProfileAdd(const _i8* pName,const _i16 NameLen,const _u8 *pMacAddr,const SlSecParams_t* pSecParams ,const SlSecParamsExt_t* pSecExtParams,const _u32 Priority,const _u32 Options)
{ {
_SlProfileAddMsg_u Msg; _SlProfileAddMsg_u Msg;
_SlCmdCtrl_t CmdCtrl = {0}; _SlCmdCtrl_t CmdCtrl = {0};
@ -335,6 +340,11 @@ _i16 sl_WlanProfileAdd(_i8* pName, _i16 NameLen, _u8 *pMacAddr, SlSecParams_t*
/* update priority */ /* update priority */
Msg.Cmd.Args.Common.Priority = (_u8)Priority; Msg.Cmd.Args.Common.Priority = (_u8)Priority;
/* verify SSID is not NULL */
if( NULL == pName )
{
return SL_INVALPARAM;
}
/* verify SSID length */ /* verify SSID length */
VERIFY_PROTOCOL(NameLen <= MAX_SSID_LEN); VERIFY_PROTOCOL(NameLen <= MAX_SSID_LEN);
/* update SSID length */ /* update SSID length */
@ -470,7 +480,7 @@ _i16 sl_WlanProfileAdd(_i8* pName, _i16 NameLen, _u8 *pMacAddr, SlSecParams_t*
} }
else else
{ {
sl_Memset(Msg.Cmd.Args.Common.Bssid, 0, sizeof(Msg.Cmd.Args.Common.Bssid)); _SlDrvMemZero(Msg.Cmd.Args.Common.Bssid, sizeof(Msg.Cmd.Args.Common.Bssid));
} }
VERIFY_RET_OK(_SlDrvCmdOp(&CmdCtrl, &Msg, NULL)); VERIFY_RET_OK(_SlDrvCmdOp(&CmdCtrl, &Msg, NULL));
@ -487,6 +497,9 @@ typedef union
_SlProfileParams_t Rsp; _SlProfileParams_t Rsp;
}_SlProfileGetMsg_u; }_SlProfileGetMsg_u;
#if _SL_INCLUDE_FUNC(sl_WlanProfileGet)
const _SlCmdCtrl_t _SlProfileGetCmdCtrl = const _SlCmdCtrl_t _SlProfileGetCmdCtrl =
{ {
SL_OPCODE_WLAN_PROFILEGETCOMMAND, SL_OPCODE_WLAN_PROFILEGETCOMMAND,
@ -494,8 +507,7 @@ const _SlCmdCtrl_t _SlProfileGetCmdCtrl =
sizeof(_SlProfileParams_t) sizeof(_SlProfileParams_t)
}; };
#if _SL_INCLUDE_FUNC(sl_WlanProfileGet) _i16 sl_WlanProfileGet(const _i16 Index,_i8* pName, _i16 *pNameLen, _u8 *pMacAddr, SlSecParams_t* pSecParams, SlGetSecParamsExt_t* pEntParams, _u32 *pPriority)
_i16 sl_WlanProfileGet(_i16 Index,_i8* pName, _i16 *pNameLen, _u8 *pMacAddr, SlSecParams_t* pSecParams, SlGetSecParamsExt_t* pEntParams, _u32 *pPriority)
{ {
_SlProfileGetMsg_u Msg; _SlProfileGetMsg_u Msg;
Msg.Cmd.index = (_u8)Index; Msg.Cmd.index = (_u8)Index;
@ -544,6 +556,9 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlProfileDelMsg_u; }_SlProfileDelMsg_u;
#if _SL_INCLUDE_FUNC(sl_WlanProfileDel)
const _SlCmdCtrl_t _SlProfileDelCmdCtrl = const _SlCmdCtrl_t _SlProfileDelCmdCtrl =
{ {
SL_OPCODE_WLAN_PROFILEDELCOMMAND, SL_OPCODE_WLAN_PROFILEDELCOMMAND,
@ -551,8 +566,7 @@ const _SlCmdCtrl_t _SlProfileDelCmdCtrl =
sizeof(_BasicResponse_t) sizeof(_BasicResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_WlanProfileDel) _i16 sl_WlanProfileDel(const _i16 Index)
_i16 sl_WlanProfileDel(_i16 Index)
{ {
_SlProfileDelMsg_u Msg; _SlProfileDelMsg_u Msg;
@ -574,6 +588,9 @@ typedef union
_WlanGetNetworkListResponse_t Rsp; _WlanGetNetworkListResponse_t Rsp;
}_SlWlanGetNetworkListMsg_u; }_SlWlanGetNetworkListMsg_u;
#if _SL_INCLUDE_FUNC(sl_WlanGetNetworkList)
const _SlCmdCtrl_t _SlWlanGetNetworkListCtrl = const _SlCmdCtrl_t _SlWlanGetNetworkListCtrl =
{ {
SL_OPCODE_WLAN_SCANRESULTSGETCOMMAND, SL_OPCODE_WLAN_SCANRESULTSGETCOMMAND,
@ -581,9 +598,7 @@ const _SlCmdCtrl_t _SlWlanGetNetworkListCtrl =
sizeof(_WlanGetNetworkListResponse_t) sizeof(_WlanGetNetworkListResponse_t)
}; };
_i16 sl_WlanGetNetworkList(const _u8 Index,const _u8 Count, Sl_WlanNetworkEntry_t *pEntries)
#if _SL_INCLUDE_FUNC(sl_WlanGetNetworkList)
_i16 sl_WlanGetNetworkList(_u8 Index, _u8 Count, Sl_WlanNetworkEntry_t *pEntries)
{ {
_i16 retVal = 0; _i16 retVal = 0;
_SlWlanGetNetworkListMsg_u Msg; _SlWlanGetNetworkListMsg_u Msg;
@ -593,9 +608,9 @@ _i16 sl_WlanGetNetworkList(_u8 Index, _u8 Count, Sl_WlanNetworkEntry_t *pEntries
{ {
return SL_EZEROLEN; return SL_EZEROLEN;
} }
CmdExt.TxPayloadLen = 0;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.RxPayloadLen = sizeof(Sl_WlanNetworkEntry_t)*(Count); CmdExt.RxPayloadLen = sizeof(Sl_WlanNetworkEntry_t)*(Count);
CmdExt.pTxPayload = NULL;
CmdExt.pRxPayload = (_u8 *)pEntries; CmdExt.pRxPayload = (_u8 *)pEntries;
Msg.Cmd.index = Index; Msg.Cmd.index = Index;
@ -623,13 +638,6 @@ typedef union
_WlanRxFilterAddCommandReponse_t Rsp; _WlanRxFilterAddCommandReponse_t Rsp;
}_SlrxFilterAddMsg_u; }_SlrxFilterAddMsg_u;
const _SlCmdCtrl_t _SlRxFilterAddtCmdCtrl =
{
SL_OPCODE_WLAN_WLANRXFILTERADDCOMMAND,
sizeof(_WlanRxFilterAddCommand_t),
sizeof(_WlanRxFilterAddCommandReponse_t)
};
/* Set command */ /* Set command */
typedef union _SlRxFilterSetMsg_u typedef union _SlRxFilterSetMsg_u
@ -639,13 +647,6 @@ typedef union _SlRxFilterSetMsg_u
}_SlRxFilterSetMsg_u; }_SlRxFilterSetMsg_u;
const _SlCmdCtrl_t _SlRxFilterSetCmdCtrl =
{
SL_OPCODE_WLAN_WLANRXFILTERSETCOMMAND,
sizeof(_WlanRxFilterSetCommand_t),
sizeof(_WlanRxFilterSetCommandReponse_t)
};
/* Get command */ /* Get command */
typedef union _SlRxFilterGetMsg_u typedef union _SlRxFilterGetMsg_u
{ {
@ -653,20 +654,19 @@ typedef union _SlRxFilterGetMsg_u
_WlanRxFilterGetCommandReponse_t Rsp; _WlanRxFilterGetCommandReponse_t Rsp;
}_SlRxFilterGetMsg_u; }_SlRxFilterGetMsg_u;
#if _SL_INCLUDE_FUNC(sl_WlanRxFilterAdd)
const _SlCmdCtrl_t _SlRxFilterGetCmdCtrl = const _SlCmdCtrl_t _SlRxFilterAddtCmdCtrl =
{ {
SL_OPCODE_WLAN_WLANRXFILTERGETCOMMAND, SL_OPCODE_WLAN_WLANRXFILTERADDCOMMAND,
sizeof(_WlanRxFilterGetCommand_t), sizeof(_WlanRxFilterAddCommand_t),
sizeof(_WlanRxFilterGetCommandReponse_t) sizeof(_WlanRxFilterAddCommandReponse_t)
}; };
/*******************************************************************************/ /*****************************************************************************
/* RX filters */ RX filters
/*******************************************************************************/ *****************************************************************************/
#if _SL_INCLUDE_FUNC(sl_WlanRxFilterAdd)
SlrxFilterID_t sl_WlanRxFilterAdd( SlrxFilterRuleType_t RuleType, SlrxFilterID_t sl_WlanRxFilterAdd( SlrxFilterRuleType_t RuleType,
SlrxFilterFlags_t FilterFlags, SlrxFilterFlags_t FilterFlags,
const SlrxFilterRule_t* const Rule, const SlrxFilterRule_t* const Rule,
@ -697,6 +697,14 @@ SlrxFilterID_t sl_WlanRxFilterAdd( SlrxFilterRuleType_t RuleType
/* RX filters */ /* RX filters */
/*******************************************************************************/ /*******************************************************************************/
#if _SL_INCLUDE_FUNC(sl_WlanRxFilterSet) #if _SL_INCLUDE_FUNC(sl_WlanRxFilterSet)
const _SlCmdCtrl_t _SlRxFilterSetCmdCtrl =
{
SL_OPCODE_WLAN_WLANRXFILTERSETCOMMAND,
sizeof(_WlanRxFilterSetCommand_t),
sizeof(_WlanRxFilterSetCommandReponse_t)
};
_i16 sl_WlanRxFilterSet(const SLrxFilterOperation_t RxFilterOperation, _i16 sl_WlanRxFilterSet(const SLrxFilterOperation_t RxFilterOperation,
const _u8* const pInputBuffer, const _u8* const pInputBuffer,
_u16 InputbufferLength) _u16 InputbufferLength)
@ -704,10 +712,10 @@ _i16 sl_WlanRxFilterSet(const SLrxFilterOperation_t RxFilterOperation,
_SlRxFilterSetMsg_u Msg; _SlRxFilterSetMsg_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.TxPayloadLen = InputbufferLength; CmdExt.TxPayloadLen = InputbufferLength;
CmdExt.pTxPayload = (_u8 *)pInputBuffer; CmdExt.pTxPayload = (_u8 *)pInputBuffer;
CmdExt.RxPayloadLen = 0;
CmdExt.pRxPayload = (_u8 *)NULL;
Msg.Cmd.RxFilterOperation = RxFilterOperation; Msg.Cmd.RxFilterOperation = RxFilterOperation;
Msg.Cmd.InputBufferLength = InputbufferLength; Msg.Cmd.InputBufferLength = InputbufferLength;
@ -724,6 +732,15 @@ _i16 sl_WlanRxFilterSet(const SLrxFilterOperation_t RxFilterOperation,
/* RX filters */ /* RX filters */
/******************************************************************************/ /******************************************************************************/
#if _SL_INCLUDE_FUNC(sl_WlanRxFilterGet) #if _SL_INCLUDE_FUNC(sl_WlanRxFilterGet)
const _SlCmdCtrl_t _SlRxFilterGetCmdCtrl =
{
SL_OPCODE_WLAN_WLANRXFILTERGETCOMMAND,
sizeof(_WlanRxFilterGetCommand_t),
sizeof(_WlanRxFilterGetCommandReponse_t)
};
_i16 sl_WlanRxFilterGet(const SLrxFilterOperation_t RxFilterOperation, _i16 sl_WlanRxFilterGet(const SLrxFilterOperation_t RxFilterOperation,
_u8* pOutputBuffer, _u8* pOutputBuffer,
_u16 OutputbufferLength) _u16 OutputbufferLength)
@ -735,11 +752,10 @@ _i16 sl_WlanRxFilterGet(const SLrxFilterOperation_t RxFilterOperation,
{ {
return SL_EZEROLEN; return SL_EZEROLEN;
} }
CmdExt.TxPayloadLen = 0;
CmdExt.pTxPayload = NULL; _SlDrvResetCmdExt(&CmdExt);
CmdExt.RxPayloadLen = OutputbufferLength; CmdExt.RxPayloadLen = OutputbufferLength;
CmdExt.pRxPayload = (_u8 *)pOutputBuffer; CmdExt.pRxPayload = (_u8 *)pOutputBuffer;
CmdExt.ActualRxPayloadLen = 0;
Msg.Cmd.RxFilterOperation = RxFilterOperation; Msg.Cmd.RxFilterOperation = RxFilterOperation;
Msg.Cmd.OutputBufferLength = OutputbufferLength; Msg.Cmd.OutputBufferLength = OutputbufferLength;
@ -774,10 +790,11 @@ _i16 sl_WlanRxStatStop(void)
#endif #endif
#if _SL_INCLUDE_FUNC(sl_WlanRxStatGet) #if _SL_INCLUDE_FUNC(sl_WlanRxStatGet)
_i16 sl_WlanRxStatGet(SlGetRxStatResponse_t *pRxStat,_u32 Flags) _i16 sl_WlanRxStatGet(SlGetRxStatResponse_t *pRxStat,const _u32 Flags)
{ {
_SlCmdCtrl_t CmdCtrl = {SL_OPCODE_WLAN_GETRXSTATCOMMAND, 0, sizeof(SlGetRxStatResponse_t)}; _SlCmdCtrl_t CmdCtrl = {SL_OPCODE_WLAN_GETRXSTATCOMMAND, 0, sizeof(SlGetRxStatResponse_t)};
sl_Memset(pRxStat,0,sizeof(SlGetRxStatResponse_t));
_SlDrvMemZero(pRxStat, sizeof(SlGetRxStatResponse_t));
VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&CmdCtrl, pRxStat, NULL)); VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&CmdCtrl, pRxStat, NULL));
return 0; return 0;
@ -814,6 +831,8 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlSmartConfigStartMsg_u; }_SlSmartConfigStartMsg_u;
#if _SL_INCLUDE_FUNC(sl_WlanSmartConfigStart)
const _SlCmdCtrl_t _SlSmartConfigStartCmdCtrl = const _SlCmdCtrl_t _SlSmartConfigStartCmdCtrl =
{ {
SL_OPCODE_WLAN_SMART_CONFIG_START_COMMAND, SL_OPCODE_WLAN_SMART_CONFIG_START_COMMAND,
@ -821,7 +840,6 @@ const _SlCmdCtrl_t _SlSmartConfigStartCmdCtrl =
sizeof(_BasicResponse_t) sizeof(_BasicResponse_t)
}; };
#if _SL_INCLUDE_FUNC(sl_WlanSmartConfigStart)
_i16 sl_WlanSmartConfigStart( const _u32 groupIdBitmask, _i16 sl_WlanSmartConfigStart( const _u32 groupIdBitmask,
const _u8 cipher, const _u8 cipher,
const _u8 publicKeyLen, const _u8 publicKeyLen,
@ -862,6 +880,8 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlwlanSetModeMsg_u; }_SlwlanSetModeMsg_u;
#if _SL_INCLUDE_FUNC(sl_WlanSetMode)
const _SlCmdCtrl_t _SlWlanSetModeCmdCtrl = const _SlCmdCtrl_t _SlWlanSetModeCmdCtrl =
{ {
SL_OPCODE_WLAN_SET_MODE, SL_OPCODE_WLAN_SET_MODE,
@ -873,8 +893,6 @@ const _SlCmdCtrl_t _SlWlanSetModeCmdCtrl =
WLAN_SET_STA_MODE = 1 WLAN_SET_STA_MODE = 1
WLAN_SET_AP_MODE = 2 WLAN_SET_AP_MODE = 2
WLAN_SET_P2P_MODE = 3 */ WLAN_SET_P2P_MODE = 3 */
#if _SL_INCLUDE_FUNC(sl_WlanSetMode)
_i16 sl_WlanSetMode(const _u8 mode) _i16 sl_WlanSetMode(const _u8 mode)
{ {
_SlwlanSetModeMsg_u Msg; _SlwlanSetModeMsg_u Msg;
@ -884,7 +902,6 @@ _i16 sl_WlanSetMode(const _u8 mode)
VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&_SlWlanSetModeCmdCtrl , &Msg, NULL)); VERIFY_RET_OK(_SlDrvCmdOp((_SlCmdCtrl_t *)&_SlWlanSetModeCmdCtrl , &Msg, NULL));
return (_i16)Msg.Rsp.status; return (_i16)Msg.Rsp.status;
} }
#endif #endif
@ -900,6 +917,9 @@ typedef union
_BasicResponse_t Rsp; _BasicResponse_t Rsp;
}_SlWlanCfgSetMsg_u; }_SlWlanCfgSetMsg_u;
#if _SL_INCLUDE_FUNC(sl_WlanSet)
const _SlCmdCtrl_t _SlWlanCfgSetCmdCtrl = const _SlCmdCtrl_t _SlWlanCfgSetCmdCtrl =
{ {
SL_OPCODE_WLAN_CFG_SET, SL_OPCODE_WLAN_CFG_SET,
@ -907,18 +927,14 @@ const _SlCmdCtrl_t _SlWlanCfgSetCmdCtrl =
sizeof(_BasicResponse_t) sizeof(_BasicResponse_t)
}; };
_i16 sl_WlanSet(const _u16 ConfigId ,const _u16 ConfigOpt,const _u16 ConfigLen,const _u8 *pValues)
#if _SL_INCLUDE_FUNC(sl_WlanSet)
_i16 sl_WlanSet(_u16 ConfigId ,_u16 ConfigOpt,_u16 ConfigLen, _u8 *pValues)
{ {
_SlWlanCfgSetMsg_u Msg; _SlWlanCfgSetMsg_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.TxPayloadLen = (ConfigLen+3) & (~3); CmdExt.TxPayloadLen = (ConfigLen+3) & (~3);
CmdExt.RxPayloadLen = 0;
CmdExt.pTxPayload = (_u8 *)pValues; CmdExt.pTxPayload = (_u8 *)pValues;
CmdExt.pRxPayload = NULL;
Msg.Cmd.ConfigId = ConfigId; Msg.Cmd.ConfigId = ConfigId;
Msg.Cmd.ConfigLen = ConfigLen; Msg.Cmd.ConfigLen = ConfigLen;
@ -940,6 +956,8 @@ typedef union
_WlanCfgSetGet_t Rsp; _WlanCfgSetGet_t Rsp;
}_SlWlanCfgMsgGet_u; }_SlWlanCfgMsgGet_u;
#if _SL_INCLUDE_FUNC(sl_WlanGet)
const _SlCmdCtrl_t _SlWlanCfgGetCmdCtrl = const _SlCmdCtrl_t _SlWlanCfgGetCmdCtrl =
{ {
SL_OPCODE_WLAN_CFG_GET, SL_OPCODE_WLAN_CFG_GET,
@ -947,8 +965,7 @@ const _SlCmdCtrl_t _SlWlanCfgGetCmdCtrl =
sizeof(_WlanCfgSetGet_t) sizeof(_WlanCfgSetGet_t)
}; };
#if _SL_INCLUDE_FUNC(sl_WlanGet) _i16 sl_WlanGet(const _u16 ConfigId, _u16 *pConfigOpt,_u16 *pConfigLen, _u8 *pValues)
_i16 sl_WlanGet(_u16 ConfigId, _u16 *pConfigOpt,_u16 *pConfigLen, _u8 *pValues)
{ {
_SlWlanCfgMsgGet_u Msg; _SlWlanCfgMsgGet_u Msg;
_SlCmdExt_t CmdExt; _SlCmdExt_t CmdExt;
@ -957,11 +974,10 @@ _i16 sl_WlanGet(_u16 ConfigId, _u16 *pConfigOpt,_u16 *pConfigLen, _u8 *pValues)
{ {
return SL_EZEROLEN; return SL_EZEROLEN;
} }
CmdExt.TxPayloadLen = 0;
_SlDrvResetCmdExt(&CmdExt);
CmdExt.RxPayloadLen = *pConfigLen; CmdExt.RxPayloadLen = *pConfigLen;
CmdExt.pTxPayload = NULL;
CmdExt.pRxPayload = (_u8 *)pValues; CmdExt.pRxPayload = (_u8 *)pValues;
CmdExt.ActualRxPayloadLen = 0;
Msg.Cmd.ConfigId = ConfigId; Msg.Cmd.ConfigId = ConfigId;
if( pConfigOpt ) if( pConfigOpt )