2018-06-08 22:41:37 +02:00
|
|
|
#ifdef HAS_GPS
|
|
|
|
|
|
|
|
#include "globals.h"
|
2018-06-17 16:25:29 +02:00
|
|
|
#include <Wire.h>
|
2018-06-08 22:41:37 +02:00
|
|
|
|
|
|
|
// Local logging tag
|
|
|
|
static const char TAG[] = "main";
|
2018-06-09 17:59:59 +02:00
|
|
|
|
2018-06-09 22:21:23 +02:00
|
|
|
// read GPS data and cast to global struct
|
2018-06-10 15:34:21 +02:00
|
|
|
void gps_read() {
|
2018-06-12 19:48:21 +02:00
|
|
|
gps_status.latitude = (uint32_t)(gps.location.lat() * 1000000);
|
|
|
|
gps_status.longitude = (uint32_t)(gps.location.lng() * 1000000);
|
|
|
|
gps_status.satellites = (uint8_t)gps.satellites.value();
|
|
|
|
gps_status.hdop = (uint16_t)gps.hdop.value();
|
|
|
|
gps_status.altitude = (uint16_t)gps.altitude.meters();
|
2018-06-09 13:18:59 +02:00
|
|
|
}
|
|
|
|
|
2018-06-09 22:21:23 +02:00
|
|
|
// GPS serial feed FreeRTos Task
|
2018-06-12 19:48:21 +02:00
|
|
|
void gps_loop(void *pvParameters) {
|
|
|
|
|
|
|
|
configASSERT(((uint32_t)pvParameters) == 1); // FreeRTOS check
|
|
|
|
|
|
|
|
// initialize and, if needed, configure, GPS
|
|
|
|
#if defined GPS_SERIAL
|
|
|
|
HardwareSerial GPS_Serial(1);
|
2018-06-17 16:25:29 +02:00
|
|
|
#elif defined GPS_QUECTEL_L76
|
|
|
|
Wire.begin(GPS_QUECTEL_L76, 400000); // I2C connect to GPS device with 400
|
2018-06-12 19:48:21 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
while (1) {
|
|
|
|
|
|
|
|
if (cfg.gpsmode) {
|
|
|
|
#if defined GPS_SERIAL
|
|
|
|
|
|
|
|
// serial connect to GPS device
|
|
|
|
GPS_Serial.begin(GPS_SERIAL);
|
|
|
|
|
|
|
|
while (cfg.gpsmode) {
|
|
|
|
// feed GPS decoder with serial NMEA data from GPS device
|
|
|
|
while (GPS_Serial.available()) {
|
|
|
|
gps.encode(GPS_Serial.read());
|
|
|
|
}
|
|
|
|
vTaskDelay(1 / portTICK_PERIOD_MS); // reset watchdog
|
|
|
|
}
|
|
|
|
// after GPS function was disabled, close connect to GPS device
|
|
|
|
GPS_Serial.end();
|
|
|
|
|
2018-06-17 16:25:29 +02:00
|
|
|
#elif defined GPS_QUECTEL_L76
|
2018-06-12 19:48:21 +02:00
|
|
|
|
|
|
|
Wire.beginTransmission(GPS_I2C_ADDRESS_WRITE);
|
2018-06-17 16:25:29 +02:00
|
|
|
Wire.write(0x00); // dummy write to start read
|
|
|
|
Wire.endTransmission();
|
|
|
|
|
|
|
|
Wire.beginTransmission(GPS_I2C_ADDRESS_READ);
|
|
|
|
while (cfg.gpsmode) {
|
|
|
|
Wire.requestFrom(GPS_I2C_ADDRESS_READ, 32);
|
|
|
|
while (Wire.available()) {
|
|
|
|
gps.encode(Wire.read());
|
|
|
|
vTaskDelay(500 / portTICK_PERIOD_MS); // polling mode: 500ms sleep
|
2018-06-08 22:41:37 +02:00
|
|
|
}
|
2018-06-12 19:48:21 +02:00
|
|
|
|
2018-06-17 16:25:29 +02:00
|
|
|
ESP_LOGI(TAG, "GPS NMEA data: passed %d / failed: %d / with fix: %d",
|
|
|
|
gps.passedChecksum(), gps.failedChecksum(),
|
|
|
|
gps.sentencesWithFix());
|
2018-06-12 19:48:21 +02:00
|
|
|
}
|
2018-06-17 16:25:29 +02:00
|
|
|
// after GPS function was disabled, close connect to GPS device
|
2018-06-09 19:20:34 +02:00
|
|
|
|
2018-06-17 16:25:29 +02:00
|
|
|
Wire.endTransmission();
|
|
|
|
|
|
|
|
#endif // GPS Type
|
2018-06-12 19:48:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
vTaskDelay(1 / portTICK_PERIOD_MS); // reset watchdog
|
|
|
|
|
|
|
|
} // end of infinite loop
|
2018-06-09 19:20:34 +02:00
|
|
|
|
|
|
|
} // gps_loop()
|
2018-06-12 19:48:21 +02:00
|
|
|
|
2018-06-08 22:41:37 +02:00
|
|
|
#endif // HAS_GPS
|