The Hiking Pal tracking device firmware. See full description on the detail page: https://www.hackster.io/bowenfeng/hiking-pal-v1-07c02d
Dependencies: FXOS8700CQ MODSERIAL mbed
Fork of Avnet_ATT_Cellular_IOT by
main.cpp@85:43d791cd5967, 2016-12-22 (annotated)
- Committer:
- bowenfeng
- Date:
- Thu Dec 22 06:52:58 2016 +0000
- Revision:
- 85:43d791cd5967
- Parent:
- 84:0bf8168b690a
- Child:
- 86:5ff234988f53
Report data using the allocated session. Remove hard coded IDs.
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
fkellermavnet | 68:6e311c747045 | 1 | /* =================================================================== |
fkellermavnet | 68:6e311c747045 | 2 | Copyright © 2016, AVNET Inc. |
fkellermavnet | 68:6e311c747045 | 3 | |
fkellermavnet | 68:6e311c747045 | 4 | Licensed under the Apache License, Version 2.0 (the "License"); |
fkellermavnet | 68:6e311c747045 | 5 | you may not use this file except in compliance with the License. |
fkellermavnet | 68:6e311c747045 | 6 | You may obtain a copy of the License at |
fkellermavnet | 68:6e311c747045 | 7 | |
fkellermavnet | 68:6e311c747045 | 8 | http://www.apache.org/licenses/LICENSE-2.0 |
fkellermavnet | 68:6e311c747045 | 9 | |
fkellermavnet | 68:6e311c747045 | 10 | Unless required by applicable law or agreed to in writing, |
fkellermavnet | 68:6e311c747045 | 11 | software distributed under the License is distributed on an |
fkellermavnet | 68:6e311c747045 | 12 | "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, |
fkellermavnet | 68:6e311c747045 | 13 | either express or implied. See the License for the specific |
fkellermavnet | 68:6e311c747045 | 14 | language governing permissions and limitations under the License. |
fkellermavnet | 68:6e311c747045 | 15 | |
fkellermavnet | 68:6e311c747045 | 16 | ======================================================================== */ |
fkellermavnet | 68:6e311c747045 | 17 | |
stefanrousseau | 55:3abf9e3f42e6 | 18 | #include "mbed.h" |
JMF | 0:9d5134074d84 | 19 | #include <cctype> |
JMF | 0:9d5134074d84 | 20 | #include <string> |
JMF | 2:0e2ef866af95 | 21 | #include "config_me.h" |
stefanrousseau | 4:f83bedd9cab4 | 22 | #include "sensors.h" |
stefanrousseau | 61:f6b93129f954 | 23 | #include "cell_modem.h" |
stefanrousseau | 11:e6602513730f | 24 | #include "hardware.h" |
stefanrousseau | 11:e6602513730f | 25 | |
stefanrousseau | 61:f6b93129f954 | 26 | I2C i2c(PTC11, PTC10); //SDA, SCL -- define the I2C pins being used |
stefanrousseau | 56:cb42ff383dab | 27 | MODSERIAL pc(USBTX, USBRX, 256, 256); // tx, rx with default tx, rx buffer sizes |
stefanrousseau | 63:90d7c69993cd | 28 | MODSERIAL mdm(PTD3, PTD2, 4096, 4096); |
stefanrousseau | 16:17c5916f2d12 | 29 | DigitalOut led_green(LED_GREEN); |
stefanrousseau | 16:17c5916f2d12 | 30 | DigitalOut led_red(LED_RED); |
stefanrousseau | 16:17c5916f2d12 | 31 | DigitalOut led_blue(LED_BLUE); |
JMF | 0:9d5134074d84 | 32 | |
bowenfeng | 85:43d791cd5967 | 33 | #define OK_COLOR 0x2 |
bowenfeng | 85:43d791cd5967 | 34 | #define ERROR_COLOR 0x1 |
bowenfeng | 85:43d791cd5967 | 35 | |
JMF | 0:9d5134074d84 | 36 | |
stefanrousseau | 3:26b3cc155f39 | 37 | //******************************************************************************************************************************************** |
stefanrousseau | 12:7c94ec5069dc | 38 | //* Create string with sensor readings that can be sent to flow as an HTTP get |
stefanrousseau | 3:26b3cc155f39 | 39 | //******************************************************************************************************************************************** |
bowenfeng | 84:0bf8168b690a | 40 | K64F_Sensors_t SENSOR_DATA = { |
stefanrousseau | 12:7c94ec5069dc | 41 | .Temperature = "0", |
stefanrousseau | 12:7c94ec5069dc | 42 | .Humidity = "0", |
stefanrousseau | 12:7c94ec5069dc | 43 | .AccelX = "0", |
stefanrousseau | 12:7c94ec5069dc | 44 | .AccelY = "0", |
stefanrousseau | 12:7c94ec5069dc | 45 | .AccelZ = "0", |
stefanrousseau | 12:7c94ec5069dc | 46 | .MagnetometerX = "0", |
stefanrousseau | 12:7c94ec5069dc | 47 | .MagnetometerY = "0", |
stefanrousseau | 12:7c94ec5069dc | 48 | .MagnetometerZ = "0", |
stefanrousseau | 12:7c94ec5069dc | 49 | .AmbientLightVis = "0", |
stefanrousseau | 12:7c94ec5069dc | 50 | .AmbientLightIr = "0", |
stefanrousseau | 12:7c94ec5069dc | 51 | .UVindex = "0", |
stefanrousseau | 12:7c94ec5069dc | 52 | .Proximity = "0", |
stefanrousseau | 12:7c94ec5069dc | 53 | .Temperature_Si7020 = "0", |
stefanrousseau | 55:3abf9e3f42e6 | 54 | .Humidity_Si7020 = "0", |
stefanrousseau | 55:3abf9e3f42e6 | 55 | .Virtual_Sensor1 = "0", |
stefanrousseau | 55:3abf9e3f42e6 | 56 | .Virtual_Sensor2 = "0", |
stefanrousseau | 55:3abf9e3f42e6 | 57 | .Virtual_Sensor3 = "0", |
stefanrousseau | 55:3abf9e3f42e6 | 58 | .Virtual_Sensor4 = "0", |
stefanrousseau | 55:3abf9e3f42e6 | 59 | .Virtual_Sensor5 = "0", |
stefanrousseau | 55:3abf9e3f42e6 | 60 | .Virtual_Sensor6 = "0", |
stefanrousseau | 55:3abf9e3f42e6 | 61 | .Virtual_Sensor7 = "0", |
stefanrousseau | 71:45a5e426df81 | 62 | .Virtual_Sensor8 = "0", |
stefanrousseau | 72:b500e1507b5f | 63 | .GPS_Satellites = "0", |
stefanrousseau | 71:45a5e426df81 | 64 | .GPS_Latitude = "0", |
stefanrousseau | 71:45a5e426df81 | 65 | .GPS_Longitude = "0", |
stefanrousseau | 71:45a5e426df81 | 66 | .GPS_Altitude = "0", |
stefanrousseau | 71:45a5e426df81 | 67 | .GPS_Speed = "0", |
stefanrousseau | 71:45a5e426df81 | 68 | .GPS_Course = "0" |
stefanrousseau | 3:26b3cc155f39 | 69 | }; |
stefanrousseau | 12:7c94ec5069dc | 70 | |
bowenfeng | 85:43d791cd5967 | 71 | char hid[20] = {0}; |
bowenfeng | 85:43d791cd5967 | 72 | char sid[20] = {0}; |
bowenfeng | 85:43d791cd5967 | 73 | char sessionName[20] = {0}; |
bowenfeng | 85:43d791cd5967 | 74 | |
bowenfeng | 84:0bf8168b690a | 75 | void display_app_firmware_version(void) { |
bowenfeng | 85:43d791cd5967 | 76 | PUTS("\r\n\r\nHiking Pal Firmware: Release 1.0 - built: "__DATE__" "__TIME__"\r\n\r\n"); |
fkellermavnet | 77:c65eae5b9958 | 77 | } |
fkellermavnet | 77:c65eae5b9958 | 78 | |
stefanrousseau | 3:26b3cc155f39 | 79 | //Periodic timer |
stefanrousseau | 3:26b3cc155f39 | 80 | Ticker OneMsTicker; |
stefanrousseau | 3:26b3cc155f39 | 81 | volatile bool bTimerExpiredFlag = false; |
stefanrousseau | 3:26b3cc155f39 | 82 | int OneMsTicks = 0; |
stefanrousseau | 3:26b3cc155f39 | 83 | int iTimer1Interval_ms = 1000; |
stefanrousseau | 3:26b3cc155f39 | 84 | //******************************************************************************************************************************************** |
stefanrousseau | 3:26b3cc155f39 | 85 | //* Periodic 1ms timer tick |
stefanrousseau | 3:26b3cc155f39 | 86 | //******************************************************************************************************************************************** |
bowenfeng | 84:0bf8168b690a | 87 | void OneMsFunction() { |
stefanrousseau | 3:26b3cc155f39 | 88 | OneMsTicks++; |
bowenfeng | 84:0bf8168b690a | 89 | if ((OneMsTicks % iTimer1Interval_ms) == 0) { |
stefanrousseau | 3:26b3cc155f39 | 90 | bTimerExpiredFlag = true; |
stefanrousseau | 3:26b3cc155f39 | 91 | } |
stefanrousseau | 3:26b3cc155f39 | 92 | } //OneMsFunction() |
stefanrousseau | 3:26b3cc155f39 | 93 | |
stefanrousseau | 16:17c5916f2d12 | 94 | //******************************************************************************************************************************************** |
stefanrousseau | 16:17c5916f2d12 | 95 | //* Set the RGB LED's Color |
stefanrousseau | 16:17c5916f2d12 | 96 | //* LED Color 0=Off to 7=White. 3 bits represent BGR (bit0=Red, bit1=Green, bit2=Blue) |
stefanrousseau | 16:17c5916f2d12 | 97 | //******************************************************************************************************************************************** |
bowenfeng | 84:0bf8168b690a | 98 | void SetLedColor(unsigned char ucColor) { |
stefanrousseau | 16:17c5916f2d12 | 99 | //Note that when an LED is on, you write a 0 to it: |
stefanrousseau | 16:17c5916f2d12 | 100 | led_red = !(ucColor & 0x1); //bit 0 |
stefanrousseau | 16:17c5916f2d12 | 101 | led_green = !(ucColor & 0x2); //bit 1 |
stefanrousseau | 16:17c5916f2d12 | 102 | led_blue = !(ucColor & 0x4); //bit 2 |
stefanrousseau | 16:17c5916f2d12 | 103 | } //SetLedColor() |
stefanrousseau | 16:17c5916f2d12 | 104 | |
bowenfeng | 84:0bf8168b690a | 105 | void extract_longlong(const char* s, char v[]) { |
bowenfeng | 84:0bf8168b690a | 106 | long long value = strtoll(s, NULL, 0); |
bowenfeng | 84:0bf8168b690a | 107 | sprintf(v, "%lld", value); |
bowenfeng | 84:0bf8168b690a | 108 | } |
bowenfeng | 84:0bf8168b690a | 109 | |
bowenfeng | 84:0bf8168b690a | 110 | void find_longlong(const char* s, const char* token, char v[]) { |
bowenfeng | 84:0bf8168b690a | 111 | const char* tokenBegin = strstr(s, token); |
bowenfeng | 84:0bf8168b690a | 112 | if (tokenBegin != 0) { |
bowenfeng | 84:0bf8168b690a | 113 | extract_longlong(tokenBegin + strlen(token), v); |
bowenfeng | 84:0bf8168b690a | 114 | } |
bowenfeng | 84:0bf8168b690a | 115 | } |
bowenfeng | 84:0bf8168b690a | 116 | |
bowenfeng | 85:43d791cd5967 | 117 | int send_receive(char* request, char* response) { |
bowenfeng | 85:43d791cd5967 | 118 | int result = cell_modem_Sendreceive(request, response); |
bowenfeng | 85:43d791cd5967 | 119 | SetLedColor(result ? OK_COLOR : ERROR_COLOR); |
bowenfeng | 85:43d791cd5967 | 120 | return result; |
bowenfeng | 85:43d791cd5967 | 121 | } |
bowenfeng | 85:43d791cd5967 | 122 | |
bowenfeng | 85:43d791cd5967 | 123 | int send_only(char* request) { |
bowenfeng | 85:43d791cd5967 | 124 | char response[512]; |
bowenfeng | 85:43d791cd5967 | 125 | return send_receive(request, response); |
bowenfeng | 85:43d791cd5967 | 126 | } |
bowenfeng | 85:43d791cd5967 | 127 | |
bowenfeng | 84:0bf8168b690a | 128 | void find_first_hiking(char hikingId[]) { |
bowenfeng | 84:0bf8168b690a | 129 | char request[512]; |
bowenfeng | 84:0bf8168b690a | 130 | char response[512]; |
bowenfeng | 84:0bf8168b690a | 131 | sprintf(request, "GET %s/hikings HTTP/1.1\r\nHost: %s\r\n\r\n", FLOW_BASE_URL, MY_SERVER_URL); |
bowenfeng | 85:43d791cd5967 | 132 | if (send_receive(&request[0], &response[0])) { |
bowenfeng | 84:0bf8168b690a | 133 | find_longlong(response, "\"id\":", hikingId); |
bowenfeng | 84:0bf8168b690a | 134 | } |
bowenfeng | 84:0bf8168b690a | 135 | } |
bowenfeng | 84:0bf8168b690a | 136 | |
bowenfeng | 84:0bf8168b690a | 137 | void join_hiking(const char* hikingId, const char* name, char sessionId[]) { |
bowenfeng | 84:0bf8168b690a | 138 | char request[512]; |
bowenfeng | 84:0bf8168b690a | 139 | char response[512]; |
bowenfeng | 84:0bf8168b690a | 140 | sprintf(request, "GET %s/hikings/%s/sessions?name=%s HTTP/1.1\r\nHost: %s\r\n\r\n", FLOW_BASE_URL, hikingId, name, MY_SERVER_URL); |
bowenfeng | 85:43d791cd5967 | 141 | if (send_receive(&request[0], &response[0])) { |
bowenfeng | 84:0bf8168b690a | 142 | find_longlong(response, "\"id\":", sessionId); |
bowenfeng | 84:0bf8168b690a | 143 | } |
bowenfeng | 84:0bf8168b690a | 144 | } |
bowenfeng | 84:0bf8168b690a | 145 | |
bowenfeng | 85:43d791cd5967 | 146 | void generate_move_request(char request[], const char* hid, const char* sid) { |
bowenfeng | 85:43d791cd5967 | 147 | sprintf( |
bowenfeng | 85:43d791cd5967 | 148 | request, |
bowenfeng | 85:43d791cd5967 | 149 | "GET %s/hikings/%s/sessions/%s/moves?lat=%s&lng=%s HTTP/1.1\r\nHost: %s\r\n\r\n", |
bowenfeng | 85:43d791cd5967 | 150 | FLOW_BASE_URL, |
bowenfeng | 85:43d791cd5967 | 151 | hid, |
bowenfeng | 85:43d791cd5967 | 152 | sid, |
bowenfeng | 85:43d791cd5967 | 153 | SENSOR_DATA.GPS_Latitude, |
bowenfeng | 85:43d791cd5967 | 154 | SENSOR_DATA.GPS_Longitude, |
bowenfeng | 85:43d791cd5967 | 155 | MY_SERVER_URL); |
bowenfeng | 85:43d791cd5967 | 156 | } |
bowenfeng | 85:43d791cd5967 | 157 | void report_move(const char* hid, const char* sid) { |
bowenfeng | 85:43d791cd5967 | 158 | char request[512]; |
bowenfeng | 85:43d791cd5967 | 159 | generate_move_request(request, hid, sid); |
bowenfeng | 85:43d791cd5967 | 160 | send_only(&request[0]); |
bowenfeng | 85:43d791cd5967 | 161 | } |
bowenfeng | 85:43d791cd5967 | 162 | |
JMF | 0:9d5134074d84 | 163 | int main() { |
stefanrousseau | 72:b500e1507b5f | 164 | //delay so that the debug terminal can open after power-on reset: |
fkellermavnet | 77:c65eae5b9958 | 165 | wait (5.0); |
stefanrousseau | 61:f6b93129f954 | 166 | pc.baud(115200); |
fkellermavnet | 77:c65eae5b9958 | 167 | |
fkellermavnet | 77:c65eae5b9958 | 168 | display_app_firmware_version(); |
fkellermavnet | 77:c65eae5b9958 | 169 | |
bowenfeng | 85:43d791cd5967 | 170 | PRINTF(GRN "Hiking Pal tracking device started!\r\n\r\n"); |
JMF | 0:9d5134074d84 | 171 | |
stefanrousseau | 61:f6b93129f954 | 172 | //Initialize the I2C sensors that are present |
stefanrousseau | 11:e6602513730f | 173 | sensors_init(); |
stefanrousseau | 12:7c94ec5069dc | 174 | read_sensors(); |
stefanrousseau | 11:e6602513730f | 175 | |
stefanrousseau | 61:f6b93129f954 | 176 | // Set LED to RED until init finishes |
stefanrousseau | 61:f6b93129f954 | 177 | SetLedColor(0x1); //Red |
JMF | 0:9d5134074d84 | 178 | // Initialize the modem |
stefanrousseau | 64:09004cd610df | 179 | PRINTF("\r\n"); |
stefanrousseau | 61:f6b93129f954 | 180 | cell_modem_init(); |
fkellermavnet | 77:c65eae5b9958 | 181 | display_wnc_firmware_rev(); |
fkellermavnet | 77:c65eae5b9958 | 182 | |
stefanrousseau | 61:f6b93129f954 | 183 | // Set LED BLUE for partial init |
stefanrousseau | 61:f6b93129f954 | 184 | SetLedColor(0x4); //Blue |
JMF | 0:9d5134074d84 | 185 | |
stefanrousseau | 3:26b3cc155f39 | 186 | //Create a 1ms timer tick function: |
stefanrousseau | 61:f6b93129f954 | 187 | iTimer1Interval_ms = SENSOR_UPDATE_INTERVAL_MS; |
stefanrousseau | 3:26b3cc155f39 | 188 | OneMsTicker.attach(OneMsFunction, 0.001f) ; |
bowenfeng | 84:0bf8168b690a | 189 | |
bowenfeng | 84:0bf8168b690a | 190 | sprintf(sessionName, "IoT-kit-%d", rand() % 1000); |
bowenfeng | 84:0bf8168b690a | 191 | |
bowenfeng | 84:0bf8168b690a | 192 | find_first_hiking(hid); |
bowenfeng | 84:0bf8168b690a | 193 | PRINTF("Found Hiking ID: "); |
bowenfeng | 84:0bf8168b690a | 194 | PRINTF(hid); |
bowenfeng | 84:0bf8168b690a | 195 | PRINTF("\r\n"); |
bowenfeng | 84:0bf8168b690a | 196 | |
bowenfeng | 84:0bf8168b690a | 197 | join_hiking(hid, sessionName, sid); |
bowenfeng | 84:0bf8168b690a | 198 | PRINTF("Allocated Session ID: "); |
bowenfeng | 84:0bf8168b690a | 199 | PRINTF(sid); |
bowenfeng | 84:0bf8168b690a | 200 | PRINTF("\r\n"); |
fkellermavnet | 26:8d6e7e7cdcae | 201 | |
JMF | 2:0e2ef866af95 | 202 | // Send and receive data perpetually |
JMF | 2:0e2ef866af95 | 203 | while(1) { |
bowenfeng | 84:0bf8168b690a | 204 | if (bTimerExpiredFlag) { |
stefanrousseau | 3:26b3cc155f39 | 205 | bTimerExpiredFlag = false; |
stefanrousseau | 4:f83bedd9cab4 | 206 | read_sensors(); //read available external sensors from a PMOD and the on-board motion sensor |
bowenfeng | 85:43d791cd5967 | 207 | report_move(hid, sid); |
stefanrousseau | 3:26b3cc155f39 | 208 | } //forever loop |
JMF | 0:9d5134074d84 | 209 | } |