Demo apps : receive a string from a client and respond with a different string, TCP/IP client
Dependencies: CC3000_Hostdriver mbed
Note
Avnet Wi-Go board
For those using Avnet's Wi-Go board, there also is a full IOT demo available at
http://mbed.org/users/frankvnk/code/Wi-Go_IOT_Demo/
New cc3000 HostDriver release
For new projects, use cc3000 mbed socket compatible API driver and examples
Info
Demo application for testing the wireless CC3000 module on the Wi-Go board.
Warning
The on-board Firmware must be updated to mbed enable a Wi-Go system.
Goto the Component page to get the FirmwareUpdate tool (scroll down to the FirmwareUpdate topic).
Setup
Note
It is recommended to run initial tests WITHOUT security settings.
- Setup a wireless router with a non-secured wireless connection using the wireless settings stored in
doTCPIP.h
.
- Alternatively, these settings can be altered to match the wireless router settings (SSID, security and static IP parameters).
When the unsecure test works,AP_KEY
andAP_SECURITY
can be enabled and set to your preferred values.
Valid values forAP_SECURITY
are :NONE
,WEP
,WPA
andWPA2
// Modify the following settings as necessary for your Wi-Fi Network setup: #define IP_ALLOC_METHOD USE_DHCP // for DHCP assigned IP address //#define IP_ALLOC_METHOD USE_STATIC_IP // for static IP address // Default SSID Settings //#define AP_KEY "thisthis" //#define AP_SECURITY WPA2 // WPA2 must be enabled for use with iPhone or Android phone hotspot! #define SSID "iot" #define STATIC_IP_OCT1 192 #define STATIC_IP_OCT2 168 #define STATIC_IP_OCT3 0 #define STATIC_IP_OCT4 10 #define STATIC_GW_OCT4 1 // Static Gateway address = STATIC_IP_OCT1.STATIC_IP_OCT2.STATIC_IP_OCT3.STATIC_GW_OCT4
- Download Python 2.7 from http://www.python.org/download/
Install it on a computer able to make a wireless connection to the router we previously set up.
- Make a wireless connection between your computer and the router.
- Download this Python script to the Python2.7 folder (credit : Jim Carver from Avnet).
- Import the
CC3000_Simple_Socket
code into your compiler and save it to the Wi-Go board.
Running the application for the first time
- Open a terminal program (eg: TeraTerm) and connect to the Wi-Go module (serial speed : 115200 baud).
- Press the reset button on the Wi-Go module.
- Following startup screen will appear (the dots in the MAC address will show your CC3000's real MAC address):
CC3000 Python demo. Wi-Go MAC address ..:..:..:..:..:.. FTC 1 PP_version 3.3 SERV_PACK 1.11 DRV_VER 7.13.19 FW_VER 7.12.14 <0> Normal run. SmartConfig will start if no valid connection exists. <1> Connect using fixed SSID : iot <2> TCP/IP client: Discover public IP address. Get time and date from a daytime server in Italy. <9> SmartConfig.
- For the initial test, select option
<1>
(Connect using fixed SSID : ...). - If all goes well, the following screen is shown (the IP address and mDNS status can be different):
Starting TCP/IP Server RunSmartConfig= 0 Attempting SSID Connection waiting waiting waiting mDNS Status= 31be Connected *** Wi-Go board DHCP assigned IP Address = 192.168.0.101 mDNS Status= 3dbe Server waiting for connection to Python
- On the computer where you installed Python2.7:
- Make sure the wireless connection between your computer and the router is active.
- Open a DOS prompt and go to the folder where Python2.7 is installed.
- Type following command :
python wigo_test.py -a 192.168.0.101 -p 15000
Note
Don't forget to replace the IP address with the real IP address assigned by DHCP to the CC3000 module.
If a connection is established, the DOS window will show
----------------- run tcp client ----------------- connected to remote ip=192.168.0.101 remote port=15000 Press ENTER ....
In return the Wi-Go board will send following info to the serial port:
Connected
When we press Enter
in the DOS window, the Wi-Go board will send following info to the serial port:
Input = Hello Wi-Go status= 13 Done, press any key to repeat
And the DOS window will show:
recv from : data: Hello Python
Application option <2> : TCP/IP client
This is a simple demo to discover a public IP address and get the date and time from a daytime server (port 13).
Using the application's options <0> or <9>
Options <0>
(Normal run) and <9>
(SmartConfig) are very similar.
They both allow us to connect the CC3000 to another wireless network, without changing the pre-configured settings stored in doTCPIP.h
.
As mentioned before, option <0>
will automatically start SmartConfig if no valid connection exists (First Time Config),
but if the CC3000 was previously configured using SmartConfig, it will automatically connect to the wireless network.
Option <9>
can be used to switch to another wireless connection.
See TI's pages on how to use the SmartConfig tool:
- Preferred method : Configuration using the SmartConfig tool
- SmartConfig download: Smart Config and Home Automation
- iOS app : available at Apple app store.
- Android app : download and install the Android SmartConfig Application on a PC.
This file contains the source code as well as the compiled APK file.
The APK file is stored inti\CC3000AndroidApp\SmartConfigCC3X\bin
.
- iOS app : available at Apple app store.
- Alternate method (no longer works since firmware upgrade 1.11 - only kept as a reference):
Configuration without the SmartConfig tool
This page also contains info on the First Time Config Probe and Beacon Definition
The Prefix can be set in cc3000.cpp. Do not change the default value for the prefix (TTT) when you want to use TI's Smartconfig application.
char aucCC3000_prefix[] = {'T', 'T', 'T'}; // Smart Config Prefix
The Device Name mentioned on the SmartConfig page is declared in doTCPIP.cpp
char DevServname[] = "CC3000";
cc3000.h
- Committer:
- frankvnk
- Date:
- 2013-08-15
- Revision:
- 1:32d1ef95eceb
- Parent:
- 0:a8e46e27d041
File content as of revision 1:32d1ef95eceb:
/***************************************************************************** * * cc3000.h - CC3000 Function Definitions * Copyright (C) 2011 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 CC3000_H #define CC3000_H #include "wlan.h" //***************************************************************************** // //! \addtogroup cc3000 //! @{ // //***************************************************************************** /** CC3000 Functions * */ #ifdef __cplusplus extern "C" { #endif extern DigitalOut ledr; extern DigitalOut ledg; extern DigitalOut ledb; extern DigitalOut led1; extern DigitalOut led2; extern DigitalOut led3; #define RED_OFF ledr = 1; #define RED_ON ledr = 0; #define RED_TOGGLE ledr = !ledr; #define GREEN_OFF ledg = 1; #define GREEN_ON ledg = 0; #define GREEN_TOGGLE ledg = !ledg; #define BLUE_OFF ledb = 1; #define BLUE_ON ledb = 0; #define BLUE_TOGGLE ledb = !ledb; #define LED_D1_OFF led1 = 1; #define LED_D1_ON led1 = 0; #define LED_D1_TOGGLE led1 = !led1; #define LED_D2_OFF led2 = 1; #define LED_D2_ON led2 = 0; #define LED_D2_TOGGLE led2 = !led2; #define LED_D3_OFF led3 = 1; #define LED_D3_ON led3 = 0; #define LED_D3_TOGGLE led3 = !led3; #define SOCKET_INACTIVE_ERR -57 #define NUM_STATES 6 #define MAX_SSID_LEN 32 #define FIRST_TIME_CONFIG_SET 0xAA #define NETAPP_IPCONFIG_MAC_OFFSET (20) #define CC3000_APP_BUFFER_SIZE (5) #define CC3000_RX_BUFFER_OVERHEAD_SIZE (20) // CC3000 State Machine Definitions enum cc3000StateEnum { CC3000_UNINIT = 0x01, // CC3000 Driver Uninitialized CC3000_INIT = 0x02, // CC3000 Driver Initialized CC3000_ASSOC = 0x04, // CC3000 Associated to AP CC3000_IP_ALLOC = 0x08, // CC3000 has IP Address CC3000_SERVER_INIT = 0x10, // CC3000 Server Initialized CC3000_CLIENT_CONNECTED = 0x20 // CC3000 Client Connected to Server }; /** * Turn all LEDs Off * @param none * @return none */ void initLEDs(void); /** Connect to an Access Point using the specified SSID. * @param ssidName is a string of the AP's SSID * @return none */ int ConnectUsingSSID(char * ssidName); /** Handle asynchronous events from CC3000 device. * @param lEventType Event type * @param data * @param length * @return none */ void CC3000_UsynchCallback(long lEventType, char * data, unsigned char length); /** Initialize a CC3000 device and triggers it to start operation. * @param none * @return none */ int initDriver(void); /** Return the highest state which we're in. * @param None * @return none */ char highestCC3000State(void); /** Return the current state bits. * @param None * @return none */ char currentCC3000State(void); /** Sets a state from the state machine. * @param None * @return none */ void setCC3000MachineState(char stat); /** Unsets a state from the state machine. * Also handles LEDs.\n * @param None * @return none */ void unsetCC3000MachineState(char stat); /** Resets the State Machine. * @param None * @return none */ void resetCC3000StateMachine(void); /** Obtains the CC3000 Connection Information from the CC3000. * @param None * @return none */ #ifndef CC3000_TINY_DRIVER tNetappIpconfigRetArgs * getCC3000Info(void); #endif /** Trigger a smart configuration process on CC3000. * It exits upon completion of the process.\n * @param None * @return none */ void StartSmartConfig(void); #ifdef __cplusplus } #endif // __cplusplus //***************************************************************************** // // Close the Doxygen group. //! @} // //***************************************************************************** #endif // CC3000_H