cc3100_Socket_Wifi_Server with Ethernet Interface not working

Dependencies:   EthernetInterface mbed-rtos mbed

Fork of cc3100_Test_Demo by David Fletcher

simplelink/cc3100_wlan.h

Committer:
dflet
Date:
2015-02-10
Revision:
0:e89ba455dbcf

File content as of revision 0:e89ba455dbcf:

/*
 * wlan.h - CC31xx/CC32xx Host Driver Implementation
 *
 * Copyright (C) 2014 Texas Instruments Incorporated - http://www.ti.com/
 *
 *
 *  Redistribution and use in source and binary forms, with or without
 *  modification, are permitted provided that the following conditions
 *  are met:
 *
 *    Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 *
 *    Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the
 *    distribution.
 *
 *    Neither the name of Texas Instruments Incorporated nor the names of
 *    its contributors may be used to endorse or promote products derived
 *    from this software without specific prior written permission.
 *
 *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 *  A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 *  OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 *  SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 *  LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 *  DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 *  THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 *  (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 *  OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 *
*/

#ifndef WLAN_H_
#define    WLAN_H_

/*****************************************************************************/
/* Include files                                                             */
/*****************************************************************************/
#include "cc3100_simplelink.h"

namespace mbed_cc3100 {

/*****************************************************************************/
/* Macro declarations                                                        */
/*****************************************************************************/

/*!

    \addtogroup wlan
    @{

*/

const uint8_t SL_BSSID_LENGTH                                                                             =    (6);
const uint8_t MAXIMAL_SSID_LENGTH                                                                         =    (32);

const uint8_t NUM_OF_RATE_INDEXES                                                                         =    (20);
const uint8_t SIZE_OF_RSSI_HISTOGRAM                                                                      =    (6);

/* WLAN Disconnect Reason Codes */
const uint8_t  SL_DISCONNECT_RESERVED_0                                                                   =    (0);
const uint8_t  SL_DISCONNECT_UNSPECIFIED_REASON                                                           =    (1);
const uint8_t  SL_PREVIOUS_AUTHENTICATION_NO_LONGER_VALID                                                 =    (2);
const uint8_t  SL_DEAUTHENTICATED_BECAUSE_SENDING_STATION_IS_LEAVING                                      =    (3);
const uint8_t  SL_DISASSOCIATED_DUE_TO_INACTIVITY                                                         =    (4);
const uint8_t  SL_DISASSOCIATED_BECAUSE_AP_IS_UNABLE_TO_HANDLE_ALL_CURRENTLY_ASSOCIATED_STATIONS          =    (5);
const uint8_t  SL_CLASS_2_FRAME_RECEIVED_FROM_NONAUTHENTICATED_STATION                                    =    (6);
const uint8_t  SL_CLASS_3_FRAME_RECEIVED_FROM_NONASSOCIATED_STATION                                       =    (7);
const uint8_t  SL_DISASSOCIATED_BECAUSE_SENDING_STATION_IS_LEAVING_BSS                                    =    (8);
const uint8_t  SL_STATION_REQUESTING_ASSOCIATION_IS_NOT_AUTHENTICATED_WITH_RESPONDING_STATION             =    (9);
const uint8_t  SL_DISASSOCIATED_BECAUSE_THE_INFORMATION_IN_THE_POWER_CAPABILITY_ELEMENT_IS_UNACCEPTABLE   =    (10);
const uint8_t  SL_DISASSOCIATED_BECAUSE_THE_INFORMATION_IN_THE_SUPPORTED_CHANNELS_ELEMENT_IS_UNACCEPTABLE =    (11);
const uint8_t  SL_DISCONNECT_RESERVED_1                                                                   =    (12);
const uint8_t  SL_INVALID_INFORMATION_ELEMENT                                                             =    (13);
const uint8_t  SL_MESSAGE_INTEGRITY_CODE_MIC_FAILURE                                                      =    (14);
const uint8_t  SL_FOUR_WAY_HANDSHAKE_TIMEOUT                                                              =    (15);
const uint8_t  SL_GROUP_KEY_HANDSHAKE_TIMEOUT                                                             =    (16);
const uint8_t  SL_RE_ASSOCIATION_REQUEST_PROBE_RESPONSE_BEACON_FRAME                                      =    (17);
const uint8_t  SL_INVALID_GROUP_CIPHER                                                                    =    (18);
const uint8_t  SL_INVALID_PAIRWISE_CIPHER                                                                 =    (19);
const uint8_t  SL_INVALID_AKMP                                                                            =    (20);
const uint8_t  SL_UNSUPPORTED_RSN_INFORMATION_ELEMENT_VERSION                                             =    (21);
const uint8_t  SL_INVALID_RSN_INFORMATION_ELEMENT_CAPABILITIES                                            =    (22);
const uint8_t  SL_IEEE_802_1X_AUTHENTICATION_FAILED                                                       =    (23);
const uint8_t  SL_CIPHER_SUITE_REJECTED_BECAUSE_OF_THE_SECURITY_POLICY                                    =    (24);
const uint8_t  SL_DISCONNECT_RESERVED_2                                                                   =    (25);
const uint8_t  SL_DISCONNECT_RESERVED_3                                                                   =    (26);
const uint8_t  SL_DISCONNECT_RESERVED_4                                                                   =    (27);
const uint8_t  SL_DISCONNECT_RESERVED_5                                                                   =    (28);
const uint8_t  SL_DISCONNECT_RESERVED_6                                                                   =    (29);
const uint8_t  SL_DISCONNECT_RESERVED_7                                                                   =    (30);
const uint8_t  SL_DISCONNECT_RESERVED_8                                                                   =    (31);
const uint8_t  SL_DISASSOCIATED_FOR_UNSPECIFIED_QOS_RELATED_REASON                                        =    (32);
const uint8_t  SL_DISASSOCIATED_BECAUSE_QAP_LACKS_SUFFICIENT_BANDWIDTH_FOR_THIS_QSTA                      =    (33);
const uint8_t  SL_DISASSOCIATED_BECAUSE_EXCESSIVE_NUMBER_OF_FRAMES_NEED_TO_BE_ACKNOWLEDGED                =    (34);
const uint8_t  SL_DISASSOCIATED_BECAUSE_QSTA_IS_TRANSMITTING_OUTSIDE_THE_LIMITS_OF_ITS_TXOPS              =    (35);
const uint8_t  SL_REQUESTED_FROM_PEER_QSTA_AS_THE_QSTA_IS_LEAVING_THE_QBSS                                =    (36);
const uint8_t  SL_REQUESTED_FROM_PEER_QSTA_AS_IT_DOES_NO_WANT_TO_USE_THE_MECHANISM                        =    (37);
const uint8_t  SL_REQUESTED_FROM_PEER_QSTA_AS_THE_QSTA_RECEIVED_FRAMES_SETUP_IS_REQUIRED                  =    (38);
const uint8_t  SL_REQUESTED_FROM_PEER_QSTA_DUE_TO_TIMEOUT                                                 =    (39);
const uint8_t  SL_PEER_QSTA_DOES_NOT_SUPPORT_THE_REQUESTED_CIPHER_SUITE                                   =    (40);
const uint8_t  SL_CISCO_DEFINED                                                                           =    (98);
const uint8_t  SL_CISCO_DEFINED_1                                                                         =    (99);
const uint8_t  SL_ROAMING_TRIGGER_NONE                                                                    =    (100);
const uint8_t  SL_ROAMING_TRIGGER_LOW_QUALITY_FOR_BG_SCAN                                                 =    (101);
const uint8_t  SL_ROAMING_TRIGGER_HIGH_QUALITY_FOR_BG_SCAN                                                =    (102);
const uint8_t  SL_ROAMING_TRIGGER_NORMAL_QUALITY_FOR_BG_SCAN                                              =    (103);
const uint8_t  SL_ROAMING_TRIGGER_LOW_TX_RATE                                                             =    (104);
const uint8_t  SL_ROAMING_TRIGGER_LOW_SNR                                                                 =    (105);
const uint8_t  SL_ROAMING_TRIGGER_LOW_QUALITY                                                             =    (106);
const uint8_t  SL_ROAMING_TRIGGER_TSPEC_REJECTED                                                          =    (107);
const uint8_t  SL_ROAMING_TRIGGER_MAX_TX_RETRIES                                                          =    (108);
const uint8_t  SL_ROAMING_TRIGGER_BSS_LOSS                                                                =    (109);
const uint8_t  SL_ROAMING_TRIGGER_BSS_LOSS_DUE_TO_MAX_TX_RETRY                                            =    (110);
const uint8_t  SL_ROAMING_TRIGGER_SWITCH_CHANNEL                                                          =    (111);
const uint8_t  SL_ROAMING_TRIGGER_AP_DISCONNECT                                                           =    (112);
const uint8_t  SL_ROAMING_TRIGGER_SECURITY_ATTACK                                                         =    (113);
const uint8_t  SL_ROAMING_TRIGGER_MAX                                                                     =    (114);
const uint8_t  SL_USER_INITIATED_DISCONNECTION                                                            =    (200);

/* Wlan error codes */
const int8_t  SL_ERROR_KEY_ERROR                                                                          =   (-3);
const int8_t  SL_ERROR_INVALID_ROLE                                                                       =   (-71);
const int8_t  SL_ERROR_INVALID_SECURITY_TYPE                                                              =   (-84);
const int8_t  SL_ERROR_PASSPHRASE_TOO_LONG                                                                =   (-85);
const int8_t  SL_ERROR_WPS_NO_PIN_OR_WRONG_PIN_LEN                                                        =   (-87);
const int8_t  SL_ERROR_EAP_WRONG_METHOD                                                                   =   (-88);
const int8_t  SL_ERROR_PASSWORD_ERROR                                                                     =   (-89);
const int8_t  SL_ERROR_EAP_ANONYMOUS_LEN_ERROR                                                            =   (-90);
const int8_t  SL_ERROR_SSID_LEN_ERROR                                                                     =   (-91);
const int8_t  SL_ERROR_USER_ID_LEN_ERROR                                                                  =   (-92);
const int8_t  SL_ERROR_ILLEGAL_WEP_KEY_INDEX                                                              =   (-95);
const int8_t  SL_ERROR_INVALID_DWELL_TIME_VALUES                                                          =   (-96);
const int8_t  SL_ERROR_INVALID_POLICY_TYPE                                                                =   (-97);
const int8_t  SL_ERROR_PM_POLICY_INVALID_OPTION                                                           =   (-98);
const int8_t  SL_ERROR_PM_POLICY_INVALID_PARAMS                                                           =   (-99);
const int16_t  SL_ERROR_WIFI_ALREADY_DISCONNECTED                                                         =   (-129);
const int8_t  SL_ERROR_WIFI_NOT_CONNECTED                                                                 =   (-59);



const uint8_t SL_SEC_TYPE_OPEN                                                                            =    (0);
const uint8_t SL_SEC_TYPE_WEP                                                                             =    (1);
const uint8_t SL_SEC_TYPE_WPA                                                                             =    (2); /* deprecated */
const uint8_t SL_SEC_TYPE_WPA_WPA2                                                                        =    (2);
const uint8_t SL_SEC_TYPE_WPS_PBC                                                                         =    (3);
const uint8_t SL_SEC_TYPE_WPS_PIN                                                                         =    (4);
const uint8_t SL_SEC_TYPE_WPA_ENT                                                                         =    (5);
const uint8_t SL_SEC_TYPE_P2P_PBC                                                                         =    (6);
const uint8_t SL_SEC_TYPE_P2P_PIN_KEYPAD                                                                  =    (7);
const uint8_t SL_SEC_TYPE_P2P_PIN_DISPLAY                                                                 =    (8);
const uint8_t SL_SEC_TYPE_P2P_PIN_AUTO                                                                    =    (9); /* NOT Supported yet */



const uint8_t SL_SCAN_SEC_TYPE_OPEN                                                                        =   (0);
const uint8_t SL_SCAN_SEC_TYPE_WEP                                                                         =   (1);
const uint8_t SL_SCAN_SEC_TYPE_WPA                                                                         =   (2);
const uint8_t SL_SCAN_SEC_TYPE_WPA2                                                                        =   (3);



const uint8_t TLS                           =     (0x1);
const uint8_t MSCHAP                        =     (0x0);
const uint8_t PSK                           =     (0x2);
const uint8_t TTLS                          =     (0x10);
const uint8_t PEAP0                         =     (0x20);
const uint8_t PEAP1                         =     (0x40);
const uint8_t FAST                          =     (0x80);

const uint8_t FAST_AUTH_PROVISIONING        =     (0x02);
const uint8_t FAST_UNAUTH_PROVISIONING      =     (0x01);
const uint8_t FAST_NO_PROVISIONING          =     (0x00);

const uint8_t EAPMETHOD_PHASE2_SHIFT        =     (8);
const uint8_t EAPMETHOD_PAIRWISE_CIPHER_SHIFT =   (19);
const uint8_t EAPMETHOD_GROUP_CIPHER_SHIFT  =     (27);

const uint8_t WPA_CIPHER_CCMP               =     (0x1);
const uint8_t WPA_CIPHER_TKIP               =     (0x2);
const uint8_t CC31XX_DEFAULT_CIPHER         =     (WPA_CIPHER_CCMP | WPA_CIPHER_TKIP);

#define EAPMETHOD(phase1,phase2,pairwise_cipher,group_cipher) \
((phase1) | \
 ((phase2) << EAPMETHOD_PHASE2_SHIFT ) |\
 ((uint32_t)(pairwise_cipher) << EAPMETHOD_PAIRWISE_CIPHER_SHIFT ) |\
 ((uint32_t)(group_cipher) << EAPMETHOD_GROUP_CIPHER_SHIFT ))

/*                                                            phase1  phase2                     pairwise_cipher         group_cipher         */
#define SL_ENT_EAP_METHOD_TLS                       EAPMETHOD(TLS   , 0                        , CC31XX_DEFAULT_CIPHER , CC31XX_DEFAULT_CIPHER)
#define SL_ENT_EAP_METHOD_TTLS_TLS                  EAPMETHOD(TTLS  , TLS                      , CC31XX_DEFAULT_CIPHER , CC31XX_DEFAULT_CIPHER)
#define SL_ENT_EAP_METHOD_TTLS_MSCHAPv2             EAPMETHOD(TTLS  , MSCHAP                   , CC31XX_DEFAULT_CIPHER , CC31XX_DEFAULT_CIPHER)
#define SL_ENT_EAP_METHOD_TTLS_PSK                  EAPMETHOD(TTLS  , PSK                      , CC31XX_DEFAULT_CIPHER , CC31XX_DEFAULT_CIPHER)
#define SL_ENT_EAP_METHOD_PEAP0_TLS                 EAPMETHOD(PEAP0 , TLS                      , CC31XX_DEFAULT_CIPHER , CC31XX_DEFAULT_CIPHER)
#define SL_ENT_EAP_METHOD_PEAP0_MSCHAPv2            EAPMETHOD(PEAP0 , MSCHAP                   , CC31XX_DEFAULT_CIPHER , CC31XX_DEFAULT_CIPHER)
#define SL_ENT_EAP_METHOD_PEAP0_PSK                 EAPMETHOD(PEAP0 , PSK                      , CC31XX_DEFAULT_CIPHER , CC31XX_DEFAULT_CIPHER)
#define SL_ENT_EAP_METHOD_PEAP1_TLS                 EAPMETHOD(PEAP1 , TLS                      , CC31XX_DEFAULT_CIPHER , CC31XX_DEFAULT_CIPHER)
#define SL_ENT_EAP_METHOD_PEAP1_MSCHAPv2            EAPMETHOD(PEAP1 , MSCHAP                   , CC31XX_DEFAULT_CIPHER , CC31XX_DEFAULT_CIPHER)
#define SL_ENT_EAP_METHOD_PEAP1_PSK                 EAPMETHOD(PEAP1 , PSK                      , CC31XX_DEFAULT_CIPHER , CC31XX_DEFAULT_CIPHER)
#define SL_ENT_EAP_METHOD_FAST_AUTH_PROVISIONING    EAPMETHOD(FAST  , FAST_AUTH_PROVISIONING   , CC31XX_DEFAULT_CIPHER , CC31XX_DEFAULT_CIPHER)
#define SL_ENT_EAP_METHOD_FAST_UNAUTH_PROVISIONING  EAPMETHOD(FAST  , FAST_UNAUTH_PROVISIONING , CC31XX_DEFAULT_CIPHER , CC31XX_DEFAULT_CIPHER)
#define SL_ENT_EAP_METHOD_FAST_NO_PROVISIONING      EAPMETHOD(FAST  , FAST_NO_PROVISIONING     , CC31XX_DEFAULT_CIPHER , CC31XX_DEFAULT_CIPHER)

const uint8_t SL_LONG_PREAMBLE                  =  (0);
const uint8_t SL_SHORT_PREAMBLE                 =  (1);

const uint8_t SL_RAW_RF_TX_PARAMS_CHANNEL_SHIFT =  (0);
const uint8_t SL_RAW_RF_TX_PARAMS_RATE_SHIFT    =  (6);
const uint8_t SL_RAW_RF_TX_PARAMS_POWER_SHIFT   =  (11);
const uint8_t SL_RAW_RF_TX_PARAMS_PREAMBLE_SHIFT = (15);

#define SL_RAW_RF_TX_PARAMS(chan,rate,power,preamble) \
    ((chan << SL_RAW_RF_TX_PARAMS_CHANNEL_SHIFT) | \
    (rate << SL_RAW_RF_TX_PARAMS_RATE_SHIFT) | \
    (power << SL_RAW_RF_TX_PARAMS_POWER_SHIFT) | \
    (preamble << SL_RAW_RF_TX_PARAMS_PREAMBLE_SHIFT))


/* wlan config application IDs */
const uint8_t SL_WLAN_CFG_AP_ID                  =  (0);
const uint8_t SL_WLAN_CFG_GENERAL_PARAM_ID       =  (1);
const uint8_t SL_WLAN_CFG_P2P_PARAM_ID           =  (2);

/* wlan AP Config set/get options */
const uint8_t WLAN_AP_OPT_SSID                   =  (0);
const uint8_t WLAN_AP_OPT_CHANNEL                =  (3);
const uint8_t WLAN_AP_OPT_HIDDEN_SSID            =  (4);
const uint8_t WLAN_AP_OPT_SECURITY_TYPE          =  (6);
const uint8_t WLAN_AP_OPT_PASSWORD               =  (7);
const uint8_t WLAN_GENERAL_PARAM_OPT_COUNTRY_CODE = (9);
const uint8_t WLAN_GENERAL_PARAM_OPT_STA_TX_POWER = (10);
const uint8_t WLAN_GENERAL_PARAM_OPT_AP_TX_POWER  = (11);

const uint8_t WLAN_P2P_OPT_DEV_NAME              =  (12);
const uint8_t WLAN_P2P_OPT_DEV_TYPE              =  (13);
const uint8_t WLAN_P2P_OPT_CHANNEL_N_REGS        =  (14);
const uint8_t WLAN_GENERAL_PARAM_OPT_INFO_ELEMENT = (16);
const uint8_t WLAN_GENERAL_PARAM_OPT_SCAN_PARAMS  = (18);      /* change the scan channels and RSSI threshold using this configuration option */

/* SmartConfig CIPHER options */
const uint8_t SMART_CONFIG_CIPHER_SFLASH         =  (0);      /* password is not delivered by the application. The Simple Manager should */
/* check if the keys are stored in the Flash.                              */
const uint8_t SMART_CONFIG_CIPHER_AES            =  (1);      /* AES (other types are not supported)                                     */
const uint8_t SMART_CONFIG_CIPHER_NONE           =  (0xFF);   /* do not check in the flash                                               */


const uint8_t SL_POLICY_CONNECTION               =  (0x10);
const uint8_t SL_POLICY_SCAN                     =  (0x20);
const uint8_t SL_POLICY_PM                       =  (0x30);
const uint8_t SL_POLICY_P2P                      =  (0x40);

#define VAL_2_MASK(position,value)           ((1 & (value))<<(position))
#define MASK_2_VAL(position,mask)            (((1 << position) & (mask)) >> (position))

#define SL_CONNECTION_POLICY(Auto,Fast,Open,anyP2P,autoSmartConfig)                (VAL_2_MASK(0,Auto) | VAL_2_MASK(1,Fast) | VAL_2_MASK(2,Open) | VAL_2_MASK(3,anyP2P) | VAL_2_MASK(4,autoSmartConfig))
#define SL_SCAN_POLICY_EN(policy)            (MASK_2_VAL(0,policy))
#define SL_SCAN_POLICY(Enable)               (VAL_2_MASK(0,Enable))


const uint8_t SL_NORMAL_POLICY                   = (0);
const uint8_t SL_LOW_LATENCY_POLICY              = (1);
const uint8_t SL_LOW_POWER_POLICY                = (2);
const uint8_t SL_ALWAYS_ON_POLICY                = (3);
const uint8_t SL_LONG_SLEEP_INTERVAL_POLICY      = (4);

const uint8_t SL_P2P_ROLE_NEGOTIATE              = (3);
const uint8_t SL_P2P_ROLE_GROUP_OWNER            = (15);
const uint8_t SL_P2P_ROLE_CLIENT                 = (0);

const uint8_t SL_P2P_NEG_INITIATOR_ACTIVE        = (0);
const uint8_t SL_P2P_NEG_INITIATOR_PASSIVE       = (1);
const uint8_t SL_P2P_NEG_INITIATOR_RAND_BACKOFF  = (2);

#define POLICY_VAL_2_OPTIONS(position,mask,policy)    ((mask & policy) << position )

#define SL_P2P_POLICY(p2pNegType,p2pNegInitiator)   (POLICY_VAL_2_OPTIONS(0,0xF,(p2pNegType > SL_P2P_ROLE_GROUP_OWNER ? SL_P2P_ROLE_GROUP_OWNER : p2pNegType)) | \
                                                     POLICY_VAL_2_OPTIONS(4,0x1,(p2pNegType > SL_P2P_ROLE_GROUP_OWNER ? 1:0)) | \
                                                     POLICY_VAL_2_OPTIONS(5,0x3, p2pNegInitiator))


/* Info elements */

const uint8_t INFO_ELEMENT_DEFAULT_ID            =  (0); /* 221 will be used */

/* info element size is up to 252 bytes (+ 3 bytes of OUI). */
const uint8_t INFO_ELEMENT_MAX_SIZE              =  (252);

/* For AP - the total length of all info elements is 300 bytes (for example - 4 info elements of 75 bytes each) */
const uint16_t INFO_ELEMENT_MAX_TOTAL_LENGTH_AP  =   (300);
/* For P2P - the total length of all info elements is 150 bytes (for example - 4 info elements of 40 bytes each) */
const uint8_t INFO_ELEMENT_MAX_TOTAL_LENGTH_P2P_GO (160);

const uint8_t INFO_ELEMENT_AP_ROLE               =  (0);
const uint8_t INFO_ELEMENT_P2P_GO_ROLE           =  (1);

/* we support up to 4 info elements per Role. */
const uint8_t MAX_PRIVATE_INFO_ELEMENTS_SUPPROTED = (4);

const uint8_t INFO_ELEMENT_DEFAULT_OUI_0         =  (0x08);
const uint8_t INFO_ELEMENT_DEFAULT_OUI_1         =  (0x00);
const uint8_t INFO_ELEMENT_DEFAULT_OUI_2         =  (0x28);

const uint32_t INFO_ELEMENT_DEFAULT_OUI          =   (0x000000);  /* 08, 00, 28 will be used */


/*****************************************************************************/
/* Structure/Enum declarations                                               */
/*****************************************************************************/

typedef enum {
    RATE_1M         = 1,
    RATE_2M         = 2,
    RATE_5_5M       = 3,
    RATE_11M        = 4,
    RATE_6M         = 6,
    RATE_9M         = 7,
    RATE_12M        = 8,
    RATE_18M        = 9,
    RATE_24M        = 10,
    RATE_36M        = 11,
    RATE_48M        = 12,
    RATE_54M        = 13,
    RATE_MCS_0      = 14,
    RATE_MCS_1      = 15,
    RATE_MCS_2      = 16,
    RATE_MCS_3      = 17,
    RATE_MCS_4      = 18,
    RATE_MCS_5      = 19,
    RATE_MCS_6      = 20,
    RATE_MCS_7      = 21,
    MAX_NUM_RATES   = 0xFF
} SlRateIndex_e;

typedef enum {
    DEV_PW_DEFAULT=0,
    DEV_PW_PIN_KEYPAD=1,
    DEV_PW_PUSH_BUTTON=4,
    DEV_PW_PIN_DISPLAY=5
} sl_p2p_dev_password_method;


typedef struct {
    uint32_t    status;
    uint32_t    ssid_len;
    uint8_t     ssid[32];
    uint32_t    private_token_len;
    uint8_t     private_token[32];
} slSmartConfigStartAsyncResponse_t;

typedef struct {
    uint16_t    status;
    uint16_t    padding;
} slSmartConfigStopAsyncResponse_t;

typedef struct {
    uint16_t    status;
    uint16_t    padding;
} slWlanConnFailureAsyncResponse_t;

typedef struct {
    uint8_t     connection_type;/* 0-STA,3-P2P_CL */
    uint8_t     ssid_len;
    uint8_t     ssid_name[32];
    uint8_t     go_peer_device_name_len;
    uint8_t     go_peer_device_name[32];
    uint8_t     bssid[6];
    uint8_t     reason_code;
    uint8_t     padding[2];
} slWlanConnectAsyncResponse_t;

typedef struct {
    uint8_t     go_peer_device_name[32];
    uint8_t     mac[6];
    uint8_t     go_peer_device_name_len;
    uint8_t     wps_dev_password_id;
    uint8_t     own_ssid[32];/* relevant for event sta-connected only */
    uint8_t     own_ssid_len;/* relevant for event sta-connected only */
    uint8_t     padding[3];
} slPeerInfoAsyncResponse_t;


typedef union {
    slSmartConfigStartAsyncResponse_t        smartConfigStartResponse; /*SL_WLAN_SMART_CONFIG_COMPLETE_EVENT*/
    slSmartConfigStopAsyncResponse_t         smartConfigStopResponse;  /*SL_WLAN_SMART_CONFIG_STOP_EVENT */
    slPeerInfoAsyncResponse_t                APModeStaConnected;       /* SL_WLAN_STA_CONNECTED_EVENT - relevant only in AP mode - holds information regarding a new STA connection */
    slPeerInfoAsyncResponse_t                APModestaDisconnected;    /* SL_WLAN_STA_DISCONNECTED_EVENT - relevant only in AP mode - holds information regarding a STA disconnection */
    slWlanConnectAsyncResponse_t             STAandP2PModeWlanConnected;   /* SL_WLAN_CONNECT_EVENT - relevant only in STA and P2P mode - holds information regarding a new connection */
    slWlanConnectAsyncResponse_t             STAandP2PModeDisconnected;   /* SL_WLAN_DISCONNECT_EVENT - relevant only in STA and P2P mode - holds information regarding a disconnection */
    slPeerInfoAsyncResponse_t                P2PModeDevFound;             /* SL_WLAN_P2P_DEV_FOUND_EVENT - relevant only in P2P mode */
    slPeerInfoAsyncResponse_t                P2PModeNegReqReceived;       /* SL_WLAN_P2P_NEG_REQ_RECEIVED_EVENT - relevant only in P2P mode */
    slWlanConnFailureAsyncResponse_t         P2PModewlanConnectionFailure;   /* SL_WLAN_CONNECTION_FAILED_EVENT - relevant only in P2P mode */

} SlWlanEventData_u;

typedef struct {
    uint32_t     Event;
    SlWlanEventData_u        EventData;
} SlWlanEvent_t;


typedef struct {
    uint32_t  ReceivedValidPacketsNumber;                     /* sum of the packets that been received OK (include filtered) */
    uint32_t  ReceivedFcsErrorPacketsNumber;                  /* sum of the packets that been dropped due to FCS error */
    uint32_t  ReceivedPlcpErrorPacketsNumber;                 /* sum of the packets that been dropped due to PLCP error */
    int16_t  AvarageDataCtrlRssi;                            /* average RSSI for all valid data packets received */
    int16_t  AvarageMgMntRssi;                               /* average RSSI for all valid management packets received */
    uint16_t  RateHistogram[NUM_OF_RATE_INDEXES];             /* rate histogram for all valid packets received */
    uint16_t  RssiHistogram[SIZE_OF_RSSI_HISTOGRAM];          /* RSSI histogram from -40 until -87 (all below and above\n RSSI will appear in the first and last cells */
    uint32_t  StartTimeStamp;                                 /* the time stamp started collecting the statistics in uSec */
    uint32_t  GetTimeStamp;                                   /* the time stamp called the get statistics command */
} SlGetRxStatResponse_t;


typedef struct {
    uint8_t ssid[MAXIMAL_SSID_LENGTH];
    uint8_t ssid_len;
    uint8_t sec_type;
    uint8_t bssid[SL_BSSID_LENGTH];
    int8_t rssi;
    int8_t reserved[3];
} Sl_WlanNetworkEntry_t;


typedef struct {
    uint8_t   Type;
    int8_t*  Key;
    uint8_t   KeyLen;
} SlSecParams_t;

typedef struct {
    int8_t*  User;
    uint8_t   UserLen;
    int8_t*  AnonUser;
    uint8_t   AnonUserLen;
    uint8_t   CertIndex;  /* not supported */
    uint32_t  EapMethod;
} SlSecParamsExt_t;

typedef struct {
    int8_t   User[32];
    uint8_t   UserLen;
    int8_t   AnonUser[32];
    uint8_t   AnonUserLen;
    uint8_t   CertIndex;  //not supported
    uint32_t  EapMethod;
} SlGetSecParamsExt_t;

typedef enum {
    ROLE_STA   =   0,
    ROLE_AP    =   2,
    ROLE_P2P     =   3,
    ROLE_STA_ERR =  -1,         /* Failure to load MAC/PHY in STA role */
    ROLE_AP_ERR  =  -ROLE_AP,   /* Failure to load MAC/PHY in AP role */
    ROLE_P2P_ERR =  -ROLE_P2P   /* Failure to load MAC/PHY in P2P role */
} SlWlanMode_t;

typedef struct {
    uint32_t   G_Channels_mask;
    int32_t   rssiThershold;
} slWlanScanParamCommand_t;


typedef struct {
    uint8_t   id;
    uint8_t   oui[3];
    uint16_t  length;
    uint8_t   data[252];
} sl_protocol_InfoElement_t;

typedef struct {
    uint8_t                       index;  /* 0 - MAX_PRIVATE_INFO_ELEMENTS_SUPPROTED */
    uint8_t                       role;   /* bit0: AP = 0, GO = 1                    */
    sl_protocol_InfoElement_t   ie;
} sl_protocol_WlanSetInfoElement_t;


class cc3100_wlan_rx_filters;
class cc3100_wlan
{

public:

    cc3100_wlan(cc3100_driver &driver, cc3100_wlan_rx_filters  &wlan_rx_filters);

    ~cc3100_wlan();


    /*****************************************************************************/
    /* Function prototypes                                                                       */
    /*****************************************************************************/


    /*!
        \brief Connect to wlan network as a station

        \param[in]      sec_type    security types options: \n
                                    - SL_SEC_TYPE_OPEN
                                    - SL_SEC_TYPE_WEP
                                    - SL_SEC_TYPE_WPA_WPA2
                                    - SL_SEC_TYPE_WPA_ENT
                                    - SL_SEC_TYPE_WPS_PBC
                                    - 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)

        \return         On success, zero is returned. On error, negative is returned
                        In case error number (-71) is returned, it indicates a connection was activated while the device it running in AP role

        \sa             sl_WlanDisconnect
        \note           belongs to \ref ext_api
        \warning        In this version only single enterprise mode could be used
                        SL_SEC_TYPE_WPA is a deprecated definition, the new definition is SL_SEC_TYPE_WPA_WPA2
    */
#if _SL_INCLUDE_FUNC(sl_WlanConnect)
    int16_t sl_WlanConnect(signed char*  pName, int16_t NameLen, uint8_t *pMacAddr, SlSecParams_t* pSecParams , SlSecParamsExt_t* pSecExtParams);
#endif

    /*!
        \brief wlan disconnect

        Disconnect connection

        \return         0 disconnected done, other already disconnected

        \sa             sl_WlanConnect
        \note           belongs to \ref ext_api
        \warning
    */
#if _SL_INCLUDE_FUNC(sl_WlanDisconnect)
    int16_t sl_WlanDisconnect(void);
#endif

    /*!
        \brief add profile

        When auto start is enabled, the device connects to a
        station from the profiles table. Up to 7 profiles are
        supported. If several profiles configured the device chose
        the highest priority profile, within each priority group,
        device will chose profile based on security policy, signal
        strength, etc parameters.


        \param[in]      pName          up to 32 bytes in case of STA the name is the
                                       SSID of the Access Point
                                       in case of P2P the name is the remote device name
        \param[in]      NameLen     name length
        \param[in]      pMacAddr    6 bytes for MAC address
        \param[in]      pSecParams     Security parameters - security type
                                       (SL_SEC_TYPE_OPEN,SL_SEC_TYPE_WEP,SL_SEC_TYPE_WPA_WPA2,
                                        SL_SEC_TYPE_P2P_PBC,SL_SEC_TYPE_P2P_PIN_KEYPAD,SL_SEC_TYPE_P2P_PIN_DISPLAY, SL_SEC_TYPE_WPA_ENT), key, and key length
                                       in case of p2p security type pin the key refers to pin code
        \param[in]      pSecExtParams  Enterprise parameters - identity, identity length,
                                       Anonymous, Anonymous length, CertIndex (not supported,
                                       certificates need to be placed in a specific file ID),
                                       EapMethod.Use NULL in case Enterprise parameters is not in use

        \param[in]      Priority    profile priority. Lowest priority: 0
        \param[in]      Options     Not supported

        \return         On success, profile stored index is returned. On error, negative value is returned

        \sa             sl_WlanProfileGet , sl_WlanProfileDel
        \note           belongs to \ref ext_api
        \warning        Only one Enterprise profile is supported.
                        Please Note that in case of adding an existing profile (compared by pName,pMACAddr and security type)
                        the old profile will be deleted and the same index will be returned.
                        SL_SEC_TYPE_WPA is a deprecated definition, the new definition is SL_SEC_TYPE_WPA_WPA2

    */
#if _SL_INCLUDE_FUNC(sl_WlanProfileAdd)
    int16_t sl_WlanProfileAdd(int8_t*  pName, int16_t NameLen, uint8_t *pMacAddr, SlSecParams_t* pSecParams , SlSecParamsExt_t* pSecExtParams, uint32_t  Priority, uint32_t  Options);
#endif

    /*!
        \brief get profile

        read profile from the device

        \param[in]      Index          profile stored index, if index does not exists
                                       error is return
        \param[out]     pName          up to 32 bytes, in case of sta mode the name of the Access Point
                                       in case of p2p mode the name of the Remote Device
        \param[out]     pNameLen       name length
        \param[out]     pMacAddr       6 bytes for MAC address
        \param[out]     pSecParams     security parameters - security type
                                       (LAN_SEC_UNSEC, WLAN_SEC_WEP, WLAN_SEC_WPA or
                                       WLAN_SEC_WPA2, WLAN_SEC_P2P_PBC, WLAN_SEC_P2P_PIN_KEYPAD or WLAN_SEC_P2P_DISPLAY), key and key length are not
                                       in case of p2p security type pin the key refers to pin code
                                       return due to security reasons.
        \param[out]     pSecExtParams  enterprise parameters - identity, identity
                                       length, Anonymous, Anonymous length
                                       CertIndex (not supported), EapMethod.
        \param[out]     Priority       profile priority

        \return         On success, Profile security type is returned (0 or positive number). On error, -1 is
                        returned

        \sa             sl_WlanProfileAdd , sl_WlanProfileDel
        \note           belongs to \ref ext_api
        \warning
    */
#if _SL_INCLUDE_FUNC(sl_WlanProfileGet)
    int16_t sl_WlanProfileGet(int16_t Index,int8_t*  pName, int16_t *pNameLen, uint8_t *pMacAddr, SlSecParams_t* pSecParams, SlGetSecParamsExt_t* pSecExtParams, uint32_t *pPriority);
#endif

    /*!
        \brief Delete WLAN profile

        Delete WLAN profile

        \param[in]   index  number of profile to delete.Possible values are 0 to 6.
                     Index value 255 will delete all saved profiles

        \return  On success, zero is returned. On error, -1 is
                   returned

        \sa   sl_WlanProfileAdd , sl_WlanProfileGet
        \note           belongs to \ref ext_api
        \warning
    */
#if _SL_INCLUDE_FUNC(sl_WlanProfileDel)
    int16_t sl_WlanProfileDel(int16_t Index);
#endif

    /*!
        \brief Set policy values

        \param[in]      Type      Type of policy to be modified. The Options are:\n
                                  - SL_POLICY_CONNECTION
                                  - SL_POLICY_SCAN
                                  - SL_POLICY_PM
                                  - SL_POLICY_P2P
        \param[in]      Policy    The option value which depends on action type
        \param[in]      pVal      An optional value pointer
        \param[in]      ValLen    An optional value length, in bytes
        \return         On success, zero is returned. On error, -1 is
                        returned
        \sa             sl_WlanPolicyGet
        \note           belongs to \ref ext_api
        \warning
        \par
        SL_POLICY_CONNECTION type defines three options available to connect the CC31xx device to the AP: \n

        -  If Auto Connect is set, the CC31xx device tries to automatically reconnect to one of its stored profiles, each time the connection fails or the device is rebooted.\n
           To set this option, use: \n
           <b> sl_WlanPolicySet(SL_POLICY_CONNECTION,SL_CONNECTION_POLICY(1,0,0,0,0),NULL,0) </b>
        -  If Fast Connect is set, the CC31xx device tries to establish a fast connection to AP. \n
           To set this option, use: \n
           <b> sl_WlanPolicySet(SL_POLICY_CONNECTION,SL_CONNECTION_POLICY(0,1,0,0,0),NULL,0) </b>
        -  (relevant for P2P mode only) - If Any P2P is set,  CC31xx/CC32xx device tries to automatically connect to the first P2P device available, \n
           supporting push button only. To set this option, use: \n
           <b> sl_WlanPolicySet(SL_POLICY_CONNECTION,SL_CONNECTION_POLICY(0,0,0,1,0),NULL,0) </b>
        -  For auto smart config upon restart (any command from Host will end this state) use: \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
        \par
        SL_POLICY_SCAN defines system scan time interval in case there is no connection. 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
                        -  For example, setting scan interval to 1 minute interval use: \n
                           uint32_t intervalInSeconds = 60;    \n
                           #define SL_SCAN_ENABLE  1       \n<b>
                           sl_WlanPolicySet(SL_POLICY_SCAN,SL_SCAN_ENABLE, (uint8_t *)&intervalInSeconds,sizeof(intervalInSeconds)); </b>\n

                        -  For example, disable scan:    \n
                           #define SL_SCAN_DISABLE  0     \n<b>
                           sl_WlanPolicySet(SL_POLICY_SCAN,SL_SCAN_DISABLE,0,0); </b>\n
        \par
        SL_POLICY_PM defines a power management policy for Station mode only:
                        -  For setting normal power management (default) policy use: <b> sl_WlanPolicySet(SL_POLICY_PM , SL_NORMAL_POLICY, NULL,0) </b>
                        -  For setting low latency power management policy use: <b> sl_WlanPolicySet(SL_POLICY_PM , SL_LOW_LATENCY_POLICY, NULL,0) </b>
                        -  For setting low power management policy use: <b> sl_WlanPolicySet(SL_POLICY_PM , SL_LOW_POWER_POLICY, NULL,0) </b>
                        -  For setting always on power management policy use: <b> sl_WlanPolicySet(SL_POLICY_PM , SL_ALWAYS_ON_POLICY, NULL,0) </b>
                        -  For setting Long Sleep Interval policy use: \n
                                uint16_t PolicyBuff[4] = {0,0,800,0}; // PolicyBuff[2] is max sleep time in mSec \n<b>
                                sl_WlanPolicySet(SL_POLICY_PM , SL_LONG_SLEEP_INTERVAL_POLICY, (uint8_t*)PolicyBuff,sizeof(PolicyBuff));  </b>\n

        SL_POLICY_P2P defines p2p negotiation policy parameters for P2P role:
                        - To set intent negotiation value, set on of the following:
                            SL_P2P_ROLE_NEGOTIATE   - intent 3
                            SL_P2P_ROLE_GROUP_OWNER - intent 15
                            SL_P2P_ROLE_CLIENT      - intent 0
                        - To set negotiation initiator value (initiator policy of first negotiation action frame), set on of the following:
                            SL_P2P_NEG_INITIATOR_ACTIVE
                            SL_P2P_NEG_INITIATOR_PASSIVE
                            SL_P2P_NEG_INITIATOR_RAND_BACKOFF
                        For example: \n
                        <b>sl_WlanPolicySet(SL_POLICY_P2P, SL_P2P_POLICY(SL_P2P_ROLE_NEGOTIATE,SL_P2P_NEG_INITIATOR_RAND_BACKOFF),NULL,0) </b>

    */
#if _SL_INCLUDE_FUNC(sl_WlanPolicySet)
    int16_t sl_WlanPolicySet(uint8_t Type , const uint8_t Policy, uint8_t *pVal,uint8_t ValLen);
#endif
    /*!
        \brief get policy values

        \param[in]      Type     SL_POLICY_CONNECTION, SL_POLICY_SCAN, SL_POLICY_PM,SL_POLICY_P2P \n

        \param[in]      Policy   argument may be set to any value \n

        \param[out]     The returned values, depends on each policy type, will be stored in the allocated buffer pointed by pVal
                        with a maximum buffer length set by the calling function and pointed to by argument *pValLen

        \return         On success, zero is returned. On error, -1 is returned

        \sa             sl_WlanPolicySet

        \note           belongs to \ref ext_api

        \warning        The value pointed by the argument *pValLen should be set to a value different from 0 and
                        greater than the buffer length returned from the SL device. Otherwise, an error will be returned.

    */
#if _SL_INCLUDE_FUNC(sl_WlanPolicyGet)
    int16_t sl_WlanPolicyGet(uint8_t Type , uint8_t Policy,uint8_t *pVal,uint8_t *pValLen);
#endif
    /*!
        \brief Gets the WLAN scan operation results

        Gets scan results , gets entry from scan result table

        \param[in]   Index - Starting index identifier (range 0-19) for getting scan results
        \param[in]   Count - How many entries to fetch. Max is (20-"Index").
        \param[out]  pEntries - pointer to an allocated Sl_WlanNetworkEntry_t.
                                the number of array items should match "Count"
                                sec_type: SL_SCAN_SEC_TYPE_OPEN, SL_SCAN_SEC_TYPE_WEP, SL_SCAN_SEC_TYPE_WPA or SL_SCAN_SEC_TYPE_WPA2


        \return  Number of valid networks list items

        \sa
        \note       belongs to \ref ext_api
        \warning    This command do not initiate any active scanning action
        \par        Example:
        \code       An example of fetching max 10 results:

                    Sl_WlanNetworkEntry_t netEntries[10];
                    int16_t resultsCount = sl_WlanGetNetworkList(0,10,&netEntries[0]);
                    for(i=0; i< resultsCount; i++)
                    {
                          printf("%s\n",netEntries[i].ssid);
                    }
        \endcode
    */
#if _SL_INCLUDE_FUNC(sl_WlanGetNetworkList)
    int16_t sl_WlanGetNetworkList(uint8_t Index, uint8_t Count, Sl_WlanNetworkEntry_t *pEntries);
#endif

    /*!
        \brief   Start collecting wlan RX statistics, for unlimited time.

        \return  On success, zero is returned. On error, -1 is returned

        \sa     sl_WlanRxStatStop      sl_WlanRxStatGet
        \note   belongs to \ref ext_api
        \warning  This API is deprecated and should be removed for next release
        \par        Example:
        \code       Getting wlan RX statistics:

        void RxStatCollectTwice()
        {
            SlGetRxStatResponse_t rxStat;
            int16_t rawSocket;
            int8_t DataFrame[200];
            struct SlTimeval_t timeval;
            timeval.tv_sec =  0;             // Seconds
            timeval.tv_usec = 20000;         // Microseconds. 10000 microseconds resolution

            sl_WlanRxStatStart();  // set statistics mode

            rawSocket = sl_Socket(SL_AF_RF, SL_SOCK_RAW, eChannel);
            // set timeout - in case we have no activity for the specified channel
            sl_SetSockOpt(rawSocket,SL_SOL_SOCKET,SL_SO_RCVTIMEO, &timeval, sizeof(timeval));    // Enable receive timeout
            status = sl_Recv(rawSocket, DataFrame, sizeof(DataFrame), 0);

            Sleep(1000); // sleep for 1 sec
            sl_WlanRxStatGet(&rxStat,0); // statistics has been cleared upon read
            Sleep(1000); // sleep for 1 sec
            sl_WlanRxStatGet(&rxStat,0);

        }
        \endcode
    */
#if _SL_INCLUDE_FUNC(sl_WlanRxStatStart)
    int16_t sl_WlanRxStatStart(void);
#endif


    /*!
        \brief    Stop collecting wlan RX statistic, (if previous called sl_WlanRxStatStart)

        \return   On success, zero is returned. On error, -1 is returned

        \sa     sl_WlanRxStatStart      sl_WlanRxStatGet
        \note           belongs to \ref ext_api
        \warning  This API is deprecated and should be removed for next release
    */
#if _SL_INCLUDE_FUNC(sl_WlanRxStatStop)
    int16_t sl_WlanRxStatStop(void);
#endif


    /*!
        \brief Get wlan RX statistics. upon calling this command, the statistics counters will be cleared.

        \param[in]  Flags should be 0  ( not applicable right now, will be added the future )
        \param[in]  pRxStat a pointer to SlGetRxStatResponse_t filled with Rx statistics results
        \return     On success, zero is returned. On error, -1 is returned

        \sa   sl_WlanRxStatStart  sl_WlanRxStatStop
        \note           belongs to \ref ext_api
        \warning
    */
#if _SL_INCLUDE_FUNC(sl_WlanRxStatGet)
    int16_t sl_WlanRxStatGet(SlGetRxStatResponse_t *pRxStat,uint32_t Flags);
#endif


    /*!
        \brief Stop Smart Config procedure. Once Smart Config will be stopped,
               Asynchronous event will be received - SL_OPCODE_WLAN_SMART_CONFIG_STOP_ASYNC_RESPONSE.

        \param[in]  none
        \param[out] none

        \return     0 - if Stop Smart Config is about to be executed without errors.

        \sa         sl_WlanSmartConfigStart
        \note           belongs to \ref ext_api
        \warning      This API is deprecated and should be removed for next release

    */
#if _SL_INCLUDE_FUNC(sl_WlanSmartConfigStop)
    int16_t sl_WlanSmartConfigStop(void);
#endif

    /*!
        \brief  Start Smart Config procedure
        \par
                The target of the procedure is to let the                      \n
                device to gain the network parameters: SSID and Password (if network is secured)             \n
                and to connect to it once located in the network range.                                      \n
                An external application should be used on a device connected to any mobile network.          \n
                The external application will transmit over the air the network parameters in secured manner.\n
                The Password may be decrypted using a Key.                                                   \n
                The decryption method may be decided in the command or embedded in the Flash.                \n
                The procedure can be activated for 1-3 group ID in the range of BIT_0 - BIT_15 where the default group ID id 0 (BIT_0) \n
                Once Smart Config has ended successfully, Asynchronous event will be received -              \n
                SL_OPCODE_WLAN_SMART_CONFIG_START_ASYNC_RESPONSE.                                            \n
                The Event will hold the SSID and an extra field that might have been delivered as well (i.e. - device name)

        \param[in]  groupIdBitmask - each bit represent a group ID that should be searched.
                                     The Default group ID id BIT_0. 2 more group can be searched
                                     in addition. The range is BIT_0 - BIT_15.
        \param[in]  chiper - 0: check in flash, 1 - AES, 0xFF - do not check in flash
        \param[in]  publicKeyLen - public key len (used for the default group ID - BIT_0)
        \param[in]  group1KeyLen - group ID1 length
        \param[in]  group2KeyLen - group ID2 length
        \param[in]  publicKey    - public key (used for the default group ID - BIT_0)
        \param[in]  group1Key    - group ID1 key
        \param[in]  group2Key    - group ID2 key

        \param[out] none

        \return     0 - if Smart Config started successfully.

        \sa         sl_WlanSmartConfigStop
        \note           belongs to \ref ext_api
        \warning
        \par
        \code       An example of starting smart Config on group ID's 0 + 1 + 2

                    sl_WlanSmartConfigStart(7,      //group ID's (BIT_0 | BIT_1 | BIT_2)
                                            1,      //decrypt key by AES method
                                            16,     //decryption key length for group ID0
                                            16,     //decryption key length for group ID1
                                            16,     //decryption key length for group ID2
                                            "Key0Key0Key0Key0", //decryption key for group ID0
                                            "Key1Key1Key1Key1", //decryption key for group ID1
                                            "Key2Key2Key2Key2"  //decryption key for group ID2
                                            );
        \endcode
    */
#if _SL_INCLUDE_FUNC(sl_WlanSmartConfigStart)
    int16_t sl_WlanSmartConfigStart(const uint32_t    groupIdBitmask,
                                    const uint8_t    cipher,
                                    const uint8_t    publicKeyLen,
                                    const uint8_t    group1KeyLen,
                                    const uint8_t    group2KeyLen,
                                    const uint8_t*    publicKey,
                                    const uint8_t*    group1Key,
                                    const uint8_t*    group2Key);
#endif


    /*!
        \brief Wlan set mode

        Setting WLAN mode

        \param[in] mode - WLAN mode to start the CC31xx device. Possible options are:
                        - ROLE_STA - for WLAN station mode
                        - ROLE_AP  - for WLAN AP mode
                        - ROLE_P2P  -for WLAN P2P mode
        \return   0 - if mode was set correctly
        \sa        sl_Start sl_Stop
        \note           belongs to \ref ext_api
        \warning   After setting the mode the system must be restarted for activating the new mode
        \par       Example:
        \code
                    //Switch from any role to STA:
                    sl_WlanSetMode(ROLE_STA);
                    sl_Stop(0);
                    sl_Start(NULL,NULL,NULL);
        \endcode

    */
#if _SL_INCLUDE_FUNC(sl_WlanSetMode)
    int16_t sl_WlanSetMode(const uint8_t mode);
#endif


    /*!
        \brief     Internal function for setting WLAN configurations

        \return    On success, zero is returned. On error one of the following error codes  returned:
                   - CONF_ERROR                        (-1)
                   - CONF_NVMEM_ACCESS_FAILED          (-2)
                   - CONF_OLD_FILE_VERSION             (-3)
                   - CONF_ERROR_NO_SUCH_COUNTRY_CODE   (-4)


        \param[in] ConfigId -  configuration id
                              - <b>SL_WLAN_CFG_AP_ID</b>
                              - <b>SL_WLAN_CFG_GENERAL_PARAM_ID</b>
                              - <b>SL_WLAN_CFG_P2P_PARAM_ID</b>

        \param[in] ConfigOpt - configurations option
                              - <b>SL_WLAN_CFG_AP_ID</b>
                                  - <b>WLAN_AP_OPT_SSID</b> \n
                                          Set SSID for AP mode. \n
                                          This options takes <b>uint8_t</b> buffer as parameter
                                  - <b>WLAN_AP_OPT_CHANNEL</b> \n
                                          Set channel for AP mode. \n
                                          The channel is dependant on the country code which is set. i.e. for "US" the channel should be in the range of [1-11] \n
                                          This option takes <b>uint8_t</b> as a parameter
                                  - <b>WLAN_AP_OPT_HIDDEN_SSID</b> \n
                                          Set Hidden SSID Mode for AP mode.Hidden options: \n
                                             0: disabled \n
                                             1: Send empty (length=0) SSID in beacon and ignore probe request for broadcast SSID \n
                                             2: Clear SSID (ASCII 0), but keep the original length (this may be required with some \n
                                                clients that do not support empty SSID) and ignore probe requests for broadcast SSID \n
                                          This option takes <b>uint8_t</b> as a parameter
                                  - <b>WLAN_AP_OPT_SECURITY_TYPE</b> \n
                                          Set Security type for AP mode. Security options are:
                                          - Open security: SL_SEC_TYPE_OPEN
                                          - WEP security:  SL_SEC_TYPE_WEP
                                          - WPA security:  SL_SEC_TYPE_WPA_WPA2  \n
                                          This option takes <b>uint8_t</b> pointer as a parameter
                                  - <b>WLAN_AP_OPT_PASSWORD</b> \n
                                          Set Password for for AP mode (for WEP or for WPA): \n
                                          Password - for WPA: 8 - 63 characters \n
                                          for WEP: 5 / 13 characters (ascii) \n
                                          This options takes <b>uint8_t</b> buffer as parameter
                              - <b>SL_WLAN_CFG_GENERAL_PARAM_ID</b>
                                  - <b>WLAN_GENERAL_PARAM_OPT_COUNTRY_CODE</b> \n
                                          Set Country Code for AP mode \n
                                          This options takes <b>uint8_t</b> 2 bytes buffer as parameter
                                  - <b>WLAN_GENERAL_PARAM_OPT_STA_TX_POWER</b> \n
                                          Set STA mode Tx power level \n
                                          Number between 0-15, as dB offset from max power (0 will set MAX power) \n
                                          This options takes <b>uint8_t</b> as parameter
                                  - <b>WLAN_GENERAL_PARAM_OPT_AP_TX_POWER</b>
                                          Set AP mode Tx power level \n
                                          Number between 0-15, as dB offset from max power (0 will set MAX power) \n
                                          This options takes <b>uint8_t</b> as parameter
                                  - <b>WLAN_GENERAL_PARAM_OPT_INFO_ELEMENT</b>
                                          Set Info Element for AP mode. \n
                                          The Application can set up to MAX_PRIVATE_INFO_ELEMENTS_SUPPROTED info elements per Role (AP / P2P GO).  \n
                                          To delete an info element use the relevant index and length = 0. \n
                                          The Application can set up to MAX_PRIVATE_INFO_ELEMENTS_SUPPROTED to the same role. \n
                                          However, for AP - no more than INFO_ELEMENT_MAX_TOTAL_LENGTH_AP bytes can be stored for all info elements. \n
                                          For P2P GO - no more than INFO_ELEMENT_MAX_TOTAL_LENGTH_P2P_GO bytes can be stored for all info elements.  \n
                                          This option takes sl_protocol_WlanSetInfoElement_t as parameter
                              - <b>SL_WLAN_CFG_P2P_PARAM_ID</b>
                                  - <b>WLAN_P2P_OPT_DEV_TYPE</b> \n
                                          Set P2P Device type.Maximum length of 17 characters. Device type is published under P2P I.E, \n
                                          allows to make devices easier to recognize. \n
                                          In case no device type is set, the default type is "1-0050F204-1"  \n
                                          This options takes <b>uint8_t</b> buffer as parameter
                                  - <b>WLAN_P2P_OPT_CHANNEL_N_REGS</b> \n
                                         Set P2P Channels. \n
                                         listen channel (either 1/6/11 for 2.4GHz) \n
                                         listen regulatory class (81 for 2.4GHz)   \n
                                         oper channel (either 1/6/11 for 2.4GHz)   \n
                                         oper regulatory class (81 for 2.4GHz)     \n
                                         listen channel and regulatory class will determine the device listen channel during p2p find listen phase \n
                                         oper channel and regulatory class will determine the operating channel preferred by this device (in case it is group owner this will be the operating channel) \n
                                         channels should be one of the social channels (1/6/11). In case no listen/oper channel selected, a random 1/6/11 will be selected.
                                         This option takes pointer to <b>uint8_t[4]</b> as parameter

        \param[in] ConfigLen - configurations len

        \param[in] pValues -   configurations values

        \sa
        \note
        \warning
        \par   Examples:
        \par
              <b> WLAN_AP_OPT_SSID: </b>
        \code
                uint8_t  str[33];
                memset(str, 0, 33);
                memcpy(str, ssid, len);  // ssid string of 32 characters
                sl_WlanSet(SL_WLAN_CFG_AP_ID, WLAN_AP_OPT_SSID, strlen(ssid), str);
        \endcode
       \par
              <b> WLAN_AP_OPT_CHANNEL: </b>
        \code
                uint8_t  val = channel;
                sl_WlanSet(SL_WLAN_CFG_AP_ID, WLAN_AP_OPT_CHANNEL, 1, (uint8_t *)&val);
        \endcode
        \par
              <b>  WLAN_AP_OPT_HIDDEN_SSID: </b>
         \code
                uint8_t  val = hidden;
                sl_WlanSet(SL_WLAN_CFG_AP_ID, WLAN_AP_OPT_HIDDEN_SSID, 1, (uint8_t *)&val);
        \endcode
        \par
              <b> WLAN_AP_OPT_SECURITY_TYPE: </b>
         \code
               uint8_t  val = SL_SEC_TYPE_WPA_WPA2;
               sl_WlanSet(SL_WLAN_CFG_AP_ID, WLAN_AP_OPT_SECURITY_TYPE, 1, (uint8_t *)&val);
        \endcode
        \par
              <b>  WLAN_AP_OPT_PASSWORD: </b>
         \code
               uint8_t  str[65];
               uint16_t  len = strlen(password);
               memset(str, 0, 65);
               memcpy(str, password, len);
               sl_WlanSet(SL_WLAN_CFG_AP_ID, WLAN_AP_OPT_PASSWORD, len, (uint8_t *)str);
        \endcode
        \par
             <b> WLAN_GENERAL_PARAM_OPT_STA_TX_POWER: </b>
         \code
             uint8_t  stapower=(uint8_t)power;
             sl_WlanSet(SL_WLAN_CFG_GENERAL_PARAM_ID, WLAN_GENERAL_PARAM_OPT_STA_TX_POWER,1,(uint8_t *)&stapower);
        \endcode
       \par
              <b> WLAN_GENERAL_PARAM_OPT_COUNTRY_CODE: </b>
        \code
                uint8_t*  str = (uint8_t *) country;  // string of 2 characters. i.e. - "US"
                sl_WlanSet(SL_WLAN_CFG_GENERAL_PARAM_ID, WLAN_GENERAL_PARAM_OPT_COUNTRY_CODE, 2, str);
        \endcode
       \par
              <b> WLAN_GENERAL_PARAM_OPT_AP_TX_POWER: </b>
        \code
             uint8_t  appower=(uint8_t)power;
             sl_WlanSet(SL_WLAN_CFG_GENERAL_PARAM_ID, WLAN_GENERAL_PARAM_OPT_AP_TX_POWER,1,(uint8_t *)&appower);
        \endcode
       \par
              <b> WLAN_P2P_OPT_DEV_TYPE: </b>
        \code
             uint8_t   str[17];
             uint16_t  len = strlen(device_type);
             memset(str, 0, 17);
             memcpy(str, device_type, len);
             sl_WlanSet(SL_WLAN_CFG_P2P_PARAM_ID, WLAN_P2P_OPT_DEV_TYPE, len, str);
        \endcode
        \par
              <b> WLAN_P2P_OPT_CHANNEL_N_REGS: </b>
        \code
            uint8_t  str[4];
            str[0] = (uint8_t)11;           // listen channel
            str[1] = (uint8_t)81;            // listen regulatory class
            str[2] = (uint8_t)6;            // oper channel
            str[3] = (uint8_t)81;            // oper regulatory class
            sl_WlanSet(SL_WLAN_CFG_P2P_PARAM_ID, WLAN_P2P_OPT_CHANNEL_N_REGS, 4, str);
        \endcode
       \par
              <b> WLAN_GENERAL_PARAM_OPT_INFO_ELEMENT: </b>
         \code
            sl_protocol_WlanSetInfoElement_t    infoele;
            infoele.index     = Index;                  // Index of the info element. range: 0 - MAX_PRIVATE_INFO_ELEMENTS_SUPPROTED
            infoele.role      = Role;                   // INFO_ELEMENT_AP_ROLE (0) or INFO_ELEMENT_P2P_GO_ROLE (1)
            infoele.ie.id     =  Id;                    // Info element ID. if INFO_ELEMENT_DEFAULT_ID (0) is set, ID will be set to 221.
            // Organization unique ID. If all 3 bytes are zero - it will be replaced with 08,00,28.
            infoele.ie.oui[0] =  Oui0;                  // Organization unique ID first Byte
            infoele.ie.oui[1] =  Oui1;                  // Organization unique ID second Byte
            infoele.ie.oui[2] =  Oui2;                  // Organization unique ID third Byte
            infoele.ie.length = Len;                    // Length of the info element. must be smaller than 253 bytes
            memset(infoele.ie.data, 0, INFO_ELEMENT_MAX_SIZE);
            if ( Len <= INFO_ELEMENT_MAX_SIZE )
            {
                memcpy(infoele.ie.data, IE, Len);           // Info element. length of the info element is [0-252]
                sl_WlanSet(SL_WLAN_CFG_GENERAL_PARAM_ID,WLAN_GENERAL_PARAM_OPT_INFO_ELEMENT,sizeof(sl_protocol_WlanSetInfoElement_t),(uint8_t* ) &infoele);
            }
            sl_WlanSet(SL_WLAN_CFG_GENERAL_PARAM_ID,WLAN_GENERAL_PARAM_OPT_INFO_ELEMENT,sizeof(sl_protocol_WlanSetInfoElement_t),(uint8_t* ) &infoele);
        \endcode

    */
#if _SL_INCLUDE_FUNC(sl_WlanSet)
    int16_t sl_WlanSet(uint16_t ConfigId ,uint16_t ConfigOpt,uint16_t ConfigLen, uint8_t *pValues);
#endif

    /*!
        \brief     Internal function for getting WLAN configurations

        \return    On success, zero is returned. On error, -1 is
                   returned

        \param[in] ConfigId -  configuration id
                              - <b>SL_WLAN_CFG_AP_ID</b>
                              - <b>SL_WLAN_CFG_GENERAL_PARAM_ID</b>
                              - <b>SL_WLAN_CFG_P2P_PARAM_ID</b>

        \param[out] pConfigOpt - get configurations option
                              - <b>SL_WLAN_CFG_AP_ID</b>
                                  - <b>WLAN_AP_OPT_SSID</b> \n
                                          Get SSID for AP mode. \n
                                          Get up to 32 characters of SSID \n
                                          This options takes <b>uint8_t</b> as parameter
                                  - <b>WLAN_AP_OPT_CHANNEL</b> \n
                                          Get channel for AP mode. \n
                                          This option takes <b>uint8_t</b> as a parameter
                                  - <b>WLAN_AP_OPT_HIDDEN_SSID</b> \n
                                          Get Hidden SSID Mode for AP mode.Hidden options: \n
                                             0: disabled \n
                                             1: Send empty (length=0) SSID in beacon and ignore probe request for broadcast SSID \n
                                             2: Clear SSID (ASCII 0), but keep the original length (this may be required with some \n
                                                clients that do not support empty SSID) and ignore probe requests for broadcast SSID \n
                                          This option takes <b>uint8_t</b> as a parameter
                                  - <b>WLAN_AP_OPT_SECURITY_TYPE</b> \n
                                          Get Security type for AP mode. Security options are:
                                          - Open security: SL_SEC_TYPE_OPEN
                                          - WEP security:  SL_SEC_TYPE_WEP
                                          - WPA security:  SL_SEC_TYPE_WPA_WPA2  \n
                                          This option takes <b>uint8_t</b> as a parameter
                                  - <b>WLAN_AP_OPT_PASSWORD</b> \n
                                          Get Password for for AP mode (for WEP or for WPA): \n
                                          Returns password - string, fills up to 64 characters. \n
                                          This options takes <b>uint8_t</b> buffer as parameter
                              - <b>SL_WLAN_CFG_GENERAL_PARAM_ID</b>
                                  - <b> WLAN_GENERAL_PARAM_OPT_SCAN_PARAMS </b> \n
                                          Get scan parameters.
                                          This option uses slWlanScanParamCommand_t as parameter
                                  - <b>WLAN_GENERAL_PARAM_OPT_COUNTRY_CODE</b> \n
                                          Get Country Code for AP mode \n
                                          This options takes <b>uint8_t</b> buffer as parameter
                                  - <b>WLAN_GENERAL_PARAM_OPT_STA_TX_POWER</b> \n
                                          Get STA mode Tx power level \n
                                          Number between 0-15, as dB offset from max power (0 indicates MAX power) \n
                                          This options takes <b>uint8_t</b> as parameter
                                  - <b>WLAN_GENERAL_PARAM_OPT_AP_TX_POWER</b>
                                          Get AP mode Tx power level \n
                                          Number between 0-15, as dB offset from max power (0 indicates MAX power) \n
                                          This options takes <b>uint8_t</b> as parameter
                              - <b>SL_WLAN_CFG_P2P_PARAM_ID</b>
                                  - <b>WLAN_P2P_OPT_CHANNEL_N_REGS</b> \n
                                         Get P2P Channels. \n
                                         listen channel (either 1/6/11 for 2.4GHz) \n
                                         listen regulatory class (81 for 2.4GHz)   \n
                                         oper channel (either 1/6/11 for 2.4GHz)   \n
                                         oper regulatory class (81 for 2.4GHz)     \n
                                         listen channel and regulatory class will determine the device listen channel during p2p find listen phase \n
                                         oper channel and regulatory class will determine the operating channel preferred by this device (in case it is group owner this will be the operating channel) \n
                                         channels should be one of the social channels (1/6/11). In case no listen/oper channel selected, a random 1/6/11 will be selected. \n
                                         This option takes pointer to <b>uint8_t[4]</b> as parameter

        \param[out] pConfigLen - The length of the allocated memory as input, when the
                                            function complete, the value of this parameter would be
                                            the len that actually read from the device.
                                            If the device return length that is longer from the input
                                            value, the function will cut the end of the returned structure
                                            and will return SL_ESMALLBUF.


        \param[out] pValues - get configurations values

        \sa   sl_WlanSet

        \note

        \warning

        \par    Examples:
        \par
              <b> WLAN_GENERAL_PARAM_OPT_SCAN_PARAMS: </b>
        \code
              slWlanScanParamCommand_t ScanParamConfig;
              uint16_t Option = WLAN_GENERAL_PARAM_OPT_SCAN_PARAMS;
              uint16_t OptionLen = sizeof(slWlanScanParamCommand_t);
              sl_WlanGet(SL_WLAN_CFG_GENERAL_PARAM_ID ,&Option,&OptionLen,(uint8_t *)&ScanParamConfig);
        \endcode
        \par
               <b> WLAN_GENERAL_PARAM_OPT_AP_TX_POWER: </b>
        \code
               int16_t TXPower = 0;
               uint16_t Option = WLAN_GENERAL_PARAM_OPT_AP_TX_POWER;
               uint16_t OptionLen = sizeof(int16_t);
               sl_WlanGet(SL_WLAN_CFG_GENERAL_PARAM_ID ,&Option,&OptionLen,(uint8_t *)&TXPower);
        \endcode
        \par
               <b> WLAN_GENERAL_PARAM_OPT_STA_TX_POWER: </b>
        \code
               int16_t TXPower = 0;
               uint16_t Option = WLAN_GENERAL_PARAM_OPT_STA_TX_POWER;
               uint16_t OptionLen = sizeof(int16_t);

               sl_WlanGet(SL_WLAN_CFG_GENERAL_PARAM_ID ,&Option,&OptionLen,(uint8_t *)&TXPower);
        \endcode
        \par
               <b> WLAN_P2P_OPT_DEV_TYPE: </b>
        \code
               int8_t device_type[18];
               uint16_t len = 18;
               uint16_t config_opt = WLAN_P2P_OPT_DEV_TYPE;
               sl_WlanGet(SL_WLAN_CFG_P2P_PARAM_ID, &config_opt , &len, (uint8_t* )device_type);
        \endcode
        \par
               <b> WLAN_AP_OPT_SSID: </b>
        \code
               int8_t ssid[32];
               uint16_t len = 32;
               uint16_t  config_opt = WLAN_AP_OPT_SSID;
               sl_WlanGet(SL_WLAN_CFG_AP_ID, &config_opt , &len, (uint8_t* )ssid);
        \endcode
        \par
               <b> WLAN_GENERAL_PARAM_OPT_COUNTRY_CODE: </b>
        \code
               int8_t country[3];
               uint16_t len = 3;
               uint16_t  config_opt = WLAN_GENERAL_PARAM_OPT_COUNTRY_CODE;
               sl_WlanGet(SL_WLAN_CFG_GENERAL_PARAM_ID, &config_opt, &len, (uint8_t* )country);
        \endcode
        \par
               <b> WLAN_AP_OPT_CHANNEL: </b>
        \code
               int8_t channel;
               uint16_t len = 1;
               uint16_t  config_opt = WLAN_AP_OPT_CHANNEL;
               sl_WlanGet(SL_WLAN_CFG_AP_ID, &config_opt, &len, (uint8_t* )&channel);
        \endcode
        \par
               <b> WLAN_AP_OPT_HIDDEN_SSID: </b>
        \code
              uint8_t hidden;
              uint16_t len = 1;
              uint16_t  config_opt = WLAN_AP_OPT_HIDDEN_SSID;
              sl_WlanGet(SL_WLAN_CFG_AP_ID, &config_opt, &len, (uint8_t* )&hidden);
        \endcode
        \par
               <b> WLAN_AP_OPT_SECURITY_TYPE: </b>
        \code
             uint8_t sec_type;
             uint16_t len = 1;
             uint16_t  config_opt = WLAN_AP_OPT_SECURITY_TYPE;
             sl_WlanGet(SL_WLAN_CFG_AP_ID, &config_opt, &len, (uint8_t* )&sec_type);
        \endcode
        \par
               <b> WLAN_AP_OPT_PASSWORD: </b>
        \code
             uint8_t password[64];
             uint16_t len = 64;
             memset(password,0,64);
             uint16_t config_opt = WLAN_AP_OPT_PASSWORD;
             sl_WlanGet(SL_WLAN_CFG_AP_ID, &config_opt, &len, (uint8_t* )password);

        \endcode
        \par
               <b> WLAN_P2P_OPT_CHANNEL_N_REGS: </b>
        \code
           uint16_t listen_channel,listen_reg,oper_channel,oper_reg;
           uint16_t len = 4;
           uint16_t  config_opt = WLAN_P2P_OPT_CHANNEL_N_REGS;
           uint8_t channel_n_regs[4];
           sl_WlanGet(SL_WLAN_CFG_P2P_PARAM_ID, &config_opt, &len, (uint8_t* )channel_n_regs);
           listen_channel = channel_n_regs[0];
           listen_reg = channel_n_regs[1];
           oper_channel = channel_n_regs[2];
           oper_reg = channel_n_regs[3];
        \endcode
    */

#if _SL_INCLUDE_FUNC(sl_WlanGet)
    int16_t sl_WlanGet(uint16_t ConfigId, uint16_t *pConfigOpt,uint16_t *pConfigLen, uint8_t *pValues);
#endif

private:

    cc3100_driver           &_driver;
    cc3100_wlan_rx_filters  &_wlan_filters;

    /*!

     Close the Doxygen group.
     @}

     */

};//class

}//namespace mbed_cc3100

#endif    /*  __WLAN_H__ */