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";
doTCPIP.h@0:a8e46e27d041, 2013-08-11 (annotated)
- Committer:
- frankvnk
- Date:
- Sun Aug 11 09:46:26 2013 +0000
- Revision:
- 0:a8e46e27d041
- Child:
- 1:32d1ef95eceb
First release
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
frankvnk | 0:a8e46e27d041 | 1 | /**************************************************************************** |
frankvnk | 0:a8e46e27d041 | 2 | * |
frankvnk | 0:a8e46e27d041 | 3 | * doTCPIP.h - CC3000 TCP/IP |
frankvnk | 0:a8e46e27d041 | 4 | * Copyright (C) 2011 Texas Instruments Incorporated - http://www.ti.com/ |
frankvnk | 0:a8e46e27d041 | 5 | * |
frankvnk | 0:a8e46e27d041 | 6 | * Redistribution and use in source and binary forms, with or without |
frankvnk | 0:a8e46e27d041 | 7 | * modification, are permitted provided that the following conditions |
frankvnk | 0:a8e46e27d041 | 8 | * are met: |
frankvnk | 0:a8e46e27d041 | 9 | * |
frankvnk | 0:a8e46e27d041 | 10 | * Redistributions of source code must retain the above copyright |
frankvnk | 0:a8e46e27d041 | 11 | * notice, this list of conditions and the following disclaimer. |
frankvnk | 0:a8e46e27d041 | 12 | * |
frankvnk | 0:a8e46e27d041 | 13 | * Redistributions in binary form must reproduce the above copyright |
frankvnk | 0:a8e46e27d041 | 14 | * notice, this list of conditions and the following disclaimer in the |
frankvnk | 0:a8e46e27d041 | 15 | * documentation and/or other materials provided with the |
frankvnk | 0:a8e46e27d041 | 16 | * distribution. |
frankvnk | 0:a8e46e27d041 | 17 | * |
frankvnk | 0:a8e46e27d041 | 18 | * Neither the name of Texas Instruments Incorporated nor the names of |
frankvnk | 0:a8e46e27d041 | 19 | * its contributors may be used to endorse or promote products derived |
frankvnk | 0:a8e46e27d041 | 20 | * from this software without specific prior written permission. |
frankvnk | 0:a8e46e27d041 | 21 | * |
frankvnk | 0:a8e46e27d041 | 22 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |
frankvnk | 0:a8e46e27d041 | 23 | * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |
frankvnk | 0:a8e46e27d041 | 24 | * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |
frankvnk | 0:a8e46e27d041 | 25 | * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |
frankvnk | 0:a8e46e27d041 | 26 | * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |
frankvnk | 0:a8e46e27d041 | 27 | * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |
frankvnk | 0:a8e46e27d041 | 28 | * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |
frankvnk | 0:a8e46e27d041 | 29 | * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |
frankvnk | 0:a8e46e27d041 | 30 | * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
frankvnk | 0:a8e46e27d041 | 31 | * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
frankvnk | 0:a8e46e27d041 | 32 | * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
frankvnk | 0:a8e46e27d041 | 33 | * |
frankvnk | 0:a8e46e27d041 | 34 | *****************************************************************************/ |
frankvnk | 0:a8e46e27d041 | 35 | |
frankvnk | 0:a8e46e27d041 | 36 | #ifndef DOTCPIP_H |
frankvnk | 0:a8e46e27d041 | 37 | #define DOTCPIP_H |
frankvnk | 0:a8e46e27d041 | 38 | |
frankvnk | 0:a8e46e27d041 | 39 | #include "cc3000.h" |
frankvnk | 0:a8e46e27d041 | 40 | /*#include "demo_config.h" |
frankvnk | 0:a8e46e27d041 | 41 | #include "httpserver.h" |
frankvnk | 0:a8e46e27d041 | 42 | #include "sensors.h"*/ |
frankvnk | 0:a8e46e27d041 | 43 | |
frankvnk | 0:a8e46e27d041 | 44 | |
frankvnk | 0:a8e46e27d041 | 45 | /** TCP/IP Functions |
frankvnk | 0:a8e46e27d041 | 46 | * |
frankvnk | 0:a8e46e27d041 | 47 | */ |
frankvnk | 0:a8e46e27d041 | 48 | #ifdef __cplusplus |
frankvnk | 0:a8e46e27d041 | 49 | extern "C" { |
frankvnk | 0:a8e46e27d041 | 50 | #endif |
frankvnk | 0:a8e46e27d041 | 51 | |
frankvnk | 0:a8e46e27d041 | 52 | #ifndef FALSE |
frankvnk | 0:a8e46e27d041 | 53 | #define FALSE 0 |
frankvnk | 0:a8e46e27d041 | 54 | #endif |
frankvnk | 0:a8e46e27d041 | 55 | |
frankvnk | 0:a8e46e27d041 | 56 | #ifndef TRUE |
frankvnk | 0:a8e46e27d041 | 57 | #define TRUE 1 |
frankvnk | 0:a8e46e27d041 | 58 | #endif |
frankvnk | 0:a8e46e27d041 | 59 | |
frankvnk | 0:a8e46e27d041 | 60 | #define SMART_CONFIG_SET 0x55 |
frankvnk | 0:a8e46e27d041 | 61 | #define TCPIP_PORT 15000 |
frankvnk | 0:a8e46e27d041 | 62 | |
frankvnk | 0:a8e46e27d041 | 63 | #define USE_DHCP 1 |
frankvnk | 0:a8e46e27d041 | 64 | #define USE_STATIC_IP 2 |
frankvnk | 0:a8e46e27d041 | 65 | |
frankvnk | 0:a8e46e27d041 | 66 | #define NONE 0 |
frankvnk | 0:a8e46e27d041 | 67 | #define WEP 1 |
frankvnk | 0:a8e46e27d041 | 68 | #define WPA 2 |
frankvnk | 0:a8e46e27d041 | 69 | #define WPA2 3 |
frankvnk | 0:a8e46e27d041 | 70 | |
frankvnk | 0:a8e46e27d041 | 71 | // Modify the following settings as necessary for your Wi-Fi Network setup: |
frankvnk | 0:a8e46e27d041 | 72 | #define IP_ALLOC_METHOD USE_DHCP // for DHCP assigned IP address |
frankvnk | 0:a8e46e27d041 | 73 | //#define IP_ALLOC_METHOD USE_STATIC_IP // for static IP address |
frankvnk | 0:a8e46e27d041 | 74 | |
frankvnk | 0:a8e46e27d041 | 75 | // Default SSID Settings |
frankvnk | 0:a8e46e27d041 | 76 | //#define SSID "HP2_Network" // or custom SSID eg. "XYZ iPhone" |
frankvnk | 0:a8e46e27d041 | 77 | //#define WPA2_KEY "fof0-gqi3-zn4i" |
frankvnk | 0:a8e46e27d041 | 78 | //#define AP_SECURITY WPA2 // WPA2 must be enabled for use with iPhone or Android phone hotspot! |
frankvnk | 0:a8e46e27d041 | 79 | #define SSID "iot" |
frankvnk | 0:a8e46e27d041 | 80 | #define AP_SECURITY NONE // no security but will connect quicker! |
frankvnk | 0:a8e46e27d041 | 81 | #define STATIC_IP_OCT1 192 |
frankvnk | 0:a8e46e27d041 | 82 | #define STATIC_IP_OCT2 168 |
frankvnk | 0:a8e46e27d041 | 83 | #define STATIC_IP_OCT3 0 |
frankvnk | 0:a8e46e27d041 | 84 | #define STATIC_IP_OCT4 10 |
frankvnk | 0:a8e46e27d041 | 85 | |
frankvnk | 0:a8e46e27d041 | 86 | #define REQ_BUFFER_SIZE 400 |
frankvnk | 0:a8e46e27d041 | 87 | |
frankvnk | 0:a8e46e27d041 | 88 | typedef struct { |
frankvnk | 0:a8e46e27d041 | 89 | unsigned char FTC; // First time config performed |
frankvnk | 0:a8e46e27d041 | 90 | unsigned char PP_version[2]; // Patch Programmer version |
frankvnk | 0:a8e46e27d041 | 91 | unsigned char SERV_PACK[2]; // Service Pack Version |
frankvnk | 0:a8e46e27d041 | 92 | unsigned char DRV_VER[3]; // Driver Version |
frankvnk | 0:a8e46e27d041 | 93 | unsigned char FW_VER[3]; // Firmware Version |
frankvnk | 0:a8e46e27d041 | 94 | unsigned char validCIK; // CIK[] is valid (Client Interface Key) |
frankvnk | 0:a8e46e27d041 | 95 | unsigned char CIK[40]; |
frankvnk | 0:a8e46e27d041 | 96 | } userFS_t; |
frankvnk | 0:a8e46e27d041 | 97 | |
frankvnk | 0:a8e46e27d041 | 98 | extern userFS_t userFS; |
frankvnk | 0:a8e46e27d041 | 99 | |
frankvnk | 0:a8e46e27d041 | 100 | extern unsigned long ulSmartConfigFinished,ulCC3000DHCP, OkToDoShutDown, ulCC3000DHCP_configured; |
frankvnk | 0:a8e46e27d041 | 101 | extern int server_running; |
frankvnk | 0:a8e46e27d041 | 102 | extern volatile unsigned char newData; |
frankvnk | 0:a8e46e27d041 | 103 | extern unsigned char ForceFixedSSID; |
frankvnk | 0:a8e46e27d041 | 104 | extern char runSmartConfig; |
frankvnk | 0:a8e46e27d041 | 105 | extern char requestBuffer[]; |
frankvnk | 0:a8e46e27d041 | 106 | extern char runFirstTimeConfig; |
frankvnk | 0:a8e46e27d041 | 107 | extern unsigned char myMAC[8]; |
frankvnk | 0:a8e46e27d041 | 108 | extern unsigned char SmartConfigProfilestored; |
frankvnk | 0:a8e46e27d041 | 109 | |
frankvnk | 0:a8e46e27d041 | 110 | extern void StartSmartConfig(void); |
frankvnk | 0:a8e46e27d041 | 111 | |
frankvnk | 0:a8e46e27d041 | 112 | |
frankvnk | 0:a8e46e27d041 | 113 | |
frankvnk | 0:a8e46e27d041 | 114 | void sendPython(int port); |
frankvnk | 0:a8e46e27d041 | 115 | void initTCPIP(void); |
frankvnk | 0:a8e46e27d041 | 116 | void runTCPIPserver(void); |
frankvnk | 0:a8e46e27d041 | 117 | |
frankvnk | 0:a8e46e27d041 | 118 | /** Checks if WiFi is still connected. |
frankvnk | 0:a8e46e27d041 | 119 | * @param None |
frankvnk | 0:a8e46e27d041 | 120 | * @return TRUE if connected, FALSE if not |
frankvnk | 0:a8e46e27d041 | 121 | * @note If not associated with an AP for 5 consecutive retries, it will reset the board. |
frankvnk | 0:a8e46e27d041 | 122 | */ |
frankvnk | 0:a8e46e27d041 | 123 | unsigned char checkWiFiConnected(void); |
frankvnk | 0:a8e46e27d041 | 124 | |
frankvnk | 0:a8e46e27d041 | 125 | /** Print MAC address. |
frankvnk | 0:a8e46e27d041 | 126 | * @param None |
frankvnk | 0:a8e46e27d041 | 127 | * @return none |
frankvnk | 0:a8e46e27d041 | 128 | */ |
frankvnk | 0:a8e46e27d041 | 129 | void print_mac(void); |
frankvnk | 0:a8e46e27d041 | 130 | |
frankvnk | 0:a8e46e27d041 | 131 | /** First time configuration. |
frankvnk | 0:a8e46e27d041 | 132 | * @param None |
frankvnk | 0:a8e46e27d041 | 133 | * @return none |
frankvnk | 0:a8e46e27d041 | 134 | */ |
frankvnk | 0:a8e46e27d041 | 135 | void do_FTC(void); |
frankvnk | 0:a8e46e27d041 | 136 | |
frankvnk | 0:a8e46e27d041 | 137 | #ifdef __cplusplus |
frankvnk | 0:a8e46e27d041 | 138 | } |
frankvnk | 0:a8e46e27d041 | 139 | #endif // __cplusplus |
frankvnk | 0:a8e46e27d041 | 140 | |
frankvnk | 0:a8e46e27d041 | 141 | #endif // DOTCPIP_H |