TI's CC3100 websocket camera demo with Arducam mini ov5642 and freertos. Should work with other M3's. Work in progress test demo.

Dependencies:   mbed

Committer:
dflet
Date:
Fri Sep 11 15:38:33 2015 +0000
Revision:
1:e448e81c416f
Parent:
0:400d8e75a8d0
Removed some debud.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
dflet 0:400d8e75a8d0 1 /*
dflet 0:400d8e75a8d0 2 * netapp.c - CC31xx/CC32xx Host Driver Implementation
dflet 0:400d8e75a8d0 3 *
dflet 0:400d8e75a8d0 4 * Copyright (C) 2014 Texas Instruments Incorporated - http://www.ti.com/
dflet 0:400d8e75a8d0 5 *
dflet 0:400d8e75a8d0 6 *
dflet 0:400d8e75a8d0 7 * Redistribution and use in source and binary forms, with or without
dflet 0:400d8e75a8d0 8 * modification, are permitted provided that the following conditions
dflet 0:400d8e75a8d0 9 * are met:
dflet 0:400d8e75a8d0 10 *
dflet 0:400d8e75a8d0 11 * Redistributions of source code must retain the above copyright
dflet 0:400d8e75a8d0 12 * notice, this list of conditions and the following disclaimer.
dflet 0:400d8e75a8d0 13 *
dflet 0:400d8e75a8d0 14 * Redistributions in binary form must reproduce the above copyright
dflet 0:400d8e75a8d0 15 * notice, this list of conditions and the following disclaimer in the
dflet 0:400d8e75a8d0 16 * documentation and/or other materials provided with the
dflet 0:400d8e75a8d0 17 * distribution.
dflet 0:400d8e75a8d0 18 *
dflet 0:400d8e75a8d0 19 * Neither the name of Texas Instruments Incorporated nor the names of
dflet 0:400d8e75a8d0 20 * its contributors may be used to endorse or promote products derived
dflet 0:400d8e75a8d0 21 * from this software without specific prior written permission.
dflet 0:400d8e75a8d0 22 *
dflet 0:400d8e75a8d0 23 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
dflet 0:400d8e75a8d0 24 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
dflet 0:400d8e75a8d0 25 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
dflet 0:400d8e75a8d0 26 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
dflet 0:400d8e75a8d0 27 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
dflet 0:400d8e75a8d0 28 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
dflet 0:400d8e75a8d0 29 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
dflet 0:400d8e75a8d0 30 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
dflet 0:400d8e75a8d0 31 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
dflet 0:400d8e75a8d0 32 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
dflet 0:400d8e75a8d0 33 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
dflet 0:400d8e75a8d0 34 *
dflet 0:400d8e75a8d0 35 */
dflet 0:400d8e75a8d0 36
dflet 0:400d8e75a8d0 37
dflet 0:400d8e75a8d0 38
dflet 0:400d8e75a8d0 39 /*****************************************************************************/
dflet 0:400d8e75a8d0 40 /* Include files */
dflet 0:400d8e75a8d0 41 /*****************************************************************************/
dflet 0:400d8e75a8d0 42 #include "cc3100_simplelink.h"
dflet 0:400d8e75a8d0 43 #include "cc3100_protocol.h"
dflet 0:400d8e75a8d0 44 #include "cc3100_driver.h"
dflet 0:400d8e75a8d0 45
dflet 0:400d8e75a8d0 46 #include "cc3100_netapp.h"
dflet 0:400d8e75a8d0 47 #include "fPtr_func.h"
dflet 0:400d8e75a8d0 48 #include "cli_uart.h"
dflet 0:400d8e75a8d0 49
dflet 0:400d8e75a8d0 50 namespace mbed_cc3100 {
dflet 0:400d8e75a8d0 51
dflet 0:400d8e75a8d0 52 /*****************************************************************************/
dflet 0:400d8e75a8d0 53 /* Macro declarations */
dflet 0:400d8e75a8d0 54 /*****************************************************************************/
dflet 0:400d8e75a8d0 55 const uint32_t NETAPP_MDNS_OPTIONS_ADD_SERVICE_BIT = ((uint32_t)0x1 << 31);
dflet 0:400d8e75a8d0 56
dflet 0:400d8e75a8d0 57 #ifdef SL_TINY
dflet 0:400d8e75a8d0 58 const uint8_t NETAPP_MDNS_MAX_SERVICE_NAME_AND_TEXT_LENGTH = 63;
dflet 0:400d8e75a8d0 59 #else
dflet 0:400d8e75a8d0 60 const uint8_t NETAPP_MDNS_MAX_SERVICE_NAME_AND_TEXT_LENGTH = 255;
dflet 0:400d8e75a8d0 61 #endif
dflet 0:400d8e75a8d0 62
dflet 0:400d8e75a8d0 63 #ifndef SL_PLATFORM_MULTI_THREADED
dflet 0:400d8e75a8d0 64 cc3100_netapp::cc3100_netapp(cc3100_driver &driver, cc3100_nonos &nonos)
dflet 0:400d8e75a8d0 65 : _driver(driver), _nonos(nonos)
dflet 0:400d8e75a8d0 66 {
dflet 0:400d8e75a8d0 67 }
dflet 0:400d8e75a8d0 68 #else
dflet 0:400d8e75a8d0 69 cc3100_netapp::cc3100_netapp(cc3100_driver &driver)
dflet 0:400d8e75a8d0 70 : _driver(driver)
dflet 0:400d8e75a8d0 71 {
dflet 0:400d8e75a8d0 72 }
dflet 0:400d8e75a8d0 73 #endif
dflet 0:400d8e75a8d0 74 cc3100_netapp::~cc3100_netapp()
dflet 0:400d8e75a8d0 75 {
dflet 0:400d8e75a8d0 76
dflet 0:400d8e75a8d0 77 }
dflet 0:400d8e75a8d0 78
dflet 0:400d8e75a8d0 79
dflet 0:400d8e75a8d0 80 /*****************************************************************************/
dflet 0:400d8e75a8d0 81 /* API functions */
dflet 0:400d8e75a8d0 82 /*****************************************************************************/
dflet 0:400d8e75a8d0 83
dflet 0:400d8e75a8d0 84 /*****************************************************************************
dflet 0:400d8e75a8d0 85 sl_NetAppStart
dflet 0:400d8e75a8d0 86 *****************************************************************************/
dflet 0:400d8e75a8d0 87 typedef union {
dflet 0:400d8e75a8d0 88 _NetAppStartStopCommand_t Cmd;
dflet 0:400d8e75a8d0 89 _NetAppStartStopResponse_t Rsp;
dflet 0:400d8e75a8d0 90 } _SlNetAppStartStopMsg_u;
dflet 0:400d8e75a8d0 91
dflet 0:400d8e75a8d0 92 #if _SL_INCLUDE_FUNC(sl_NetAppStart)
dflet 0:400d8e75a8d0 93 const _SlCmdCtrl_t _SlNetAppStartCtrl = {
dflet 0:400d8e75a8d0 94 SL_OPCODE_NETAPP_START_COMMAND,
dflet 0:400d8e75a8d0 95 sizeof(_NetAppStartStopCommand_t),
dflet 0:400d8e75a8d0 96 sizeof(_NetAppStartStopResponse_t)
dflet 0:400d8e75a8d0 97 };
dflet 0:400d8e75a8d0 98
dflet 0:400d8e75a8d0 99 int16_t cc3100_netapp::sl_NetAppStart(const uint32_t AppBitMap)
dflet 0:400d8e75a8d0 100 {
dflet 0:400d8e75a8d0 101 _SlNetAppStartStopMsg_u Msg;
dflet 0:400d8e75a8d0 102 Msg.Cmd.appId = AppBitMap;
dflet 0:400d8e75a8d0 103 VERIFY_RET_OK(_driver._SlDrvCmdOp((_SlCmdCtrl_t *)&_SlNetAppStartCtrl, &Msg, NULL));
dflet 0:400d8e75a8d0 104
dflet 0:400d8e75a8d0 105 return Msg.Rsp.status;
dflet 0:400d8e75a8d0 106 }
dflet 0:400d8e75a8d0 107 #endif
dflet 0:400d8e75a8d0 108
dflet 0:400d8e75a8d0 109 /*****************************************************************************
dflet 0:400d8e75a8d0 110 sl_NetAppStop
dflet 0:400d8e75a8d0 111 *****************************************************************************/
dflet 0:400d8e75a8d0 112 #if _SL_INCLUDE_FUNC(sl_NetAppStop)
dflet 0:400d8e75a8d0 113 const _SlCmdCtrl_t _SlNetAppStopCtrl =
dflet 0:400d8e75a8d0 114 {
dflet 0:400d8e75a8d0 115 SL_OPCODE_NETAPP_STOP_COMMAND,
dflet 0:400d8e75a8d0 116 sizeof(_NetAppStartStopCommand_t),
dflet 0:400d8e75a8d0 117 sizeof(_NetAppStartStopResponse_t)
dflet 0:400d8e75a8d0 118 };
dflet 0:400d8e75a8d0 119 int16_t cc3100_netapp::sl_NetAppStop(const uint32_t AppBitMap)
dflet 0:400d8e75a8d0 120 {
dflet 0:400d8e75a8d0 121
dflet 0:400d8e75a8d0 122 _SlNetAppStartStopMsg_u Msg;
dflet 0:400d8e75a8d0 123 Msg.Cmd.appId = AppBitMap;
dflet 0:400d8e75a8d0 124 VERIFY_RET_OK(_driver._SlDrvCmdOp((_SlCmdCtrl_t *)&_SlNetAppStopCtrl, &Msg, NULL));
dflet 0:400d8e75a8d0 125
dflet 0:400d8e75a8d0 126 return Msg.Rsp.status;
dflet 0:400d8e75a8d0 127 }
dflet 0:400d8e75a8d0 128 #endif
dflet 0:400d8e75a8d0 129
dflet 0:400d8e75a8d0 130
dflet 0:400d8e75a8d0 131 /******************************************************************************/
dflet 0:400d8e75a8d0 132 /* sl_NetAppGetServiceList */
dflet 0:400d8e75a8d0 133 /******************************************************************************/
dflet 0:400d8e75a8d0 134 typedef struct {
dflet 0:400d8e75a8d0 135 uint8_t IndexOffest;
dflet 0:400d8e75a8d0 136 uint8_t MaxServiceCount;
dflet 0:400d8e75a8d0 137 uint8_t Flags;
dflet 0:400d8e75a8d0 138 int8_t Padding;
dflet 0:400d8e75a8d0 139 } NetappGetServiceListCMD_t;
dflet 0:400d8e75a8d0 140
dflet 0:400d8e75a8d0 141 typedef union {
dflet 0:400d8e75a8d0 142 NetappGetServiceListCMD_t Cmd;
dflet 0:400d8e75a8d0 143 _BasicResponse_t Rsp;
dflet 0:400d8e75a8d0 144 } _SlNetappGetServiceListMsg_u;
dflet 0:400d8e75a8d0 145
dflet 0:400d8e75a8d0 146 #if _SL_INCLUDE_FUNC(sl_NetAppGetServiceList)
dflet 0:400d8e75a8d0 147 const _SlCmdCtrl_t _SlGetServiceListeCtrl = {
dflet 0:400d8e75a8d0 148 SL_OPCODE_NETAPP_NETAPP_MDNS_LOOKUP_SERVICE,
dflet 0:400d8e75a8d0 149 sizeof(NetappGetServiceListCMD_t),
dflet 0:400d8e75a8d0 150 sizeof(_BasicResponse_t)
dflet 0:400d8e75a8d0 151 };
dflet 0:400d8e75a8d0 152
dflet 0:400d8e75a8d0 153 int16_t cc3100_netapp::sl_NetAppGetServiceList(const uint8_t IndexOffest,
dflet 0:400d8e75a8d0 154 const uint8_t MaxServiceCount,
dflet 0:400d8e75a8d0 155 const uint8_t Flags,
dflet 0:400d8e75a8d0 156 int8_t *pBuffer,
dflet 0:400d8e75a8d0 157 const uint32_t RxBufferLength
dflet 0:400d8e75a8d0 158 )
dflet 0:400d8e75a8d0 159 {
dflet 0:400d8e75a8d0 160 int32_t retVal= 0;
dflet 0:400d8e75a8d0 161 _SlNetappGetServiceListMsg_u Msg;
dflet 0:400d8e75a8d0 162 _SlCmdExt_t CmdExt;
dflet 0:400d8e75a8d0 163 uint16_t ServiceSize = 0;
dflet 0:400d8e75a8d0 164 uint16_t BufferSize = 0;
dflet 0:400d8e75a8d0 165
dflet 0:400d8e75a8d0 166 /*
dflet 0:400d8e75a8d0 167 Calculate RX pBuffer size
dflet 0:400d8e75a8d0 168 WARNING:
dflet 0:400d8e75a8d0 169 if this size is BufferSize than 1480 error should be returned because there
dflet 0:400d8e75a8d0 170 is no place in the RX packet.
dflet 0:400d8e75a8d0 171 */
dflet 0:400d8e75a8d0 172 switch(Flags) {
dflet 0:400d8e75a8d0 173 case SL_NET_APP_FULL_SERVICE_WITH_TEXT_IPV4_TYPE:
dflet 0:400d8e75a8d0 174 ServiceSize = sizeof(SlNetAppGetFullServiceWithTextIpv4List_t);
dflet 0:400d8e75a8d0 175 break;
dflet 0:400d8e75a8d0 176
dflet 0:400d8e75a8d0 177 case SL_NET_APP_FULL_SERVICE_IPV4_TYPE:
dflet 0:400d8e75a8d0 178 ServiceSize = sizeof(SlNetAppGetFullServiceIpv4List_t);
dflet 0:400d8e75a8d0 179 break;
dflet 0:400d8e75a8d0 180
dflet 0:400d8e75a8d0 181 case SL_NET_APP_SHORT_SERVICE_IPV4_TYPE:
dflet 0:400d8e75a8d0 182 ServiceSize = sizeof(SlNetAppGetShortServiceIpv4List_t);
dflet 0:400d8e75a8d0 183 break;
dflet 0:400d8e75a8d0 184
dflet 0:400d8e75a8d0 185 default:
dflet 0:400d8e75a8d0 186 ServiceSize = sizeof(_BasicResponse_t);
dflet 0:400d8e75a8d0 187 break;
dflet 0:400d8e75a8d0 188 }
dflet 0:400d8e75a8d0 189
dflet 0:400d8e75a8d0 190
dflet 0:400d8e75a8d0 191
dflet 0:400d8e75a8d0 192 BufferSize = MaxServiceCount * ServiceSize;
dflet 0:400d8e75a8d0 193
dflet 0:400d8e75a8d0 194 /*Check the size of the requested services is smaller than size of the user buffer.
dflet 0:400d8e75a8d0 195 If not an error is returned in order to avoid overwriting memory. */
dflet 0:400d8e75a8d0 196 if(RxBufferLength <= BufferSize) {
dflet 0:400d8e75a8d0 197 return SL_ERROR_NETAPP_RX_BUFFER_LENGTH_ERROR;
dflet 0:400d8e75a8d0 198 }
dflet 0:400d8e75a8d0 199
dflet 0:400d8e75a8d0 200 _driver._SlDrvResetCmdExt(&CmdExt);
dflet 0:400d8e75a8d0 201 CmdExt.RxPayloadLen = BufferSize;
dflet 0:400d8e75a8d0 202
dflet 0:400d8e75a8d0 203 CmdExt.pRxPayload = (uint8_t *)pBuffer;
dflet 0:400d8e75a8d0 204
dflet 0:400d8e75a8d0 205 Msg.Cmd.IndexOffest = IndexOffest;
dflet 0:400d8e75a8d0 206 Msg.Cmd.MaxServiceCount = MaxServiceCount;
dflet 0:400d8e75a8d0 207 Msg.Cmd.Flags = Flags;
dflet 0:400d8e75a8d0 208 Msg.Cmd.Padding = 0;
dflet 0:400d8e75a8d0 209
dflet 0:400d8e75a8d0 210 VERIFY_RET_OK(_driver._SlDrvCmdOp((_SlCmdCtrl_t *)&_SlGetServiceListeCtrl, &Msg, &CmdExt));
dflet 0:400d8e75a8d0 211 retVal = Msg.Rsp.status;
dflet 0:400d8e75a8d0 212
dflet 0:400d8e75a8d0 213 return (int16_t)retVal;
dflet 0:400d8e75a8d0 214 }
dflet 0:400d8e75a8d0 215
dflet 0:400d8e75a8d0 216 #endif
dflet 0:400d8e75a8d0 217
dflet 0:400d8e75a8d0 218 /*****************************************************************************/
dflet 0:400d8e75a8d0 219 /* sl_mDNSRegisterService */
dflet 0:400d8e75a8d0 220 /*****************************************************************************/
dflet 0:400d8e75a8d0 221 /*
dflet 0:400d8e75a8d0 222 * The below struct depicts the constant parameters of the command/API RegisterService.
dflet 0:400d8e75a8d0 223 *
dflet 0:400d8e75a8d0 224 1. ServiceLen - The length of the service should be smaller than NETAPP_MDNS_MAX_SERVICE_NAME_AND_TEXT_LENGTH.
dflet 0:400d8e75a8d0 225 2. TextLen - The length of the text should be smaller than NETAPP_MDNS_MAX_SERVICE_NAME_AND_TEXT_LENGTH.
dflet 0:400d8e75a8d0 226 3. port - The port on this target host.
dflet 0:400d8e75a8d0 227 4. TTL - The TTL of the service
dflet 0:400d8e75a8d0 228 5. Options - bitwise parameters:
dflet 0:400d8e75a8d0 229 bit 0 - is unique (means if the service needs to be unique)
dflet 0:400d8e75a8d0 230 bit 31 - for internal use if the service should be added or deleted (set means ADD).
dflet 0:400d8e75a8d0 231 bit 1-30 for future.
dflet 0:400d8e75a8d0 232
dflet 0:400d8e75a8d0 233 NOTE:
dflet 0:400d8e75a8d0 234
dflet 0:400d8e75a8d0 235 1. There are another variable parameter is this API which is the service name and the text.
dflet 0:400d8e75a8d0 236 2. According to now there is no warning and Async event to user on if the service is a unique.
dflet 0:400d8e75a8d0 237 *
dflet 0:400d8e75a8d0 238 */
dflet 0:400d8e75a8d0 239
dflet 0:400d8e75a8d0 240 typedef struct {
dflet 0:400d8e75a8d0 241 uint8_t ServiceNameLen;
dflet 0:400d8e75a8d0 242 uint8_t TextLen;
dflet 0:400d8e75a8d0 243 uint16_t Port;
dflet 0:400d8e75a8d0 244 uint32_t TTL;
dflet 0:400d8e75a8d0 245 uint32_t Options;
dflet 0:400d8e75a8d0 246 } NetappMdnsSetService_t;
dflet 0:400d8e75a8d0 247
dflet 0:400d8e75a8d0 248 typedef union {
dflet 0:400d8e75a8d0 249 NetappMdnsSetService_t Cmd;
dflet 0:400d8e75a8d0 250 _BasicResponse_t Rsp;
dflet 0:400d8e75a8d0 251 } _SlNetappMdnsRegisterServiceMsg_u;
dflet 0:400d8e75a8d0 252
dflet 0:400d8e75a8d0 253 #if _SL_INCLUDE_FUNC(sl_NetAppMDNSRegisterUnregisterService)
dflet 0:400d8e75a8d0 254 const _SlCmdCtrl_t _SlRegisterServiceCtrl = {
dflet 0:400d8e75a8d0 255 SL_OPCODE_NETAPP_MDNSREGISTERSERVICE,
dflet 0:400d8e75a8d0 256 sizeof(NetappMdnsSetService_t),
dflet 0:400d8e75a8d0 257 sizeof(_BasicResponse_t)
dflet 0:400d8e75a8d0 258 };
dflet 0:400d8e75a8d0 259
dflet 0:400d8e75a8d0 260 /******************************************************************************
dflet 0:400d8e75a8d0 261
dflet 0:400d8e75a8d0 262 sl_NetAppMDNSRegisterService
dflet 0:400d8e75a8d0 263
dflet 0:400d8e75a8d0 264 CALLER user from its host
dflet 0:400d8e75a8d0 265
dflet 0:400d8e75a8d0 266
dflet 0:400d8e75a8d0 267 DESCRIPTION:
dflet 0:400d8e75a8d0 268 Add/delete service
dflet 0:400d8e75a8d0 269 The function manipulates the command that register the service and call
dflet 0:400d8e75a8d0 270 to the NWP in order to add/delete the service to/from the mDNS package and to/from the DB.
dflet 0:400d8e75a8d0 271
dflet 0:400d8e75a8d0 272 This register service is a service offered by the application.
dflet 0:400d8e75a8d0 273 This unregister service is a service offered by the application before.
dflet 0:400d8e75a8d0 274
dflet 0:400d8e75a8d0 275 The service name should be full service name according to RFC
dflet 0:400d8e75a8d0 276 of the DNS-SD - means the value in name field in SRV answer.
dflet 0:400d8e75a8d0 277
dflet 0:400d8e75a8d0 278 Example for service name:
dflet 0:400d8e75a8d0 279 1. PC1._ipp._tcp.local
dflet 0:400d8e75a8d0 280 2. PC2_server._ftp._tcp.local
dflet 0:400d8e75a8d0 281
dflet 0:400d8e75a8d0 282 If the option is_unique is set, mDNS probes the service name to make sure
dflet 0:400d8e75a8d0 283 it is unique before starting to announce the service on the network.
dflet 0:400d8e75a8d0 284 Instance is the instance portion of the service name.
dflet 0:400d8e75a8d0 285
dflet 0:400d8e75a8d0 286
dflet 0:400d8e75a8d0 287
dflet 0:400d8e75a8d0 288
dflet 0:400d8e75a8d0 289 PARAMETERS:
dflet 0:400d8e75a8d0 290
dflet 0:400d8e75a8d0 291 The command is from constant parameters and variables parameters.
dflet 0:400d8e75a8d0 292
dflet 0:400d8e75a8d0 293 Constant parameters are:
dflet 0:400d8e75a8d0 294
dflet 0:400d8e75a8d0 295 ServiceLen - The length of the service.
dflet 0:400d8e75a8d0 296 TextLen - The length of the service should be smaller than 64.
dflet 0:400d8e75a8d0 297 port - The port on this target host.
dflet 0:400d8e75a8d0 298 TTL - The TTL of the service
dflet 0:400d8e75a8d0 299 Options - bitwise parameters:
dflet 0:400d8e75a8d0 300 bit 0 - is unique (means if the service needs to be unique)
dflet 0:400d8e75a8d0 301 bit 31 - for internal use if the service should be added or deleted (set means ADD).
dflet 0:400d8e75a8d0 302 bit 1-30 for future.
dflet 0:400d8e75a8d0 303
dflet 0:400d8e75a8d0 304 The variables parameters are:
dflet 0:400d8e75a8d0 305
dflet 0:400d8e75a8d0 306 Service name(full service name) - The service name.
dflet 0:400d8e75a8d0 307 Example for service name:
dflet 0:400d8e75a8d0 308 1. PC1._ipp._tcp.local
dflet 0:400d8e75a8d0 309 2. PC2_server._ftp._tcp.local
dflet 0:400d8e75a8d0 310
dflet 0:400d8e75a8d0 311 Text - The description of the service.
dflet 0:400d8e75a8d0 312 should be as mentioned in the RFC
dflet 0:400d8e75a8d0 313 (according to type of the service IPP,FTP...)
dflet 0:400d8e75a8d0 314
dflet 0:400d8e75a8d0 315 NOTE - pay attention
dflet 0:400d8e75a8d0 316
dflet 0:400d8e75a8d0 317 1. Temporary - there is an allocation on stack of internal buffer.
dflet 0:400d8e75a8d0 318 Its size is NETAPP_MDNS_MAX_SERVICE_NAME_AND_TEXT_LENGTH.
dflet 0:400d8e75a8d0 319 It means that the sum of the text length and service name length cannot be bigger than
dflet 0:400d8e75a8d0 320 NETAPP_MDNS_MAX_SERVICE_NAME_AND_TEXT_LENGTH.
dflet 0:400d8e75a8d0 321 If it is - An error is returned.
dflet 0:400d8e75a8d0 322
dflet 0:400d8e75a8d0 323 2. According to now from certain constraints the variables parameters are set in the
dflet 0:400d8e75a8d0 324 attribute part (contain constant parameters)
dflet 0:400d8e75a8d0 325
dflet 0:400d8e75a8d0 326
dflet 0:400d8e75a8d0 327
dflet 0:400d8e75a8d0 328 RETURNS: Status - the immediate response of the command status.
dflet 0:400d8e75a8d0 329 0 means success.
dflet 0:400d8e75a8d0 330
dflet 0:400d8e75a8d0 331
dflet 0:400d8e75a8d0 332
dflet 0:400d8e75a8d0 333 ******************************************************************************/
dflet 0:400d8e75a8d0 334 int16_t cc3100_netapp::sl_NetAppMDNSRegisterUnregisterService(const char* pServiceName,
dflet 0:400d8e75a8d0 335 const uint8_t ServiceNameLen,
dflet 0:400d8e75a8d0 336 const char* pText,
dflet 0:400d8e75a8d0 337 const uint8_t TextLen,
dflet 0:400d8e75a8d0 338 const uint16_t Port,
dflet 0:400d8e75a8d0 339 const uint32_t TTL,
dflet 0:400d8e75a8d0 340 const uint32_t Options)
dflet 0:400d8e75a8d0 341 {
dflet 0:400d8e75a8d0 342
dflet 0:400d8e75a8d0 343 _SlNetappMdnsRegisterServiceMsg_u Msg;
dflet 0:400d8e75a8d0 344 _SlCmdExt_t CmdExt ;
dflet 0:400d8e75a8d0 345 unsigned char ServiceNameAndTextBuffer[NETAPP_MDNS_MAX_SERVICE_NAME_AND_TEXT_LENGTH];
dflet 0:400d8e75a8d0 346 unsigned char *TextPtr;
dflet 0:400d8e75a8d0 347
dflet 0:400d8e75a8d0 348 /*
dflet 0:400d8e75a8d0 349
dflet 0:400d8e75a8d0 350 NOTE - pay attention
dflet 0:400d8e75a8d0 351
dflet 0:400d8e75a8d0 352 1. Temporary - there is an allocation on stack of internal buffer.
dflet 0:400d8e75a8d0 353 Its size is NETAPP_MDNS_MAX_SERVICE_NAME_AND_TEXT_LENGTH.
dflet 0:400d8e75a8d0 354 It means that the sum of the text length and service name length cannot be bigger than
dflet 0:400d8e75a8d0 355 NETAPP_MDNS_MAX_SERVICE_NAME_AND_TEXT_LENGTH.
dflet 0:400d8e75a8d0 356 If it is - An error is returned.
dflet 0:400d8e75a8d0 357
dflet 0:400d8e75a8d0 358 2. According to now from certain constraints the variables parameters are set in the
dflet 0:400d8e75a8d0 359 attribute part (contain constant parameters)
dflet 0:400d8e75a8d0 360
dflet 0:400d8e75a8d0 361
dflet 0:400d8e75a8d0 362 */
dflet 0:400d8e75a8d0 363
dflet 0:400d8e75a8d0 364 /*build the attribute part of the command.
dflet 0:400d8e75a8d0 365 It contains the constant parameters of the command*/
dflet 0:400d8e75a8d0 366
dflet 0:400d8e75a8d0 367 Msg.Cmd.ServiceNameLen = ServiceNameLen;
dflet 0:400d8e75a8d0 368 Msg.Cmd.Options = Options;
dflet 0:400d8e75a8d0 369 Msg.Cmd.Port = Port;
dflet 0:400d8e75a8d0 370 Msg.Cmd.TextLen = TextLen;
dflet 0:400d8e75a8d0 371 Msg.Cmd.TTL = TTL;
dflet 0:400d8e75a8d0 372
dflet 0:400d8e75a8d0 373 /*Build the payload part of the command
dflet 0:400d8e75a8d0 374 Copy the service name and text to one buffer.
dflet 0:400d8e75a8d0 375 NOTE - pay attention
dflet 0:400d8e75a8d0 376 The size of the service length + the text length should be smaller than 255,
dflet 0:400d8e75a8d0 377 Until the simplelink drive supports to variable length through SPI command. */
dflet 0:400d8e75a8d0 378 if(TextLen + ServiceNameLen > (NETAPP_MDNS_MAX_SERVICE_NAME_AND_TEXT_LENGTH - 1 )) { /*-1 is for giving a place to set null termination at the end of the text*/
dflet 0:400d8e75a8d0 379 return -1;
dflet 0:400d8e75a8d0 380 }
dflet 0:400d8e75a8d0 381
dflet 0:400d8e75a8d0 382 _driver._SlDrvMemZero(ServiceNameAndTextBuffer, NETAPP_MDNS_MAX_SERVICE_NAME_AND_TEXT_LENGTH);
dflet 0:400d8e75a8d0 383
dflet 0:400d8e75a8d0 384
dflet 0:400d8e75a8d0 385 /*Copy the service name*/
dflet 0:400d8e75a8d0 386 memcpy(ServiceNameAndTextBuffer,
dflet 0:400d8e75a8d0 387 pServiceName,
dflet 0:400d8e75a8d0 388 ServiceNameLen);
dflet 0:400d8e75a8d0 389
dflet 0:400d8e75a8d0 390 if(TextLen > 0 ) {
dflet 0:400d8e75a8d0 391
dflet 0:400d8e75a8d0 392 TextPtr = &ServiceNameAndTextBuffer[ServiceNameLen];
dflet 0:400d8e75a8d0 393 /*Copy the text just after the service name*/
dflet 0:400d8e75a8d0 394 memcpy(TextPtr, pText, TextLen);
dflet 0:400d8e75a8d0 395 }
dflet 0:400d8e75a8d0 396
dflet 0:400d8e75a8d0 397 _driver._SlDrvResetCmdExt(&CmdExt);
dflet 0:400d8e75a8d0 398 CmdExt.TxPayloadLen = (TextLen + ServiceNameLen);
dflet 0:400d8e75a8d0 399 CmdExt.pTxPayload = (uint8_t *)ServiceNameAndTextBuffer;
dflet 0:400d8e75a8d0 400
dflet 0:400d8e75a8d0 401
dflet 0:400d8e75a8d0 402 VERIFY_RET_OK(_driver._SlDrvCmdOp((_SlCmdCtrl_t *)&_SlRegisterServiceCtrl, &Msg, &CmdExt));
dflet 0:400d8e75a8d0 403
dflet 0:400d8e75a8d0 404 return (int16_t)Msg.Rsp.status;
dflet 0:400d8e75a8d0 405
dflet 0:400d8e75a8d0 406
dflet 0:400d8e75a8d0 407 }
dflet 0:400d8e75a8d0 408 #endif
dflet 0:400d8e75a8d0 409
dflet 0:400d8e75a8d0 410 /**********************************************************************************************/
dflet 0:400d8e75a8d0 411 #if _SL_INCLUDE_FUNC(sl_NetAppMDNSRegisterService)
dflet 0:400d8e75a8d0 412 int16_t cc3100_netapp::sl_NetAppMDNSRegisterService(const char* pServiceName,
dflet 0:400d8e75a8d0 413 const uint8_t ServiceNameLen,
dflet 0:400d8e75a8d0 414 const char* pText,
dflet 0:400d8e75a8d0 415 const uint8_t TextLen,
dflet 0:400d8e75a8d0 416 const uint16_t Port,
dflet 0:400d8e75a8d0 417 const uint32_t TTL,
dflet 0:400d8e75a8d0 418 uint32_t Options)
dflet 0:400d8e75a8d0 419 {
dflet 0:400d8e75a8d0 420
dflet 0:400d8e75a8d0 421 /*
dflet 0:400d8e75a8d0 422
dflet 0:400d8e75a8d0 423 NOTE - pay attention
dflet 0:400d8e75a8d0 424
dflet 0:400d8e75a8d0 425 1. Temporary - there is an allocation on stack of internal buffer.
dflet 0:400d8e75a8d0 426 Its size is NETAPP_MDNS_MAX_SERVICE_NAME_AND_TEXT_LENGTH.
dflet 0:400d8e75a8d0 427 It means that the sum of the text length and service name length cannot be bigger than
dflet 0:400d8e75a8d0 428 NETAPP_MDNS_MAX_SERVICE_NAME_AND_TEXT_LENGTH.
dflet 0:400d8e75a8d0 429 If it is - An error is returned.
dflet 0:400d8e75a8d0 430
dflet 0:400d8e75a8d0 431 2. According to now from certain constraints the variables parameters are set in the
dflet 0:400d8e75a8d0 432 attribute part (contain constant parameters)
dflet 0:400d8e75a8d0 433
dflet 0:400d8e75a8d0 434 */
dflet 0:400d8e75a8d0 435
dflet 0:400d8e75a8d0 436 /*Set the add service bit in the options parameter.
dflet 0:400d8e75a8d0 437 In order not use different opcodes for the register service and unregister service
dflet 0:400d8e75a8d0 438 bit 31 in option is taken for this purpose. if it is set it means in NWP that the service should be added
dflet 0:400d8e75a8d0 439 if it is cleared it means that the service should be deleted and there is only meaning to pServiceName
dflet 0:400d8e75a8d0 440 and ServiceNameLen values. */
dflet 0:400d8e75a8d0 441 Options |= NETAPP_MDNS_OPTIONS_ADD_SERVICE_BIT;
dflet 0:400d8e75a8d0 442
dflet 0:400d8e75a8d0 443 return (sl_NetAppMDNSRegisterUnregisterService( pServiceName, ServiceNameLen, pText, TextLen, Port, TTL, Options));
dflet 0:400d8e75a8d0 444
dflet 0:400d8e75a8d0 445
dflet 0:400d8e75a8d0 446 }
dflet 0:400d8e75a8d0 447 #endif
dflet 0:400d8e75a8d0 448 /**********************************************************************************************/
dflet 0:400d8e75a8d0 449
dflet 0:400d8e75a8d0 450
dflet 0:400d8e75a8d0 451
dflet 0:400d8e75a8d0 452 /**********************************************************************************************/
dflet 0:400d8e75a8d0 453 #if _SL_INCLUDE_FUNC(sl_NetAppMDNSUnRegisterService)
dflet 0:400d8e75a8d0 454 int16_t cc3100_netapp::sl_NetAppMDNSUnRegisterService(const char* pServiceName, const uint8_t ServiceNameLen)
dflet 0:400d8e75a8d0 455 {
dflet 0:400d8e75a8d0 456 uint32_t Options = 0;
dflet 0:400d8e75a8d0 457
dflet 0:400d8e75a8d0 458 /*
dflet 0:400d8e75a8d0 459
dflet 0:400d8e75a8d0 460 NOTE - pay attention
dflet 0:400d8e75a8d0 461
dflet 0:400d8e75a8d0 462 The size of the service length should be smaller than 255,
dflet 0:400d8e75a8d0 463 Until the simplelink drive supports to variable length through SPI command.
dflet 0:400d8e75a8d0 464
dflet 0:400d8e75a8d0 465
dflet 0:400d8e75a8d0 466 */
dflet 0:400d8e75a8d0 467
dflet 0:400d8e75a8d0 468 /*Clear the add service bit in the options parameter.
dflet 0:400d8e75a8d0 469 In order not use different opcodes for the register service and unregister service
dflet 0:400d8e75a8d0 470 bit 31 in option is taken for this purpose. if it is set it means in NWP that the service should be added
dflet 0:400d8e75a8d0 471 if it is cleared it means that the service should be deleted and there is only meaning to pServiceName
dflet 0:400d8e75a8d0 472 and ServiceNameLen values.*/
dflet 0:400d8e75a8d0 473
dflet 0:400d8e75a8d0 474 Options &= (~NETAPP_MDNS_OPTIONS_ADD_SERVICE_BIT);
dflet 0:400d8e75a8d0 475
dflet 0:400d8e75a8d0 476 return (sl_NetAppMDNSRegisterUnregisterService(pServiceName, ServiceNameLen, NULL, 0, 0, 0, Options));
dflet 0:400d8e75a8d0 477
dflet 0:400d8e75a8d0 478
dflet 0:400d8e75a8d0 479 }
dflet 0:400d8e75a8d0 480 #endif
dflet 0:400d8e75a8d0 481 /**********************************************************************************************/
dflet 0:400d8e75a8d0 482
dflet 0:400d8e75a8d0 483
dflet 0:400d8e75a8d0 484
dflet 0:400d8e75a8d0 485 /*****************************************************************************/
dflet 0:400d8e75a8d0 486 /* sl_DnsGetHostByService */
dflet 0:400d8e75a8d0 487 /*****************************************************************************/
dflet 0:400d8e75a8d0 488 /*
dflet 0:400d8e75a8d0 489 * The below struct depicts the constant parameters of the command/API sl_DnsGetHostByService.
dflet 0:400d8e75a8d0 490 *
dflet 0:400d8e75a8d0 491 1. ServiceLen - The length of the service should be smaller than 255.
dflet 0:400d8e75a8d0 492 2. AddrLen - TIPv4 or IPv6 (SL_AF_INET , SL_AF_INET6).
dflet 0:400d8e75a8d0 493 *
dflet 0:400d8e75a8d0 494 */
dflet 0:400d8e75a8d0 495
dflet 0:400d8e75a8d0 496 typedef struct {
dflet 0:400d8e75a8d0 497 uint8_t ServiceLen;
dflet 0:400d8e75a8d0 498 uint8_t AddrLen;
dflet 0:400d8e75a8d0 499 uint16_t Padding;
dflet 0:400d8e75a8d0 500 } _GetHostByServiceCommand_t;
dflet 0:400d8e75a8d0 501
dflet 0:400d8e75a8d0 502
dflet 0:400d8e75a8d0 503
dflet 0:400d8e75a8d0 504 /*
dflet 0:400d8e75a8d0 505 * The below structure depict the constant parameters that are returned in the Async event answer
dflet 0:400d8e75a8d0 506 * according to command/API sl_DnsGetHostByService for IPv4 and IPv6.
dflet 0:400d8e75a8d0 507 *
dflet 0:400d8e75a8d0 508 1Status - The status of the response.
dflet 0:400d8e75a8d0 509 2.Address - Contains the IP address of the service.
dflet 0:400d8e75a8d0 510 3.Port - Contains the port of the service.
dflet 0:400d8e75a8d0 511 4.TextLen - Contains the max length of the text that the user wants to get.
dflet 0:400d8e75a8d0 512 it means that if the test of service is bigger that its value than
dflet 0:400d8e75a8d0 513 the text is cut to inout_TextLen value.
dflet 0:400d8e75a8d0 514 Output: Contain the length of the text that is returned. Can be full text or part
dflet 0:400d8e75a8d0 515 of the text (see above).
dflet 0:400d8e75a8d0 516
dflet 0:400d8e75a8d0 517 *
dflet 0:400d8e75a8d0 518
dflet 0:400d8e75a8d0 519 typedef struct {
dflet 0:400d8e75a8d0 520 uint16_t Status;
dflet 0:400d8e75a8d0 521 uint16_t TextLen;
dflet 0:400d8e75a8d0 522 uint32_t Port;
dflet 0:400d8e75a8d0 523 uint32_t Address;
dflet 0:400d8e75a8d0 524 } _GetHostByServiceIPv4AsyncResponse_t;
dflet 0:400d8e75a8d0 525 */
dflet 0:400d8e75a8d0 526
dflet 0:400d8e75a8d0 527 typedef struct {
dflet 0:400d8e75a8d0 528 uint16_t Status;
dflet 0:400d8e75a8d0 529 uint16_t TextLen;
dflet 0:400d8e75a8d0 530 uint32_t Port;
dflet 0:400d8e75a8d0 531 uint32_t Address[4];
dflet 0:400d8e75a8d0 532 } _GetHostByServiceIPv6AsyncResponse_t;
dflet 0:400d8e75a8d0 533
dflet 0:400d8e75a8d0 534
dflet 0:400d8e75a8d0 535 typedef union {
dflet 0:400d8e75a8d0 536 _GetHostByServiceIPv4AsyncResponse_t IpV4;
dflet 0:400d8e75a8d0 537 _GetHostByServiceIPv6AsyncResponse_t IpV6;
dflet 0:400d8e75a8d0 538 } _GetHostByServiceAsyncResponseAttribute_u;
dflet 0:400d8e75a8d0 539
dflet 0:400d8e75a8d0 540 typedef union {
dflet 0:400d8e75a8d0 541 _GetHostByServiceCommand_t Cmd;
dflet 0:400d8e75a8d0 542 _BasicResponse_t Rsp;
dflet 0:400d8e75a8d0 543 } _SlGetHostByServiceMsg_u;
dflet 0:400d8e75a8d0 544
dflet 0:400d8e75a8d0 545 #if _SL_INCLUDE_FUNC(sl_NetAppDnsGetHostByService)
dflet 0:400d8e75a8d0 546 const _SlCmdCtrl_t _SlGetHostByServiceCtrl = {
dflet 0:400d8e75a8d0 547 SL_OPCODE_NETAPP_MDNSGETHOSTBYSERVICE,
dflet 0:400d8e75a8d0 548 sizeof(_GetHostByServiceCommand_t),
dflet 0:400d8e75a8d0 549 sizeof(_BasicResponse_t)
dflet 0:400d8e75a8d0 550 };
dflet 0:400d8e75a8d0 551
dflet 0:400d8e75a8d0 552 int32_t cc3100_netapp::sl_NetAppDnsGetHostByService(unsigned char *pServiceName, /* string containing all (or only part): name + subtype + service */
dflet 0:400d8e75a8d0 553 const uint8_t ServiceLen,
dflet 0:400d8e75a8d0 554 const uint8_t Family, /* 4-IPv4 , 16-IPv6 */
dflet 0:400d8e75a8d0 555 uint32_t pAddr[],
dflet 0:400d8e75a8d0 556 uint32_t *pPort,
dflet 0:400d8e75a8d0 557 uint16_t *pTextLen, /* in: max len , out: actual len */
dflet 0:400d8e75a8d0 558 unsigned char *pText)
dflet 0:400d8e75a8d0 559 {
dflet 0:400d8e75a8d0 560
dflet 0:400d8e75a8d0 561 _SlGetHostByServiceMsg_u Msg;
dflet 0:400d8e75a8d0 562 _SlCmdExt_t CmdExt ;
dflet 0:400d8e75a8d0 563 _GetHostByServiceAsyncResponse_t AsyncRsp;
dflet 0:400d8e75a8d0 564 uint8_t ObjIdx = MAX_CONCURRENT_ACTIONS;
dflet 0:400d8e75a8d0 565
dflet 0:400d8e75a8d0 566 /*
dflet 0:400d8e75a8d0 567 Note:
dflet 0:400d8e75a8d0 568 1. The return's attributes are belonged to first service that is found.
dflet 0:400d8e75a8d0 569 It can be other services with the same service name will response to
dflet 0:400d8e75a8d0 570 the query. The results of these responses are saved in the peer cache of the NWP, and
dflet 0:400d8e75a8d0 571 should be read by another API.
dflet 0:400d8e75a8d0 572
dflet 0:400d8e75a8d0 573 2. Text length can be 120 bytes only - not more
dflet 0:400d8e75a8d0 574 It is because of constraints in the NWP on the buffer that is allocated for the Async event.
dflet 0:400d8e75a8d0 575
dflet 0:400d8e75a8d0 576 3.The API waits to Async event by blocking. It means that the API is finished only after an Async event
dflet 0:400d8e75a8d0 577 is sent by the NWP.
dflet 0:400d8e75a8d0 578
dflet 0:400d8e75a8d0 579 4.No rolling option!!! - only PTR type is sent.
dflet 0:400d8e75a8d0 580
dflet 0:400d8e75a8d0 581
dflet 0:400d8e75a8d0 582 */
dflet 0:400d8e75a8d0 583 /*build the attribute part of the command.
dflet 0:400d8e75a8d0 584 It contains the constant parameters of the command */
dflet 0:400d8e75a8d0 585
dflet 0:400d8e75a8d0 586 Msg.Cmd.ServiceLen = ServiceLen;
dflet 0:400d8e75a8d0 587 Msg.Cmd.AddrLen = Family;
dflet 0:400d8e75a8d0 588
dflet 0:400d8e75a8d0 589 /*Build the payload part of the command
dflet 0:400d8e75a8d0 590 Copy the service name and text to one buffer.*/
dflet 0:400d8e75a8d0 591 _driver._SlDrvResetCmdExt(&CmdExt);
dflet 0:400d8e75a8d0 592 CmdExt.TxPayloadLen = ServiceLen;
dflet 0:400d8e75a8d0 593
dflet 0:400d8e75a8d0 594 CmdExt.pTxPayload = (uint8_t *)pServiceName;
dflet 0:400d8e75a8d0 595
dflet 0:400d8e75a8d0 596
dflet 0:400d8e75a8d0 597 /*set pointers to the output parameters (the returned parameters).
dflet 0:400d8e75a8d0 598 This pointers are belonged to local struct that is set to global Async response parameter.
dflet 0:400d8e75a8d0 599 It is done in order not to run more than one sl_DnsGetHostByService at the same time.
dflet 0:400d8e75a8d0 600 The API should be run only if global parameter is pointed to NULL. */
dflet 0:400d8e75a8d0 601 AsyncRsp.out_pText = pText;
dflet 0:400d8e75a8d0 602 AsyncRsp.inout_TextLen = (uint16_t* )pTextLen;
dflet 0:400d8e75a8d0 603 AsyncRsp.out_pPort = pPort;
dflet 0:400d8e75a8d0 604 AsyncRsp.out_pAddr = (uint32_t *)pAddr;
dflet 0:400d8e75a8d0 605
dflet 0:400d8e75a8d0 606
dflet 0:400d8e75a8d0 607 ObjIdx = _driver._SlDrvProtectAsyncRespSetting((uint8_t*)&AsyncRsp, GETHOSYBYSERVICE_ID, SL_MAX_SOCKETS);
dflet 0:400d8e75a8d0 608
dflet 0:400d8e75a8d0 609 if (MAX_CONCURRENT_ACTIONS == ObjIdx)
dflet 0:400d8e75a8d0 610 {
dflet 0:400d8e75a8d0 611 return SL_POOL_IS_EMPTY;
dflet 0:400d8e75a8d0 612 }
dflet 0:400d8e75a8d0 613
dflet 0:400d8e75a8d0 614 if (SL_AF_INET6 == Family) {
dflet 0:400d8e75a8d0 615 g_pCB->ObjPool[ObjIdx].AdditionalData |= SL_NETAPP_FAMILY_MASK;
dflet 0:400d8e75a8d0 616 }
dflet 0:400d8e75a8d0 617 /* Send the command */
dflet 0:400d8e75a8d0 618 VERIFY_RET_OK(_driver._SlDrvCmdOp((_SlCmdCtrl_t *)&_SlGetHostByServiceCtrl, &Msg, &CmdExt));
dflet 0:400d8e75a8d0 619
dflet 0:400d8e75a8d0 620
dflet 0:400d8e75a8d0 621
dflet 0:400d8e75a8d0 622 /* If the immediate reponse is O.K. than wait for aSYNC event response. */
dflet 0:400d8e75a8d0 623 if(SL_RET_CODE_OK == Msg.Rsp.status) {
dflet 0:400d8e75a8d0 624 _driver._SlDrvSyncObjWaitForever(&g_pCB->ObjPool[ObjIdx].SyncObj);
dflet 0:400d8e75a8d0 625
dflet 0:400d8e75a8d0 626 /* If we are - it means that Async event was sent.
dflet 0:400d8e75a8d0 627 The results are copied in the Async handle return functions */
dflet 0:400d8e75a8d0 628
dflet 0:400d8e75a8d0 629 Msg.Rsp.status = AsyncRsp.Status;
dflet 0:400d8e75a8d0 630 }
dflet 0:400d8e75a8d0 631
dflet 0:400d8e75a8d0 632 _driver._SlDrvReleasePoolObj(ObjIdx);
dflet 0:400d8e75a8d0 633 return Msg.Rsp.status;
dflet 0:400d8e75a8d0 634 }
dflet 0:400d8e75a8d0 635 #endif
dflet 0:400d8e75a8d0 636
dflet 0:400d8e75a8d0 637 /*****************************************************************************/
dflet 0:400d8e75a8d0 638 /* _sl_HandleAsync_DnsGetHostByAddr */
dflet 0:400d8e75a8d0 639 /*****************************************************************************/
dflet 0:400d8e75a8d0 640 #ifndef SL_TINY_EXT
dflet 0:400d8e75a8d0 641 void cc3100_netapp::_sl_HandleAsync_DnsGetHostByAddr(void *pVoidBuf)
dflet 0:400d8e75a8d0 642 {
dflet 0:400d8e75a8d0 643 SL_TRACE0(DBG_MSG, MSG_303, "STUB: _sl_HandleAsync_DnsGetHostByAddr not implemented yet!");
dflet 0:400d8e75a8d0 644 return;
dflet 0:400d8e75a8d0 645 }
dflet 0:400d8e75a8d0 646 #endif
dflet 0:400d8e75a8d0 647 /*****************************************************************************/
dflet 0:400d8e75a8d0 648 /* sl_DnsGetHostByName */
dflet 0:400d8e75a8d0 649 /*****************************************************************************/
dflet 0:400d8e75a8d0 650 typedef union {
dflet 0:400d8e75a8d0 651 _GetHostByNameIPv4AsyncResponse_t IpV4;
dflet 0:400d8e75a8d0 652 _GetHostByNameIPv6AsyncResponse_t IpV6;
dflet 0:400d8e75a8d0 653 } _GetHostByNameAsyncResponse_u;
dflet 0:400d8e75a8d0 654
dflet 0:400d8e75a8d0 655 typedef union {
dflet 0:400d8e75a8d0 656 _GetHostByNameCommand_t Cmd;
dflet 0:400d8e75a8d0 657 _BasicResponse_t Rsp;
dflet 0:400d8e75a8d0 658 } _SlGetHostByNameMsg_u;
dflet 0:400d8e75a8d0 659
dflet 0:400d8e75a8d0 660 #if _SL_INCLUDE_FUNC(sl_NetAppDnsGetHostByName)
dflet 0:400d8e75a8d0 661 const _SlCmdCtrl_t _SlGetHostByNameCtrl = {
dflet 0:400d8e75a8d0 662 SL_OPCODE_NETAPP_DNSGETHOSTBYNAME,
dflet 0:400d8e75a8d0 663 sizeof(_GetHostByNameCommand_t),
dflet 0:400d8e75a8d0 664 sizeof(_BasicResponse_t)
dflet 0:400d8e75a8d0 665 };
dflet 0:400d8e75a8d0 666
dflet 0:400d8e75a8d0 667 int16_t cc3100_netapp::sl_NetAppDnsGetHostByName(unsigned char * hostname, const uint16_t usNameLen, uint32_t* out_ip_addr, const uint8_t family)
dflet 0:400d8e75a8d0 668 {
dflet 0:400d8e75a8d0 669 _SlGetHostByNameMsg_u Msg;
dflet 0:400d8e75a8d0 670 _SlCmdExt_t ExtCtrl;
dflet 0:400d8e75a8d0 671 _GetHostByNameAsyncResponse_u AsyncRsp;
dflet 0:400d8e75a8d0 672 uint8_t ObjIdx = MAX_CONCURRENT_ACTIONS;
dflet 0:400d8e75a8d0 673
dflet 0:400d8e75a8d0 674 _driver._SlDrvResetCmdExt(&ExtCtrl);
dflet 0:400d8e75a8d0 675 ExtCtrl.TxPayloadLen = usNameLen;
dflet 0:400d8e75a8d0 676
dflet 0:400d8e75a8d0 677 ExtCtrl.pTxPayload = (unsigned char *)hostname;
dflet 0:400d8e75a8d0 678
dflet 0:400d8e75a8d0 679
dflet 0:400d8e75a8d0 680 Msg.Cmd.Len = usNameLen;
dflet 0:400d8e75a8d0 681 Msg.Cmd.family = family;
dflet 0:400d8e75a8d0 682
dflet 0:400d8e75a8d0 683 /*Use Obj to issue the command, if not available try later */
dflet 0:400d8e75a8d0 684 ObjIdx = (uint8_t)_driver._SlDrvWaitForPoolObj(GETHOSYBYNAME_ID,SL_MAX_SOCKETS);
dflet 0:400d8e75a8d0 685 if (MAX_CONCURRENT_ACTIONS == ObjIdx) {
dflet 0:400d8e75a8d0 686 printf("SL_POOL_IS_EMPTY \r\n");
dflet 0:400d8e75a8d0 687 return SL_POOL_IS_EMPTY;
dflet 0:400d8e75a8d0 688 }
dflet 0:400d8e75a8d0 689
dflet 0:400d8e75a8d0 690 _driver._SlDrvProtectionObjLockWaitForever();
dflet 0:400d8e75a8d0 691
dflet 0:400d8e75a8d0 692 g_pCB->ObjPool[ObjIdx].pRespArgs = (uint8_t *)&AsyncRsp;
dflet 0:400d8e75a8d0 693 /*set bit to indicate IPv6 address is expected */
dflet 0:400d8e75a8d0 694 if (SL_AF_INET6 == family) {
dflet 0:400d8e75a8d0 695 g_pCB->ObjPool[ObjIdx].AdditionalData |= SL_NETAPP_FAMILY_MASK;
dflet 0:400d8e75a8d0 696 }
dflet 0:400d8e75a8d0 697
dflet 0:400d8e75a8d0 698 _driver._SlDrvProtectionObjUnLock();
dflet 0:400d8e75a8d0 699
dflet 0:400d8e75a8d0 700 VERIFY_RET_OK(_driver._SlDrvCmdOp((_SlCmdCtrl_t *)&_SlGetHostByNameCtrl, &Msg, &ExtCtrl));
dflet 0:400d8e75a8d0 701
dflet 0:400d8e75a8d0 702 if(SL_RET_CODE_OK == Msg.Rsp.status) {
dflet 0:400d8e75a8d0 703 _driver._SlDrvSyncObjWaitForever(&g_pCB->ObjPool[ObjIdx].SyncObj);
dflet 0:400d8e75a8d0 704 Msg.Rsp.status = AsyncRsp.IpV4.status;
dflet 0:400d8e75a8d0 705
dflet 0:400d8e75a8d0 706 if(SL_OS_RET_CODE_OK == (int16_t)Msg.Rsp.status) {
dflet 0:400d8e75a8d0 707 memcpy((int8_t *)out_ip_addr, (signed char *)&AsyncRsp.IpV4.ip0, (SL_AF_INET == family) ? SL_IPV4_ADDRESS_SIZE : SL_IPV6_ADDRESS_SIZE);
dflet 0:400d8e75a8d0 708 }
dflet 0:400d8e75a8d0 709 }
dflet 0:400d8e75a8d0 710 _driver._SlDrvReleasePoolObj(ObjIdx);
dflet 0:400d8e75a8d0 711 return Msg.Rsp.status;
dflet 0:400d8e75a8d0 712 }
dflet 0:400d8e75a8d0 713 #endif
dflet 0:400d8e75a8d0 714
dflet 0:400d8e75a8d0 715 #ifndef SL_TINY_EXT
dflet 0:400d8e75a8d0 716 void cc3100_netapp::CopyPingResultsToReport(_PingReportResponse_t *pResults,SlPingReport_t *pReport)
dflet 0:400d8e75a8d0 717 {
dflet 0:400d8e75a8d0 718 pReport->PacketsSent = pResults->numSendsPings;
dflet 0:400d8e75a8d0 719 pReport->PacketsReceived = pResults->numSuccsessPings;
dflet 0:400d8e75a8d0 720 pReport->MinRoundTime = pResults->rttMin;
dflet 0:400d8e75a8d0 721 pReport->MaxRoundTime = pResults->rttMax;
dflet 0:400d8e75a8d0 722 pReport->AvgRoundTime = pResults->rttAvg;
dflet 0:400d8e75a8d0 723 pReport->TestTime = pResults->testTime;
dflet 0:400d8e75a8d0 724 }
dflet 0:400d8e75a8d0 725 #endif
dflet 0:400d8e75a8d0 726 /*****************************************************************************/
dflet 0:400d8e75a8d0 727 /* sl_PingStart */
dflet 0:400d8e75a8d0 728 /*****************************************************************************/
dflet 0:400d8e75a8d0 729 typedef union {
dflet 0:400d8e75a8d0 730 _PingStartCommand_t Cmd;
dflet 0:400d8e75a8d0 731 _PingReportResponse_t Rsp;
dflet 0:400d8e75a8d0 732 } _SlPingStartMsg_u;
dflet 0:400d8e75a8d0 733
dflet 0:400d8e75a8d0 734
dflet 0:400d8e75a8d0 735 typedef enum {
dflet 0:400d8e75a8d0 736 CMD_PING_TEST_RUNNING = 0,
dflet 0:400d8e75a8d0 737 CMD_PING_TEST_STOPPED
dflet 0:400d8e75a8d0 738 } _SlPingStatus_e;
dflet 0:400d8e75a8d0 739
dflet 0:400d8e75a8d0 740 P_SL_DEV_PING_CALLBACK pPingCallBackFunc;
dflet 0:400d8e75a8d0 741
dflet 0:400d8e75a8d0 742 #if _SL_INCLUDE_FUNC(sl_NetAppPingStart)
dflet 0:400d8e75a8d0 743 int16_t cc3100_netapp::sl_NetAppPingStart(const SlPingStartCommand_t* pPingParams, const uint8_t family, SlPingReport_t *pReport, const P_SL_DEV_PING_CALLBACK pPingCallback)
dflet 0:400d8e75a8d0 744 {
dflet 0:400d8e75a8d0 745
dflet 0:400d8e75a8d0 746 _SlCmdCtrl_t CmdCtrl = {0, sizeof(_PingStartCommand_t), sizeof(_BasicResponse_t)};
dflet 0:400d8e75a8d0 747 _SlPingStartMsg_u Msg;
dflet 0:400d8e75a8d0 748 _PingReportResponse_t PingRsp;
dflet 0:400d8e75a8d0 749 uint8_t ObjIdx = MAX_CONCURRENT_ACTIONS;
dflet 0:400d8e75a8d0 750
dflet 0:400d8e75a8d0 751 if( 0 == pPingParams->Ip )
dflet 0:400d8e75a8d0 752 { /* stop any ongoing ping */
dflet 0:400d8e75a8d0 753 return _driver._SlDrvBasicCmd(SL_OPCODE_NETAPP_PINGSTOP);
dflet 0:400d8e75a8d0 754 }
dflet 0:400d8e75a8d0 755
dflet 0:400d8e75a8d0 756 if(SL_AF_INET == family) {
dflet 0:400d8e75a8d0 757 CmdCtrl.Opcode = SL_OPCODE_NETAPP_PINGSTART;
dflet 0:400d8e75a8d0 758 memcpy(&Msg.Cmd.ip0, &pPingParams->Ip, SL_IPV4_ADDRESS_SIZE);
dflet 0:400d8e75a8d0 759 } else {
dflet 0:400d8e75a8d0 760 CmdCtrl.Opcode = SL_OPCODE_NETAPP_PINGSTART_V6;
dflet 0:400d8e75a8d0 761 memcpy(&Msg.Cmd.ip0, &pPingParams->Ip, SL_IPV6_ADDRESS_SIZE);
dflet 0:400d8e75a8d0 762 }
dflet 0:400d8e75a8d0 763
dflet 0:400d8e75a8d0 764 Msg.Cmd.pingIntervalTime = pPingParams->PingIntervalTime;
dflet 0:400d8e75a8d0 765 Msg.Cmd.PingSize = pPingParams->PingSize;
dflet 0:400d8e75a8d0 766 Msg.Cmd.pingRequestTimeout = pPingParams->PingRequestTimeout;
dflet 0:400d8e75a8d0 767 Msg.Cmd.totalNumberOfAttempts = pPingParams->TotalNumberOfAttempts;
dflet 0:400d8e75a8d0 768 Msg.Cmd.flags = pPingParams->Flags;
dflet 0:400d8e75a8d0 769
dflet 0:400d8e75a8d0 770 if( pPingCallback ) {
dflet 0:400d8e75a8d0 771 pPingCallBackFunc = pPingCallback;
dflet 0:400d8e75a8d0 772 } else {
dflet 0:400d8e75a8d0 773 /*Use Obj to issue the command, if not available try later */
dflet 0:400d8e75a8d0 774 ObjIdx = (uint8_t)_driver._SlDrvWaitForPoolObj(PING_ID,SL_MAX_SOCKETS);
dflet 0:400d8e75a8d0 775 if (MAX_CONCURRENT_ACTIONS == ObjIdx) {
dflet 0:400d8e75a8d0 776 return SL_POOL_IS_EMPTY;
dflet 0:400d8e75a8d0 777 }
dflet 0:400d8e75a8d0 778 #ifndef SL_PLATFORM_MULTI_THREADED
dflet 0:400d8e75a8d0 779 OSI_RET_OK_CHECK(_nonos.sl_LockObjLock(&g_pCB->ProtectionLockObj, SL_OS_WAIT_FOREVER));
dflet 0:400d8e75a8d0 780 #else
dflet 0:400d8e75a8d0 781 OSI_RET_OK_CHECK(sl_LockObjLock(&g_pCB->ProtectionLockObj, SL_OS_WAIT_FOREVER));
dflet 0:400d8e75a8d0 782 #endif
dflet 0:400d8e75a8d0 783 /* async response handler for non callback mode */
dflet 0:400d8e75a8d0 784 g_pCB->ObjPool[ObjIdx].pRespArgs = (uint8_t *)&PingRsp;
dflet 0:400d8e75a8d0 785 pPingCallBackFunc = NULL;
dflet 0:400d8e75a8d0 786 #ifndef SL_PLATFORM_MULTI_THREADED
dflet 0:400d8e75a8d0 787 OSI_RET_OK_CHECK(_nonos.sl_LockObjUnlock(&g_pCB->ProtectionLockObj));
dflet 0:400d8e75a8d0 788 #else
dflet 0:400d8e75a8d0 789 OSI_RET_OK_CHECK(sl_LockObjUnlock(&g_pCB->ProtectionLockObj));
dflet 0:400d8e75a8d0 790 #endif
dflet 0:400d8e75a8d0 791 }
dflet 0:400d8e75a8d0 792
dflet 0:400d8e75a8d0 793
dflet 0:400d8e75a8d0 794 VERIFY_RET_OK(_driver._SlDrvCmdOp(&CmdCtrl, &Msg, NULL));
dflet 0:400d8e75a8d0 795 /*send the command*/
dflet 0:400d8e75a8d0 796 if(CMD_PING_TEST_RUNNING == (int16_t)Msg.Rsp.status || CMD_PING_TEST_STOPPED == (int16_t)Msg.Rsp.status ) {
dflet 0:400d8e75a8d0 797 /* block waiting for results if no callback function is used */
dflet 0:400d8e75a8d0 798 if( NULL == pPingCallback ) {
dflet 0:400d8e75a8d0 799 _driver._SlDrvSyncObjWaitForever(&g_pCB->ObjPool[ObjIdx].SyncObj);
dflet 0:400d8e75a8d0 800 if( SL_OS_RET_CODE_OK == (int16_t)PingRsp.status ) {
dflet 0:400d8e75a8d0 801 CopyPingResultsToReport(&PingRsp,pReport);
dflet 0:400d8e75a8d0 802 }
dflet 0:400d8e75a8d0 803 _driver._SlDrvReleasePoolObj(ObjIdx);
dflet 0:400d8e75a8d0 804 }
dflet 0:400d8e75a8d0 805 } else {
dflet 0:400d8e75a8d0 806 /* ping failure, no async response */
dflet 0:400d8e75a8d0 807 if( NULL == pPingCallback ) {
dflet 0:400d8e75a8d0 808 _driver._SlDrvReleasePoolObj(ObjIdx);
dflet 0:400d8e75a8d0 809 }
dflet 0:400d8e75a8d0 810 }
dflet 0:400d8e75a8d0 811
dflet 0:400d8e75a8d0 812 return Msg.Rsp.status;
dflet 0:400d8e75a8d0 813 }
dflet 0:400d8e75a8d0 814 #endif
dflet 0:400d8e75a8d0 815
dflet 0:400d8e75a8d0 816 /*****************************************************************************/
dflet 0:400d8e75a8d0 817 /* sl_NetAppSet */
dflet 0:400d8e75a8d0 818 /*****************************************************************************/
dflet 0:400d8e75a8d0 819 typedef union {
dflet 0:400d8e75a8d0 820 _NetAppSetGet_t Cmd;
dflet 0:400d8e75a8d0 821 _BasicResponse_t Rsp;
dflet 0:400d8e75a8d0 822 } _SlNetAppMsgSet_u;
dflet 0:400d8e75a8d0 823
dflet 0:400d8e75a8d0 824 #if _SL_INCLUDE_FUNC(sl_NetAppSet)
dflet 0:400d8e75a8d0 825 const _SlCmdCtrl_t _SlNetAppSetCmdCtrl = {
dflet 0:400d8e75a8d0 826 SL_OPCODE_NETAPP_NETAPPSET,
dflet 0:400d8e75a8d0 827 sizeof(_NetAppSetGet_t),
dflet 0:400d8e75a8d0 828 sizeof(_BasicResponse_t)
dflet 0:400d8e75a8d0 829 };
dflet 0:400d8e75a8d0 830
dflet 0:400d8e75a8d0 831 int32_t cc3100_netapp::sl_NetAppSet(const uint8_t AppId ,const uint8_t Option, const uint8_t OptionLen, const uint8_t *pOptionValue)
dflet 0:400d8e75a8d0 832 {
dflet 0:400d8e75a8d0 833
dflet 0:400d8e75a8d0 834 _SlNetAppMsgSet_u Msg;
dflet 0:400d8e75a8d0 835 _SlCmdExt_t CmdExt;
dflet 0:400d8e75a8d0 836
dflet 0:400d8e75a8d0 837 _driver._SlDrvResetCmdExt(&CmdExt);
dflet 0:400d8e75a8d0 838 CmdExt.TxPayloadLen = (OptionLen+3) & (~3);
dflet 0:400d8e75a8d0 839
dflet 0:400d8e75a8d0 840 CmdExt.pTxPayload = (uint8_t *)pOptionValue;
dflet 0:400d8e75a8d0 841
dflet 0:400d8e75a8d0 842 Msg.Cmd.AppId = AppId;
dflet 0:400d8e75a8d0 843 Msg.Cmd.ConfigLen = OptionLen;
dflet 0:400d8e75a8d0 844 Msg.Cmd.ConfigOpt = Option;
dflet 0:400d8e75a8d0 845
dflet 0:400d8e75a8d0 846 VERIFY_RET_OK(_driver._SlDrvCmdOp((_SlCmdCtrl_t *)&_SlNetAppSetCmdCtrl, &Msg, &CmdExt));
dflet 0:400d8e75a8d0 847
dflet 0:400d8e75a8d0 848 return (int16_t)Msg.Rsp.status;
dflet 0:400d8e75a8d0 849 }
dflet 0:400d8e75a8d0 850 #endif
dflet 0:400d8e75a8d0 851
dflet 0:400d8e75a8d0 852 /*****************************************************************************/
dflet 0:400d8e75a8d0 853 /* sl_NetAppSendTokenValue */
dflet 0:400d8e75a8d0 854 /*****************************************************************************/
dflet 0:400d8e75a8d0 855 typedef union {
dflet 0:400d8e75a8d0 856 sl_NetAppHttpServerSendToken_t Cmd;
dflet 0:400d8e75a8d0 857 _BasicResponse_t Rsp;
dflet 0:400d8e75a8d0 858 } _SlNetAppMsgSendTokenValue_u;
dflet 0:400d8e75a8d0 859
dflet 0:400d8e75a8d0 860 #if defined(sl_HttpServerCallback) || defined(EXT_LIB_REGISTERED_HTTP_SERVER_EVENTS)
dflet 0:400d8e75a8d0 861 const _SlCmdCtrl_t _SlNetAppSendTokenValueCmdCtrl = {
dflet 0:400d8e75a8d0 862 SL_OPCODE_NETAPP_HTTPSENDTOKENVALUE,
dflet 0:400d8e75a8d0 863 sizeof(sl_NetAppHttpServerSendToken_t),
dflet 0:400d8e75a8d0 864 sizeof(_BasicResponse_t)
dflet 0:400d8e75a8d0 865 };
dflet 0:400d8e75a8d0 866
dflet 0:400d8e75a8d0 867 uint16_t cc3100_netapp::sl_NetAppSendTokenValue(slHttpServerData_t * Token_value)
dflet 0:400d8e75a8d0 868 {
dflet 0:400d8e75a8d0 869
dflet 0:400d8e75a8d0 870 _SlNetAppMsgSendTokenValue_u Msg;
dflet 0:400d8e75a8d0 871 _SlCmdExt_t CmdExt;
dflet 0:400d8e75a8d0 872
dflet 0:400d8e75a8d0 873 CmdExt.TxPayloadLen = (Token_value->value_len+3) & (~3);
dflet 0:400d8e75a8d0 874 CmdExt.RxPayloadLen = 0;
dflet 0:400d8e75a8d0 875 CmdExt.pTxPayload = (uint8_t *) Token_value->token_value;
dflet 0:400d8e75a8d0 876 CmdExt.pRxPayload = NULL;
dflet 0:400d8e75a8d0 877
dflet 0:400d8e75a8d0 878 Msg.Cmd.token_value_len = Token_value->value_len;
dflet 0:400d8e75a8d0 879 Msg.Cmd.token_name_len = Token_value->name_len;
dflet 0:400d8e75a8d0 880 memcpy(&Msg.Cmd.token_name[0], Token_value->token_name, Token_value->name_len);
dflet 0:400d8e75a8d0 881
dflet 0:400d8e75a8d0 882
dflet 0:400d8e75a8d0 883 VERIFY_RET_OK(_driver._SlDrvCmdSend((_SlCmdCtrl_t *)&_SlNetAppSendTokenValueCmdCtrl, &Msg, &CmdExt));
dflet 0:400d8e75a8d0 884
dflet 0:400d8e75a8d0 885 return Msg.Rsp.status;
dflet 0:400d8e75a8d0 886 }
dflet 0:400d8e75a8d0 887 #endif
dflet 0:400d8e75a8d0 888
dflet 0:400d8e75a8d0 889 /*****************************************************************************/
dflet 0:400d8e75a8d0 890 /* sl_NetAppGet */
dflet 0:400d8e75a8d0 891 /*****************************************************************************/
dflet 0:400d8e75a8d0 892 typedef union {
dflet 0:400d8e75a8d0 893 _NetAppSetGet_t Cmd;
dflet 0:400d8e75a8d0 894 _NetAppSetGet_t Rsp;
dflet 0:400d8e75a8d0 895 } _SlNetAppMsgGet_u;
dflet 0:400d8e75a8d0 896
dflet 0:400d8e75a8d0 897 #if _SL_INCLUDE_FUNC(sl_NetAppGet)
dflet 0:400d8e75a8d0 898 const _SlCmdCtrl_t _SlNetAppGetCmdCtrl = {
dflet 0:400d8e75a8d0 899 SL_OPCODE_NETAPP_NETAPPGET,
dflet 0:400d8e75a8d0 900 sizeof(_NetAppSetGet_t),
dflet 0:400d8e75a8d0 901 sizeof(_NetAppSetGet_t)
dflet 0:400d8e75a8d0 902 };
dflet 0:400d8e75a8d0 903
dflet 0:400d8e75a8d0 904 int32_t cc3100_netapp::sl_NetAppGet(const uint8_t AppId, const uint8_t Option, uint8_t *pOptionLen, uint8_t *pOptionValue)
dflet 0:400d8e75a8d0 905 {
dflet 0:400d8e75a8d0 906 _SlNetAppMsgGet_u Msg;
dflet 0:400d8e75a8d0 907 _SlCmdExt_t CmdExt;
dflet 0:400d8e75a8d0 908
dflet 0:400d8e75a8d0 909 if (*pOptionLen == 0) {
dflet 0:400d8e75a8d0 910 return SL_EZEROLEN;
dflet 0:400d8e75a8d0 911 }
dflet 0:400d8e75a8d0 912
dflet 0:400d8e75a8d0 913 _driver._SlDrvResetCmdExt(&CmdExt);
dflet 0:400d8e75a8d0 914 CmdExt.RxPayloadLen = *pOptionLen;
dflet 0:400d8e75a8d0 915
dflet 0:400d8e75a8d0 916 CmdExt.pRxPayload = (uint8_t *)pOptionValue;
dflet 0:400d8e75a8d0 917
dflet 0:400d8e75a8d0 918 Msg.Cmd.AppId = AppId;
dflet 0:400d8e75a8d0 919 Msg.Cmd.ConfigOpt = Option;
dflet 0:400d8e75a8d0 920 VERIFY_RET_OK(_driver._SlDrvCmdOp((_SlCmdCtrl_t *)&_SlNetAppGetCmdCtrl, &Msg, &CmdExt));
dflet 0:400d8e75a8d0 921
dflet 0:400d8e75a8d0 922
dflet 0:400d8e75a8d0 923 if (CmdExt.RxPayloadLen < CmdExt.ActualRxPayloadLen) {
dflet 0:400d8e75a8d0 924 *pOptionLen = (uint8_t)CmdExt.RxPayloadLen;
dflet 0:400d8e75a8d0 925 return SL_ESMALLBUF;
dflet 0:400d8e75a8d0 926 } else {
dflet 0:400d8e75a8d0 927 *pOptionLen = (uint8_t)CmdExt.ActualRxPayloadLen;
dflet 0:400d8e75a8d0 928 }
dflet 0:400d8e75a8d0 929
dflet 0:400d8e75a8d0 930 return (int16_t)Msg.Rsp.Status;
dflet 0:400d8e75a8d0 931 }
dflet 0:400d8e75a8d0 932 #endif
dflet 0:400d8e75a8d0 933
dflet 0:400d8e75a8d0 934 #ifndef SL_PLATFORM_MULTI_THREADED
dflet 0:400d8e75a8d0 935 cc3100_flowcont::cc3100_flowcont(cc3100_driver &driver, cc3100_nonos &nonos)
dflet 0:400d8e75a8d0 936 : _driver(driver), _nonos(nonos)
dflet 0:400d8e75a8d0 937 {
dflet 0:400d8e75a8d0 938 }
dflet 0:400d8e75a8d0 939 #else
dflet 0:400d8e75a8d0 940 cc3100_flowcont::cc3100_flowcont(cc3100_driver &driver)
dflet 0:400d8e75a8d0 941 : _driver(driver)
dflet 0:400d8e75a8d0 942 {
dflet 0:400d8e75a8d0 943 }
dflet 0:400d8e75a8d0 944 #endif
dflet 0:400d8e75a8d0 945 cc3100_flowcont::~cc3100_flowcont()
dflet 0:400d8e75a8d0 946 {
dflet 0:400d8e75a8d0 947
dflet 0:400d8e75a8d0 948 }
dflet 0:400d8e75a8d0 949 #if 0
dflet 0:400d8e75a8d0 950 /*****************************************************************************/
dflet 0:400d8e75a8d0 951 /* _SlDrvFlowContInit */
dflet 0:400d8e75a8d0 952 /*****************************************************************************/
dflet 0:400d8e75a8d0 953 void cc3100_flowcont::_SlDrvFlowContInit(void)
dflet 0:400d8e75a8d0 954 {
dflet 0:400d8e75a8d0 955 g_pCB->FlowContCB.TxPoolCnt = FLOW_CONT_MIN;
dflet 0:400d8e75a8d0 956
dflet 0:400d8e75a8d0 957 OSI_RET_OK_CHECK(_nonos.sl_LockObjCreate(&g_pCB->FlowContCB.TxLockObj, "TxLockObj"));
dflet 0:400d8e75a8d0 958
dflet 0:400d8e75a8d0 959 OSI_RET_OK_CHECK(_nonos.sl_SyncObjCreate(&g_pCB->FlowContCB.TxSyncObj, "TxSyncObj"));
dflet 0:400d8e75a8d0 960 }
dflet 0:400d8e75a8d0 961
dflet 0:400d8e75a8d0 962 /*****************************************************************************/
dflet 0:400d8e75a8d0 963 /* _SlDrvFlowContDeinit */
dflet 0:400d8e75a8d0 964 /*****************************************************************************/
dflet 0:400d8e75a8d0 965 void cc3100_flowcont::_SlDrvFlowContDeinit(void)
dflet 0:400d8e75a8d0 966 {
dflet 0:400d8e75a8d0 967 g_pCB->FlowContCB.TxPoolCnt = 0;
dflet 0:400d8e75a8d0 968
dflet 0:400d8e75a8d0 969 OSI_RET_OK_CHECK(_nonos.sl_LockObjDelete(&g_pCB->FlowContCB.TxLockObj, 0));
dflet 0:400d8e75a8d0 970
dflet 0:400d8e75a8d0 971 OSI_RET_OK_CHECK(_nonos.sl_SyncObjDelete(&g_pCB->FlowContCB.TxSyncObj, 0));
dflet 0:400d8e75a8d0 972 }
dflet 0:400d8e75a8d0 973 #endif
dflet 0:400d8e75a8d0 974 }//namespace mbed_cc3100
dflet 0:400d8e75a8d0 975
dflet 0:400d8e75a8d0 976