cc3000 hostdriver with the mbed socket interface. Hacked TCP Classes for better control of non-blocking sockets.

Fork of cc3000_hostdriver_mbedsocket by Martin Kojtal

Revision:
29:c40918cd9b6d
Parent:
27:5118ab0f6aa4
Child:
30:251a0a7d88de
diff -r 8c7cc1c76ff8 -r c40918cd9b6d cc3000.h
--- a/cc3000.h	Sat Oct 05 20:29:39 2013 +0200
+++ b/cc3000.h	Sun Oct 06 17:17:48 2013 +0200
@@ -76,7 +76,7 @@
     #else
         #define DBG_SOCKET(x, ...) std::printf("[CC3000 : SOCKET] "x"\r\n", ##__VA_ARGS__);
     #endif
-    
+
 #else
     #define DBG_SOCKET(x, ...)
 #endif
@@ -88,7 +88,7 @@
     #else
         #define DBG_HCI(x, ...) std::printf("[CC3000 : HCI RX] "x"\r\n", ##__VA_ARGS__);
     #endif
-    
+
 #else
     #define DBG_HCI(x, ...)
 #endif
@@ -100,7 +100,7 @@
     #else
         #define DBG_HCI_CMD(x, ...) std::printf("[CC3000 : HCI TX] "x"\r\n", ##__VA_ARGS__);
     #endif
-    
+
 #else
     #define DBG_HCI_CMD(x, ...)
 #endif
@@ -113,7 +113,7 @@
     #else
         #define DBG_CC(x, ...) std::printf("[CC3000] "x"\r\n", ##__VA_ARGS__);
     #endif
-    
+
 #else
     #define DBG_CC(x, ...)
 #endif
@@ -166,68 +166,149 @@
      */
     bool get_tx_complete_signal();
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     void set_tx_complete_signal(bool value);
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     uint8_t *get_received_buffer();
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     void set_received_buffer(uint8_t value);
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     uint8_t *get_transmit_buffer();
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     void set_transmit_buffer(uint8_t value);
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     uint16_t get_number_free_buffers();
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     void set_number_free_buffers(uint16_t value);
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     uint16_t get_buffer_length();
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     void set_buffer_length(uint16_t value);
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     uint16_t get_pending_data();
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     void set_pending_data(uint16_t value);
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     uint16_t get_op_code();
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     void set_op_code(uint16_t code);
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     uint16_t get_released_packets();
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     void set_number_of_released_packets(uint16_t value);
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     uint16_t get_sent_packets();
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     void set_sent_packets(uint16_t value);
-
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t get_transmit_error();
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void set_transmit_error(int32_t value);
-
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     uint16_t get_buffer_size(void);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void set_buffer_size(uint16_t value);
-
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void *get_func_pointer(FunctionNumber function);
-
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     uint8_t *get_received_data(void);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void set_received_data(uint8_t *pointer);
-
 private:
     uint8_t  _data_received_flag;
     bool     _tx_complete_signal;
@@ -259,20 +340,83 @@
  */
 class cc3000_event {
 public:
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     cc3000_event(cc3000_simple_link &simplelink, cc3000_hci &hci, cc3000_spi &spi, cc3000 &cc3000);
-    ~cc3000_event();
-
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
+     ~cc3000_event();
+     /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void hci_unsol_handle_patch_request(uint8_t *event_hdr);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     uint8_t *hci_event_handler(void *ret_param, uint8_t *from, uint8_t *fromlen);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t hci_unsol_event_handler(uint8_t *event_hdr);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t hci_unsolicited_event_handler(void);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t get_socket_active_status(int32_t sd);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void set_socket_active_status(int32_t sd, int32_t status);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t hci_event_unsol_flowcontrol_handler(uint8_t *event);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void update_socket_active_status(uint8_t *resp_params);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void simplelink_wait_event(uint16_t op_code, void *ret_param);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void simplelink_wait_data(uint8_t *buffer, uint8_t *from, uint8_t *fromlen);
-
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void received_handler(uint8_t *buffer);
  private:
     uint32_t            socket_active_status;
@@ -284,16 +428,66 @@
 
 class cc3000_netapp {
 public:
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     cc3000_netapp(cc3000_simple_link &simple_link, cc3000_nvmem &nvmem, cc3000_hci &hci, cc3000_event &event);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     ~cc3000_netapp();
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t config_mac_adrress(uint8_t *mac);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t dhcp(uint32_t *ip, uint32_t *subnet_mask,uint32_t *default_gateway, uint32_t *dns_server);
 #ifndef CC3000_TINY_DRIVER
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void ipconfig(tNetappIpconfigRetArgs *ipconfig);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t timeout_values(uint32_t *dhcp, uint32_t *arp,uint32_t *keep_alive, uint32_t *inactivity);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t ping_send(uint32_t *ip, uint32_t ping_attempts, uint32_t ping_size, uint32_t ping_timeout);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void ping_report();
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t ping_stop();
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t arp_flush();
 #endif
 private:
@@ -306,13 +500,53 @@
 #ifndef CC3000_UNENCRYPTED_SMART_CONFIG
 class cc3000_security {
 public:
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void expandKey(uint8_t *expanded_key, uint8_t *key);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     uint8_t galois_mul2(uint8_t value);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void aes_encr(uint8_t *state, uint8_t *expanded_key);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void aes_decr(uint8_t *state, uint8_t *expanded_key);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void aes_encrypt(uint8_t *state, uint8_t *key);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     void aes_decrypt(uint8_t *state, uint8_t *key);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t aes_read_key(uint8_t *key);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t aes_write_key(uint8_t *key);
 private:
     uint8_t _expanded_key[176];
@@ -321,26 +555,121 @@
 
 class cc3000_socket {
 public:
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     cc3000_socket(cc3000_simple_link &simplelink, cc3000_hci &hci, cc3000_event &event);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     ~cc3000_socket();
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t socket(int32_t domain, int32_t type, int32_t protocol);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t accept(int32_t sd, sockaddr *addr, socklen_t *addrlen);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t bind(int32_t sd, const sockaddr *addr, int32_t addrlen);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t HostFlowControlConsumeBuff(int32_t sd);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t closesocket(int32_t sd);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t listen(int32_t sd, int32_t backlog);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t connect(int32_t sd, const sockaddr *addr, int32_t addrlen);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t select(int32_t nfds, fd_set *readsds, fd_set *writesds, fd_set *exceptsds, struct timeval *timeout);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t getsockopt (int32_t sd, int32_t level, int32_t optname, void *optval, socklen_t *optlen);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t simple_link_recv(int32_t sd, void *buf, int32_t len, int32_t flags, sockaddr *from, socklen_t *fromlen, int32_t opcode);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t simple_link_send(int32_t sd, const void *buf, int32_t len, int32_t flags, const sockaddr *to, int32_t tolen, int32_t opcode);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t recv(int32_t sd, void *buf, int32_t len, int32_t flags);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t recvfrom(int32_t sd, void *buf, int32_t len, int32_t flags, sockaddr *from, socklen_t *fromlen);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t send(int32_t sd, const void *buf, int32_t len, int32_t flags);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t sendto(int32_t sd, const void *buf, int32_t len, int32_t flags, const sockaddr *to, socklen_t tolen);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t mdns_advertiser(uint16_t mdns_enabled, uint8_t * device_service_name, uint16_t device_service_name_length);
 #ifndef CC3000_TINY_DRIVER
     int32_t gethostbyname(uint8_t *hostname, uint16_t name_length, uint32_t *out_ip_addr);
+    /**
+     *  \brief
+     *  \param
+     *  \return
+     */
     int32_t setsockopt(int32_t sd, int32_t level, int32_t optname, const void *optval, socklen_t optlen);
 #endif
 private:
@@ -376,33 +705,63 @@
      */
      uint32_t first_write(uint8_t *buffer, uint16_t length);
      /**
+     *  \brief
+     *  \param
+     *  \return
      */
      uint32_t write(uint8_t *buffer, uint16_t length);
      /**
+     *  \brief
+     *  \param
+     *  \return
      */
      void write_synchronous(uint8_t *data, uint16_t size);
      /**
+     *  \brief
+     *  \param
+     *  \return
      */
      void read_synchronous(uint8_t *data, uint16_t size);
      /**
+     *  \brief
+     *  \param
+     *  \return
      */
      uint32_t read_data_cont();
      /**
+     *  \brief
+     *  \param
+     *  \return
      */
     void wlan_irq_enable();
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     void wlan_irq_disable();
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     void wlan_irq_set(uint8_t value);
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     uint32_t wlan_irq_read();
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     void WLAN_IRQHandler();
     /**
+     *  \brief
+     *  \param
+     *  \return
      */
     void write_wlan_en(uint8_t value);
 private:
@@ -419,13 +778,56 @@
 
 class cc3000_hci {
 public:
+    /**
+     *  \brief Ctor
+     *  \param spi Reference to spi object.
+     *  \return none
+     */
     cc3000_hci(cc3000_spi &spi);
+    /**
+     *  \brief Dtor
+     *  \param none
+     *  \return none
+     */
     ~cc3000_hci();
+    /**
+     *  \brief Initiate an HCI command.
+     *  \param op_code command operation code
+     *  \param buffer  pointer to the command's arguments buffer
+     *  \param length  length of the arguments
+     *  \return ???
+     */
     uint16_t command_send(uint16_t op_code, uint8_t *buffer, uint8_t length);
+    /**
+     *  \brief Initiate an HCI data write operation
+     *  \param op_code     command operation code
+     *  \param args        pointer to the command's arguments buffer
+     *  \param arg_length  length of the arguments
+     *  \param data_length length od data
+     *  \param tail        pointer to the data buffer
+     *  \param tail_length buffer length
+     *  \return ???
+     */
     uint32_t data_send(uint8_t op_code, uint8_t *args, uint16_t arg_length,
                         uint16_t data_length, const uint8_t *tail, uint16_t tail_length);
+    /**
+     *  \brief Prepare HCI header and initiate an HCI data write operation.
+     *  \param op_code     command operation code
+     *  \param buffer      pointer to the data buffer
+     *  \param arg_length  arguments length
+     *  \param data_length data length
+     *  \return none
+     */
     void data_command_send(uint16_t op_code, uint8_t *buffer, uint8_t arg_length,
                             uint16_t data_length);
+    /**
+     *  \brief Prepare HCI header and initiate an HCI patch write operation.
+     *  \param op_code     command operation code
+     *  \param buffer      pointer to the command's arguments buffer
+     *  \param patch       pointer to patch content buffer
+     *  \param data_length data length
+     *  \return none
+     */
     void patch_send(uint8_t op_code, uint8_t *buffer, uint8_t *patch, uint16_t data_length);
 private:
     cc3000_spi &_spi;
@@ -433,15 +835,82 @@
 
 class cc3000_nvmem {
 public:
-    cc3000_nvmem(cc3000_hci &hci, cc3000_event &_event,cc3000_simple_link &simple_link);
+    /**
+     *  \brief Ctor
+     *  \param hci          Reference to hci object.
+     *  \param event        Reference to event object.
+     *  \param simple_link  Reference to simple link object.
+     *  \return none
+     */
+    cc3000_nvmem(cc3000_hci &hci, cc3000_event &event, cc3000_simple_link &simple_link);
+    /**
+     *  \brief Dtor
+     *  \param none
+     *  \return none
+     */
     ~cc3000_nvmem();
+    /**
+     *  \brief Reads data from the file referred by the file_id parameter.
+     *      Reads data from file offset till length. Err if the file can't be used,
+     *      is invalid, or if the read is out of bounds.
+     *  \param file_id nvmem file id.
+     *  \param length  number of bytes to read.
+     *  \param offset  offset in file from where to read.
+     *  \param buff    output buffer pointer.
+     *  \return
+     *      Number of bytes read, otherwise error.
+     */
     int32_t read(uint32_t file_id, uint32_t length, uint32_t offset, uint8_t *buff);
+    /**
+     *  \brief Write data to nvmem.
+     *  \param file_id      Nvmem file id
+     *  \param length       number of bytes to write
+     *  \param entry_offset offset in file to start write operation from
+     *  \param buff         data to write
+     *  \return
+     *      On success 0, error otherwise.
+     */
     int32_t write(uint32_t file_id, uint32_t length, uint32_t entry_offset, uint8_t *buff);
+    /**
+     *  \brief Write MAC address to EEPROM.
+     *  \param mac Mac address to be set
+     *  \return
+     *      On success 0, error otherwise.
+     */
     uint8_t set_mac_address(uint8_t *mac);
+    /**
+     *  \brief Read MAC address from EEPROM.
+     *  \param mac Mac address
+     *  \return
+     *      on success 0, error otherwise.
+     */
     uint8_t get_mac_address(uint8_t *mac);
+    /**
+     *  \brief Program a patch to a specific file ID. The SP data is assumed to be organized in 2-dimensional.
+     *      Each line is SP_PORTION_SIZE bytes long.
+     *  \param file_id nvmem file id/
+     *  \param length  number of bytes to write
+     *  \param data    SP data to write
+     *  \return
+     *      On success 0, error otherwise.
+     */
     uint8_t write_patch(uint32_t file_id, uint32_t length, const uint8_t *data);
+    /**
+     *  \brief Create new file entry and allocate space on the NVMEM. Applies only to user files.
+     *  \param file_id nvmem file Id
+     *  \param new_len entry ulLength
+     *  \return
+     */
     int32_t create_entry(uint32_t file_id, uint32_t new_len);
 #ifndef CC3000_TINY_DRIVER
+    /**
+     *  \brief Read patch version. read package version (WiFi FW patch, river-supplicant-NS patch,
+     *      bootloader patch)
+     *  \param patch_ver First number indicates package ID and the second number indicates
+     *      package build number
+     *  \return
+     *      On success 0, error otherwise.
+     */
     uint8_t read_sp_version(uint8_t* patch_ver);
 #endif
 private:
@@ -452,46 +921,200 @@
 
 class cc3000_wlan {
 public:
+    /**
+     *  \brief Ctor
+     *  \param simple_link Reference to simple link object.
+     *  \param event       Reference to event object.
+     *  \param spi         Reference to spi object.
+     *  \param hci         Reference to hci object.
+     *  \return none
+     */
     cc3000_wlan(cc3000_simple_link &simple_link, cc3000_event &event, cc3000_spi &spi, cc3000_hci &hci);
+    /**
+     *  \brief Dtor
+     *  \param none
+     *  \return none
+     */
     ~cc3000_wlan();
-    /** Send SIMPLE LINK START to cc3000
-     *  \param patches_available_host Flag to indicate if patches are available
+    /**
+     *  \brief Send SIMPLE LINK START to cc3000.
+     *  \param patches_available_host Flag to indicate if patches are available.
      *  \return none
      */
     void simpleLink_init_start(uint16_t patches_available_host);
-    /** Start wlan device. Blocking call until init is completed
-     *  \param patches_available_host Flag to indicate if patches are available
+    /**
+     *  \brief Start wlan device. Blocking call until init is completed.
+     *  \param patches_available_host Flag to indicate if patches are available.
      *  \return none
      */
     void start(uint16_t patches_available_host);
-    /** Stop wlan device
+    /**
+     *  \brief Stop wlan device
      *  \param none
      *  \return none
      */
     void stop(void);
 #ifndef CC3000_TINY_DRIVER
+    /**
+     *  \brief Connect to AP.
+     *  \param sec_type    Security option.
+     *  \param ssid        up to 32 bytes, ASCII SSID
+     *  \param ssid_length length of SSID
+     *  \param b_ssid      6 bytes specified the AP bssid
+     *  \param key         up to 16 bytes specified the AP security key
+     *  \param key_len     key length
+     *  \return
+     *      On success, zero is returned. On error, negative is returned.
+     */
     int32_t connect(uint32_t sec_type, const uint8_t *ssid, int32_t ssid_length, uint8_t *b_ssid, uint8_t *key, int32_t key_len);
+    /**
+     *  \brief Add profile. Up to 7 profiles are supported.
+     *  \param sec_type                      Security option.
+     *  \param ssid                          Up to 32 bytes, ASCII SSID
+     *  \param ssid_length                   Length of SSID
+     *  \param b_ssid                        6 bytes specified the AP bssid
+     *  \param priority                      Up to 16 bytes specified the AP security key
+     *  \param pairwise_cipher_or_tx_key_len Key length
+     *  \param group_cipher_tx_key_index     Key length for WEP security
+     *  \param key_mgmt                      KEY management
+     *  \param pf_or_key                     Security key
+     *  \param pass_phrase_length            Security key length for WPA\WPA2
+     *  \return
+     *      On success, zero is returned. On error, negative is returned.
+     */
     int32_t add_profile(uint32_t sec_type, uint8_t* ssid, uint32_t ssid_length, uint8_t *b_ssid, uint32_t priority, uint32_t pairwise_cipher_or_tx_key_len, uint32_t group_cipher_tx_key_index,
                           uint32_t key_mgmt, uint8_t* pf_or_key, uint32_t pass_phrase_length);
+    /**
+     *  \brief Gets entry from scan result table. The scan results are returned
+     *      one by one, and each entry represents a single AP found in the area.
+     *  \param scan_timeout Not supported yet
+     *  \param results      Scan result
+     *  \return
+     *      On success, zero is returned. On error, -1 is returned
+     */
     int32_t ioctl_get_scan_results(uint32_t scan_timeout, uint8_t *results);
+    /**
+     *  \brief Start and stop scan procedure. Set scan parameters.
+     *  \param enable             Start/stop application scan
+     *  \param min_dwell_time     Minimum dwell time value to be used for each channel, in ms. (Default: 20)
+     *  \param max_dwell_time     Maximum dwell time value to be used for each channel, in ms. (Default: 30)
+     *  \param num_probe_requests Max probe request between dwell time. (Default:2)
+     *  \param channel_mask       Bitwise, up to 13 channels (0x1fff).
+     *  \param rssi_threshold     RSSI threshold. Saved: yes (Default: -80)
+     *  \param snr_threshold      NSR threshold. Saved: yes (Default: 0)
+     *  \param default_tx_power   probe Tx power. Saved: yes (Default: 205)
+     *  \param interval_list      Pointer to array with 16 entries (16 channels)
+     *  \return
+     *      On success, zero is returned. On error, -1 is returned.
+     */
     int32_t ioctl_set_scan_params(uint32_t enable, uint32_t min_dwell_time, uint32_t max_dwell_time, uint32_t num_probe_requests,
                                 uint32_t channel_mask, int32_t rssi_threshold, uint32_t snr_threshold, uint32_t default_tx_power, uint32_t *interval_list);
+    /**
+     *  \brief Get wlan status: disconnected, scanning, connecting or connected
+     *  \param none
+     *  \return
+     *      WLAN_STATUS_DISCONNECTED, WLAN_STATUS_SCANING, STATUS_CONNECTING or WLAN_STATUS_CONNECTED
+     */
     int32_t ioctl_statusget(void);
 #else
+    /**
+     *  \brief Connect to AP
+     *  \param ssid        Up to 32 bytes and is ASCII SSID of the AP
+     *  \param ssid_length Length of the SSID
+     *  \return
+     *      On success, zero is returned. On error, negative is returned.
+     */
     int32_t connect(const uint8_t *ssid, int32_t ssid_length);
+    /**
+     *  \brief When auto start is enabled, the device connects to station from the profiles table.
+     *      If several profiles configured the device choose the highest priority profile.
+     *  \param sec_type                      WLAN_SEC_UNSEC,WLAN_SEC_WEP,WLAN_SEC_WPA,WLAN_SEC_WPA2
+     *  \param ssid                          SSID up to 32 bytes
+     *  \param ssid_length                   SSID length
+     *  \param b_ssid                        bssid 6 bytes
+     *  \param priority                      Profile priority. Lowest priority:0.
+     *  \param pairwise_cipher_or_tx_key_len Key length for WEP security
+     *  \param group_cipher_tx_key_index     Key index
+     *  \param key_mgmt                      KEY management
+     *  \param pf_or_key                     Security key
+     *  \param pass_phrase_length            Security key length for WPA\WPA2
+     *  \return
+     *      On success, zero is returned. On error, -1 is returned
+     */
     int32_t add_profile(uint32_t sec_type, uint8_t *ssid, uint32_t ssid_length, uint8_t *b_ssid, uint32_t priority,
                       uint32_t pairwise_cipher_or_tx_key_len, uint32_t group_cipher_tx_key_index, uint32_t key_mgmt,
                       uint8_t* pf_or_key, uint32_t pass_phrase_length);
 #endif
 #ifndef CC3000_UNENCRYPTED_SMART_CONFIG
+    /**
+     *  \brief Process the acquired data and store it as a profile.
+     *  \param none
+     *  \return
+     *      On success, zero is returned. On error, -1 is returned.
+     */
     int32_t smart_config_process(void);
 #endif
+    /**
+     *  \brief Disconnect connection from AP.
+     *  \param none
+     *  \return
+     *      0 if disconnected done, other CC3000 already disconnected.
+     */
     int32_t disconnect();
+    /**
+     *  \brief When auto is enabled, the device tries to connect according the following policy:
+     *      1) If fast connect is enabled and last connection is valid, the device will try to
+     *      connect to it without the scanning procedure (fast). The last connection will be
+     *      marked as invalid, due to adding/removing profile.
+     *      2) If profile exists, the device will try to connect it (Up to seven profiles).
+     *      3) If fast and profiles are not found, and open mode is enabled, the device
+     *      will try to connect to any AP.
+     *      Note that the policy settings are stored in the CC3000 NVMEM.
+     *  \param should_connect_to_open_ap Enable(1), disable(0) connect to any available AP.
+     *  \param use_fast_connect          Enable(1), disable(0). if enabled, tries to
+     *                                   connect to the last connected AP.
+     *  \param use_profiles              Enable(1), disable(0) auto connect after reset.
+     *                                   and periodically reconnect if needed.
+     *  \return
+     *      On success, zero is returned. On error, -1 is returned
+     */
     int32_t ioctl_set_connection_policy(uint32_t should_connect_to_open_ap, uint32_t use_fast_connect, uint32_t use_profiles);
+    /**
+     *  \brief Delete WLAN profile
+     *  \param index Number of profile to delete
+     *  \return
+     *      On success, zero is returned. On error, -1 is returned
+     */
     int32_t ioctl_del_profile(uint32_t index);
+    /**
+     *  \brief Mask event according to bit mask. In case that event is
+     *      masked (1), the device will not send the masked event to host.
+     *  \param mask event mask
+     *  \return
+     *      On success, zero is returned. On error, -1 is returned
+     */
     int32_t set_event_mask(uint32_t mask);
+    /**
+     *  \brief Start to acquire device profile. The device acquire its own
+     *      profile, if profile message is found.
+     *  \param encrypted_flag Indicates whether the information is encrypted
+     *  \return
+     *      On success, zero is returned. On error, -1 is returned.
+     */
     int32_t smart_config_start(uint32_t encrypted_flag);
+    /**
+     *  \brief Stop the acquire profile procedure.
+     *  \param none
+     *  \return
+     *      On success, zero is returned. On error, -1 is returned
+     */
     int32_t smart_config_stop(void);
+    /**
+     *  \brief Configure station ssid prefix.
+     *  \param new_prefix 3 bytes identify the SSID prefix for the Smart Config.
+     *  \return
+     *      On success, zero is returned. On error, -1 is returned.
+     */
     int32_t smart_config_set_prefix(uint8_t *new_prefix);
 private:
     cc3000_simple_link  &_simple_link;
@@ -566,16 +1189,18 @@
  */
 class cc3000 {
 public:
+    /** status structure */
     typedef struct {
-        bool dhcp;
-        bool connected;
+        bool    dhcp;
+        bool    connected;
         uint8_t socket;
-        bool smart_config_complete;
-        bool stop_smart_config;
-        bool dhcp_configured;
-        bool ok_to_shut_down;
+        bool    smart_config_complete;
+        bool    stop_smart_config;
+        bool    dhcp_configured;
+        bool    ok_to_shut_down;
     } tStatus;
-    /** ctor for cc3000 class.
+    /**
+     *  \brief Ctor.
      *  \param cc3000_irq IRQ pin
      *  \param cc3000_en  Enable pin
      *  \param cc3000_cs  Chip select pin
@@ -583,93 +1208,111 @@
      *  \param irq_port   IRQ pin's port
      */
     cc3000(PinName cc3000_irq, PinName cc3000_en, PinName cc3000_cs, SPI cc3000_spi, IRQn_Type irq_port);
-    /** dtor
+    /**
+     *  \brief Dtor.
      */
     ~cc3000();
-    /** Initiate cc3000. It starts the wlan communication and deletes profiles.
+    /**
+     *  \brief Initiate cc3000. It starts the wlan communication and deletes profiles.
      *  \param patch Patch
      */
     void start(uint8_t patch);
-    /** Stops the wlan communication.
+    /**
+     *  \brief Stops the wlan communication.
      */
     void stop();
-    /** Restarts the wlan communication.
+    /**
+     *  \brief Restarts the wlan communication.
      */
     void restart(uint8_t patch);
-    /** Disconnect wlan device
+    /**
+     *  \brief Disconnect wlan device
      *
      */
     bool disconnect(void);
-    /** Callback which is called from the event class. This updates status of cc3000.
+    /**
+     *  \brief Callback which is called from the event class. This updates status of cc3000.
      *  \param event_type Type of the event
      *  \param data       Pointer to data
      *  \param length     Length of data
      *  \return none
      */
     void usync_callback(int32_t event_type, uint8_t *data, uint8_t length);
-    /** Connect to SSID (open/secured) with timeout (10ms).
+    /**
+     *  \brief Connect to SSID (open/secured) with timeout (10ms).
      *  \param ssid          SSID name
      *  \param key           Security key (if key = 0, open connection)
      *  \param security_mode Security mode
      *  \return true if connection was established, false otherwise.
      */
     bool connect_to_AP(const uint8_t *ssid, const uint8_t *key, int32_t security_mode);
-    /** Connect to SSID which is secured
+    /**
+     *  \brief Connect to SSID which is secured
      *  \param ssid          SSID name
      *  \param key           Security key
      *  \param security_mode Security mode
      *  \return true if connection was established, false otherwise.
      */
     bool connect_secure(const uint8_t *ssid, const uint8_t *key, int32_t security_mode);
-    /** Connect to SSID which is open (no security)
+    /**
+     *  \brief Connect to SSID which is open (no security)
      *  \param ssid          SSID name
      *  \return true if connection was established, false otherwise.
      */
     bool connect_open(const uint8_t *ssid);
-    /** Status of the cc3000 connection.
+    /**
+     *  \brief Status of the cc3000 connection.
      *  \return true if it's connected, false otherwise.
      */
     bool is_connected();
-    /** Status of DHCP.
+    /**
+     *  \brief Status of DHCP.
      *  \param none
      *  \return true if DCHP is configured, false otherwise.
      */
     bool is_dhcp_configured();
-    /** Status of smart confing completation.
+    /**
+     *  \brief Status of smart confing completation.
      *  \param none
      *  \return smart config was set, false otherwise.
      */
     bool is_smart_confing_completed();
-    /** Return the cc3000's mac address.
+    /**
+     *  \brief Return the cc3000's mac address.
      *  \param address Retreived mac address.
      *  \return
      */
     uint8_t get_mac_address(uint8_t address[6]);
-    /** Set the cc3000's mac address
-     *  \param address Mac address to be set
+    /**
+     *  \brief Set the cc3000's mac address.
+     *  \param address Mac address to be set.
      *  \return
      */
     uint8_t set_mac_address(uint8_t address[6]);
-    /** Get user file info
-     *  \param  info_file Pointer where info will be stored
-     *  \param  size      Available size
+    /**
+     *  \brief Get user file info.
+     *  \param  info_file Pointer where info will be stored.
+     *  \param  size      Available size.
      *  \return none
      */
     void get_user_file_info(uint8_t *info_file, size_t size);
-    /** Set user filo info
-     *  \param info_file Pointer to user's info
+    /**
+     *  \brief Set user filo info.
+     *  \param info_file Pointer to user's info.
      *  \return none
      */
     void set_user_file_info(uint8_t *info_file, size_t size);
-    /** Start smart config
-     *  \param smart_config_key Pointer to smart config key
+    /**
+     *  \brief Start smart config.
+     *  \param smart_config_key Pointer to smart config key.
      *  \return none
      */
     void start_smart_config(const uint8_t *smart_config_key);  /* TODO enable AES ? */
 #ifndef CC3000_TINY_DRIVER
-    /** Return ip configuration
-     * \param ip_config Pointer to ipconfig data
-     * \return true if it's connected and info was retrieved, false otherwise.
+    /**
+     *  \brief Return ip configuration.
+     *  \param ip_config Pointer to ipconfig data.
+     *  \return true if it's connected and info was retrieved, false otherwise.
      */
     bool get_ip_config(tNetappIpconfigRetArgs *ip_config);
 #endif
@@ -685,22 +1328,32 @@
      *  \return server with socket != -1
      */
     cc3000_server create_tcp_server(uint32_t ip_address, uint16_t port);
-    /** Creates udp client
+    /**
+     *  \brief Creates udp client
      *  \param ip_address Server's IP address
      *  \param port       Server's PORT
      *  \return client with socket != -1
      */
     cc3000_client create_udp_client(uint32_t ip_address, uint16_t port);
-    /** Delete all stored profiles
-     * \param none
+    /**
+     *  \brief Delete all stored profiles
+     *  \param none
      *  \return none
      */
     void delete_profiles(void);
     /**
-     *
+     *  \brief Ping an ip address
+     *  \param ip       Destination IP address
+     *  \param attempts Number of attempts
+     *  \param timeout  Time to wait for a response,in milliseconds.
+     *  \param size     Send buffer size which may be up to 1400 bytes
      */
     uint32_t ping(uint32_t ip, uint8_t attempts, uint16_t timeout, uint8_t size);
-
+    /**
+     *  \brief Returns cc3000 instance
+     *  \param none
+     *  \return Pointer to cc3000 object
+     */
     static cc3000 *get_instance() {
         return _inst;
     }
@@ -725,35 +1378,35 @@
 };
 
 /**
-* Copy 32 bit to stream while converting to little endian format.
-* @param  p       pointer to the new stream
-* @param  u32     pointer to the 32 bit
-* @return         pointer to the new stream
-*/
+ * Copy 32 bit to stream while converting to little endian format.
+ * @param  p       pointer to the new stream
+ * @param  u32     pointer to the 32 bit
+ * @return         pointer to the new stream
+ */
 uint8_t *UINT32_TO_STREAM_f (uint8_t *p, uint32_t u32);
 
 /**
-* Copy 16 bit to stream while converting to little endian format.
-* @param  p       pointer to the new stream
-* @param  u32     pointer to the 16 bit
-* @return         pointer to the new stream
-*/
+ * Copy 16 bit to stream while converting to little endian format.
+ * @param  p       pointer to the new stream
+ * @param  u32     pointer to the 16 bit
+ * @return         pointer to the new stream
+ */
 uint8_t *UINT16_TO_STREAM_f (uint8_t *p, uint16_t u16);
 
 /**
-* Copy received stream to 16 bit in little endian format.
-* @param  p          pointer to the stream
-* @param  offset     offset in the stream
-* @return            pointer to the new 16 bit
-*/
+ * Copy received stream to 16 bit in little endian format.
+ * @param  p          pointer to the stream
+ * @param  offset     offset in the stream
+ * @return            pointer to the new 16 bit
+ */
 uint16_t STREAM_TO_UINT16_f(uint8_t* p, uint16_t offset);
 
 /**
-* Copy received stream to 32 bit in little endian format.
-* @param  p          pointer to the stream
-* @param  offset     offset in the stream
-* @return            pointer to the new 32 bit
-*/
+ * Copy received stream to 32 bit in little endian format.
+ * @param  p          pointer to the stream
+ * @param  offset     offset in the stream
+ * @return            pointer to the new 32 bit
+ */
 uint32_t STREAM_TO_UINT32_f(uint8_t* p, uint16_t offset);
 
 } /* end of mbed_cc3000 namespace */