This thread has been locked.

If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.

Compiler/TM4C1294NCPDT: qs_IOT

Part Number: EK-TM4C1294XL

Tool/software: TI C/C++ Compiler

please help for edit  "qs_iot"  program for 10 led lights ("ti\TivaWare_C_Series-2.1.4.178\examples\boards\ek-tm4c1294xl\qs_iot")...

I am try but there is some error i could not solve error....

  • Hi,
    qs_iot is the only example we have that interacts with the cloud server by Exosite. You are free to reference and modify per your application.
  • I know but I am edit this program for 4 led and due to some error I try  to find error using debug process and I am not identify the error (FLAUT INT generated) .

    Help for this. 

  • KISHAN PATEL said:
    I am not identify the error (FLAUT INT generated)

    Can you please clarify what error you are getting? What is FLAUT INT? Are you getting an unexpected hard fault or you are not getting the expected interrupt? Did you get this error when you are running your code or you only get this error when you are in debug (i.e. single step or hitting a breakpoint)? 

  • I am try single step or hitting a breakpoint but it is not work...
    I am send program code to u give your mail id..
  • Part Number: EK-TM4C1294XL

    Tool/software: TI C/C++ Compiler

    I am upload 2 screen shots and my edited qs_iot.c file is build with no error and I am debug the program at this time FSR routine after this" if(SyncWithExosite(g_psDeviceStatistics))
                {
                    //
                    // If the sync is successful, reset the "retries" count to zero
                    //
    qs_iot.c
    //*****************************************************************************
    //
    // qs_iot.c - Quickstart application that connects to a cloud server.
    //
    // Copyright (c) 2013-2017 Texas Instruments Incorporated.  All rights reserved.
    // Software License Agreement
    // 
    // Texas Instruments (TI) is supplying this software for use solely and
    // exclusively on TI's microcontroller products. The software is owned by
    // TI and/or its suppliers, and is protected under applicable copyright
    // laws. You may not combine this software with "viral" open-source
    // software in order to form a larger program.
    // 
    // THIS SOFTWARE IS PROVIDED "AS IS" AND WITH ALL FAULTS.
    // NO WARRANTIES, WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT
    // NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
    // A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE. TI SHALL NOT, UNDER ANY
    // CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR CONSEQUENTIAL
    // DAMAGES, FOR ANY REASON WHATSOEVER.
    // 
    // This is part of revision 2.1.4.178 of the EK-TM4C1294XL Firmware Package.
    //
    //*****************************************************************************
    
    #include <stdint.h>
    #include <stdbool.h>
    #include <string.h>
    #include "inc/hw_memmap.h"
    #include "inc/hw_types.h"
    #include "inc/hw_ints.h"
    #include "inc/hw_adc.h"
    #include "driverlib/adc.h"
    #include "driverlib/gpio.h"
    #include "driverlib/pin_map.h"
    #include "driverlib/rom.h"
    #include "driverlib/rom_map.h"
    #include "driverlib/sysctl.h"
    #include "driverlib/systick.h"
    #include "driverlib/uart.h"
    #include "driverlib/interrupt.h"
    #include "driverlib/timer.h"
    #include "utils/cmdline.h"
    #include "utils/uartstdio.h"
    #include "utils/ustdlib.h"
    #include "utils/lwiplib.h"
    #include "drivers/pinout.h"
    #include "drivers/buttons.h"
    #include "drivers/exosite_hal_lwip.h"
    #include "drivers/eth_client_lwip.h"
    #include "exosite.h"
    #include "stats.h"
    #include "qs_iot.h"
    #include "requests.h"
    #include "commands.h"
    #include "tictactoe.h"
    
    //*****************************************************************************
    //
    //! \addtogroup example_list
    //! <h1>Internet of Things Quickstart (qs_iot)</h1>
    //!
    //!
    //! This application records various information about user activity on the
    //! board, and periodically reports it to a cloud server managed by Exosite.
    //! In order to use all of the features of this application, you will need to
    //! have an account with Exosite, and make sure that the device you are using
    //! is registered to your Exosite profile with its original MAC address from
    //! the factory.
    //!
    //! If you do not yet have an Exosite account, you can create one at
    //! http://ti.exosite.com.  The web interface there will help guide you through
    //! the account creation process.  There is also information in the Quickstart
    //! document that is shipped along with the EK-TM4C1294XL evaluation kit.
    //!
    //! This application uses a command-line based interface through a virtual COM
    //! port on UART 0, with the settings 115,200-8-N-1.  This application also
    //! requires a wired Ethernet connection with internet access to perform
    //! cloud-connected activities.
    //!
    //! Once the application is running you should be able to see program output
    //! over the virtual COM port, and interact with the command-line.  The command
    //! line will allow you to see the information being sent to and from Exosite's
    //! servers, change the state of LEDs, and play a game of tic-tac-toe.  If you
    //! have internet connectivity issues, need to find your MAC address, or need
    //! to re-activate your EK-TM4C1294XL board with Exosite, the command line
    //! interface also has options to support these operations.  Type
    //! 'help' at the command prompt to see a list of available commands.
    //!
    //! If your local internet connection requires the use of a proxy server, you
    //! will need to enter a command over the virtual COM port terminal before the
    //! device will be able to connect to Exosite.  When prompted by the
    //! application, type 'setproxy help' for information on how to configure the
    //! proxy.  Alternatively, you may uncomment the define statements below for
    //! "CUSTOM_PROXY" settings, fill in the correct information for your local
    //! http proxy server, and recompile this example.  This will permanently set
    //! your proxy as the default connection point.
    //!
    //
    //*****************************************************************************
    
    //*****************************************************************************
    //
    // The error routine that is called if the driver library encounters an error.
    //
    //*****************************************************************************
    #ifdef DEBUG
    void
    __error__(char *pcFilename, uint32_t ui32Line)
    {
    }
    #endif
    
    //*****************************************************************************
    //
    // Global macro definitions.
    //
    //*****************************************************************************
    #define MAX_SYNC_RETRIES        10
    
    // #define CUSTOM_PROXY
    // #define PROXY_ADDRESS           "your.proxy.address"
    // #define PROXY_PORT              80
    
    //*****************************************************************************
    //
    // Global variables that will be linked to Exosite.
    //
    //*****************************************************************************
    uint32_t g_ui32SW1Presses = 0;
    uint32_t g_ui32SW2Presses = 0;
    uint32_t g_ui32InternalTempF = 0;
    uint32_t g_ui32InternalTempC = 0;
    uint32_t g_ui32TimerIntCount = 0;
    uint32_t g_ui32SecondsOnTime = 0;
    uint32_t g_ui32LEDD1 = 0;
    uint32_t g_ui32LEDD2 = 0;
    uint32_t g_ui32LEDD3 = 0;
    uint32_t g_ui32LEDD4 = 0;
    uint32_t g_ui32LEDD5 = 0;
    
    char g_pcLocation[50] = "";
    char g_pcContactEmail[100] = "";
    char g_pcAlert[140] = "";
    
    //*****************************************************************************
    //
    // Global structures used to interface with Exosite.
    //
    //*****************************************************************************
    tStat g_sSW1Presses =
        {"SW1-presses", &g_ui32SW1Presses, "usrsw1", INT, WRITE_ONLY};
    
    tStat g_sSW2Presses =
        {"SW2-presses", &g_ui32SW2Presses, "usrsw2", INT, WRITE_ONLY};
    
    tStat g_sInternalTempF =
        {"Temp(F)", &g_ui32InternalTempF, 0, INT, WRITE_ONLY};
    
    tStat g_sInternalTempC =
        {"Temp(C)", &g_ui32InternalTempC, "jtemp", INT, WRITE_ONLY};
    
    tStat g_sSecondsOnTime =
        {"Time since reset", &g_ui32SecondsOnTime, "ontime", INT, WRITE_ONLY};
    
    tStat g_sLEDD1 =
        {"LED D1", &g_ui32LEDD1, "ledd1", INT, READ_WRITE};
    
    tStat g_sLEDD2 =
        {"LED D2", &g_ui32LEDD2, "ledd2", INT, READ_WRITE};
    		
    tStat g_sLEDD3 =
        {"LED D3", &g_ui32LEDD3, "ledd3", INT, READ_WRITE};
    tStat g_sLEDD4 =
        {"LED D4", &g_ui32LEDD4, "ledd4", INT, READ_WRITE};
    tStat g_sLEDD5 =
        {"LED D5", &g_ui32LEDD5, "ledd5", INT, READ_WRITE};
    
    		
    
    
    
    tStat g_sLocation =
        {"Location", g_pcLocation, "location", STRING, READ_ONLY};
    
    tStat g_sBoardState =
        {NULL, &g_ui32BoardState, "gamestate", HEX, WRITE_ONLY};
    
    tStat g_sContactEmail =
        {"Contact Email", g_pcContactEmail, "emailaddr", STRING, READ_WRITE};
    
    tStat g_sAlert =
        {"Alert Message", g_pcAlert, "alert", STRING, NONE};
    
    //*****************************************************************************
    //
    // Global array of pointers to all tStat structures to be synced with Exosite.
    //
    //*****************************************************************************
    tStat *g_psDeviceStatistics[NUM_STATS]=
    {
        &g_sSW1Presses,
        &g_sSW2Presses,
        &g_sInternalTempF,
        &g_sInternalTempC,
        &g_sSecondsOnTime,
        &g_sLEDD1,
        &g_sLEDD2,
        &g_sLEDD3,
    		&g_sLEDD4,
    		&g_sLEDD5,
    		
    
        &g_sLocation,
        &g_sBoardState,
        &g_sContactEmail,
        &g_sAlert,
        NULL
    };
    
    //*****************************************************************************
    //
    // Global variable to keep track of the system clock.
    //
    //*****************************************************************************
    uint32_t g_ui32SysClock = 0;
    
    //*****************************************************************************
    //
    // Global variable to keep track of the IP address.
    //
    //*****************************************************************************
    uint32_t g_ui32IPAddr;
    
    //*****************************************************************************
    //
    // Flags to keep track of application state.
    //
    //*****************************************************************************
    bool g_bPrintingData = false;
    bool g_bGameActive = false;
    volatile bool g_bOnline = false;
    
    //*****************************************************************************
    //
    // Global variables to keep track of the error conditions.
    //
    //*****************************************************************************
    enum
    {
        ERR_IP_ADDR,
        ERR_CIK,
        ERR_UNKNOWN,
        ERR_NO_ERR
    } g_ui32Err = ERR_NO_ERR;
    
    uint32_t g_ui32LinkRetries = 0;
    
    //*****************************************************************************
    //
    // Input buffer for the command line interpreter.
    //
    //*****************************************************************************
    char g_cInput[APP_INPUT_BUF_SIZE];
    
    //*****************************************************************************
    //
    // Given a list of statistics, prints each item to the UART.
    //
    //*****************************************************************************
    void
    PrintStats(tStat **psStats)
    {
        uint32_t ui32Index;
        char pcStatValue[256];
        char *pcStatName;
    
        //
        // Loop over all statistics in the list.
        //
        for(ui32Index = 0; psStats[ui32Index] != NULL; ui32Index++)
        {
            if(psStats[ui32Index]->pcName)
            {
                //
                // For each statistic, print the name and current value to the UART.
                //
                pcStatName = psStats[ui32Index]->pcName;
                StatPrintValue(psStats[ui32Index], pcStatValue);
    
                UARTprintf("%25s= %s\n", pcStatName, pcStatValue);
            }
        }
    }
    
    //*****************************************************************************
    //
    // Prints the current MAC address to the UART.
    //
    //*****************************************************************************
    void
    PrintMac(void)
    {
        uint8_t ui8Idx;
        uint8_t pui8MACAddr[6];
    
        //
        // Get the MAC address from the Ethernet Client layer.
        //
        EthClientMACAddrGet(pui8MACAddr);
    
        UARTprintf("Current MAC: ");
    
        //
        // Extract each pair of characters and print them to the UART.
        //
        for(ui8Idx = 0; ui8Idx < 6; ui8Idx++)
        {
            UARTprintf("%02x", pui8MACAddr[ui8Idx]);
        }
    
        UARTprintf("\n");
    }
    
    //*****************************************************************************
    //
    // This function prints a list of local statistics for this board.
    //
    //*****************************************************************************
    void
    PrintAllData(void)
    {
        char cExositeCIK[CIK_LENGTH];
    
        if(UARTPeek('\r') != -1)
        {
            g_bPrintingData = false;
    
            //
            // Get a user command back
            //
            UARTgets(g_cInput, APP_INPUT_BUF_SIZE);
    
            //
            // Print a prompt
            //
            UARTprintf("\n> ");
    
            return;
        }
    
        UARTprintf("\033[2J\033[H");
        UARTprintf("Welcome to the Connected LaunchPad!!\n");
        UARTprintf("Internet of Things Demo\n");
        UARTprintf("Type 'help' for help.\n\n");
    
        //
        // Print out the MAC address for reference
        //
        PrintMac();
    
        //
        // Check to see if we already have a CIK, and print it to the UART
        //
        if(Exosite_GetCIK(cExositeCIK))
        {
            UARTprintf("Current CIK: %s\n", cExositeCIK);
        }
        else
        {
            UARTprintf("No CIK found. Connect to Exosite to obtain one.\n");
        }
    
        //
        // Check to see how many times (if any) we've failed to connect to the
        // server.
        //
        if((g_ui32LinkRetries == 0) && g_bOnline)
        {
            //
            // For zero failures, report a "Link OK"
            //
            UARTprintf("Link Status: OK\n");
        }
        else if((g_ui32LinkRetries < MAX_SYNC_RETRIES) && g_bOnline)
        {
            //
            // For the first few failures, report that we are trying to
            // re-establish a link.
            //
            UARTprintf("Link Status: Lost (Retries: %d)\n", g_ui32LinkRetries);
        }
        else
        {
            //
            // If we have exceeded the maximum number of retries, show status as
            // offline.
            //
            UARTprintf("Link Status: Offline");
        }
    
        //
        // Print some header text.
        //
        UARTprintf("\nCollected Statistics\n");
        UARTprintf("--------------------\n");
    
        PrintStats(g_psDeviceStatistics);
    
        UARTprintf("\nPress Enter to return to the command prompt...\n");
    
        UARTFlushTx(0);
    
        return;
    }
    
    //*****************************************************************************
    //
    // Prints a help message to the UART to help with troubleshooting Exosite
    // connection issues.
    //
    //*****************************************************************************
    void
    PrintConnectionHelp(void)
    {
        UARTprintf("Troubleshooting Exosite Connection:\n\n");
    
        UARTprintf("    + Make sure you are connected to the internet.\n\n");
    
        UARTprintf("    + Make sure you have created an Exosite profile.\n\n");
    
        UARTprintf("    + Make sure you have a \"Connected Launchpad\" device\n");
        UARTprintf("      created in your Exosite profile.\n\n");
    
        UARTprintf("    + Make sure your that your board's MAC address is\n");
        UARTprintf("      correctly registered with your exosite profile.\n\n");
    
        UARTprintf("    + If you have a CIK, make sure it matches the CIK for\n");
        UARTprintf("      this device in your online profile with Exosite.\n\n");
    
        UARTprintf("    + If you have a proxy, make sure to configure it using\n");
        UARTprintf("      this terminal. Type 'setproxy help' to get started.\n");
        UARTprintf("      Once the proxy is set, type 'activate' to obtain a\n");
        UARTprintf("      new CIK, or 'connect' to connect to exosite using an\n");
        UARTprintf("      existing CIK.\n\n");
    
        UARTprintf("    + Make sure your device is available for provisioning.\n");
        UARTprintf("      If you are not sure that provisioning is enabled,\n");
        UARTprintf("      check the Read Me First documentation or the online\n");
        UARTprintf("      exosite portal for more information.\n\n");
    }
    
    //*****************************************************************************
    //
    // Attempts to find a CIK in the EEPROM. Reports the status of this operation
    // to the UART.
    //
    //*****************************************************************************
    bool
    GetEEPROMCIK(void)
    {
        char pcExositeCIK[50];
    
        //
        // Try to read the CIK from EEPROM, and alert the user based on what we
        // find.
        //
        if(Exosite_GetCIK(pcExositeCIK))
        {
            //
            // If a CIK is found, continue on to make sure that the CIK is valid.
            //
            UARTprintf("CIK found in EEPROM storage.\n\nCIK: %s\n\n",
                       pcExositeCIK);
        }
        else
        {
            //
            // If a CIK was not found, return immediately and indicate the failure.
            //
            UARTprintf("No CIK found in EEPROM.\n");
            return 0;
        }
    
        UARTprintf("Connecting to Exosite...\r");
    
        //
        // If a CIK was found, try to sync with Exosite. This should tell us if
        // the CIK is valid or not.
        //
        if(SyncWithExosite(g_psDeviceStatistics))
        {
            //
            // If the sync worked, the CIK is valid. Alert the caller.
            //
            UARTprintf("Connected! Type 'stats' to see data for this board.");
            return 1;
        }
        else
        {
            //
            // If the sync failed, the CIK is probably invalid, so pass the error
            // back to the caller.
            //
            UARTprintf("Initial sync failed. CIK may be invalid.\n");
            return 0;
        }
    }
    
    //*****************************************************************************
    //
    // Attempts to provision a new CIK through a request to Exosite's servers. This
    // should be used when Exosite's CIK does not match the CIK for this device, or
    // when a CIK is not found in EEPROM.
    //
    //*****************************************************************************
    bool
    ProvisionCIK(void)
    {
        uint32_t ui32Idx;
        char pcExositeCIK[50];
    
        //
        // If we get here, no CIK was found in EEPROM storage. We may need to
        // obtain a CIK from the server.
        //
        UARTprintf("Connecting to exosite to obtain a new CIK... \n");
    
        //
        // Try to activate with Exosite a few times. If we succeed move on with the
        // new CIK. Otherwise, fail.
        //
        for(ui32Idx = 0; ui32Idx < 1; ui32Idx++)
        {
            if(Exosite_Activate())
            {
                //
                // If exosite gives us a CIK, send feedback to the user
                //
                UARTprintf("CIK acquired!\n\n");
    
                if(Exosite_GetCIK(pcExositeCIK))
                {
                    UARTprintf("CIK: %s\n\n", pcExositeCIK);
                    UARTprintf("Connected! ");
                    UARTprintf("Type 'stats' to see data for this board.");
                }
                else
                {
                    //
                    // This shouldn't ever happen, but print an error message in
                    // case it does.
                    //
                    UARTprintf("ERROR reading new CIK from EEPROM.\n");
                }
    
                //
                // Return "true" indicating that we found a valid CIK.
                //
                return true;
            }
            else
            {
                //
                // If the activation fails, wait at least one second before
                // retrying.
                //
                //ROM_SysCtlDelay(g_ui32SysClock/3);
                if(Exosite_StatusCode() == EXO_STATUS_CONFLICT)
                {
                    //
                    // This can occur if the MAC address for this board has already
                    // been activated, and the device has not been re-enabled for a
                    // new CIK.
                    //
                    UARTprintf("\nExosite reported that this device is not\n");
                    UARTprintf("available for provisioning. Check to make sure\n");
                    UARTprintf("that you have the correct MAC address, and that\n");
                    UARTprintf("this device is enabled for provisioning in your\n");
                    UARTprintf("Exosite profile.\n\n");
    
                    return false;
                }
            }
        }
    
        //
        // Exosite didn't respond, so let the user know.
        //
        UARTprintf("No CIK could be obtained.\n\n");
    
        PrintConnectionHelp();
    
        //
        // Return "false", indicating that no CIK was found.
        //
        return false;
    }
    
    //*****************************************************************************
    //
    // Attempts to provision a new CIK through a request to Exosite's servers. This
    // should be used when Exosite's CIK does not match the CIK for this device, or
    // when a CIK is not found in EEPROM.
    //
    //*****************************************************************************
    bool
    LocateValidCIK(void)
    {
        //
        // Try to obtain a valid CIK.
        //
        UARTprintf("Locating CIK... ");
    
        //
        // Check the EEPROM for a valid CIK first. If none can be found
        // there, try to provision a CIK from exosite. If we can obtain a
        // CIK, make sure to set the global state variable that indicates
        // that we can connect to exosite.
        //
        if(GetEEPROMCIK())
        {
            return true;
        }
        else if(ProvisionCIK())
        {
            return true;
        }
        else
        {
            //
            // If both cases above fail, return false, indicating that we did not
            // find a CIK.
            //
            return false;
        }
    }
    
    //*****************************************************************************
    //
    // Takes a reading from the internal temperature sensor, and updates the
    // corresponding global statistics.
    //
    //*****************************************************************************
    void
    UpdateInternalTemp(void)
    {
        uint32_t pui32ADC0Value[1], ui32TempValueC, ui32TempValueF;
    
        //
        // Take a temperature reading with the ADC.
        //
        ROM_ADCProcessorTrigger(ADC0_BASE, 3);
    
        //
        // Wait for the ADC to finish taking the sample
        //
        while(!ROM_ADCIntStatus(ADC0_BASE, 3, false))
        {
        }
    
        //
        // Clear the interrupt
        //
        ROM_ADCIntClear(ADC0_BASE, 3);
    
        //
        // Read the analog voltage measurement.
        //
        ROM_ADCSequenceDataGet(ADC0_BASE, 3, pui32ADC0Value);
    
        //
        // Convert the measurement to degrees Celcius and Fahrenheit, and save to
        // the global state variables.
        //
        ui32TempValueC = ((1475 * 4096) - (2250 * pui32ADC0Value[0])) / 40960;
        g_ui32InternalTempC = ui32TempValueC;
        ui32TempValueF = ((ui32TempValueC * 9) + 160) / 5;
        g_ui32InternalTempF = ui32TempValueF;
    }
    
    //*****************************************************************************
    //
    // Polls the buttons, and updates global state accordingly.
    //
    //*****************************************************************************
    void
    UpdateButtons(void)
    {
        uint8_t ui8Buttons, ui8ButtonsChanged;
    
        //
        // Check the current debounced state of the buttons.
        //
        ui8Buttons = ButtonsPoll(&ui8ButtonsChanged,0);
    
        //
        // If either button has been pressed, record that status to the
        // corresponding global variable.
        //
        if(BUTTON_PRESSED(USR_SW1, ui8Buttons, ui8ButtonsChanged))
        {
            g_ui32SW1Presses++;
        }
        else if(BUTTON_PRESSED(USR_SW2, ui8Buttons, ui8ButtonsChanged))
        {
            g_ui32SW2Presses++;
        }
    }
    
    //*****************************************************************************
    //
    // Turns LEDs on or off based on global state variables.
    //
    //*****************************************************************************
    void
    UpdateLEDs(void)
    {
        //
        // If either LED's global flag is set, turn that LED on. Otherwise, turn
        // them off.
        //
        if(g_ui32LEDD1)
        {
            ROM_GPIOPinWrite(GPIO_PORTN_BASE, GPIO_PIN_1, GPIO_PIN_1);
        }
        else
        {
            ROM_GPIOPinWrite(GPIO_PORTN_BASE, GPIO_PIN_1, 0);
        }
    
        if(g_ui32LEDD2)
        {
            ROM_GPIOPinWrite(GPIO_PORTN_BASE, GPIO_PIN_0, GPIO_PIN_0);
        }
        else
        {
            ROM_GPIOPinWrite(GPIO_PORTN_BASE, GPIO_PIN_0, 0);
        }
    		
    		if(g_ui32LEDD3)
                {
                    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_0, GPIO_PIN_0);
                }
                else
                {
                    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_0, 0);
                }
        if(g_ui32LEDD4)
            {
                ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_2, GPIO_PIN_2);
    					
            }
            else
            {
                ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_2, 0);
            }
        if(g_ui32LEDD5)
            {
                ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_1, GPIO_PIN_1);
            }
            else
            {
                ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_1, 0);
            }
    
    }
    
    //*****************************************************************************
    //
    // Prompts the user for a command, and blocks while waiting for the user's
    // input. This function will return after the execution of a single command.
    //
    //*****************************************************************************
    void
    CheckForUserCommands(void)
    {
        int iStatus;
    
        //
        // Peek to see if a full command is ready for processing
        //
        if(UARTPeek('\r') == -1)
        {
            //
            // If not, return so other functions get a chance to run.
            //
            return;
        }
    
        //
        // If we do have commands, process them immediately in the order they were
        // received.
        //
        while(UARTPeek('\r') != -1)
        {
            //
            // Get a user command back
            //
            UARTgets(g_cInput, APP_INPUT_BUF_SIZE);
    
            //
            // Process the received command
            //
            iStatus = CmdLineProcess(g_cInput);
    
            //
            // Handle the case of bad command.
            //
            if(iStatus == CMDLINE_BAD_CMD)
            {
                UARTprintf("Bad command!\n");
            }
    
            //
            // Handle the case of too many arguments.
            //
            else if(iStatus == CMDLINE_TOO_MANY_ARGS)
            {
                UARTprintf("Too many arguments for command processor!\n");
            }
        }
    
        //
        // Print a prompt
        //
        UARTprintf("\n> ");
    
    }
    
    
    //*****************************************************************************
    //
    // Interrupt handler for Timer0A.
    //
    // This function will be called periodically on the expiration of Timer0A It
    // performs periodic tasks, such as looking for input on the physical buttons,
    // and reporting usage statistics to the cloud.
    //
    //*****************************************************************************
    void
    Timer0IntHandler(void)
    {
        //
        // Clear the timer interrupt.
        //
        ROM_TimerIntClear(TIMER0_BASE, TIMER_TIMA_TIMEOUT);
    
        //
        // Keep track of the number of times this interrupt handler has been
        // called.
        //
        g_ui32TimerIntCount++;
    
        //
        // Poll the GPIOs for the buttons to check for press events. Update global
        // variables as necessary.
        //
        UpdateButtons();
    
        if((!g_bPrintingData) && (!g_bGameActive))
        {
            CheckForUserCommands();
        }
    
        //
        // Once per second, perform the following operations.
        //
        if(!(g_ui32TimerIntCount % APP_TICKS_PER_SEC))
        {
            //
            // Keep track of the total seconds of on-time
            //
            g_ui32SecondsOnTime++;
    
            //
            // Take a reading from the internal temperature sensor.
            //
            UpdateInternalTemp();
    
            //
            // Set the LEDs to the correct state.
            //
            UpdateLEDs();
    
            //
            // Check to see if we have any on-going actions that require the UART
            //
            if(g_bPrintingData)
            {
                //
                // If the user has requested a data print-out, perform that here.
                //
                PrintAllData();
            }
            else if(g_bGameActive)
            {
                //
                // If the user is playing a game of tic-tac-toe, enter the game
                // state machine here.
                //
                if(AdvanceGameState())
                {
                    //
                    // When the tic-tac-toe game state function returns a '1', the
                    // game is over. Print a newline, remove the 'g_bGameActive'
                    // flag, and resume normal operation.
                    //
                    UARTprintf("\n> ");
                    g_bGameActive = 0;
                }
            }
        }
    
        //
        // Make sure the running tally of the number of interrupts doesn't
        // overflow.
        //
        if(g_ui32TimerIntCount == (20 * APP_TICKS_PER_SEC))
        {
            //
            // Reset the interrupt count to zero.
            //
            g_ui32TimerIntCount = 0;
    
        }
    
    }
    
    //*****************************************************************************
    //
    // Configures Timer 0 as a general purpose, periodic timer for handling button
    // presses.
    //
    //*****************************************************************************
    void
    ConfigureTimer0(void)
    {
        //
        // Enable the peripherals used by this example.
        //
        ROM_SysCtlPeripheralEnable(SYSCTL_PERIPH_TIMER0);
    
        //
        // Configure the two 32-bit periodic timers.
        //
        ROM_TimerConfigure(TIMER0_BASE, TIMER_CFG_PERIODIC);
        ROM_TimerLoadSet(TIMER0_BASE, TIMER_A, g_ui32SysClock / APP_TICKS_PER_SEC);
    
        //
        // Lower the priority of this interrupt
        //
        ROM_IntPriorityGroupingSet(4);
        ROM_IntPrioritySet(INT_TIMER0A, 0xE0);
    
        //
        // Setup the interrupts for the timer timeouts.
        //
        ROM_IntEnable(INT_TIMER0A);
        ROM_TimerIntEnable(TIMER0_BASE, TIMER_TIMA_TIMEOUT);
    }
    
    //*****************************************************************************
    //
    // Enables and configures ADC0 to read the internal temperature sensor into
    // sample sequencer 3.
    //
    //*****************************************************************************
    void
    ConfigureADC0(void)
    {
        //
        // Enable clock to ADC0.
        //
        ROM_SysCtlPeripheralEnable(SYSCTL_PERIPH_ADC0);
    
        //
        // Configure ADC0 Sample Sequencer 3 for processor trigger operation.
        //
        ROM_ADCSequenceConfigure(ADC0_BASE, 3, ADC_TRIGGER_PROCESSOR, 0);
    
        //
        // Increase the hold time of this sample sequencer to account for the
        // temperature sensor erratum (ADC#09).
        //
        HWREG(ADC0_BASE + ADC_O_SSTSH3) = 0x4;
    
        //
        // Configure ADC0 sequencer 3 for a single sample of the temperature
        // sensor.
        //
        ROM_ADCSequenceStepConfigure(ADC0_BASE, 3, 0, ADC_CTL_TS | ADC_CTL_IE |
                                     ADC_CTL_END);
    
        //
        // Enable the sequencer.
        //
        ROM_ADCSequenceEnable(ADC0_BASE, 3);
    
        //
        // Clear the interrupt bit for sequencer 3 to make sure it is not set
        // before the first sample is taken.
        //
        ROM_ADCIntClear(ADC0_BASE, 3);
    }
    
    //*****************************************************************************
    //
    // Main function.
    //
    //*****************************************************************************
    int
    main(void)
    {
        uint32_t ui32Timeout, ui32CIKRetries, ui32IPAddr;
    
        //
        // Run from the PLL at 120 MHz.
        //
        g_ui32SysClock = MAP_SysCtlClockFreqSet((SYSCTL_XTAL_25MHZ |
                                                 SYSCTL_OSC_MAIN |
                                                 SYSCTL_USE_PLL |
                                                 SYSCTL_CFG_VCO_480), 120000000);
    
        //
        // Set the pinout for the board, including required pins for Ethernet
        // operation.
        //
        PinoutSet(1,0);
    
        //
        // Enable the UART, clear the terminal, and print a brief message.
        //
        UARTStdioConfig(0, 115200, g_ui32SysClock);
    
        //
        // Configure necessary peripherals.
        //
        ConfigureTimer0();
        ConfigureADC0();
    
        //
        // Take an initial reading of the internal temperature
        //
        UpdateInternalTemp();
    
        //
        // Initialize the buttons
        //
        ButtonsInit();
    
        //
        // If a proxy has been pre-defined, enable it here.
        //
    #ifdef CUSTOM_PROXY
        usprintf(g_pcProxyAddress, PROXY_ADDRESS);
        g_ui16ProxyPort = PROXY_PORT;
        g_bUseProxy = true;
    #endif
    
        //
        // Clear the screen, and print a welcome message.
        //
        UARTprintf("\033[2J\033[H");
        UARTprintf("Welcome to the Connected LaunchPad!!\n");
        UARTprintf("Internet of Things Demo\n");
        UARTprintf("Type \'help\' for help.\n\n");
    
        //
        // Initialize Exosite layer to allow Exosite-based user commands later.
        //
        Exosite_Init("texasinstruments", "ek-tm4c1294xl", IF_ENET, 0);
    
        //
        // Start with the assumption that we are not online yet.
        //
        g_bOnline = false;
    
        //
        // Assume that the IP address is not acquired.
        //
        g_ui32IPAddr = 0;
        ui32IPAddr = 0;
        g_ui32Err = ERR_IP_ADDR;
    
        //
        // Clear the error variables.
        //
        ui32CIKRetries = 0;
    
        //
        // Print the MAC address, which users will need to register with Exosite.
        //
        PrintMac();
    
        //
        // Notify the user that we are obtaining an IP address.
        //
        UARTprintf("Obtaining IP... \n");
    
        //
        // Loop a few times to make sure that DHCP has time to find an IP.
        //
        for(ui32Timeout = 10; ui32Timeout > 0; ui32Timeout--)
        {
            //
            // Check to see if we have an IP yet.
            //
            if((lwIPLocalIPAddrGet() != 0xffffffff) &&
               (lwIPLocalIPAddrGet() != 0x00000000))
            {
                //
                // Report that we found an IP address.
                //
                UARTprintf("IP Address Acquired: ");
                ui32IPAddr = lwIPLocalIPAddrGet();
                UARTprintf("%d.",ui32IPAddr & 0xFF );
                UARTprintf("%d.",ui32IPAddr >> 8 & 0xFF );
                UARTprintf("%d.",ui32IPAddr >> 16 & 0xFF );
                UARTprintf("%d\n",ui32IPAddr >> 24 & 0xFF );
    
                //
                // Update the global IP Address variable.  Also update the global
                // error variable.
                //
                g_ui32IPAddr = ui32IPAddr;
                g_ui32Err = ERR_NO_ERR;
    
                //
                // If we can find and validate a CIK with Exosite, set the flag to
                // indicate have a valid connection to the cloud.
                //
                g_bOnline = LocateValidCIK();
    
                break;
            }
            else if(ui32Timeout == 0)
            {
                //
                // Alert the user if it takes a long time to find an IP address. An
                // IP address can still be found later, so this is not an
                // indication of failure.
                //
                UARTprintf("No IP address found, continuing \n"
                           "to search in the background\n");
            }
    
            //
            // Delay a second to allow DHCP to find us an IP address.
            //
            ROM_SysCtlDelay(g_ui32SysClock / 3);
        }
    
        //
        // If we don't have a valid exosite connection, let the user know that the
        // device is "offline" and not performing any data synchronization with the
        // cloud.
        //
        if(!g_bOnline)
        {
            UARTprintf("Continuing in offline mode.\n\n");
        }
    
        //
        // Print a prompt
        //
        UARTprintf("\n> ");
    
        //
        // Enable interrupts and start the timer. This will enable the UART console
        // input, and also enable updates to the various cloud-enabled variables.
        //
        ROM_IntMasterEnable();
        ROM_TimerEnable(TIMER0_BASE, TIMER_A);
    
        //
        // Main application loop.
        //
        while(1)
        {
            //
            // Only run the following loop if we have a valid connection to
            // Exosite.
            //
            if(g_bOnline)
            {
                //
                // Attempt to sync data with Exosite
                //
                if(SyncWithExosite(g_psDeviceStatistics))
                {
                    //
                    // If the sync is successful, reset the "retries" count to zero
                    //
                    g_ui32LinkRetries = 0;
                }
                else if(Exosite_StatusCode() == EXO_STATUS_NOAUTH)
                {
                    //
                    // Failed for having an old CIK.  Flush the UART output, and
                    // stop any data-printing operation.
                    //
                    g_bPrintingData = 0;
                    UARTFlushTx(0);
    
                    //
                    // Alert the user of the expired CIK.
                    //
                    UARTprintf("\nCIK no longer valid.\n");
                    UARTprintf("The application will automatically try to ");
                    UARTprintf("acquire a new CIK.\n");
                    UARTprintf("\n> ");
    
                    //
                    // We did connect to Exosite, so the link is still valid, but
                    // data syncing will not work.  Do not increment the number of
                    // link retries, but do consider the board "offline" for data
                    // syncing.
                    //
                    g_bOnline = false;
                    g_ui32Err = ERR_CIK;
                    ui32CIKRetries = 0;
    
                    //
                    // Put the LEDs in error indicating mode.  Turn LED D1 off.
                    // LED D2 is used as error indicator in this case.
                    //
                    g_ui32LEDD1 = 0;
                }
                else
                {
                    //
                    // Sync failed for some other reason.  Since we don't know the
                    // reason for this failure, try to sync with Exosite server
                    // again.  Increment the failure counter to aid in debug.
                    //
                    g_ui32LinkRetries++;
                }
    
                //
                // Check if IP address has changed.
                //
                ui32IPAddr = lwIPLocalIPAddrGet();
                if(g_ui32IPAddr != ui32IPAddr)
                {
                    //
                    // Yes, then let the app know that link is lost and we are
                    // offline.
                    //
                    g_bOnline = false;
                    g_ui32Err = ERR_IP_ADDR;
    
                    //
                    // Alert the user that IP Address is lost.
                    //
                    g_bPrintingData = 0;
                    UARTFlushTx(0);
                    UARTprintf("\nIP Address lost/changed.\n");
    
                    //
                    // Put the LEDs in error indicating mode.  Turn LED D2 off.
                    // LED D1 is used as the error indicator in this case.
                    //
                    g_ui32LEDD2 = 0;
                }
            }
            else
            {
                //
                // If we are here it means that connection to Exosite is lost.
                // Handle the different cases that could have caused this.
                //
                switch(g_ui32Err)
                {
                    case ERR_IP_ADDR:
                    {
                        //
                        // Check if IP address has been acquired.
                        //
                        ui32IPAddr = lwIPLocalIPAddrGet();
                        if((ui32IPAddr == 0xffffffff) || (ui32IPAddr == 0x00000000))
                        {
                            //
                            // No - Delay a second to allow DHCP to find an IP
                            // address.
                            //
                            ROM_SysCtlDelay(g_ui32SysClock / 3);
    
                            //
                            // Change the state of LED D1 so that it blinks,
                            // indicating that IP Address is lost.
                            //
                            g_ui32LEDD1 ^= 1;
                            break;
                        }
    
                        //
                        // Report the IP address to the user.
                        //
                        UARTprintf("IP Address Acquired: ");
                        UARTprintf("%d.",ui32IPAddr & 0xFF );
                        UARTprintf("%d.",ui32IPAddr >> 8 & 0xFF );
                        UARTprintf("%d.",ui32IPAddr >> 16 & 0xFF );
                        UARTprintf("%d\n",ui32IPAddr >> 24 & 0xFF );
    
                        //
                        // Update the global IP Address variable.
                        //
                        g_ui32IPAddr = ui32IPAddr;
    
                        //
                        // Check if the CIK is valid.  This also helps in verifying
                        // connection with Exosite.
                        //
                        g_bOnline = LocateValidCIK();
                        if(!g_bOnline)
                        {
                            //
                            // Failed to connect to Exosite.  Assume that CIK is
                            // not valid.
                            //
                            g_ui32Err = ERR_CIK;
                            ui32CIKRetries = 0;
                            break;
                        }
    
                        //
                        // Print a prompt
                        //
                        UARTprintf("\n> ");
    
                        //
                        // Reset the necessary variables to inform the application
                        // that the error is cleared.
                        //
                        g_ui32Err = ERR_NO_ERR;
                        g_ui32LinkRetries = 0;
    
                        break;
                    }
    
                    case ERR_CIK:
                    {
                        //
                        // Attempt to acquire a new CIK from Exosite.
                        //
                        if(ProvisionCIK())
                        {
                            //
                            // Success - notify the application that we are
                            // connected to Exosite.  Also reset the necessary
                            // error variables.
                            //
                            g_bOnline = true;
                            g_ui32Err = ERR_NO_ERR;
                            ui32CIKRetries = 0;
    
                            break;
                        }
    
                        //
                        // Since we failed to acquire a new CIK, try a few times
                        // before giving up.
                        //
                        ui32CIKRetries++;
                        if(ui32CIKRetries > 5)
                        {
                            //
                            // Report to the user.
                            //
                            UARTprintf("\nCIK no longer valid.  Tried %d times ",
                                       ui32CIKRetries);
                            UARTprintf("to acquire new CIK but failed.\n");
                            UARTprintf("Log in to exosite to check on the ");
                            UARTprintf("status of your device.\n");
    
                            //
                            // Failed to acquire new CIK after trying a few times.
                            // So stop trying to acquire new CIK.
                            //
                            g_ui32Err = ERR_UNKNOWN;
                            ui32CIKRetries = 0;
                        }
    
                        //
                        // Change the state of LED D2 so that it blinks, indicating
                        // that CIK is no longer valid.
                        //
                        g_ui32LEDD2 ^= 1;
                        break;
                    }
    
                    case ERR_UNKNOWN:
                    {
                        //
                        // Report to the user.
                        //
                        UARTprintf("\nFailed to connect to Exosite due to ");
                        UARTprintf("unknown reason.\n");
    
                        //
                        // Display IP address.
                        //
                        UARTprintf("IP Address: ");
                        ui32IPAddr = lwIPLocalIPAddrGet();
                        UARTprintf("%d.",ui32IPAddr & 0xFF );
                        UARTprintf("%d.",ui32IPAddr >> 8 & 0xFF );
                        UARTprintf("%d.",ui32IPAddr >> 16 & 0xFF );
                        UARTprintf("%d\n",ui32IPAddr >> 24 & 0xFF );
    
                        UARTprintf("Trying to sync with Exosite Server again.\n");
                        UARTprintf("\n> ");
    
                        //
                        // Set the appropriate flags to retry syncing with Exosite
                        // server.
                        //
                        g_bOnline = true;
                        g_ui32Err = ERR_NO_ERR;
    
                        break;
                    }
    
                    case ERR_NO_ERR:
                    default:
                    {
                        break;
                    }
                }
            }
        }
    }
    

                    g_ui32LinkRetries = 0;
                }"

     

     

  • Hello Kishan,

    I merged your latest post with this thread you made a couple days as I believe the prior information contained here as well as the thread topic you provided is required to understand this new post of yours.
  • Sir please give me a solution...
  • Hi Kishan,

    What happen when you run up to the if(SyncWithExosite(g_psDeviceStatistics))?
  • "if(SyncWithExosite(g_psDeviceStatistics))" In this step "REQUEST.C" file start the execute after CPU go to in " FaultISR" ...

    qs_IOT is only for 2-LED control using exosite. Here I should edit this program for 4-LED control using exosite server but when I add one more LED then this problem is generating.
  • There are various reasons that can cause you to have software fault. Sometimes it is due to the stack overflow. What you can quickly try out is to increase your stack size and see if that helps. You will need to rewind your code and look at the LR register to understand what instruction leads you to the fault. Please refer to the app note www.ti.com/.../spma043.pdf to trace the root cause of the faults.
  • it is not work sir ....
  • Hi KP,

    You can't just add LED's into (ports.c) or IOT server client without also modifying (stats.c) e.g. add your 2 new unique LED's alias (NAMES) to send into the cloud. The alias used in (stats.c) has to match the IOT sever LED alias name exactly. You must also change the #defined [NUM_STATS] value to match total count of all Tstat (stats.h) or very likely you get IOT fault in the connection.

    Hope this helps you.
  • Hi Sir,
    What should I modify in "STATS.C" file and you say changed "#defined[NUM_STATS] =15" I already modified and try it ...
    You edit "qs_iot" program for "6-LEDS" .What is the modification in this program you give the modification to me..
    I have trying to modifying this program few weeks...
    please give the suggestion which actually help to in this "qs_iot" program "6 leds" interfacing.
  • Hi BP101, really appreciate you jump in to help as I don't have much experience with the intricacies on this example code.
  • The NUM_STATS is a critical value and will fault the MCU if off by even one, always 1 more than the total number of tStat in your list

    You must add your 6 LED into existing tStat list (stats.c/h) as unique alias names much like the sample stats are defined but with your own names, copy existing syntax format. The 6 LED sever names must have same alias you named in (stats.c), like LED1=(myaliasforled1),LED2(myaliasforled2)etc.. The LED status update can be defined as read/write or other of your choice depending on the LED function being a bidirectional control or not. Meaning you can turn on the LED from the cloud server, is read function update in IOT application and LED write update from IOT application up to sever.

  • BTW if the server alias names do not match the applications stats exactly, the IOT server likely would not authenticate your CIK. In that case your application may fail to activate CIK and you have to reassign a new CIK at server and activate it at the client console. That sometimes happens when the client CIK in EEROM does not match the CIK at the server, make sure they are the same on both ends of the connection.
  • Thank you sir ...
    I am try for 4led as you say when I add one more led after it is not work . You try practically in this board for 5 or 6 led light and identify the problem and say to me what is the problem ..

    //*****************************************************************************
    //
    // qs_iot.c - Quickstart application that connects to a cloud server.
    //
    // Copyright (c) 2013-2017 Texas Instruments Incorporated. All rights reserved.
    // Software License Agreement
    //
    // Texas Instruments (TI) is supplying this software for use solely and
    // exclusively on TI's microcontroller products. The software is owned by
    // TI and/or its suppliers, and is protected under applicable copyright
    // laws. You may not combine this software with "viral" open-source
    // software in order to form a larger program.
    //
    // THIS SOFTWARE IS PROVIDED "AS IS" AND WITH ALL FAULTS.
    // NO WARRANTIES, WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT
    // NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
    // A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE. TI SHALL NOT, UNDER ANY
    // CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR CONSEQUENTIAL
    // DAMAGES, FOR ANY REASON WHATSOEVER.
    //
    // This is part of revision 2.1.4.178 of the EK-TM4C1294XL Firmware Package.
    //
    //*****************************************************************************

    #include <stdint.h>
    #include <stdbool.h>
    #include <string.h>
    #include "inc/hw_memmap.h"
    #include "inc/hw_types.h"
    #include "inc/hw_ints.h"
    #include "inc/hw_adc.h"
    #include "driverlib/adc.h"
    #include "driverlib/gpio.h"
    #include "driverlib/pin_map.h"
    #include "driverlib/rom.h"
    #include "driverlib/rom_map.h"
    #include "driverlib/sysctl.h"
    #include "driverlib/systick.h"
    #include "driverlib/uart.h"
    #include "driverlib/interrupt.h"
    #include "driverlib/timer.h"
    #include "utils/cmdline.h"
    #include "utils/uartstdio.h"
    #include "utils/ustdlib.h"
    #include "utils/lwiplib.h"
    #include "drivers/pinout.h"
    #include "drivers/buttons.h"
    #include "drivers/exosite_hal_lwip.h"
    #include "drivers/eth_client_lwip.h"
    #include "exosite.h"
    #include "stats.h"
    #include "qs_iot.h"
    #include "requests.h"
    #include "commands.h"
    #include "tictactoe.h"

    //*****************************************************************************
    //
    //! \addtogroup example_list
    //! <h1>Internet of Things Quickstart (qs_iot)</h1>
    //!
    //!
    //! This application records various information about user activity on the
    //! board, and periodically reports it to a cloud server managed by Exosite.
    //! In order to use all of the features of this application, you will need to
    //! have an account with Exosite, and make sure that the device you are using
    //! is registered to your Exosite profile with its original MAC address from
    //! the factory.
    //!
    //! If you do not yet have an Exosite account, you can create one at
    //! http://ti.exosite.com. The web interface there will help guide you through
    //! the account creation process. There is also information in the Quickstart
    //! document that is shipped along with the EK-TM4C1294XL evaluation kit.
    //!
    //! This application uses a command-line based interface through a virtual COM
    //! port on UART 0, with the settings 115,200-8-N-1. This application also
    //! requires a wired Ethernet connection with internet access to perform
    //! cloud-connected activities.
    //!
    //! Once the application is running you should be able to see program output
    //! over the virtual COM port, and interact with the command-line. The command
    //! line will allow you to see the information being sent to and from Exosite's
    //! servers, change the state of LEDs, and play a game of tic-tac-toe. If you
    //! have internet connectivity issues, need to find your MAC address, or need
    //! to re-activate your EK-TM4C1294XL board with Exosite, the command line
    //! interface also has options to support these operations. Type
    //! 'help' at the command prompt to see a list of available commands.
    //!
    //! If your local internet connection requires the use of a proxy server, you
    //! will need to enter a command over the virtual COM port terminal before the
    //! device will be able to connect to Exosite. When prompted by the
    //! application, type 'setproxy help' for information on how to configure the
    //! proxy. Alternatively, you may uncomment the define statements below for
    //! "CUSTOM_PROXY" settings, fill in the correct information for your local
    //! http proxy server, and recompile this example. This will permanently set
    //! your proxy as the default connection point.
    //!
    //
    //*****************************************************************************

    //*****************************************************************************
    //
    // The error routine that is called if the driver library encounters an error.
    //
    //*****************************************************************************
    #ifdef DEBUG
    void
    __error__(char *pcFilename, uint32_t ui32Line)
    {
    }
    #endif

    //*****************************************************************************
    //
    // Global macro definitions.
    //
    //*****************************************************************************
    #define MAX_SYNC_RETRIES 20

    // #define CUSTOM_PROXY
    // #define PROXY_ADDRESS "your.proxy.address"
    // #define PROXY_PORT 80

    //*****************************************************************************
    //
    // Global variables that will be linked to Exosite.
    //
    //*****************************************************************************
    uint32_t g_ui32SW1Presses = 0;
    uint32_t g_ui32SW2Presses = 0;
    uint32_t g_ui32InternalTempF = 0;
    uint32_t g_ui32InternalTempC = 0;
    uint32_t g_ui32TimerIntCount = 0;
    uint32_t g_ui32SecondsOnTime = 0;
    uint32_t g_ui32LEDD1 = 0;
    uint32_t g_ui32LEDD2 = 0;
    uint32_t g_ui32LEDD3 = 0;
    uint32_t g_ui32LEDD4 = 0;
    uint32_t g_ui32LEDD5 = 0;

    char g_pcLocation[50] = "";
    char g_pcContactEmail[100] = "";
    char g_pcAlert[140] = "";

    //*****************************************************************************
    //
    // Global structures used to interface with Exosite.
    //
    //*****************************************************************************
    tStat g_sSW1Presses =
    {"SW1-presses", &g_ui32SW1Presses, "usrsw1", INT, WRITE_ONLY};

    tStat g_sSW2Presses =
    {"SW2-presses", &g_ui32SW2Presses, "usrsw2", INT, WRITE_ONLY};

    tStat g_sInternalTempF =
    {"Temp(F)", &g_ui32InternalTempF, 0, INT, WRITE_ONLY};

    tStat g_sInternalTempC =
    {"Temp(C)", &g_ui32InternalTempC, "jtemp", INT, WRITE_ONLY};

    tStat g_sSecondsOnTime =
    {"Time since reset", &g_ui32SecondsOnTime, "ontime", INT, WRITE_ONLY};

    tStat g_sLEDD1 =
    {"LED D1", &g_ui32LEDD1, "ledd1", INT, READ_WRITE};

    tStat g_sLEDD2 =
    {"LED D2", &g_ui32LEDD2, "ledd2", INT, READ_WRITE};

    tStat g_sLEDD3 =
    {"LED D3", &g_ui32LEDD3, "ledd3", INT, READ_WRITE};

    tStat g_sLEDD4 =
    {"LED D4", &g_ui32LEDD4, "ledd4", INT, READ_WRITE};

    tStat g_sLEDD5 =
    {"LED D5", &g_ui32LEDD5, "ledd5", INT, READ_WRITE};

    tStat g_sLocation =
    {"Location", g_pcLocation, "location", STRING, READ_ONLY};

    tStat g_sBoardState =
    {NULL, &g_ui32BoardState, "gamestate", HEX, WRITE_ONLY};

    tStat g_sContactEmail =
    {"Contact Email", g_pcContactEmail, "emailaddr", STRING, READ_WRITE};

    tStat g_sAlert =
    {"Alert Message", g_pcAlert, "alert", STRING, NONE};

    //*****************************************************************************
    //
    // Global array of pointers to all tStat structures to be synced with Exosite.
    //
    //*****************************************************************************
    tStat *g_psDeviceStatistics[NUM_STATS]=
    {
    &g_sSW1Presses,
    &g_sSW2Presses,
    &g_sInternalTempF,
    &g_sInternalTempC,
    &g_sSecondsOnTime,
    &g_sLEDD1,
    &g_sLEDD2,
    &g_sLEDD3,
    &g_sLEDD4,
    &g_sLEDD5,
    &g_sLocation,
    &g_sBoardState,
    &g_sContactEmail,
    &g_sAlert,
    NULL
    };

    //*****************************************************************************
    //
    // Global variable to keep track of the system clock.
    //
    //*****************************************************************************
    uint32_t g_ui32SysClock = 0;

    //*****************************************************************************
    //
    // Global variable to keep track of the IP address.
    //
    //*****************************************************************************
    uint32_t g_ui32IPAddr;

    //*****************************************************************************
    //
    // Flags to keep track of application state.
    //
    //*****************************************************************************
    bool g_bPrintingData = false;
    bool g_bGameActive = false;
    volatile bool g_bOnline = false;

    //*****************************************************************************
    //
    // Global variables to keep track of the error conditions.
    //
    //*****************************************************************************
    enum
    {
    ERR_IP_ADDR,
    ERR_CIK,
    ERR_UNKNOWN,
    ERR_NO_ERR
    } g_ui32Err = ERR_NO_ERR;

    uint32_t g_ui32LinkRetries = 0;

    //*****************************************************************************
    //
    // Input buffer for the command line interpreter.
    //
    //*****************************************************************************
    char g_cInput[APP_INPUT_BUF_SIZE];

    //*****************************************************************************
    //
    // Given a list of statistics, prints each item to the UART.
    //
    //*****************************************************************************
    void
    PrintStats(tStat **psStats)
    {
    uint32_t ui32Index;
    char pcStatValue[256];
    char *pcStatName;

    //
    // Loop over all statistics in the list.
    //
    for(ui32Index = 0; psStats[ui32Index] != NULL; ui32Index++)
    {
    if(psStats[ui32Index]->pcName)
    {
    //
    // For each statistic, print the name and current value to the UART.
    //
    pcStatName = psStats[ui32Index]->pcName;
    StatPrintValue(psStats[ui32Index], pcStatValue);

    UARTprintf("%25s= %s\n", pcStatName, pcStatValue);
    }
    }
    }

    //*****************************************************************************
    //
    // Prints the current MAC address to the UART.
    //
    //*****************************************************************************
    void
    PrintMac(void)
    {
    uint8_t ui8Idx;
    uint8_t pui8MACAddr[6];

    //
    // Get the MAC address from the Ethernet Client layer.
    //
    EthClientMACAddrGet(pui8MACAddr);

    UARTprintf("Current MAC: ");

    //
    // Extract each pair of characters and print them to the UART.
    //
    for(ui8Idx = 0; ui8Idx < 6; ui8Idx++)
    {
    UARTprintf("%02x", pui8MACAddr[ui8Idx]);
    }

    UARTprintf("\n");
    }

    //*****************************************************************************
    //
    // This function prints a list of local statistics for this board.
    //
    //*****************************************************************************
    void
    PrintAllData(void)
    {
    char cExositeCIK[CIK_LENGTH];

    if(UARTPeek('\r') != -1)
    {
    g_bPrintingData = false;

    //
    // Get a user command back
    //
    UARTgets(g_cInput, APP_INPUT_BUF_SIZE);

    //
    // Print a prompt
    //
    UARTprintf("\n> ");

    return;
    }

    UARTprintf("\033[2J\033[H");
    UARTprintf("Welcome to the Connected LaunchPad!!\n");
    UARTprintf("Internet of Things Demo\n");
    UARTprintf("Type 'help' for help.\n\n");

    //
    // Print out the MAC address for reference
    //
    PrintMac();

    //
    // Check to see if we already have a CIK, and print it to the UART
    //
    if(Exosite_GetCIK(cExositeCIK))
    {
    UARTprintf("Current CIK: %s\n", cExositeCIK);
    }
    else
    {
    UARTprintf("No CIK found. Connect to Exosite to obtain one.\n");
    }

    //
    // Check to see how many times (if any) we've failed to connect to the
    // server.
    //
    if((g_ui32LinkRetries == 0) && g_bOnline)
    {
    //
    // For zero failures, report a "Link OK"
    //
    UARTprintf("Link Status: OK\n");
    }
    else if((g_ui32LinkRetries < MAX_SYNC_RETRIES) && g_bOnline)
    {
    //
    // For the first few failures, report that we are trying to
    // re-establish a link.
    //
    UARTprintf("Link Status: Lost (Retries: %d)\n", g_ui32LinkRetries);
    }
    else
    {
    //
    // If we have exceeded the maximum number of retries, show status as
    // offline.
    //
    UARTprintf("Link Status: Offline");
    }

    //
    // Print some header text.
    //
    UARTprintf("\nCollected Statistics\n");
    UARTprintf("--------------------\n");

    PrintStats(g_psDeviceStatistics);

    UARTprintf("\nPress Enter to return to the command prompt...\n");

    UARTFlushTx(0);

    return;
    }

    //*****************************************************************************
    //
    // Prints a help message to the UART to help with troubleshooting Exosite
    // connection issues.
    //
    //*****************************************************************************
    void
    PrintConnectionHelp(void)
    {
    UARTprintf("Troubleshooting Exosite Connection:\n\n");

    UARTprintf(" + Make sure you are connected to the internet.\n\n");

    UARTprintf(" + Make sure you have created an Exosite profile.\n\n");

    UARTprintf(" + Make sure you have a \"Connected Launchpad\" device\n");
    UARTprintf(" created in your Exosite profile.\n\n");

    UARTprintf(" + Make sure your that your board's MAC address is\n");
    UARTprintf(" correctly registered with your exosite profile.\n\n");

    UARTprintf(" + If you have a CIK, make sure it matches the CIK for\n");
    UARTprintf(" this device in your online profile with Exosite.\n\n");

    UARTprintf(" + If you have a proxy, make sure to configure it using\n");
    UARTprintf(" this terminal. Type 'setproxy help' to get started.\n");
    UARTprintf(" Once the proxy is set, type 'activate' to obtain a\n");
    UARTprintf(" new CIK, or 'connect' to connect to exosite using an\n");
    UARTprintf(" existing CIK.\n\n");

    UARTprintf(" + Make sure your device is available for provisioning.\n");
    UARTprintf(" If you are not sure that provisioning is enabled,\n");
    UARTprintf(" check the Read Me First documentation or the online\n");
    UARTprintf(" exosite portal for more information.\n\n");
    }

    //*****************************************************************************
    //
    // Attempts to find a CIK in the EEPROM. Reports the status of this operation
    // to the UART.
    //
    //*****************************************************************************
    bool
    GetEEPROMCIK(void)
    {
    char pcExositeCIK[50];

    //
    // Try to read the CIK from EEPROM, and alert the user based on what we
    // find.
    //
    if(Exosite_GetCIK(pcExositeCIK))
    {
    //
    // If a CIK is found, continue on to make sure that the CIK is valid.
    //
    UARTprintf("CIK found in EEPROM storage.\n\nCIK: %s\n\n",
    pcExositeCIK);
    }
    else
    {
    //
    // If a CIK was not found, return immediately and indicate the failure.
    //
    UARTprintf("No CIK found in EEPROM.\n");
    return 0;
    }

    UARTprintf("Connecting to Exosite...\r");

    //
    // If a CIK was found, try to sync with Exosite. This should tell us if
    // the CIK is valid or not.
    //
    if(SyncWithExosite(g_psDeviceStatistics))
    {
    //
    // If the sync worked, the CIK is valid. Alert the caller.
    //
    UARTprintf("Connected! Type 'stats' to see data for this board.");
    return 1;
    }
    else
    {
    //
    // If the sync failed, the CIK is probably invalid, so pass the error
    // back to the caller.
    //
    UARTprintf("Initial sync failed. CIK may be invalid.\n");
    return 0;
    }
    }

    //*****************************************************************************
    //
    // Attempts to provision a new CIK through a request to Exosite's servers. This
    // should be used when Exosite's CIK does not match the CIK for this device, or
    // when a CIK is not found in EEPROM.
    //
    //*****************************************************************************
    bool
    ProvisionCIK(void)
    {
    uint32_t ui32Idx;
    char pcExositeCIK[50];

    //
    // If we get here, no CIK was found in EEPROM storage. We may need to
    // obtain a CIK from the server.
    //
    UARTprintf("Connecting to exosite to obtain a new CIK... \n");

    //
    // Try to activate with Exosite a few times. If we succeed move on with the
    // new CIK. Otherwise, fail.
    //
    for(ui32Idx = 0; ui32Idx < 1; ui32Idx++)
    {
    if(Exosite_Activate())
    {
    //
    // If exosite gives us a CIK, send feedback to the user
    //
    UARTprintf("CIK acquired!\n\n");

    if(Exosite_GetCIK(pcExositeCIK))
    {
    UARTprintf("CIK: %s\n\n", pcExositeCIK);
    UARTprintf("Connected! ");
    UARTprintf("Type 'stats' to see data for this board.");
    }
    else
    {
    //
    // This shouldn't ever happen, but print an error message in
    // case it does.
    //
    UARTprintf("ERROR reading new CIK from EEPROM.\n");
    }

    //
    // Return "true" indicating that we found a valid CIK.
    //
    return true;
    }
    else
    {
    //
    // If the activation fails, wait at least one second before
    // retrying.
    //
    //ROM_SysCtlDelay(g_ui32SysClock/3);
    if(Exosite_StatusCode() == EXO_STATUS_CONFLICT)
    {
    //
    // This can occur if the MAC address for this board has already
    // been activated, and the device has not been re-enabled for a
    // new CIK.
    //
    UARTprintf("\nExosite reported that this device is not\n");
    UARTprintf("available for provisioning. Check to make sure\n");
    UARTprintf("that you have the correct MAC address, and that\n");
    UARTprintf("this device is enabled for provisioning in your\n");
    UARTprintf("Exosite profile.\n\n");

    return false;
    }
    }
    }

    //
    // Exosite didn't respond, so let the user know.
    //
    UARTprintf("No CIK could be obtained.\n\n");

    PrintConnectionHelp();

    //
    // Return "false", indicating that no CIK was found.
    //
    return false;
    }

    //*****************************************************************************
    //
    // Attempts to provision a new CIK through a request to Exosite's servers. This
    // should be used when Exosite's CIK does not match the CIK for this device, or
    // when a CIK is not found in EEPROM.
    //
    //*****************************************************************************
    bool
    LocateValidCIK(void)
    {
    //
    // Try to obtain a valid CIK.
    //
    UARTprintf("Locating CIK... ");

    //
    // Check the EEPROM for a valid CIK first. If none can be found
    // there, try to provision a CIK from exosite. If we can obtain a
    // CIK, make sure to set the global state variable that indicates
    // that we can connect to exosite.
    //
    if(GetEEPROMCIK())
    {
    return true;
    }
    else if(ProvisionCIK())
    {
    return true;
    }
    else
    {
    //
    // If both cases above fail, return false, indicating that we did not
    // find a CIK.
    //
    return false;
    }
    }

    //*****************************************************************************
    //
    // Takes a reading from the internal temperature sensor, and updates the
    // corresponding global statistics.
    //
    //*****************************************************************************
    void
    UpdateInternalTemp(void)
    {
    uint32_t pui32ADC0Value[1], ui32TempValueC, ui32TempValueF;

    //
    // Take a temperature reading with the ADC.
    //
    ROM_ADCProcessorTrigger(ADC0_BASE, 3);

    //
    // Wait for the ADC to finish taking the sample
    //
    while(!ROM_ADCIntStatus(ADC0_BASE, 3, false))
    {
    }

    //
    // Clear the interrupt
    //
    ROM_ADCIntClear(ADC0_BASE, 3);

    //
    // Read the analog voltage measurement.
    //
    ROM_ADCSequenceDataGet(ADC0_BASE, 3, pui32ADC0Value);

    //
    // Convert the measurement to degrees Celcius and Fahrenheit, and save to
    // the global state variables.
    //
    ui32TempValueC = ((1475 * 4096) - (2250 * pui32ADC0Value[0])) / 40960;
    g_ui32InternalTempC = ui32TempValueC;
    ui32TempValueF = ((ui32TempValueC * 9) + 160) / 5;
    g_ui32InternalTempF = ui32TempValueF;
    }

    //*****************************************************************************
    //
    // Polls the buttons, and updates global state accordingly.
    //
    //*****************************************************************************
    void
    UpdateButtons(void)
    {
    uint8_t ui8Buttons, ui8ButtonsChanged;

    //
    // Check the current debounced state of the buttons.
    //
    ui8Buttons = ButtonsPoll(&ui8ButtonsChanged,0);

    //
    // If either button has been pressed, record that status to the
    // corresponding global variable.
    //
    if(BUTTON_PRESSED(USR_SW1, ui8Buttons, ui8ButtonsChanged))
    {
    g_ui32SW1Presses++;
    }
    else if(BUTTON_PRESSED(USR_SW2, ui8Buttons, ui8ButtonsChanged))
    {
    g_ui32SW2Presses++;
    }
    }

    //*****************************************************************************
    //
    // Turns LEDs on or off based on global state variables.
    //
    //*****************************************************************************
    void
    UpdateLEDs(void)
    {
    //
    // If either LED's global flag is set, turn that LED on. Otherwise, turn
    // them off.
    //
    if(g_ui32LEDD1)
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_1, GPIO_PIN_1);
    }
    else
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_1, 0);
    }

    if(g_ui32LEDD2)
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_0, GPIO_PIN_0);
    }
    else
    {
    ROM_GPIOPinWrite(GPIO_PORTN_BASE, GPIO_PIN_0, 0);
    }

    if(g_ui32LEDD3)
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_2, GPIO_PIN_2);
    }
    else
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_2, 0);
    }
    if(g_ui32LEDD4)
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_3, GPIO_PIN_3);

    }
    else
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_3, 0);
    }
    if(g_ui32LEDD5)
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_4, GPIO_PIN_4);
    }
    else
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_4, 0);
    }

    }

    //*****************************************************************************
    //
    // Prompts the user for a command, and blocks while waiting for the user's
    // input. This function will return after the execution of a single command.
    //
    //*****************************************************************************
    void
    CheckForUserCommands(void)
    {
    int iStatus;

    //
    // Peek to see if a full command is ready for processing
    //
    if(UARTPeek('\r') == -1)
    {
    //
    // If not, return so other functions get a chance to run.
    //
    return;
    }

    //
    // If we do have commands, process them immediately in the order they were
    // received.
    //
    while(UARTPeek('\r') != -1)
    {
    //
    // Get a user command back
    //
    UARTgets(g_cInput, APP_INPUT_BUF_SIZE);

    //
    // Process the received command
    //
    iStatus = CmdLineProcess(g_cInput);

    //
    // Handle the case of bad command.
    //
    if(iStatus == CMDLINE_BAD_CMD)
    {
    UARTprintf("Bad command!\n");
    }

    //
    // Handle the case of too many arguments.
    //
    else if(iStatus == CMDLINE_TOO_MANY_ARGS)
    {
    UARTprintf("Too many arguments for command processor!\n");
    }
    }

    //
    // Print a prompt
    //
    UARTprintf("\n> ");

    }


    //*****************************************************************************
    //
    // Interrupt handler for Timer0A.
    //
    // This function will be called periodically on the expiration of Timer0A It
    // performs periodic tasks, such as looking for input on the physical buttons,
    // and reporting usage statistics to the cloud.
    //
    //*****************************************************************************
    void
    Timer0IntHandler(void)
    {
    //
    // Clear the timer interrupt.
    //
    ROM_TimerIntClear(TIMER0_BASE, TIMER_TIMA_TIMEOUT);

    //
    // Keep track of the number of times this interrupt handler has been
    // called.
    //
    g_ui32TimerIntCount++;

    //
    // Poll the GPIOs for the buttons to check for press events. Update global
    // variables as necessary.
    //
    UpdateButtons();

    if((!g_bPrintingData) && (!g_bGameActive))
    {
    CheckForUserCommands();
    }

    //
    // Once per second, perform the following operations.
    //
    if(!(g_ui32TimerIntCount % APP_TICKS_PER_SEC))
    {
    //
    // Keep track of the total seconds of on-time
    //
    g_ui32SecondsOnTime++;

    //
    // Take a reading from the internal temperature sensor.
    //
    UpdateInternalTemp();

    //
    // Set the LEDs to the correct state.
    //
    UpdateLEDs();

    //
    // Check to see if we have any on-going actions that require the UART
    //
    if(g_bPrintingData)
    {
    //
    // If the user has requested a data print-out, perform that here.
    //
    PrintAllData();
    }
    else if(g_bGameActive)
    {
    //
    // If the user is playing a game of tic-tac-toe, enter the game
    // state machine here.
    //
    if(AdvanceGameState())
    {
    //
    // When the tic-tac-toe game state function returns a '1', the
    // game is over. Print a newline, remove the 'g_bGameActive'
    // flag, and resume normal operation.
    //
    UARTprintf("\n> ");
    g_bGameActive = 0;
    }
    }
    }

    //
    // Make sure the running tally of the number of interrupts doesn't
    // overflow.
    //
    if(g_ui32TimerIntCount == (20 * APP_TICKS_PER_SEC))
    {
    //
    // Reset the interrupt count to zero.
    //
    g_ui32TimerIntCount = 0;

    }

    }

    //*****************************************************************************
    //
    // Configures Timer 0 as a general purpose, periodic timer for handling button
    // presses.
    //
    //*****************************************************************************
    void
    ConfigureTimer0(void)
    {
    //
    // Enable the peripherals used by this example.
    //
    ROM_SysCtlPeripheralEnable(SYSCTL_PERIPH_TIMER0);

    //
    // Configure the two 32-bit periodic timers.
    //
    ROM_TimerConfigure(TIMER0_BASE, TIMER_CFG_PERIODIC);
    ROM_TimerLoadSet(TIMER0_BASE, TIMER_A, g_ui32SysClock / APP_TICKS_PER_SEC);

    //
    // Lower the priority of this interrupt
    //
    ROM_IntPriorityGroupingSet(4);
    ROM_IntPrioritySet(INT_TIMER0A, 0xE0);

    //
    // Setup the interrupts for the timer timeouts.
    //
    ROM_IntEnable(INT_TIMER0A);
    ROM_TimerIntEnable(TIMER0_BASE, TIMER_TIMA_TIMEOUT);
    }

    //*****************************************************************************
    //
    // Enables and configures ADC0 to read the internal temperature sensor into
    // sample sequencer 3.
    //
    //*****************************************************************************
    void
    ConfigureADC0(void)
    {
    //
    // Enable clock to ADC0.
    //
    ROM_SysCtlPeripheralEnable(SYSCTL_PERIPH_ADC0);

    //
    // Configure ADC0 Sample Sequencer 3 for processor trigger operation.
    //
    ROM_ADCSequenceConfigure(ADC0_BASE, 3, ADC_TRIGGER_PROCESSOR, 0);

    //
    // Increase the hold time of this sample sequencer to account for the
    // temperature sensor erratum (ADC#09).
    //
    HWREG(ADC0_BASE + ADC_O_SSTSH3) = 0x4;

    //
    // Configure ADC0 sequencer 3 for a single sample of the temperature
    // sensor.
    //
    ROM_ADCSequenceStepConfigure(ADC0_BASE, 3, 0, ADC_CTL_TS | ADC_CTL_IE |
    ADC_CTL_END);

    //
    // Enable the sequencer.
    //
    ROM_ADCSequenceEnable(ADC0_BASE, 3);

    //
    // Clear the interrupt bit for sequencer 3 to make sure it is not set
    // before the first sample is taken.
    //
    ROM_ADCIntClear(ADC0_BASE, 3);
    }

    //*****************************************************************************
    //
    // Main function.
    //
    //*****************************************************************************
    int
    main(void)
    {
    uint32_t ui32Timeout, ui32CIKRetries, ui32IPAddr;

    //
    // Run from the PLL at 120 MHz.
    //
    g_ui32SysClock = MAP_SysCtlClockFreqSet((SYSCTL_XTAL_25MHZ |
    SYSCTL_OSC_MAIN |
    SYSCTL_USE_PLL |
    SYSCTL_CFG_VCO_480), 120000000);

    //
    // Set the pinout for the board, including required pins for Ethernet
    // operation.
    //
    PinoutSet(1,0);

    //
    // Enable the UART, clear the terminal, and print a brief message.
    //
    UARTStdioConfig(0, 115200, g_ui32SysClock);

    //
    // Configure necessary peripherals.
    //
    ConfigureTimer0();
    ConfigureADC0();

    //
    // Take an initial reading of the internal temperature
    //
    UpdateInternalTemp();

    //
    // Initialize the buttons
    //
    ButtonsInit();

    //
    // If a proxy has been pre-defined, enable it here.
    //
    #ifdef CUSTOM_PROXY
    usprintf(g_pcProxyAddress, PROXY_ADDRESS);
    g_ui16ProxyPort = PROXY_PORT;
    g_bUseProxy = true;
    #endif

    //
    // Clear the screen, and print a welcome message.
    //
    UARTprintf("\033[2J\033[H");
    UARTprintf("Welcome to the Connected LaunchPad!!\n");
    UARTprintf("Internet of Things Demo\n");
    UARTprintf("Type \'help\' for help.\n\n");

    //
    // Initialize Exosite layer to allow Exosite-based user commands later.
    //
    Exosite_Init("texasinstruments", "ek-tm4c1294xl", IF_ENET, 0);

    //
    // Start with the assumption that we are not online yet.
    //
    g_bOnline = false;

    //
    // Assume that the IP address is not acquired.
    //
    g_ui32IPAddr = 0;
    ui32IPAddr = 0;
    g_ui32Err = ERR_IP_ADDR;

    //
    // Clear the error variables.
    //
    ui32CIKRetries = 0;

    //
    // Print the MAC address, which users will need to register with Exosite.
    //
    PrintMac();

    //
    // Notify the user that we are obtaining an IP address.
    //
    UARTprintf("Obtaining IP... \n");

    //
    // Loop a few times to make sure that DHCP has time to find an IP.
    //
    for(ui32Timeout = 10; ui32Timeout > 0; ui32Timeout--)
    {
    //
    // Check to see if we have an IP yet.
    //
    if((lwIPLocalIPAddrGet() != 0xffffffff) &&
    (lwIPLocalIPAddrGet() != 0x00000000))
    {
    //
    // Report that we found an IP address.
    //
    UARTprintf("IP Address Acquired: ");
    ui32IPAddr = lwIPLocalIPAddrGet();
    UARTprintf("%d.",ui32IPAddr & 0xFF );
    UARTprintf("%d.",ui32IPAddr >> 8 & 0xFF );
    UARTprintf("%d.",ui32IPAddr >> 16 & 0xFF );
    UARTprintf("%d\n",ui32IPAddr >> 24 & 0xFF );

    //
    // Update the global IP Address variable. Also update the global
    // error variable.
    //
    g_ui32IPAddr = ui32IPAddr;
    g_ui32Err = ERR_NO_ERR;

    //
    // If we can find and validate a CIK with Exosite, set the flag to
    // indicate have a valid connection to the cloud.
    //
    g_bOnline = LocateValidCIK();

    break;
    }
    else if(ui32Timeout == 0)
    {
    //
    // Alert the user if it takes a long time to find an IP address. An
    // IP address can still be found later, so this is not an
    // indication of failure.
    //
    UARTprintf("No IP address found, continuing \n"
    "to search in the background\n");
    }

    //
    // Delay a second to allow DHCP to find us an IP address.
    //
    ROM_SysCtlDelay(g_ui32SysClock / 3);
    }

    //
    // If we don't have a valid exosite connection, let the user know that the
    // device is "offline" and not performing any data synchronization with the
    // cloud.
    //
    if(!g_bOnline)
    {
    UARTprintf("Continuing in offline mode.\n\n");
    }

    //
    // Print a prompt
    //
    UARTprintf("\n> ");

    //
    // Enable interrupts and start the timer. This will enable the UART console
    // input, and also enable updates to the various cloud-enabled variables.
    //
    ROM_IntMasterEnable();
    ROM_TimerEnable(TIMER0_BASE, TIMER_A);

    //
    // Main application loop.
    //
    while(1)
    {
    //
    // Only run the following loop if we have a valid connection to
    // Exosite.
    //
    if(g_bOnline)
    {
    //
    // Attempt to sync data with Exosite
    //
    if(SyncWithExosite(g_psDeviceStatistics))
    {
    //
    // If the sync is successful, reset the "retries" count to zero
    //
    g_ui32LinkRetries = 0;
    }
    else if(Exosite_StatusCode() == EXO_STATUS_NOAUTH)
    {
    //
    // Failed for having an old CIK. Flush the UART output, and
    // stop any data-printing operation.
    //
    g_bPrintingData = 0;
    UARTFlushTx(0);

    //
    // Alert the user of the expired CIK.
    //
    UARTprintf("\nCIK no longer valid.\n");
    UARTprintf("The application will automatically try to ");
    UARTprintf("acquire a new CIK.\n");
    UARTprintf("\n> ");

    //
    // We did connect to Exosite, so the link is still valid, but
    // data syncing will not work. Do not increment the number of
    // link retries, but do consider the board "offline" for data
    // syncing.
    //
    g_bOnline = false;
    g_ui32Err = ERR_CIK;
    ui32CIKRetries = 0;

    //
    // Put the LEDs in error indicating mode. Turn LED D1 off.
    // LED D2 is used as error indicator in this case.
    //
    g_ui32LEDD1 = 0;
    }
    else
    {
    //
    // Sync failed for some other reason. Since we don't know the
    // reason for this failure, try to sync with Exosite server
    // again. Increment the failure counter to aid in debug.
    //
    g_ui32LinkRetries++;
    }

    //
    // Check if IP address has changed.
    //
    ui32IPAddr = lwIPLocalIPAddrGet();
    if(g_ui32IPAddr != ui32IPAddr)
    {
    //
    // Yes, then let the app know that link is lost and we are
    // offline.
    //
    g_bOnline = false;
    g_ui32Err = ERR_IP_ADDR;

    //
    // Alert the user that IP Address is lost.
    //
    g_bPrintingData = 0;
    UARTFlushTx(0);
    UARTprintf("\nIP Address lost/changed.\n");

    //
    // Put the LEDs in error indicating mode. Turn LED D2 off.
    // LED D1 is used as the error indicator in this case.
    //
    g_ui32LEDD2 = 0;
    }
    }
    else
    {
    //
    // If we are here it means that connection to Exosite is lost.
    // Handle the different cases that could have caused this.
    //
    switch(g_ui32Err)
    {
    case ERR_IP_ADDR:
    {
    //
    // Check if IP address has been acquired.
    //
    ui32IPAddr = lwIPLocalIPAddrGet();
    if((ui32IPAddr == 0xffffffff) || (ui32IPAddr == 0x00000000))
    {
    //
    // No - Delay a second to allow DHCP to find an IP
    // address.
    //
    ROM_SysCtlDelay(g_ui32SysClock / 3);

    //
    // Change the state of LED D1 so that it blinks,
    // indicating that IP Address is lost.
    //
    g_ui32LEDD1 ^= 1;
    break;
    }

    //
    // Report the IP address to the user.
    //
    UARTprintf("IP Address Acquired: ");
    UARTprintf("%d.",ui32IPAddr & 0xFF );
    UARTprintf("%d.",ui32IPAddr >> 8 & 0xFF );
    UARTprintf("%d.",ui32IPAddr >> 16 & 0xFF );
    UARTprintf("%d\n",ui32IPAddr >> 24 & 0xFF );

    //
    // Update the global IP Address variable.
    //
    g_ui32IPAddr = ui32IPAddr;

    //
    // Check if the CIK is valid. This also helps in verifying
    // connection with Exosite.
    //
    g_bOnline = LocateValidCIK();
    if(!g_bOnline)
    {
    //
    // Failed to connect to Exosite. Assume that CIK is
    // not valid.
    //
    g_ui32Err = ERR_CIK;
    ui32CIKRetries = 0;
    break;
    }

    //
    // Print a prompt
    //
    UARTprintf("\n> ");

    //
    // Reset the necessary variables to inform the application
    // that the error is cleared.
    //
    g_ui32Err = ERR_NO_ERR;
    g_ui32LinkRetries = 0;

    break;
    }

    case ERR_CIK:
    {
    //
    // Attempt to acquire a new CIK from Exosite.
    //
    if(ProvisionCIK())
    {
    //
    // Success - notify the application that we are
    // connected to Exosite. Also reset the necessary
    // error variables.
    //
    g_bOnline = true;
    g_ui32Err = ERR_NO_ERR;
    ui32CIKRetries = 0;

    break;
    }

    //
    // Since we failed to acquire a new CIK, try a few times
    // before giving up.
    //
    ui32CIKRetries++;
    if(ui32CIKRetries > 5)
    {
    //
    // Report to the user.
    //
    UARTprintf("\nCIK no longer valid. Tried %d times ",
    ui32CIKRetries);
    UARTprintf("to acquire new CIK but failed.\n");
    UARTprintf("Log in to exosite to check on the ");
    UARTprintf("status of your device.\n");

    //
    // Failed to acquire new CIK after trying a few times.
    // So stop trying to acquire new CIK.
    //
    g_ui32Err = ERR_UNKNOWN;
    ui32CIKRetries = 0;
    }

    //
    // Change the state of LED D2 so that it blinks, indicating
    // that CIK is no longer valid.
    //
    g_ui32LEDD2 ^= 1;
    break;
    }

    case ERR_UNKNOWN:
    {
    //
    // Report to the user.
    //
    UARTprintf("\nFailed to connect to Exosite due to ");
    UARTprintf("unknown reason.\n");

    //
    // Display IP address.
    //
    UARTprintf("IP Address: ");
    ui32IPAddr = lwIPLocalIPAddrGet();
    UARTprintf("%d.",ui32IPAddr & 0xFF );
    UARTprintf("%d.",ui32IPAddr >> 8 & 0xFF );
    UARTprintf("%d.",ui32IPAddr >> 16 & 0xFF );
    UARTprintf("%d\n",ui32IPAddr >> 24 & 0xFF );

    UARTprintf("Trying to sync with Exosite Server again.\n");
    UARTprintf("\n> ");

    //
    // Set the appropriate flags to retry syncing with Exosite
    // server.
    //
    g_bOnline = true;
    g_ui32Err = ERR_NO_ERR;

    break;
    }

    case ERR_NO_ERR:
    default:
    {
    break;
    }
    }
    }
    }
    }




    #define NUM_STATS 16
  • Hi BP101,
    I am try you suggestion but it is work up to the 4Leds after 5Leds it is not work you try practically on tm4c1294xl board qs_iot for up to 6led light and find problem ..and help me
  • //*****************************************************************************
    //
    // qs_iot.c - Quickstart application that connects to a cloud server.
    //
    // Copyright (c) 2013-2017 Texas Instruments Incorporated. All rights reserved.
    // Software License Agreement
    //
    // Texas Instruments (TI) is supplying this software for use solely and
    // exclusively on TI's microcontroller products. The software is owned by
    // TI and/or its suppliers, and is protected under applicable copyright
    // laws. You may not combine this software with "viral" open-source
    // software in order to form a larger program.
    //
    // THIS SOFTWARE IS PROVIDED "AS IS" AND WITH ALL FAULTS.
    // NO WARRANTIES, WHETHER EXPRESS, IMPLIED OR STATUTORY, INCLUDING, BUT
    // NOT LIMITED TO, IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
    // A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE. TI SHALL NOT, UNDER ANY
    // CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR CONSEQUENTIAL
    // DAMAGES, FOR ANY REASON WHATSOEVER.
    //
    // This is part of revision 2.1.4.178 of the EK-TM4C1294XL Firmware Package.
    //
    //*****************************************************************************

    #include <stdint.h>
    #include <stdbool.h>
    #include <string.h>
    #include "inc/hw_memmap.h"
    #include "inc/hw_types.h"
    #include "inc/hw_ints.h"
    #include "inc/hw_adc.h"
    #include "driverlib/adc.h"
    #include "driverlib/gpio.h"
    #include "driverlib/pin_map.h"
    #include "driverlib/rom.h"
    #include "driverlib/rom_map.h"
    #include "driverlib/sysctl.h"
    #include "driverlib/systick.h"
    #include "driverlib/uart.h"
    #include "driverlib/interrupt.h"
    #include "driverlib/timer.h"
    #include "utils/cmdline.h"
    #include "utils/uartstdio.h"
    #include "utils/ustdlib.h"
    #include "utils/lwiplib.h"
    #include "drivers/pinout.h"
    #include "drivers/buttons.h"
    #include "drivers/exosite_hal_lwip.h"
    #include "drivers/eth_client_lwip.h"
    #include "exosite.h"
    #include "stats.h"
    #include "qs_iot.h"
    #include "requests.h"
    #include "commands.h"
    #include "tictactoe.h"

    //*****************************************************************************
    //
    //! \addtogroup example_list
    //! <h1>Internet of Things Quickstart (qs_iot)</h1>
    //!
    //!
    //! This application records various information about user activity on the
    //! board, and periodically reports it to a cloud server managed by Exosite.
    //! In order to use all of the features of this application, you will need to
    //! have an account with Exosite, and make sure that the device you are using
    //! is registered to your Exosite profile with its original MAC address from
    //! the factory.
    //!
    //! If you do not yet have an Exosite account, you can create one at
    //! http://ti.exosite.com. The web interface there will help guide you through
    //! the account creation process. There is also information in the Quickstart
    //! document that is shipped along with the EK-TM4C1294XL evaluation kit.
    //!
    //! This application uses a command-line based interface through a virtual COM
    //! port on UART 0, with the settings 115,200-8-N-1. This application also
    //! requires a wired Ethernet connection with internet access to perform
    //! cloud-connected activities.
    //!
    //! Once the application is running you should be able to see program output
    //! over the virtual COM port, and interact with the command-line. The command
    //! line will allow you to see the information being sent to and from Exosite's
    //! servers, change the state of LEDs, and play a game of tic-tac-toe. If you
    //! have internet connectivity issues, need to find your MAC address, or need
    //! to re-activate your EK-TM4C1294XL board with Exosite, the command line
    //! interface also has options to support these operations. Type
    //! 'help' at the command prompt to see a list of available commands.
    //!
    //! If your local internet connection requires the use of a proxy server, you
    //! will need to enter a command over the virtual COM port terminal before the
    //! device will be able to connect to Exosite. When prompted by the
    //! application, type 'setproxy help' for information on how to configure the
    //! proxy. Alternatively, you may uncomment the define statements below for
    //! "CUSTOM_PROXY" settings, fill in the correct information for your local
    //! http proxy server, and recompile this example. This will permanently set
    //! your proxy as the default connection point.
    //!
    //
    //*****************************************************************************

    //*****************************************************************************
    //
    // The error routine that is called if the driver library encounters an error.
    //
    //*****************************************************************************
    #ifdef DEBUG
    void
    __error__(char *pcFilename, uint32_t ui32Line)
    {
    }
    #endif

    //*****************************************************************************
    //
    // Global macro definitions.
    //
    //*****************************************************************************
    #define MAX_SYNC_RETRIES 20

    // #define CUSTOM_PROXY
    // #define PROXY_ADDRESS "your.proxy.address"
    // #define PROXY_PORT 80

    //*****************************************************************************
    //
    // Global variables that will be linked to Exosite.
    //
    //*****************************************************************************
    uint32_t g_ui32SW1Presses = 0;
    uint32_t g_ui32SW2Presses = 0;
    uint32_t g_ui32InternalTempF = 0;
    uint32_t g_ui32InternalTempC = 0;
    uint32_t g_ui32TimerIntCount = 0;
    uint32_t g_ui32SecondsOnTime = 0;
    uint32_t g_ui32LEDD1 = 0;
    uint32_t g_ui32LEDD2 = 0;
    uint32_t g_ui32LEDD3 = 0;
    uint32_t g_ui32LEDD4 = 0;
    uint32_t g_ui32LEDD5 = 0;

    char g_pcLocation[50] = "";
    char g_pcContactEmail[100] = "";
    char g_pcAlert[140] = "";

    //*****************************************************************************
    //
    // Global structures used to interface with Exosite.
    //
    //*****************************************************************************
    tStat g_sSW1Presses =
    {"SW1-presses", &g_ui32SW1Presses, "usrsw1", INT, WRITE_ONLY};

    tStat g_sSW2Presses =
    {"SW2-presses", &g_ui32SW2Presses, "usrsw2", INT, WRITE_ONLY};

    tStat g_sInternalTempF =
    {"Temp(F)", &g_ui32InternalTempF, 0, INT, WRITE_ONLY};

    tStat g_sInternalTempC =
    {"Temp(C)", &g_ui32InternalTempC, "jtemp", INT, WRITE_ONLY};

    tStat g_sSecondsOnTime =
    {"Time since reset", &g_ui32SecondsOnTime, "ontime", INT, WRITE_ONLY};

    tStat g_sLEDD1 =
    {"LED D1", &g_ui32LEDD1, "ledd1", INT, READ_WRITE};

    tStat g_sLEDD2 =
    {"LED D2", &g_ui32LEDD2, "ledd2", INT, READ_WRITE};

    tStat g_sLEDD3 =
    {"LED D3", &g_ui32LEDD3, "ledd3", INT, READ_WRITE};

    tStat g_sLEDD4 =
    {"LED D4", &g_ui32LEDD4, "ledd4", INT, READ_WRITE};

    tStat g_sLEDD5 =
    {"LED D5", &g_ui32LEDD5, "ledd5", INT, READ_WRITE};

    tStat g_sLocation =
    {"Location", g_pcLocation, "location", STRING, READ_ONLY};

    tStat g_sBoardState =
    {NULL, &g_ui32BoardState, "gamestate", HEX, WRITE_ONLY};

    tStat g_sContactEmail =
    {"Contact Email", g_pcContactEmail, "emailaddr", STRING, READ_WRITE};

    tStat g_sAlert =
    {"Alert Message", g_pcAlert, "alert", STRING, NONE};

    //*****************************************************************************
    //
    // Global array of pointers to all tStat structures to be synced with Exosite.
    //
    //*****************************************************************************
    tStat *g_psDeviceStatistics[NUM_STATS]=
    {
    &g_sSW1Presses,
    &g_sSW2Presses,
    &g_sInternalTempF,
    &g_sInternalTempC,
    &g_sSecondsOnTime,
    &g_sLEDD1,
    &g_sLEDD2,
    &g_sLEDD3,
    &g_sLEDD4,
    &g_sLEDD5,
    &g_sLocation,
    &g_sBoardState,
    &g_sContactEmail,
    &g_sAlert,
    NULL
    };

    //*****************************************************************************
    //
    // Global variable to keep track of the system clock.
    //
    //*****************************************************************************
    uint32_t g_ui32SysClock = 0;

    //*****************************************************************************
    //
    // Global variable to keep track of the IP address.
    //
    //*****************************************************************************
    uint32_t g_ui32IPAddr;

    //*****************************************************************************
    //
    // Flags to keep track of application state.
    //
    //*****************************************************************************
    bool g_bPrintingData = false;
    bool g_bGameActive = false;
    volatile bool g_bOnline = false;

    //*****************************************************************************
    //
    // Global variables to keep track of the error conditions.
    //
    //*****************************************************************************
    enum
    {
    ERR_IP_ADDR,
    ERR_CIK,
    ERR_UNKNOWN,
    ERR_NO_ERR
    } g_ui32Err = ERR_NO_ERR;

    uint32_t g_ui32LinkRetries = 0;

    //*****************************************************************************
    //
    // Input buffer for the command line interpreter.
    //
    //*****************************************************************************
    char g_cInput[APP_INPUT_BUF_SIZE];

    //*****************************************************************************
    //
    // Given a list of statistics, prints each item to the UART.
    //
    //*****************************************************************************
    void
    PrintStats(tStat **psStats)
    {
    uint32_t ui32Index;
    char pcStatValue[256];
    char *pcStatName;

    //
    // Loop over all statistics in the list.
    //
    for(ui32Index = 0; psStats[ui32Index] != NULL; ui32Index++)
    {
    if(psStats[ui32Index]->pcName)
    {
    //
    // For each statistic, print the name and current value to the UART.
    //
    pcStatName = psStats[ui32Index]->pcName;
    StatPrintValue(psStats[ui32Index], pcStatValue);

    UARTprintf("%25s= %s\n", pcStatName, pcStatValue);
    }
    }
    }

    //*****************************************************************************
    //
    // Prints the current MAC address to the UART.
    //
    //*****************************************************************************
    void
    PrintMac(void)
    {
    uint8_t ui8Idx;
    uint8_t pui8MACAddr[6];

    //
    // Get the MAC address from the Ethernet Client layer.
    //
    EthClientMACAddrGet(pui8MACAddr);

    UARTprintf("Current MAC: ");

    //
    // Extract each pair of characters and print them to the UART.
    //
    for(ui8Idx = 0; ui8Idx < 6; ui8Idx++)
    {
    UARTprintf("%02x", pui8MACAddr[ui8Idx]);
    }

    UARTprintf("\n");
    }

    //*****************************************************************************
    //
    // This function prints a list of local statistics for this board.
    //
    //*****************************************************************************
    void
    PrintAllData(void)
    {
    char cExositeCIK[CIK_LENGTH];

    if(UARTPeek('\r') != -1)
    {
    g_bPrintingData = false;

    //
    // Get a user command back
    //
    UARTgets(g_cInput, APP_INPUT_BUF_SIZE);

    //
    // Print a prompt
    //
    UARTprintf("\n> ");

    return;
    }

    UARTprintf("\033[2J\033[H");
    UARTprintf("Welcome to the Connected LaunchPad!!\n");
    UARTprintf("Internet of Things Demo\n");
    UARTprintf("Type 'help' for help.\n\n");

    //
    // Print out the MAC address for reference
    //
    PrintMac();

    //
    // Check to see if we already have a CIK, and print it to the UART
    //
    if(Exosite_GetCIK(cExositeCIK))
    {
    UARTprintf("Current CIK: %s\n", cExositeCIK);
    }
    else
    {
    UARTprintf("No CIK found. Connect to Exosite to obtain one.\n");
    }

    //
    // Check to see how many times (if any) we've failed to connect to the
    // server.
    //
    if((g_ui32LinkRetries == 0) && g_bOnline)
    {
    //
    // For zero failures, report a "Link OK"
    //
    UARTprintf("Link Status: OK\n");
    }
    else if((g_ui32LinkRetries < MAX_SYNC_RETRIES) && g_bOnline)
    {
    //
    // For the first few failures, report that we are trying to
    // re-establish a link.
    //
    UARTprintf("Link Status: Lost (Retries: %d)\n", g_ui32LinkRetries);
    }
    else
    {
    //
    // If we have exceeded the maximum number of retries, show status as
    // offline.
    //
    UARTprintf("Link Status: Offline");
    }

    //
    // Print some header text.
    //
    UARTprintf("\nCollected Statistics\n");
    UARTprintf("--------------------\n");

    PrintStats(g_psDeviceStatistics);

    UARTprintf("\nPress Enter to return to the command prompt...\n");

    UARTFlushTx(0);

    return;
    }

    //*****************************************************************************
    //
    // Prints a help message to the UART to help with troubleshooting Exosite
    // connection issues.
    //
    //*****************************************************************************
    void
    PrintConnectionHelp(void)
    {
    UARTprintf("Troubleshooting Exosite Connection:\n\n");

    UARTprintf(" + Make sure you are connected to the internet.\n\n");

    UARTprintf(" + Make sure you have created an Exosite profile.\n\n");

    UARTprintf(" + Make sure you have a \"Connected Launchpad\" device\n");
    UARTprintf(" created in your Exosite profile.\n\n");

    UARTprintf(" + Make sure your that your board's MAC address is\n");
    UARTprintf(" correctly registered with your exosite profile.\n\n");

    UARTprintf(" + If you have a CIK, make sure it matches the CIK for\n");
    UARTprintf(" this device in your online profile with Exosite.\n\n");

    UARTprintf(" + If you have a proxy, make sure to configure it using\n");
    UARTprintf(" this terminal. Type 'setproxy help' to get started.\n");
    UARTprintf(" Once the proxy is set, type 'activate' to obtain a\n");
    UARTprintf(" new CIK, or 'connect' to connect to exosite using an\n");
    UARTprintf(" existing CIK.\n\n");

    UARTprintf(" + Make sure your device is available for provisioning.\n");
    UARTprintf(" If you are not sure that provisioning is enabled,\n");
    UARTprintf(" check the Read Me First documentation or the online\n");
    UARTprintf(" exosite portal for more information.\n\n");
    }

    //*****************************************************************************
    //
    // Attempts to find a CIK in the EEPROM. Reports the status of this operation
    // to the UART.
    //
    //*****************************************************************************
    bool
    GetEEPROMCIK(void)
    {
    char pcExositeCIK[50];

    //
    // Try to read the CIK from EEPROM, and alert the user based on what we
    // find.
    //
    if(Exosite_GetCIK(pcExositeCIK))
    {
    //
    // If a CIK is found, continue on to make sure that the CIK is valid.
    //
    UARTprintf("CIK found in EEPROM storage.\n\nCIK: %s\n\n",
    pcExositeCIK);
    }
    else
    {
    //
    // If a CIK was not found, return immediately and indicate the failure.
    //
    UARTprintf("No CIK found in EEPROM.\n");
    return 0;
    }

    UARTprintf("Connecting to Exosite...\r");

    //
    // If a CIK was found, try to sync with Exosite. This should tell us if
    // the CIK is valid or not.
    //
    if(SyncWithExosite(g_psDeviceStatistics))
    {
    //
    // If the sync worked, the CIK is valid. Alert the caller.
    //
    UARTprintf("Connected! Type 'stats' to see data for this board.");
    return 1;
    }
    else
    {
    //
    // If the sync failed, the CIK is probably invalid, so pass the error
    // back to the caller.
    //
    UARTprintf("Initial sync failed. CIK may be invalid.\n");
    return 0;
    }
    }

    //*****************************************************************************
    //
    // Attempts to provision a new CIK through a request to Exosite's servers. This
    // should be used when Exosite's CIK does not match the CIK for this device, or
    // when a CIK is not found in EEPROM.
    //
    //*****************************************************************************
    bool
    ProvisionCIK(void)
    {
    uint32_t ui32Idx;
    char pcExositeCIK[50];

    //
    // If we get here, no CIK was found in EEPROM storage. We may need to
    // obtain a CIK from the server.
    //
    UARTprintf("Connecting to exosite to obtain a new CIK... \n");

    //
    // Try to activate with Exosite a few times. If we succeed move on with the
    // new CIK. Otherwise, fail.
    //
    for(ui32Idx = 0; ui32Idx < 1; ui32Idx++)
    {
    if(Exosite_Activate())
    {
    //
    // If exosite gives us a CIK, send feedback to the user
    //
    UARTprintf("CIK acquired!\n\n");

    if(Exosite_GetCIK(pcExositeCIK))
    {
    UARTprintf("CIK: %s\n\n", pcExositeCIK);
    UARTprintf("Connected! ");
    UARTprintf("Type 'stats' to see data for this board.");
    }
    else
    {
    //
    // This shouldn't ever happen, but print an error message in
    // case it does.
    //
    UARTprintf("ERROR reading new CIK from EEPROM.\n");
    }

    //
    // Return "true" indicating that we found a valid CIK.
    //
    return true;
    }
    else
    {
    //
    // If the activation fails, wait at least one second before
    // retrying.
    //
    //ROM_SysCtlDelay(g_ui32SysClock/3);
    if(Exosite_StatusCode() == EXO_STATUS_CONFLICT)
    {
    //
    // This can occur if the MAC address for this board has already
    // been activated, and the device has not been re-enabled for a
    // new CIK.
    //
    UARTprintf("\nExosite reported that this device is not\n");
    UARTprintf("available for provisioning. Check to make sure\n");
    UARTprintf("that you have the correct MAC address, and that\n");
    UARTprintf("this device is enabled for provisioning in your\n");
    UARTprintf("Exosite profile.\n\n");

    return false;
    }
    }
    }

    //
    // Exosite didn't respond, so let the user know.
    //
    UARTprintf("No CIK could be obtained.\n\n");

    PrintConnectionHelp();

    //
    // Return "false", indicating that no CIK was found.
    //
    return false;
    }

    //*****************************************************************************
    //
    // Attempts to provision a new CIK through a request to Exosite's servers. This
    // should be used when Exosite's CIK does not match the CIK for this device, or
    // when a CIK is not found in EEPROM.
    //
    //*****************************************************************************
    bool
    LocateValidCIK(void)
    {
    //
    // Try to obtain a valid CIK.
    //
    UARTprintf("Locating CIK... ");

    //
    // Check the EEPROM for a valid CIK first. If none can be found
    // there, try to provision a CIK from exosite. If we can obtain a
    // CIK, make sure to set the global state variable that indicates
    // that we can connect to exosite.
    //
    if(GetEEPROMCIK())
    {
    return true;
    }
    else if(ProvisionCIK())
    {
    return true;
    }
    else
    {
    //
    // If both cases above fail, return false, indicating that we did not
    // find a CIK.
    //
    return false;
    }
    }

    //*****************************************************************************
    //
    // Takes a reading from the internal temperature sensor, and updates the
    // corresponding global statistics.
    //
    //*****************************************************************************
    void
    UpdateInternalTemp(void)
    {
    uint32_t pui32ADC0Value[1], ui32TempValueC, ui32TempValueF;

    //
    // Take a temperature reading with the ADC.
    //
    ROM_ADCProcessorTrigger(ADC0_BASE, 3);

    //
    // Wait for the ADC to finish taking the sample
    //
    while(!ROM_ADCIntStatus(ADC0_BASE, 3, false))
    {
    }

    //
    // Clear the interrupt
    //
    ROM_ADCIntClear(ADC0_BASE, 3);

    //
    // Read the analog voltage measurement.
    //
    ROM_ADCSequenceDataGet(ADC0_BASE, 3, pui32ADC0Value);

    //
    // Convert the measurement to degrees Celcius and Fahrenheit, and save to
    // the global state variables.
    //
    ui32TempValueC = ((1475 * 4096) - (2250 * pui32ADC0Value[0])) / 40960;
    g_ui32InternalTempC = ui32TempValueC;
    ui32TempValueF = ((ui32TempValueC * 9) + 160) / 5;
    g_ui32InternalTempF = ui32TempValueF;
    }

    //*****************************************************************************
    //
    // Polls the buttons, and updates global state accordingly.
    //
    //*****************************************************************************
    void
    UpdateButtons(void)
    {
    uint8_t ui8Buttons, ui8ButtonsChanged;

    //
    // Check the current debounced state of the buttons.
    //
    ui8Buttons = ButtonsPoll(&ui8ButtonsChanged,0);

    //
    // If either button has been pressed, record that status to the
    // corresponding global variable.
    //
    if(BUTTON_PRESSED(USR_SW1, ui8Buttons, ui8ButtonsChanged))
    {
    g_ui32SW1Presses++;
    }
    else if(BUTTON_PRESSED(USR_SW2, ui8Buttons, ui8ButtonsChanged))
    {
    g_ui32SW2Presses++;
    }
    }

    //*****************************************************************************
    //
    // Turns LEDs on or off based on global state variables.
    //
    //*****************************************************************************
    void
    UpdateLEDs(void)
    {
    //
    // If either LED's global flag is set, turn that LED on. Otherwise, turn
    // them off.
    //
    if(g_ui32LEDD1)
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_1, GPIO_PIN_1);
    }
    else
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_1, 0);
    }

    if(g_ui32LEDD2)
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_0, GPIO_PIN_0);
    }
    else
    {
    ROM_GPIOPinWrite(GPIO_PORTN_BASE, GPIO_PIN_0, 0);
    }

    if(g_ui32LEDD3)
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_2, GPIO_PIN_2);
    }
    else
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_2, 0);
    }
    if(g_ui32LEDD4)
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_3, GPIO_PIN_3);

    }
    else
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_3, 0);
    }
    if(g_ui32LEDD5)
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_4, GPIO_PIN_4);
    }
    else
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_4, 0);
    }

    }

    //*****************************************************************************
    //
    // Prompts the user for a command, and blocks while waiting for the user's
    // input. This function will return after the execution of a single command.
    //
    //*****************************************************************************
    void
    CheckForUserCommands(void)
    {
    int iStatus;

    //
    // Peek to see if a full command is ready for processing
    //
    if(UARTPeek('\r') == -1)
    {
    //
    // If not, return so other functions get a chance to run.
    //
    return;
    }

    //
    // If we do have commands, process them immediately in the order they were
    // received.
    //
    while(UARTPeek('\r') != -1)
    {
    //
    // Get a user command back
    //
    UARTgets(g_cInput, APP_INPUT_BUF_SIZE);

    //
    // Process the received command
    //
    iStatus = CmdLineProcess(g_cInput);

    //
    // Handle the case of bad command.
    //
    if(iStatus == CMDLINE_BAD_CMD)
    {
    UARTprintf("Bad command!\n");
    }

    //
    // Handle the case of too many arguments.
    //
    else if(iStatus == CMDLINE_TOO_MANY_ARGS)
    {
    UARTprintf("Too many arguments for command processor!\n");
    }
    }

    //
    // Print a prompt
    //
    UARTprintf("\n> ");

    }


    //*****************************************************************************
    //
    // Interrupt handler for Timer0A.
    //
    // This function will be called periodically on the expiration of Timer0A It
    // performs periodic tasks, such as looking for input on the physical buttons,
    // and reporting usage statistics to the cloud.
    //
    //*****************************************************************************
    void
    Timer0IntHandler(void)
    {
    //
    // Clear the timer interrupt.
    //
    ROM_TimerIntClear(TIMER0_BASE, TIMER_TIMA_TIMEOUT);

    //
    // Keep track of the number of times this interrupt handler has been
    // called.
    //
    g_ui32TimerIntCount++;

    //
    // Poll the GPIOs for the buttons to check for press events. Update global
    // variables as necessary.
    //
    UpdateButtons();

    if((!g_bPrintingData) && (!g_bGameActive))
    {
    CheckForUserCommands();
    }

    //
    // Once per second, perform the following operations.
    //
    if(!(g_ui32TimerIntCount % APP_TICKS_PER_SEC))
    {
    //
    // Keep track of the total seconds of on-time
    //
    g_ui32SecondsOnTime++;

    //
    // Take a reading from the internal temperature sensor.
    //
    UpdateInternalTemp();

    //
    // Set the LEDs to the correct state.
    //
    UpdateLEDs();

    //
    // Check to see if we have any on-going actions that require the UART
    //
    if(g_bPrintingData)
    {
    //
    // If the user has requested a data print-out, perform that here.
    //
    PrintAllData();
    }
    else if(g_bGameActive)
    {
    //
    // If the user is playing a game of tic-tac-toe, enter the game
    // state machine here.
    //
    if(AdvanceGameState())
    {
    //
    // When the tic-tac-toe game state function returns a '1', the
    // game is over. Print a newline, remove the 'g_bGameActive'
    // flag, and resume normal operation.
    //
    UARTprintf("\n> ");
    g_bGameActive = 0;
    }
    }
    }

    //
    // Make sure the running tally of the number of interrupts doesn't
    // overflow.
    //
    if(g_ui32TimerIntCount == (20 * APP_TICKS_PER_SEC))
    {
    //
    // Reset the interrupt count to zero.
    //
    g_ui32TimerIntCount = 0;

    }

    }

    //*****************************************************************************
    //
    // Configures Timer 0 as a general purpose, periodic timer for handling button
    // presses.
    //
    //*****************************************************************************
    void
    ConfigureTimer0(void)
    {
    //
    // Enable the peripherals used by this example.
    //
    ROM_SysCtlPeripheralEnable(SYSCTL_PERIPH_TIMER0);

    //
    // Configure the two 32-bit periodic timers.
    //
    ROM_TimerConfigure(TIMER0_BASE, TIMER_CFG_PERIODIC);
    ROM_TimerLoadSet(TIMER0_BASE, TIMER_A, g_ui32SysClock / APP_TICKS_PER_SEC);

    //
    // Lower the priority of this interrupt
    //
    ROM_IntPriorityGroupingSet(4);
    ROM_IntPrioritySet(INT_TIMER0A, 0xE0);

    //
    // Setup the interrupts for the timer timeouts.
    //
    ROM_IntEnable(INT_TIMER0A);
    ROM_TimerIntEnable(TIMER0_BASE, TIMER_TIMA_TIMEOUT);
    }

    //*****************************************************************************
    //
    // Enables and configures ADC0 to read the internal temperature sensor into
    // sample sequencer 3.
    //
    //*****************************************************************************
    void
    ConfigureADC0(void)
    {
    //
    // Enable clock to ADC0.
    //
    ROM_SysCtlPeripheralEnable(SYSCTL_PERIPH_ADC0);

    //
    // Configure ADC0 Sample Sequencer 3 for processor trigger operation.
    //
    ROM_ADCSequenceConfigure(ADC0_BASE, 3, ADC_TRIGGER_PROCESSOR, 0);

    //
    // Increase the hold time of this sample sequencer to account for the
    // temperature sensor erratum (ADC#09).
    //
    HWREG(ADC0_BASE + ADC_O_SSTSH3) = 0x4;

    //
    // Configure ADC0 sequencer 3 for a single sample of the temperature
    // sensor.
    //
    ROM_ADCSequenceStepConfigure(ADC0_BASE, 3, 0, ADC_CTL_TS | ADC_CTL_IE |
    ADC_CTL_END);

    //
    // Enable the sequencer.
    //
    ROM_ADCSequenceEnable(ADC0_BASE, 3);

    //
    // Clear the interrupt bit for sequencer 3 to make sure it is not set
    // before the first sample is taken.
    //
    ROM_ADCIntClear(ADC0_BASE, 3);
    }

    //*****************************************************************************
    //
    // Main function.
    //
    //*****************************************************************************
    int
    main(void)
    {
    uint32_t ui32Timeout, ui32CIKRetries, ui32IPAddr;

    //
    // Run from the PLL at 120 MHz.
    //
    g_ui32SysClock = MAP_SysCtlClockFreqSet((SYSCTL_XTAL_25MHZ |
    SYSCTL_OSC_MAIN |
    SYSCTL_USE_PLL |
    SYSCTL_CFG_VCO_480), 120000000);

    //
    // Set the pinout for the board, including required pins for Ethernet
    // operation.
    //
    PinoutSet(1,0);

    //
    // Enable the UART, clear the terminal, and print a brief message.
    //
    UARTStdioConfig(0, 115200, g_ui32SysClock);

    //
    // Configure necessary peripherals.
    //
    ConfigureTimer0();
    ConfigureADC0();

    //
    // Take an initial reading of the internal temperature
    //
    UpdateInternalTemp();

    //
    // Initialize the buttons
    //
    ButtonsInit();

    //
    // If a proxy has been pre-defined, enable it here.
    //
    #ifdef CUSTOM_PROXY
    usprintf(g_pcProxyAddress, PROXY_ADDRESS);
    g_ui16ProxyPort = PROXY_PORT;
    g_bUseProxy = true;
    #endif

    //
    // Clear the screen, and print a welcome message.
    //
    UARTprintf("\033[2J\033[H");
    UARTprintf("Welcome to the Connected LaunchPad!!\n");
    UARTprintf("Internet of Things Demo\n");
    UARTprintf("Type \'help\' for help.\n\n");

    //
    // Initialize Exosite layer to allow Exosite-based user commands later.
    //
    Exosite_Init("texasinstruments", "ek-tm4c1294xl", IF_ENET, 0);

    //
    // Start with the assumption that we are not online yet.
    //
    g_bOnline = false;

    //
    // Assume that the IP address is not acquired.
    //
    g_ui32IPAddr = 0;
    ui32IPAddr = 0;
    g_ui32Err = ERR_IP_ADDR;

    //
    // Clear the error variables.
    //
    ui32CIKRetries = 0;

    //
    // Print the MAC address, which users will need to register with Exosite.
    //
    PrintMac();

    //
    // Notify the user that we are obtaining an IP address.
    //
    UARTprintf("Obtaining IP... \n");

    //
    // Loop a few times to make sure that DHCP has time to find an IP.
    //
    for(ui32Timeout = 10; ui32Timeout > 0; ui32Timeout--)
    {
    //
    // Check to see if we have an IP yet.
    //
    if((lwIPLocalIPAddrGet() != 0xffffffff) &&
    (lwIPLocalIPAddrGet() != 0x00000000))
    {
    //
    // Report that we found an IP address.
    //
    UARTprintf("IP Address Acquired: ");
    ui32IPAddr = lwIPLocalIPAddrGet();
    UARTprintf("%d.",ui32IPAddr & 0xFF );
    UARTprintf("%d.",ui32IPAddr >> 8 & 0xFF );
    UARTprintf("%d.",ui32IPAddr >> 16 & 0xFF );
    UARTprintf("%d\n",ui32IPAddr >> 24 & 0xFF );

    //
    // Update the global IP Address variable. Also update the global
    // error variable.
    //
    g_ui32IPAddr = ui32IPAddr;
    g_ui32Err = ERR_NO_ERR;

    //
    // If we can find and validate a CIK with Exosite, set the flag to
    // indicate have a valid connection to the cloud.
    //
    g_bOnline = LocateValidCIK();

    break;
    }
    else if(ui32Timeout == 0)
    {
    //
    // Alert the user if it takes a long time to find an IP address. An
    // IP address can still be found later, so this is not an
    // indication of failure.
    //
    UARTprintf("No IP address found, continuing \n"
    "to search in the background\n");
    }

    //
    // Delay a second to allow DHCP to find us an IP address.
    //
    ROM_SysCtlDelay(g_ui32SysClock / 3);
    }

    //
    // If we don't have a valid exosite connection, let the user know that the
    // device is "offline" and not performing any data synchronization with the
    // cloud.
    //
    if(!g_bOnline)
    {
    UARTprintf("Continuing in offline mode.\n\n");
    }

    //
    // Print a prompt
    //
    UARTprintf("\n> ");

    //
    // Enable interrupts and start the timer. This will enable the UART console
    // input, and also enable updates to the various cloud-enabled variables.
    //
    ROM_IntMasterEnable();
    ROM_TimerEnable(TIMER0_BASE, TIMER_A);

    //
    // Main application loop.
    //
    while(1)
    {
    //
    // Only run the following loop if we have a valid connection to
    // Exosite.
    //
    if(g_bOnline)
    {
    //
    // Attempt to sync data with Exosite
    //
    if(SyncWithExosite(g_psDeviceStatistics))
    {
    //
    // If the sync is successful, reset the "retries" count to zero
    //
    g_ui32LinkRetries = 0;
    }
    else if(Exosite_StatusCode() == EXO_STATUS_NOAUTH)
    {
    //
    // Failed for having an old CIK. Flush the UART output, and
    // stop any data-printing operation.
    //
    g_bPrintingData = 0;
    UARTFlushTx(0);

    //
    // Alert the user of the expired CIK.
    //
    UARTprintf("\nCIK no longer valid.\n");
    UARTprintf("The application will automatically try to ");
    UARTprintf("acquire a new CIK.\n");
    UARTprintf("\n> ");

    //
    // We did connect to Exosite, so the link is still valid, but
    // data syncing will not work. Do not increment the number of
    // link retries, but do consider the board "offline" for data
    // syncing.
    //
    g_bOnline = false;
    g_ui32Err = ERR_CIK;
    ui32CIKRetries = 0;

    //
    // Put the LEDs in error indicating mode. Turn LED D1 off.
    // LED D2 is used as error indicator in this case.
    //
    g_ui32LEDD1 = 0;
    }
    else
    {
    //
    // Sync failed for some other reason. Since we don't know the
    // reason for this failure, try to sync with Exosite server
    // again. Increment the failure counter to aid in debug.
    //
    g_ui32LinkRetries++;
    }

    //
    // Check if IP address has changed.
    //
    ui32IPAddr = lwIPLocalIPAddrGet();
    if(g_ui32IPAddr != ui32IPAddr)
    {
    //
    // Yes, then let the app know that link is lost and we are
    // offline.
    //
    g_bOnline = false;
    g_ui32Err = ERR_IP_ADDR;

    //
    // Alert the user that IP Address is lost.
    //
    g_bPrintingData = 0;
    UARTFlushTx(0);
    UARTprintf("\nIP Address lost/changed.\n");

    //
    // Put the LEDs in error indicating mode. Turn LED D2 off.
    // LED D1 is used as the error indicator in this case.
    //
    g_ui32LEDD2 = 0;
    }
    }
    else
    {
    //
    // If we are here it means that connection to Exosite is lost.
    // Handle the different cases that could have caused this.
    //
    switch(g_ui32Err)
    {
    case ERR_IP_ADDR:
    {
    //
    // Check if IP address has been acquired.
    //
    ui32IPAddr = lwIPLocalIPAddrGet();
    if((ui32IPAddr == 0xffffffff) || (ui32IPAddr == 0x00000000))
    {
    //
    // No - Delay a second to allow DHCP to find an IP
    // address.
    //
    ROM_SysCtlDelay(g_ui32SysClock / 3);

    //
    // Change the state of LED D1 so that it blinks,
    // indicating that IP Address is lost.
    //
    g_ui32LEDD1 ^= 1;
    break;
    }

    //
    // Report the IP address to the user.
    //
    UARTprintf("IP Address Acquired: ");
    UARTprintf("%d.",ui32IPAddr & 0xFF );
    UARTprintf("%d.",ui32IPAddr >> 8 & 0xFF );
    UARTprintf("%d.",ui32IPAddr >> 16 & 0xFF );
    UARTprintf("%d\n",ui32IPAddr >> 24 & 0xFF );

    //
    // Update the global IP Address variable.
    //
    g_ui32IPAddr = ui32IPAddr;

    //
    // Check if the CIK is valid. This also helps in verifying
    // connection with Exosite.
    //
    g_bOnline = LocateValidCIK();
    if(!g_bOnline)
    {
    //
    // Failed to connect to Exosite. Assume that CIK is
    // not valid.
    //
    g_ui32Err = ERR_CIK;
    ui32CIKRetries = 0;
    break;
    }

    //
    // Print a prompt
    //
    UARTprintf("\n> ");

    //
    // Reset the necessary variables to inform the application
    // that the error is cleared.
    //
    g_ui32Err = ERR_NO_ERR;
    g_ui32LinkRetries = 0;

    break;
    }

    case ERR_CIK:
    {
    //
    // Attempt to acquire a new CIK from Exosite.
    //
    if(ProvisionCIK())
    {
    //
    // Success - notify the application that we are
    // connected to Exosite. Also reset the necessary
    // error variables.
    //
    g_bOnline = true;
    g_ui32Err = ERR_NO_ERR;
    ui32CIKRetries = 0;

    break;
    }

    //
    // Since we failed to acquire a new CIK, try a few times
    // before giving up.
    //
    ui32CIKRetries++;
    if(ui32CIKRetries > 5)
    {
    //
    // Report to the user.
    //
    UARTprintf("\nCIK no longer valid. Tried %d times ",
    ui32CIKRetries);
    UARTprintf("to acquire new CIK but failed.\n");
    UARTprintf("Log in to exosite to check on the ");
    UARTprintf("status of your device.\n");

    //
    // Failed to acquire new CIK after trying a few times.
    // So stop trying to acquire new CIK.
    //
    g_ui32Err = ERR_UNKNOWN;
    ui32CIKRetries = 0;
    }

    //
    // Change the state of LED D2 so that it blinks, indicating
    // that CIK is no longer valid.
    //
    g_ui32LEDD2 ^= 1;
    break;
    }

    case ERR_UNKNOWN:
    {
    //
    // Report to the user.
    //
    UARTprintf("\nFailed to connect to Exosite due to ");
    UARTprintf("unknown reason.\n");

    //
    // Display IP address.
    //
    UARTprintf("IP Address: ");
    ui32IPAddr = lwIPLocalIPAddrGet();
    UARTprintf("%d.",ui32IPAddr & 0xFF );
    UARTprintf("%d.",ui32IPAddr >> 8 & 0xFF );
    UARTprintf("%d.",ui32IPAddr >> 16 & 0xFF );
    UARTprintf("%d\n",ui32IPAddr >> 24 & 0xFF );

    UARTprintf("Trying to sync with Exosite Server again.\n");
    UARTprintf("\n> ");

    //
    // Set the appropriate flags to retry syncing with Exosite
    // server.
    //
    g_bOnline = true;
    g_ui32Err = ERR_NO_ERR;

    break;
    }

    case ERR_NO_ERR:
    default:
    {
    break;
    }
    }
    }
    }
    }
  • #define NUM_STATS 18
    uint32_t g_ui32SW1Presses = 0;
    uint32_t g_ui32SW2Presses = 0;
    uint32_t g_ui32InternalTempF = 0;
    uint32_t g_ui32InternalTempC = 0;
    uint32_t g_ui32TimerIntCount = 0;
    uint32_t g_ui32SecondsOnTime = 0;
    uint32_t g_ui32LEDD1 = 0;
    uint32_t g_ui32LEDD2 = 0;
    uint32_t g_ui32LEDD3 = 0;
    uint32_t g_ui32LEDD4 = 0;
    uint32_t g_ui32LEDD5 = 0;

    char g_pcLocation[50] = "";
    char g_pcContactEmail[100] = "";
    char g_pcAlert[140] = "";

    //*****************************************************************************
    //
    // Global structures used to interface with Exosite.
    //
    //*****************************************************************************
    tStat g_sSW1Presses =
    {"SW1-presses", &g_ui32SW1Presses, "usrsw1", INT, WRITE_ONLY};

    tStat g_sSW2Presses =
    {"SW2-presses", &g_ui32SW2Presses, "usrsw2", INT, WRITE_ONLY};

    tStat g_sInternalTempF =
    {"Temp(F)", &g_ui32InternalTempF, 0, INT, WRITE_ONLY};

    tStat g_sInternalTempC =
    {"Temp(C)", &g_ui32InternalTempC, "jtemp", INT, WRITE_ONLY};

    tStat g_sSecondsOnTime =
    {"Time since reset", &g_ui32SecondsOnTime, "ontime", INT, WRITE_ONLY};

    tStat g_sLEDD1 =
    {"LED D1", &g_ui32LEDD1, "ledd1", INT, READ_WRITE};

    tStat g_sLEDD2 =
    {"LED D2", &g_ui32LEDD2, "ledd2", INT, READ_WRITE};

    tStat g_sLEDD3 =
    {"LED D3", &g_ui32LEDD3, "ledd3", INT, READ_WRITE};

    tStat g_sLEDD4 =
    {"LED D4", &g_ui32LEDD4, "ledd4", INT, READ_WRITE};

    tStat g_sLEDD5 =
    {"LED D5", &g_ui32LEDD5, "ledd5", INT, READ_WRITE};

    tStat g_sLocation =
    {"Location", g_pcLocation, "location", STRING, READ_ONLY};

    tStat g_sBoardState =
    {NULL, &g_ui32BoardState, "gamestate", HEX, WRITE_ONLY};

    tStat g_sContactEmail =
    {"Contact Email", g_pcContactEmail, "emailaddr", STRING, READ_WRITE};

    tStat g_sAlert =
    {"Alert Message", g_pcAlert, "alert", STRING, NONE};

    //*****************************************************************************
    //
    // Global array of pointers to all tStat structures to be synced with Exosite.
    //
    //*****************************************************************************
    tStat *g_psDeviceStatistics[NUM_STATS]=
    {
    &g_sSW1Presses,
    &g_sSW2Presses,
    &g_sInternalTempF,
    &g_sInternalTempC,
    &g_sSecondsOnTime,
    &g_sLEDD1,
    &g_sLEDD2,
    &g_sLEDD3,
    &g_sLEDD4,
    &g_sLEDD5,
    &g_sLocation,
    &g_sBoardState,
    &g_sContactEmail,
    &g_sAlert,
    NULL
    };
    void
    UpdateLEDs(void)
    {
    //
    // If either LED's global flag is set, turn that LED on. Otherwise, turn
    // them off.
    //
    if(g_ui32LEDD1)
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_1, GPIO_PIN_1);
    }
    else
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_1, 0);
    }

    if(g_ui32LEDD2)
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_0, GPIO_PIN_0);
    }
    else
    {
    ROM_GPIOPinWrite(GPIO_PORTN_BASE, GPIO_PIN_0, 0);
    }

    if(g_ui32LEDD3)
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_2, GPIO_PIN_2);
    }
    else
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_2, 0);
    }
    if(g_ui32LEDD4)
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_3, GPIO_PIN_3);

    }
    else
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_3, 0);
    }
    if(g_ui32LEDD5)
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_4, GPIO_PIN_4);
    }
    else
    {
    ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_4, 0);
    }

    }
  •  

    KISHAN PATEL said:
    #define NUM_STATS 18

    1. Counting 14 total tStat + 1 makes 15 like you say earlier posting and (tStat *g_psDeviceStatistics[NUM_STATS]=) and global structures must be same names, check also global exports stats.h.

    2. You must also define the GPIO ports configuration for additional LED's you adding with existing 2 user LED on launch pad, the other 2 launch pad LED's are configured Ethernet link & activity.

    3. Alternatively back track e.g. import unmodified IOT project to CCS, flash launch pad and delete your added LED aliases on IOT server.

        A. Make valid server connection verify EEROM CIK authenticates, application validates if the tStat aliases are the same on both client and server then bOnline = true. 

        B. Add only 1 new led at a time into application get idea where things going wrong, you can leave any added LED GPIO configurations in (ports.c). 

        C. Do not overwrite the defined Ethernet LED's or faults may occur, besides you need them to know what is network status etc....

    Good work getting the idea now, be patient try to look at application as it relates to the Launch pad hardware layout, e.g. check schematic frequently.

  • Welcome to the Connected LaunchPad!!
    Internet of Things Demo
    Type 'help' for help.

    Current MAC: 001ab603243b
    Obtaining IP...
    Continuing in offline mode.


    > IP Address Acquired: 192.168.43.221
    Locating CIK... CIK found in EEPROM storage.

    CIK: e87661f3bec8808ba6db5c9f68bd46649611152b

    Connected! Type 'stats' to see data for this board.
    > stats

    After add led5 this it's not work ....

    Here I am attach my edited" qs_iot "program file..

    qs_iot.zip

  • CIK same both the side and completion of sync after it is not work....
  • KISHAN PATEL said:
    After add led5 this it's not work ....

    What is the error message you get from IOT server? Is it possible alias is wrong on IOT server LED5 (no others) cause error? Is it possible GPIO PK4 accidently shorted out on launch pad?

    You may have to put more effort to debug your own application, not many will open a zip file, TI engineers from time to time may. Please use code Insert </> when positing your (short) code snips in the future.

    Good luck in your debug time.

  • Hi BP101,
    I checked "alias" is same from both the side and PK4 is dose not use in for IOT just I configure it as you saying "PK4 accidently shorted out on launch pad" I am remove this and debug it ....
    It is not working.
    Sir you try practically and resolved my problems other wise "TIVA WARE" qs_iot project creator contact ..
  • KISHAN PATEL said:
    "PK4 accidently shorted out on launch pad" I am remove this and debug it ....
    It is not working.

    Perhaps even the LED could be bad too?.

    KISHAN PATEL said:
    I checked "alias" is same from both the side

    Agree alias appear the same both ends.

    It seems to me you believe the problem is local since only LED5 is causing authenticate issue ? not sure as you did not post the connection error. Generally authenticate errors are caused by alias name not being the same somewhere in application code. The print stats command is a local print function of the tStat's, confused me too when (bOnline=false) in that case LED update is called from 1 second GPTM interrupt loop.

  • Hi BP101,

    Sir you said " The print stats command is a local print function of the tStat's, confused me too when (bOnline=false) in that case LED update is called from 1 second GPTM interrupt loop." I appreciate with your all suggestion but I was tried all ....but problem is LED5 after this program does not work when I add one more "ADC channel" it is work for ADC on both the side LED5 is problem . As par your suggestion Every time "Fault ISR" generated this is main problem.
  • Have you tried to enter CCS debug and check control register fault value if hard (0x3) using datasheet codes? Then check NVIC register fault status register, if Precise the memory address location of fault is true otherwise it is a bogus address. E.g. set CCS debug properties for Stellaris ICDI (uncheck) load/reset program after launching debug, exit debug, launch app enter debug when it faults, click connect ICON and simulator will read current debug state (may need to click refresh icon). Read Wiki and datasheet section how to read and understand CCS debug fault codes.

    Alternatively (run) the application; check (run to main ICDI setting) in project debug properties dialog, run the loaded application. The faulting source code will often stop near the offending syntax or routine that caused the fault.
  • KISHAN PATEL said:
    but problem is LED5 after this program does not work when I add one more "ADC channel" it is work for ADC on both the side LED5 is problem . As par your suggestion Every time "Fault ISR" generated this is main problem.

    What is port N?

    if(g_ui32LEDD2)
    {
     ROM_GPIOPinWrite(GPIO_PORTK_BASE, GPIO_PIN_0, GPIO_PIN_0);
     }
       else
     {
        ROM_GPIOPinWrite(GPIO_PORTN_BASE, GPIO_PIN_0, 0);
     }
    

  • Sir i am try this one ..

    not work .

  • I was referring to your posted code PORTN ----- should it not actually be PORTK?
  • "
    I was referring to your posted code PORTN ----- should it not actually be PORTK?"
    you should referring zip..
  • [quote user="KISHAN PATEL"]you should referring zip..[/quote

    Making it difficult for helpers posting (unedited) syntax mistakes is not going to aid in your success. Patiently await any CCS debug register report, that will likely help your success!

    The type of debug faults/codes can help indicate problem areas in your application. Your post was not very clear regarding LED4, did it fault too ? or only fault after adding LED5?

    Also consider it difficult for helpers being your English is very short to elaborate on the details. Earlier posts were very demanding in tone, no others in forum jumping in to aid your demise.
  • Hi TI community...

    I repeat the problem of  "qs_iot" program again.

    In the "Tiware examples" for the "TM4C1294XL" board examples are given there is one program for IOT purpose(qs_iot).

    I was run this program it is work nicely .. I was edit this program for more led lights I was add one led in "program" and "exosite data" this led is connect with "GPIO K0.0" it is work .

    and I was edit for one more led it is connect with "GPIO K0.1" now this program is for "4-led " control using "ti exo-site" .after this I am add one more " LED" five no. led it is connected with "GPIO K0.2"

    give same "alias" both the side as well as "portal data" and "program" .After added five no. led cpu going in "FAULT_ISR" .As per previous given suggestion I was try debug and step by step program run

    but "FAULT_ISR" generated in "request.c" file .

    I am attach  my program rar file.

    <<<<<<7725.qs_iot.zip>>>>>>>>>