Simple app demonstrating network join feature of WiConnect Host Library.

Dependencies:   WiConnect mbed

Committer:
dan_ackme
Date:
Wed Aug 13 04:41:54 2014 -0700
Revision:
1:b4e1870b6daa
Child:
3:15daf72c279c
renamed file

Who changed what in which revision?

UserRevisionLine numberNew contents of line
dan_ackme 1:b4e1870b6daa 1 /**
dan_ackme 1:b4e1870b6daa 2 * @example join/example.cpp
dan_ackme 1:b4e1870b6daa 3 *
dan_ackme 1:b4e1870b6daa 4 * This is an example of using the join network API to
dan_ackme 1:b4e1870b6daa 5 * join a WiFi network.
dan_ackme 1:b4e1870b6daa 6 *
dan_ackme 1:b4e1870b6daa 7 * It works as follows:
dan_ackme 1:b4e1870b6daa 8 * 1. Instantiate the WiConnect Library
dan_ackme 1:b4e1870b6daa 9 * 2. Initiate Communication with WiFi Module
dan_ackme 1:b4e1870b6daa 10 * 3. Join a network using the specified parameters
dan_ackme 1:b4e1870b6daa 11 * 4. Wait for the module to join
dan_ackme 1:b4e1870b6daa 12 * 5. That's it!
dan_ackme 1:b4e1870b6daa 13 *
dan_ackme 1:b4e1870b6daa 14 *
dan_ackme 1:b4e1870b6daa 15 */
dan_ackme 1:b4e1870b6daa 16
dan_ackme 1:b4e1870b6daa 17
dan_ackme 1:b4e1870b6daa 18 /******************************************************************************
dan_ackme 1:b4e1870b6daa 19 * Example Variables
dan_ackme 1:b4e1870b6daa 20 */
dan_ackme 1:b4e1870b6daa 21
dan_ackme 1:b4e1870b6daa 22 // This is the name of your WiFi network
dan_ackme 1:b4e1870b6daa 23 // Look for this name in your WiFi settings
dan_ackme 1:b4e1870b6daa 24 // (e.g. your phone's list of WiFi networks in the WiFi settings menu)
dan_ackme 1:b4e1870b6daa 25 // tip: add double-quotes around SSID to add spaces to name
dan_ackme 1:b4e1870b6daa 26 #define NETWORK_SSID "\"<YOUR NETWORK NAME HERE>\""
dan_ackme 1:b4e1870b6daa 27
dan_ackme 1:b4e1870b6daa 28 // This is the password of your WiFi network
dan_ackme 1:b4e1870b6daa 29 // Leave as empty string (e.g "") to connect to OPEN network
dan_ackme 1:b4e1870b6daa 30 #define NETWORK_PASSWORD "\"<YOUR NETWORK PASSWORD HERE>\""
dan_ackme 1:b4e1870b6daa 31
dan_ackme 1:b4e1870b6daa 32
dan_ackme 1:b4e1870b6daa 33
dan_ackme 1:b4e1870b6daa 34
dan_ackme 1:b4e1870b6daa 35 /******************************************************************************
dan_ackme 1:b4e1870b6daa 36 * Includes
dan_ackme 1:b4e1870b6daa 37 */
dan_ackme 1:b4e1870b6daa 38
dan_ackme 1:b4e1870b6daa 39 // include C library headers
dan_ackme 1:b4e1870b6daa 40 #include <stdio.h> // needed for printf
dan_ackme 1:b4e1870b6daa 41
dan_ackme 1:b4e1870b6daa 42 // include target specific defines
dan_ackme 1:b4e1870b6daa 43 #include "target_config.h"
dan_ackme 1:b4e1870b6daa 44 // include the Wiconnect Host Library API header
dan_ackme 1:b4e1870b6daa 45 #include "Wiconnect.h"
dan_ackme 1:b4e1870b6daa 46
dan_ackme 1:b4e1870b6daa 47
dan_ackme 1:b4e1870b6daa 48
dan_ackme 1:b4e1870b6daa 49 /******************************************************************************
dan_ackme 1:b4e1870b6daa 50 * Global Defines
dan_ackme 1:b4e1870b6daa 51 */
dan_ackme 1:b4e1870b6daa 52
dan_ackme 1:b4e1870b6daa 53
dan_ackme 1:b4e1870b6daa 54 // Serial used for printfs to terminal (i.e. NOT used for WiConnect)
dan_ackme 1:b4e1870b6daa 55 static Serial consoleSerial(STDIO_UART_TX, STDIO_UART_RX);
dan_ackme 1:b4e1870b6daa 56
dan_ackme 1:b4e1870b6daa 57
dan_ackme 1:b4e1870b6daa 58
dan_ackme 1:b4e1870b6daa 59
dan_ackme 1:b4e1870b6daa 60 /******************************************************************************
dan_ackme 1:b4e1870b6daa 61 * Starting point of application
dan_ackme 1:b4e1870b6daa 62 */
dan_ackme 1:b4e1870b6daa 63 int main(int argc, char **argv)
dan_ackme 1:b4e1870b6daa 64 {
dan_ackme 1:b4e1870b6daa 65 NetworkStatus networkStatus;
dan_ackme 1:b4e1870b6daa 66
dan_ackme 1:b4e1870b6daa 67
dan_ackme 1:b4e1870b6daa 68 consoleSerial.baud(115200); // console terminal to 115200 baud
dan_ackme 1:b4e1870b6daa 69
dan_ackme 1:b4e1870b6daa 70 //-------------------------------------------------------------------------
dan_ackme 1:b4e1870b6daa 71 // STEP 1: Instantiate WiConnect Library
dan_ackme 1:b4e1870b6daa 72 //-------------------------------------------------------------------------
dan_ackme 1:b4e1870b6daa 73
dan_ackme 1:b4e1870b6daa 74 // Setup wiconnect serial interface configuration
dan_ackme 1:b4e1870b6daa 75 // Here we only specify the rx buffer size and not rx buffer pointer, this means
dan_ackme 1:b4e1870b6daa 76 // The serial RX buffer will be dynamically allocated
dan_ackme 1:b4e1870b6daa 77 SerialConfig serialConfig(WICONNECT_RX_PIN, WICONNECT_TX_PIN, 256, NULL);
dan_ackme 1:b4e1870b6daa 78
dan_ackme 1:b4e1870b6daa 79 // Instantiate the Wiconnect library
dan_ackme 1:b4e1870b6daa 80 // Here we only specify the buffer size and not buffer pointer, this means
dan_ackme 1:b4e1870b6daa 81 // The internal buffer will be dynamically allocated
dan_ackme 1:b4e1870b6daa 82 Wiconnect wiconnect(serialConfig, 256, NULL, WICONNECT_RESET_PIN);
dan_ackme 1:b4e1870b6daa 83
dan_ackme 1:b4e1870b6daa 84
dan_ackme 1:b4e1870b6daa 85 //-------------------------------------------------------------------------
dan_ackme 1:b4e1870b6daa 86 // STEP 2: Initiate Communication with WiFi Module
dan_ackme 1:b4e1870b6daa 87 //-------------------------------------------------------------------------
dan_ackme 1:b4e1870b6daa 88
dan_ackme 1:b4e1870b6daa 89 printf("Initializing WiConnect Library...\r\n");
dan_ackme 1:b4e1870b6daa 90
dan_ackme 1:b4e1870b6daa 91 // Initialize communication with WiFi module
dan_ackme 1:b4e1870b6daa 92 if(wiconnect.init(true) != WICONNECT_SUCCESS)
dan_ackme 1:b4e1870b6daa 93 {
dan_ackme 1:b4e1870b6daa 94 printf("Failed to initialize communication with WiFi module!\r\n"
dan_ackme 1:b4e1870b6daa 95 "Make sure the wires are connected correctly\r\n");
dan_ackme 1:b4e1870b6daa 96 for(;;); // infinite loop
dan_ackme 1:b4e1870b6daa 97 }
dan_ackme 1:b4e1870b6daa 98
dan_ackme 1:b4e1870b6daa 99
dan_ackme 1:b4e1870b6daa 100 //-------------------------------------------------------------------------
dan_ackme 1:b4e1870b6daa 101 // STEP 3: Join a network using the specified parameters
dan_ackme 1:b4e1870b6daa 102 //-------------------------------------------------------------------------
dan_ackme 1:b4e1870b6daa 103
dan_ackme 1:b4e1870b6daa 104 printf("Joining network: %s....\r\n", NETWORK_SSID);
dan_ackme 1:b4e1870b6daa 105
dan_ackme 1:b4e1870b6daa 106 // Initiate module join sequence
dan_ackme 1:b4e1870b6daa 107 if(wiconnect.join(NETWORK_SSID, NETWORK_PASSWORD) != WICONNECT_SUCCESS)
dan_ackme 1:b4e1870b6daa 108 {
dan_ackme 1:b4e1870b6daa 109 printf("Failed to send join command\r\n");
dan_ackme 1:b4e1870b6daa 110 for(;;); // infinite loop
dan_ackme 1:b4e1870b6daa 111 }
dan_ackme 1:b4e1870b6daa 112
dan_ackme 1:b4e1870b6daa 113 //-------------------------------------------------------------------------
dan_ackme 1:b4e1870b6daa 114 // STEP 4: Wait for the module to join the network
dan_ackme 1:b4e1870b6daa 115 //-------------------------------------------------------------------------
dan_ackme 1:b4e1870b6daa 116
dan_ackme 1:b4e1870b6daa 117 printf("Waiting to join network....\r\n");
dan_ackme 1:b4e1870b6daa 118
dan_ackme 1:b4e1870b6daa 119 do
dan_ackme 1:b4e1870b6daa 120 {
dan_ackme 1:b4e1870b6daa 121 // poll the module for the network status
dan_ackme 1:b4e1870b6daa 122 if(wiconnect.getNetworkStatus(&networkStatus) != WICONNECT_SUCCESS)
dan_ackme 1:b4e1870b6daa 123 {
dan_ackme 1:b4e1870b6daa 124 printf("Failed to get network status\r\n");
dan_ackme 1:b4e1870b6daa 125 for(;;); // infinite loop
dan_ackme 1:b4e1870b6daa 126 }
dan_ackme 1:b4e1870b6daa 127
dan_ackme 1:b4e1870b6daa 128 // loop until the network status is not down
dan_ackme 1:b4e1870b6daa 129 } while(networkStatus == NETWORK_STATUS_DOWN);
dan_ackme 1:b4e1870b6daa 130
dan_ackme 1:b4e1870b6daa 131 //-------------------------------------------------------------------------
dan_ackme 1:b4e1870b6daa 132 // STEP 5: Done!
dan_ackme 1:b4e1870b6daa 133 //-------------------------------------------------------------------------
dan_ackme 1:b4e1870b6daa 134
dan_ackme 1:b4e1870b6daa 135 printf("Network join example has completed!\r\n");
dan_ackme 1:b4e1870b6daa 136
dan_ackme 1:b4e1870b6daa 137 for(;;); // infinite loop
dan_ackme 1:b4e1870b6daa 138
dan_ackme 1:b4e1870b6daa 139 return 0;
dan_ackme 1:b4e1870b6daa 140 }
dan_ackme 1:b4e1870b6daa 141