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";
Revisions of doTCPIP.h
Revision | Date | Message | Actions |
---|---|---|---|
3:63bff0590657 | 2013-08-27 | Added option to use secure connection using a fixed ssid | File Diff Annotate |
2:13ced2cb5933 | 2013-08-18 | improved program output | File Diff Annotate |
1:32d1ef95eceb | 2013-08-15 | Common code moved to cc3000_common | File Diff Annotate |
0:a8e46e27d041 | 2013-08-11 | First release | File Diff Annotate |