cc3000_ntp_demo_F446RE

Dependencies:   NTPClient2 NVIC_set_all_priorities cc3000_hostdriver_mbedsocket mbed

Fork of cc3000_ntp_demo by Martin Kojtal

Revision:
2:f163731f852a
Parent:
1:fd70c76e74b2
Child:
3:4a2dfa38a61e
--- a/main.cpp	Tue Oct 01 04:48:37 2013 +0000
+++ b/main.cpp	Thu Oct 03 14:46:22 2013 +0000
@@ -14,24 +14,25 @@
  * limitations under the License.
  */
 #include "mbed.h"
-#include "KL25Z_irq_prio.h"
 #include "cc3000.h"
 #include "main.h"
 #include "NTPClient.h"
 
 using namespace mbed_cc3000;
 
-#if (WIGO_BOARD)
-// Wi-Go battery charger control
-DigitalOut PWR_EN1(PTB2);
-DigitalOut PWR_EN2(PTB3);
-#endif
-
 Serial pc(USBTX, USBRX);
-cc3000 wigo(PTA16, PTA13, PTD0, SPI(PTD2, PTD3, PTC5), PORTA_IRQn);
 tUserFS user_info;
 NTPClient ntp;
 
+/* cc3000 module declaration specific for user's board. Check also init() */
+#if (MY_BOARD == WIGO)
+cc3000 wifi(PTA16, PTA13, PTD0, SPI(PTD2, PTD3, PTC5), PORTA_IRQn);
+#elif (MY_BOARD == WIFI_DIPCORTEX)
+cc3000 wifi(p28, p27, p30, SPI(p21, p14, p37), PIN_INT0_IRQn);
+#else
+
+#endif
+
 #ifndef CC3000_UNENCRYPTED_SMART_CONFIG
   const uint8_t smartconfigkey[] = {0x73,0x6d,0x61,0x72,0x74,0x63,0x6f,0x6e,0x66,0x69,0x67,0x41,0x45,0x53,0x31,0x36};
 #else
@@ -45,16 +46,16 @@
 void print_cc3000_info() {
     uint8_t myMAC[8];
 
-    printf("MAC address + cc3000 info\n");
-    wigo.get_user_file_info((uint8_t *)&user_info, sizeof(user_info));
-    wigo.get_mac_address(myMAC);
-    printf(" MAC address %02x:%02x:%02x:%02x:%02x:%02x\n\n", myMAC[0], myMAC[1], myMAC[2], myMAC[3], myMAC[4], myMAC[5]);
+    printf("MAC address + cc3000 info \r\n");
+    wifi.get_user_file_info((uint8_t *)&user_info, sizeof(user_info));
+    wifi.get_mac_address(myMAC);
+    printf(" MAC address %02x:%02x:%02x:%02x:%02x:%02x \r\n \r\n", myMAC[0], myMAC[1], myMAC[2], myMAC[3], myMAC[4], myMAC[5]);
 
-    printf(" FTC        %i\n",user_info.FTC);
-    printf(" PP_version %i.%i\n",user_info.PP_version[0], user_info.PP_version[1]);
-    printf(" SERV_PACK  %i.%i\n",user_info.SERV_PACK[0], user_info.SERV_PACK[1]);
-    printf(" DRV_VER    %i.%i.%i\n",user_info.DRV_VER[0], user_info.DRV_VER[1], user_info.DRV_VER[2]);
-    printf(" FW_VER     %i.%i.%i\n",user_info.FW_VER[0], user_info.FW_VER[1], user_info.FW_VER[2]);
+    printf(" FTC        %i \r\n",user_info.FTC);
+    printf(" PP_version %i.%i \r\n",user_info.PP_version[0], user_info.PP_version[1]);
+    printf(" SERV_PACK  %i.%i \r\n",user_info.SERV_PACK[0], user_info.SERV_PACK[1]);
+    printf(" DRV_VER    %i.%i.%i \r\n",user_info.DRV_VER[0], user_info.DRV_VER[1], user_info.DRV_VER[2]);
+    printf(" FW_VER     %i.%i.%i \r\n",user_info.FW_VER[0], user_info.FW_VER[1], user_info.FW_VER[2]);
 }
 
 /** Connect to SSID with a timeout
@@ -63,9 +64,9 @@
  *  \param  sec_mode Security mode
  *  \return none
  */
-void connect_to_ssid(uint8_t *ssid, uint8_t *key, uint8_t sec_mode) {
+void connect_to_ssid(char *ssid, char *key, unsigned char sec_mode) {
     printf("Connecting to SSID: %s. Timeout is 10s.\n",ssid);
-    if (wigo.connect_to_AP(ssid, key, sec_mode) == true) {
+    if (wifi.connect_to_AP((uint8_t *)ssid, (uint8_t *)key, sec_mode) == true) {
         printf(" Connected\n");
     } else {
         printf(" Connection timed-out (error). Please restart.\n");
@@ -77,22 +78,8 @@
  *  \param  ssid Name of SSID
  *  \return none
  */
-void connect_to_ssid(uint8_t *ssid) {
-    wigo.connect_open(ssid);
-}
-
-void wigo_init(void) {
-    /* KL25 specific code */
-    // Wi-Go set current to 500mA since we're turning on the Wi-Fi
-    SET_PWR_EN1;
-    SET_PWR_EN2;
-
-    NVIC_SetAllPriority(3);
-    NVIC_SetPriority(SPI0_IRQn, 0x0);     // Wi-Fi SPI interrupt must be higher priority than SysTick
-    NVIC_SetPriority(PORTA_IRQn, 0x1);
-    NVIC_SetPriority(SysTick_IRQn, 0x2);  // SysTick set to lower priority than Wi-Fi SPI bus interrupt
-    CLEAR_PCR_INTERRUPT;
-    CLEAN_PORT_INTERRUPT;
+void connect_to_ssid(char *ssid) {
+    wifi.connect_open((uint8_t *)ssid);
 }
 
 /** First time configuration
@@ -100,15 +87,15 @@
  *  \return none
  */
 void do_FTC(void) {
-    printf("Running First Time Configuration\n");
-    wigo.start_smart_config(smartconfigkey);
-    while (wigo.is_dhcp_configured() == false) {
+    printf("Running First Time Configuration \r\n");
+    wifi.start_smart_config(smartconfigkey);
+    while (wifi.is_dhcp_configured() == false) {
          wait_ms(500);
-         printf("Waiting for dhcp to be set.\n");
+         printf("Waiting for dhcp to be set. \r\n");
     }
     user_info.FTC = 1;
-    wigo.set_user_file_info((uint8_t *)&user_info, sizeof(user_info));
-    wigo._wlan.stop();
+    wifi.set_user_file_info((uint8_t *)&user_info, sizeof(user_info));
+    wifi._wlan.stop();
     printf("FTC finished.\n");
 }
 
@@ -117,56 +104,56 @@
  *  \return int
  */
 int main() {
-    wigo_init();
+    init(); /* board dependent init */
     pc.baud(115200);
 
-    wigo.start(0);
-    printf("CC3000 ping demo.\n");
+    wifi.start(0);
+    printf("CC3000 NTP client demo. \r\n");
     print_cc3000_info();
 
-    printf("Attempting SSID Connection\n");
+    printf("Attempting SSID Connection. \r\n");
 #if (USE_SMART_CONFIG == 1)
     if (user_info.FTC == 1) {
-        wigo._wlan.ioctl_set_connection_policy(0, 1, 1);
+        wifi._wlan.ioctl_set_connection_policy(0, 1, 1);
     } else {
-        printf("Smart config is not set, starting configuration\n");
+        printf("Smart config is not set, starting configuration. \r\n");
         do_FTC();
-        printf("Smart config is set. Please restart your board.\n");
+        printf("Smart config is set. Please restart your board. \r\n");
         while(1);
     }
 #else
-    wigo._wlan.ioctl_set_connection_policy(0, 0, 0);
+    wifi._wlan.ioctl_set_connection_policy(0, 0, 0);
 
 
 #ifndef CC3000_TINY_DRIVER
 #ifdef AP_KEY
-    connect_to_ssid((uint8_t *)SSID,(uint8_t *)AP_KEY,AP_SECURITY);
+    connect_to_ssid(SSID, AP_KEY, AP_SECURITY);
 #else
-    connect_to_ssid((uint8_t *)SSID);
+    connect_to_ssid(SSID);
 #endif
 #else
-    connect_to_ssid((uint8_t *)SSID);
+    connect_to_ssid(SSID);
 #endif
 #endif
     printf("DHCP request\n");
-    while (wigo.is_dhcp_configured() == false) {
+    while (wifi.is_dhcp_configured() == false) {
          wait_ms(500);
-         printf("  Waiting for dhcp to be set.\n");
+         printf("  Waiting for dhcp to be set. \r\n");
     }
 
-    printf("Getting time, 10s timeout.\n");
+    printf("Getting time, 10s timeout. \r\n");
     if (ntp.setTime("0.uk.pool.ntp.org") == 0)
     {
-      printf("Set time successfully\r\n");
+      printf("Set time successfully. \r\n");
       time_t ctTime;
       ctTime = time(NULL);
-      printf("Time is set to (UTC): %s\r\n", ctime(&ctTime));
+      printf("Time is set to (UTC): %s \r\n", ctime(&ctTime));
     }
     else
     {
-      printf("Error\r\n");
+      printf("Error. \r\n");
     } 
 
-    wigo.disconnect();
+    wifi.disconnect();
 }