Dreamforce 2014 Workshop RFID Case Generator - FRDM-K64F

Dependencies:   EndpointMain-rfid EthernetInterface StatusReporter BufferedSerial mbed-rtos mbed Logger C12832

Fork of df-2014-workshop-rfid-case-generator-ublox by Doug Anson

Committer:
ansond
Date:
Fri Aug 29 04:25:50 2014 +0000
Revision:
20:f548e2de5b0b
Parent:
19:341ce6a43a84
Child:
22:1b9e29933ab3
updates

Who changed what in which revision?

UserRevisionLine numberNew contents of line
ansond 0:df2aa79c64f2 1 /* Copyright C2014 ARM, MIT License
ansond 0:df2aa79c64f2 2 *
ansond 0:df2aa79c64f2 3 * Permission is hereby granted, free of charge, to any person obtaining a copy of this software
ansond 0:df2aa79c64f2 4 * and associated documentation files the "Software", to deal in the Software without restriction,
ansond 0:df2aa79c64f2 5 * including without limitation the rights to use, copy, modify, merge, publish, distribute,
ansond 0:df2aa79c64f2 6 * sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is
ansond 0:df2aa79c64f2 7 * furnished to do so, subject to the following conditions:
ansond 0:df2aa79c64f2 8 *
ansond 0:df2aa79c64f2 9 * The above copyright notice and this permission notice shall be included in all copies or
ansond 0:df2aa79c64f2 10 * substantial portions of the Software.
ansond 0:df2aa79c64f2 11 *
ansond 0:df2aa79c64f2 12 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING
ansond 0:df2aa79c64f2 13 * BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
ansond 0:df2aa79c64f2 14 * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
ansond 0:df2aa79c64f2 15 * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
ansond 0:df2aa79c64f2 16 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
ansond 0:df2aa79c64f2 17 */
ansond 0:df2aa79c64f2 18
ansond 13:2561e3855a81 19 // StatusReporter
ansond 13:2561e3855a81 20 #include "StatusReporter.h"
ansond 0:df2aa79c64f2 21
ansond 0:df2aa79c64f2 22 // our LCD Panel
ansond 0:df2aa79c64f2 23 #include "C12832_lcd.h"
ansond 0:df2aa79c64f2 24 C12832_LCD lcd;
ansond 0:df2aa79c64f2 25
ansond 0:df2aa79c64f2 26 // our Serial port
ansond 0:df2aa79c64f2 27 #include "Serial.h"
ansond 0:df2aa79c64f2 28 Serial pc(USBTX, USBRX);
ansond 0:df2aa79c64f2 29
ansond 3:03108e424931 30 // Ethernet
ansond 3:03108e424931 31 #include "EthernetInterface.h"
ansond 3:03108e424931 32 EthernetInterface ethernet;
ansond 3:03108e424931 33
ansond 20:f548e2de5b0b 34 // HTTP
ansond 20:f548e2de5b0b 35 #include "HTTPClient.h"
ansond 20:f548e2de5b0b 36 HTTPClient http;
ansond 20:f548e2de5b0b 37
ansond 6:427c387b10e7 38 // HARD RESET
ansond 6:427c387b10e7 39 extern "C" void HardFault_Handler() { NVIC_SystemReset(); }
ansond 6:427c387b10e7 40
ansond 0:df2aa79c64f2 41 // Main Entry...
ansond 0:df2aa79c64f2 42 int main() {
ansond 0:df2aa79c64f2 43 // create our object instances
ansond 13:2561e3855a81 44 ErrorHandler logger(&pc,&lcd);
ansond 0:df2aa79c64f2 45
ansond 0:df2aa79c64f2 46 // announce
ansond 13:2561e3855a81 47 logger.log("ARM/DreamForce 2014 mbed Status Reporter v%s",APP_VERSION);
ansond 19:341ce6a43a84 48 logger.turnLEDBlue();
ansond 0:df2aa79c64f2 49
ansond 3:03108e424931 50 // initialize Ethernet
ansond 3:03108e424931 51 logger.log("Initializing Ethernet...");
ansond 3:03108e424931 52 ethernet.init();
ansond 0:df2aa79c64f2 53
ansond 3:03108e424931 54 // get a DHCP address and bring the network interface up
ansond 3:03108e424931 55 logger.log("Getting IP Address...");
ansond 19:341ce6a43a84 56 logger.turnLEDOrange();
ansond 3:03108e424931 57 if (ethernet.connect() == 0) {
ansond 3:03108e424931 58 // log our IP address (DHCP)
ansond 3:03108e424931 59 logger.log("IP Address: %s",ethernet.getIPAddress());
ansond 3:03108e424931 60
ansond 13:2561e3855a81 61 // create the StatusReporter
ansond 20:f548e2de5b0b 62 StatusReporter status_reporter(&logger,(void *)&http);
ansond 3:03108e424931 63
ansond 8:fefcecb66463 64 // entering main loop
ansond 8:fefcecb66463 65 logger.log("Entering Main Loop...\r\nScanning...");
ansond 19:341ce6a43a84 66 logger.turnLEDGreen();
ansond 8:fefcecb66463 67
ansond 3:03108e424931 68 // Enter the main loop
ansond 3:03108e424931 69 while(true) {
ansond 13:2561e3855a81 70 // check and report on status updates
ansond 13:2561e3855a81 71 status_reporter.checkAndReportOnStatus();
ansond 3:03108e424931 72
ansond 3:03108e424931 73 // wait a bit and look again
ansond 3:03108e424931 74 wait_ms(WAIT_TIME_MS);
ansond 3:03108e424931 75 }
ansond 3:03108e424931 76 }
ansond 3:03108e424931 77 else {
ansond 3:03108e424931 78 logger.log("No Network... Exiting...");
ansond 19:341ce6a43a84 79 logger.turnLEDRed();
ansond 6:427c387b10e7 80 exit(1);
ansond 3:03108e424931 81 }
ansond 3:03108e424931 82
ansond 3:03108e424931 83 // disconnect
ansond 4:46459ed734f3 84 logger.log("Disconnecting...");
ansond 19:341ce6a43a84 85 logger.turnLEDOrange();
ansond 3:03108e424931 86 ethernet.disconnect();
ansond 4:46459ed734f3 87
ansond 4:46459ed734f3 88 // Exit
ansond 6:427c387b10e7 89 logger.log("Exiting...");
ansond 19:341ce6a43a84 90 logger.turnLEDBlue();
ansond 6:427c387b10e7 91 exit(1);
ansond 0:df2aa79c64f2 92 }