GPSProvider wrapper library for STMicroelectronics' X-NUCLEO-GNSS1A1 Expansion Board.
X_NUCLEO_GNSS1A1 Library
GPS_Provider wrapper library for STMicroelectronics' X-NUCLEO-GNSS1A1 component.
Overview
This library includes drivers for ST’s Teseo-LIV3F Global Navigation Satellite System (GNSS) device and middleware for the NMEA protocol support. This firmware package implements the port of the GPS_Provider to STMicroelectronics' X-NUCLEO-GNSS1A1 GNSS Expansion Board.
The key features of the library are:
- Complete software to build applications using Teseo-LIV3F GNSS device
- Middleware for the NMEA protocol support
Furthermore the library provides the following advanced features:
- Geofencing - allows the Teseo-LIV3F receiver to raise a NMEA message when the resolved GNSS position is close to or entering or exiting from a specific circle
- Odometer - provides information on the traveled distance using only the resolved GNSS position
- Data Logging - allows the Teseo-LIV3F receiver to save locally on the flash the resolved GNSS position to be retrieved on demand from the Host
Hardware description
The X-NUCLEO-GNSS1A1 is a Global Navigation Satellite System Expansion Board usable with the STM32 Nucleo system and other Arduino compatible platforms. It is designed around the STMicroelectronics Teseo-LIV3F GNSS receiver IC working on multiple constellations (GPS/Galileo/Glonass/BeiDou/QZSS).
The Teseo-LIV3F module is designed for top performance in a minimal space. Within its 10x10mm compact size, Teseo-LIV3F offers superior accuracy thanks to the on board 26MHz Temperature Compensated Crystal Oscillator (TCXO) and a reduced Time To First Fix (TTFF) relying to its dedicated 32KHz Real Time Clock (RTC) oscillator.
The X-NUCLEO-GNSS1A1, hosting the Teseo-LIV3F, is compatible with Arduino UNO R3 connector layout and interfaces with the MCU via the UART channel. To connect by serial port the GNSS receiver and the host the following parameters must be used:
- 8 data bits
- No parity
- 1 stop bit
- 9600 bauds
A GPS/GLONASS/Beidou antenna, distributed along with the X-NUCLEO-GNSS1A1 Expansion Board, must be connected to the antenna connector present on the Expansion Board. For the X-NUCLEO-GNSS1A1 proper operations, the following jumper settings must be used:
- J2 open
- J3 closed
- J4 closed
- J5 open
- J6 closed
- J7 closed
- J8 open
- J9 closed
- J10 open
- J11 closed
- J12 closed
- J13 closed
- J14 closed
- J15 closed
Tested platforms
This firmware has been tested on STM32 NUCLEO-F401RE
Example Application
To run GNSS example applications using X-NUCLEO-GNSS1A1 Expansion Board based on mbed OS, please refer to TeseoLocation page.
Revision 5:1fe1ba1f0013, committed 2021-01-14
- Comitter:
- apalmieri
- Date:
- Thu Jan 14 09:29:14 2021 +0000
- Parent:
- 4:9d0addf682f0
- Commit message:
- Get GNSS library aligned with mbed-os-6.6.0
Changed in this revision
--- a/Components/Teseo/Teseo.cpp Thu Feb 14 11:37:40 2019 +0000 +++ b/Components/Teseo/Teseo.cpp Thu Jan 14 09:29:14 2021 +0000 @@ -44,6 +44,10 @@ #include "Teseo.h" +#if MBED_CONF_TESEO_TRACE_ENABLED == 1 +#define TESEO_LOG_INFO(...) printf(__VA_ARGS__) +#endif + static char TESEO_NAME[] = "Teseo-LIV3F"; /* static char _OK[] = "OK"; @@ -82,17 +86,15 @@ PinName wakeupPin, PinName ppsPin, PinName uartTxPin, - PinName uartRxPin, - Serial *serialDebug): + PinName uartRxPin): _loc_led2(LOC_LED2), _reset(resetPin, 1), _pps(ppsPin), _wakeup(wakeupPin, 0), _uartRx(uartRxPin), - _uartTx(uartTxPin), - _serialDebug(serialDebug) + _uartTx(uartTxPin) { - wait_ms(POWERON_STABLE_SIGNAL_DELAY_MS); + wait_us(POWERON_STABLE_SIGNAL_DELAY_MS*1000); _uart = NULL; _i2c = NULL; @@ -106,18 +108,16 @@ PinName ppsPin, PinName uartTxPin, PinName uartRxPin, - I2C *i2cBus, - Serial *serialDebug): + I2C *i2cBus): _loc_led2(LOC_LED2), _reset(resetPin, 1), _pps(ppsPin), _wakeup(wakeupPin, 0), _uartRx(uartRxPin), _uartTx(uartTxPin), - _serialDebug(serialDebug), _i2c(i2cBus) { - wait_ms(POWERON_STABLE_SIGNAL_DELAY_MS); + wait_us(POWERON_STABLE_SIGNAL_DELAY_MS*1000); _uart = NULL; _locState = TESEO_LOC_STATE_IDLE; @@ -140,52 +140,42 @@ } void -Teseo::_ResetFast(Serial *serialDebug) +Teseo::_ResetFast(void) { - if (serialDebug) { - serialDebug->printf("%s: Resetting...", TESEO_NAME); - } + TESEO_LOG_INFO("%s: Resetting...", TESEO_NAME); _reset.write(0); - - wait_ms(5); + + wait_us(5000); _reset.write(1); - - wait_ms(70); - - if (serialDebug) { - serialDebug->printf("Done...\n\r"); - } + + wait_us(70000); + + TESEO_LOG_INFO("Done...\n\r"); } void -Teseo::_Reset(Serial *serialDebug) +Teseo::_Reset(void) { - if (serialDebug) { - serialDebug->printf("%s: Resetting...", TESEO_NAME); - } + TESEO_LOG_INFO("%s: Resetting...", TESEO_NAME); //_pps.output(); //_pps.write(0); - //wait_ms(500); - _reset.write(1); - wait_ms(500); + wait_us(500000); //500ms _reset.write(0); //_pps.write(0); - wait_ms(500); + wait_us(500000); //500ms _reset.write(1); - - if (serialDebug) { - serialDebug->printf("Done...\n\r"); - } - + + TESEO_LOG_INFO("Done...\n\r"); + //_pps.write(1); //wait_ms(1000); @@ -197,19 +187,19 @@ Teseo::_SendString(char *buf, int len) { for (int i = 0; i < len; ++i) { - while (!_uart->writeable()); - _uart->putc(buf[i]); + while (!_uart->writable()); + _uart->write((const void *)&buf[i], 1); } } int Teseo::_WakeUp() { - wait_ms(100); + wait_us(100000); //100ms _wakeup.write(1); - wait_ms(500); + wait_us(500000); //500ms _wakeup.write(0); @@ -243,7 +233,7 @@ { char crc[3]; - sprintf(crc, "*%02X", _CRC(teseoCmds[c].cmd, -1)); + snprintf(crc, 3, "*%02X", _CRC(teseoCmds[c].cmd, -1)); _SendString(teseoCmds[c].cmd, strlen(teseoCmds[c].cmd)); _SendString(crc, 3); @@ -254,7 +244,7 @@ { char crc[5]; - sprintf(crc, "*%02X\n\r", _CRC(cmd, strlen(cmd))); + snprintf(crc, 5, "*%02X\n\r", _CRC(cmd, strlen(cmd))); //printf("CRC=%s\n\r", crc); _SendString(cmd, strlen(cmd)); @@ -264,12 +254,12 @@ void Teseo::ReadSentence(Teseo::eMsg msg) { + struct _teseoMsg *message; eStatus status = TESEO_STATUS_FAILURE; do { - osEvent evt = queue.get(); - if (evt.status == osEventMessage) { - struct _teseoMsg *message = (struct _teseoMsg *)evt.value.p; + bool stat = queue.try_get_for(Kernel::wait_for_u32_forever, &message); + if (stat == true) { if (message->len > 0) { status = _GetMsg(msg, message->buf); } @@ -282,11 +272,8 @@ void Teseo::_InitUART(int br) { - _uart = new (std::nothrow) Serial(_uartRx, _uartTx); - if(_uart != NULL) { - _uart->format(8, SerialBase::None, 1); - _uart->baud(br); - } else { + _uart = new (std::nothrow) BufferedSerial(_uartRx, _uartTx); + if(_uart == NULL) { TESEO_LOG_INFO("Error allocating UART.\r\n"); } } @@ -294,7 +281,7 @@ bool Teseo::setPowerMode(GPSProvider::PowerMode_t pwrMode) { - /* TBI */ + //TBI return false; } @@ -311,22 +298,22 @@ { char c; - struct _teseoMsg *msg = mpool.alloc(); + struct _teseoMsg *msg = mpool.try_alloc(); msg->len = 0; while(true) { if (_uart->readable()) { - c = _uart->getc(); + _uart->read(&c, 1); if (c == '$') { - queue.put(msg); - msg = mpool.alloc(); + queue.try_put(msg); + msg = mpool.try_alloc(); msg->len = 0; } msg->buf[msg->len++] = c; } else { - Thread::yield(); //wait_us(100); Allow other threads to run + ThisThread::yield(); //wait_us(100); Allow other threads to run } } } @@ -348,7 +335,6 @@ // Start thread for UART listener and set the highest priority serialStreamThread = new (std::nothrow) Thread(); if(serialStreamThread != NULL) { - serialStreamThread->set_priority(osPriorityRealtime); serialStreamThread->start(callback(_UARTStreamProcess, this)); } else { TESEO_LOG_INFO("Error allocating serialStreamThread\r\n"); @@ -629,14 +615,6 @@ { eStatus status; -#if 0 - _serialDebug->printf("\n\r --------------------->\n\r"); - for (int i = 0; i < TESEO_RXBUF_LEN ; ++i) { - _serialDebug->putc((int)buffer[i]); - } - _serialDebug->printf("\n\r<---------------------\n\r"); -#endif - status = (eStatus)parse_gpgga(&pData.gpgga_data, buffer); if(status == TESEO_STATUS_SUCCESS) { outputHandler(LOC_OUTPUT_LOCATION, msg, &pData); @@ -647,14 +625,6 @@ Teseo::_GetPSTMsg(Teseo::ePSTMsg msg, uint8_t *buffer) { eStatus status; - -#if 0 - _serialDebug->printf("\n\r --------------------->\n\r"); - for (int i = 0; i < TESEO_RXBUF_LEN ; ++i) { - _serialDebug->putc((int)buffer[i]); - } - _serialDebug->printf("\n\r<---------------------\n\r"); -#endif switch(msg) { @@ -699,9 +669,11 @@ void Teseo::process(void) { - osEvent evt = queue.get(); - if (evt.status == osEventMessage) { - struct _teseoMsg *message = (struct _teseoMsg *)evt.value.p; + struct _teseoMsg *message; + + bool stat = queue.try_get_for(Kernel::wait_for_u32_forever, &message); + + if (stat == true) { if (message->len > 0) { for(int m = 0; m < PSTM_NMEA_MSGS_NUM; m++) { @@ -725,7 +697,7 @@ void Teseo::reset(void) { - _ResetFast(_serialDebug); + _ResetFast(); } gps_provider_error_t
--- a/Components/Teseo/Teseo.h Thu Feb 14 11:37:40 2019 +0000 +++ b/Components/Teseo/Teseo.h Thu Jan 14 09:29:14 2021 +0000 @@ -61,16 +61,6 @@ #define LOC_OUTPUT_NMEA (2) #define LOC_OUTPUT_PSTM (3) -#if 1 -#define TESEO_LOG_INFO(...) -#else -#define TESEO_LOG_INFO(...) { \ - if (_serialDebug != NULL) { \ - (_serialDebug->printf(__VA_ARGS__)); \ - } \ - } -#endif - /** * @brief Constant that indicates the maximum number of nmea messages to be processed. */ @@ -193,8 +183,7 @@ PinName _uartRx; PinName _uartTx; - Serial *_uart; - Serial *_serialDebug; + BufferedSerial *_uart; I2C *_i2c; tTeseoData pData; @@ -232,15 +221,12 @@ * GPIO pin for serial Tx channel between the host and the GNSS controller. * @param [in] uartRxPin * GPIO pin for serial Rx channel between the host and the GNSS controller. - * @param [in] serialDebug - * The debug port for diagnostic messages; can be NULL. */ Teseo(PinName resetPin, PinName wakeupPin, PinName ppsPin, PinName uartTxPin, - PinName uartRxPin, - Serial *serialDebug = NULL); + PinName uartRxPin); /** Constructor: Teseo * Create the Teseo, accept specified configuration @@ -257,16 +243,13 @@ * GPIO pin for serial Rx channel between the host and the GNSS controller. * @param [in] i2cBus * I2C Bus not supported yet. - * @param [in] serialDebug - * The debug port for diagnostic messages; can be NULL. */ Teseo(PinName resetPin, PinName wakeupPin, PinName ppsPin, PinName uartTxPin, PinName uartRxPin, - I2C *i2cBus, - Serial *serialDebug = NULL); + I2C *i2cBus); /** Register output callback and event callback functions * @param app_output_cb Teseo class output the location and satellite information to application @@ -327,8 +310,8 @@ virtual gps_provider_error_t resetOdo(void); void _InitUART(int br = STD_UART_BAUD); - void _ResetFast(Serial *serialDebug = NULL); - void _Reset(Serial *serialDebug = NULL); + void _ResetFast(void); + void _Reset(void); void _SendString(char *buf, int len); int _WakeUp(); int _CRC(char *buf, int size);
--- a/createTeseoGNSS.cpp Thu Feb 14 11:37:40 2019 +0000 +++ b/createTeseoGNSS.cpp Thu Jan 14 09:29:14 2021 +0000 @@ -45,15 +45,14 @@ static void _AppEventCallback(eTeseoLocEventType event, uint32_t data); static char msg[256]; -static char *geofenceCirclePosition[] = { +static const char *geofenceCirclePosition[] = { "Unknown", "Outside", "Boundary", "Inside" }; -extern Serial serialDebug; -#define TESEO_APP_LOG_INFO(...) serialDebug.printf(__VA_ARGS__) +#define TESEO_GNSS_LOG(...) printf(__VA_ARGS__) GPSProviderImplBase * createGPSProviderInstance(void) @@ -62,8 +61,7 @@ TESEO_PIN_WAKEUP, TESEO_PIN_PPS, TESEO_PIN_TX, - TESEO_PIN_RX, - &serialDebug); + TESEO_PIN_RX); /* Register output callback and event callback functions */ gnss.TeseoLocRegOutput(_AppOutputCallback, _AppEventCallback); @@ -81,70 +79,70 @@ { // char msg[256]; - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); sprintf(msg, "Constellation:\t\t[ %s ]\t", pData->gns_data.constellation); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); if (strcmp(pData->gns_data.constellation, "$GPGSV") == 0) { - TESEO_APP_LOG_INFO("-- only GPS constellation is enabled\n\r"); + TESEO_GNSS_LOG("-- only GPS constellation is enabled\n\r"); } else if (strcmp(pData->gns_data.constellation, "$GLGSV") == 0) { - TESEO_APP_LOG_INFO("-- only GLONASS constellation is enabled\n\r"); + TESEO_GNSS_LOG("-- only GLONASS constellation is enabled\n\r"); } else if (strcmp(pData->gns_data.constellation, "$GAGSV") == 0) { - TESEO_APP_LOG_INFO("-- only GALILEO constellation is enabled\n\r"); + TESEO_GNSS_LOG("-- only GALILEO constellation is enabled\n\r"); } else if (strcmp(pData->gns_data.constellation, "$BDGSV") == 0) { - TESEO_APP_LOG_INFO("-- only BEIDOU constellation is enabled\n\r"); + TESEO_GNSS_LOG("-- only BEIDOU constellation is enabled\n\r"); } else if (strcmp(pData->gns_data.constellation, "$QZGSV") == 0) { - TESEO_APP_LOG_INFO("-- only QZSS constellation is enabled\n\r"); + TESEO_GNSS_LOG("-- only QZSS constellation is enabled\n\r"); } else if (strcmp(pData->gns_data.constellation, "$GNGSV") == 0) { - TESEO_APP_LOG_INFO("-- message to report all satellites for all enabled constellations\n\r"); + TESEO_GNSS_LOG("-- message to report all satellites for all enabled constellations\n\r"); } sprintf(msg, "UTC:\t\t\t[ %02d:%02d:%02d ]\n\r", pData->gns_data.utc.hh, pData->gns_data.utc.mm, pData->gns_data.utc.ss); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Latitude:\t\t[ %.0f' %d'' %c ]\n\r", (pData->gns_data.xyz.lat - ((int)pData->gns_data.xyz.lat % 100)) / 100, ((int)pData->gns_data.xyz.lat % 100), pData->gns_data.xyz.ns); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Longitude:\t\t[ %.0f' %d'' %c ]\n\r", (pData->gns_data.xyz.lon - ((int)pData->gns_data.xyz.lon % 100)) / 100, ((int)pData->gns_data.xyz.lon % 100), pData->gns_data.xyz.ew); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Satellites locked:\t[ %d ]\n\r", pData->gns_data.sats); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"HDOP:\t\t\t[ %.01f ]\n\r", pData->gns_data.hdop); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Altitude:\t\t[ %.01f ]\n\r", pData->gns_data.xyz.alt); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Geoid infos:\t\t[ %.01f ]\n\r", pData->gns_data.geo_sep); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); // sprintf(msg,"ID - Checksum:\t\t[ *%x ]\n\r", // (pData->gns_data.checksum); - // TESEO_APP_LOG_INFO(msg); + // TESEO_GNSS_LOG("%s", msg); - TESEO_APP_LOG_INFO("\n\n\r"); + TESEO_GNSS_LOG("\n\n\r"); return; } @@ -159,47 +157,47 @@ { // char msg[256]; - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); sprintf(msg, "UTC:\t\t\t[ %02d:%02d:%02d ]\n\r", pData->gpgst_data.utc.hh, pData->gpgst_data.utc.mm, pData->gpgst_data.utc.ss); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"EHPE:\t\t[ %.01f ]\n\r", pData->gpgst_data.EHPE); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Semi-major Dev:\t\t[ %.01f ]\n\r", pData->gpgst_data.semi_major_dev); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Semi-minor Dev:\t\t[ %.01f ]\n\r", pData->gpgst_data.semi_minor_dev); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Semi-maior Angle:\t\t[ %.01f ]\n\r", pData->gpgst_data.semi_major_angle); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Lat Err Dev:\t\t[ %.01f ]\n\r", pData->gpgst_data.lat_err_dev); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Lon Err Dev:\t\t[ %.01f ]\n\r", pData->gpgst_data.lon_err_dev); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Alt Err Dev:\t\t[ %.01f ]\n\r", pData->gpgst_data.alt_err_dev); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); // sprintf(msg,"ID - Checksum:\t\t[ *%x ]\n\r", // pData->gpgst_data.checksum); -// TESEO_APP_LOG_INFO(msg); +// TESEO_GNSS_LOG("%s", msg); - TESEO_APP_LOG_INFO("\n\n\r"); + TESEO_GNSS_LOG("\n\n\r"); return; } @@ -214,54 +212,54 @@ { // char msg[256]; - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); sprintf(msg, "UTC:\t\t\t\t[ %02d:%02d:%02d ]\n\r", pData->gprmc_data.utc.hh, pData->gprmc_data.utc.mm, pData->gprmc_data.utc.ss); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Status:\t\t\t\t[ %c ]\t\t", pData->gprmc_data.status); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); if (pData->gprmc_data.status == 'A') { - TESEO_APP_LOG_INFO("-- Valid (reported in 2D and 3D fix conditions)\n\r"); + TESEO_GNSS_LOG("-- Valid (reported in 2D and 3D fix conditions)\n\r"); } else if (pData->gprmc_data.status == 'V') { - TESEO_APP_LOG_INFO("-- Warning (reported in NO FIX conditions)\n\r"); + TESEO_GNSS_LOG("-- Warning (reported in NO FIX conditions)\n\r"); } else { - TESEO_APP_LOG_INFO("-- Unknown status\n\r"); + TESEO_GNSS_LOG("-- Unknown status\n\r"); } sprintf(msg,"Latitude:\t\t\t[ %.0f' %02d'' %c ]\n\r", ((pData->gprmc_data.xyz.lat - ((int)pData->gprmc_data.xyz.lat % 100))) / 100, ((int)pData->gprmc_data.xyz.lat % 100), pData->gprmc_data.xyz.ns); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Longitude:\t\t\t[ %.0f' %02d'' %c ]\n\r", ((pData->gprmc_data.xyz.lon - ((int)pData->gprmc_data.xyz.lon % 100))) / 100, ((int)pData->gprmc_data.xyz.lon % 100), pData->gprmc_data.xyz.ew); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Speed over ground (knots):\t[ %.01f ]\n\r", pData->gprmc_data.speed); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Trackgood:\t\t\t[ %.01f ]\n\r", pData->gprmc_data.trackgood); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Date (ddmmyy):\t\t\t[ %d ]\n\r", pData->gprmc_data.date); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Magnetic Variation:\t\t[ %.01f ]\n\r", pData->gprmc_data.mag_var); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); if (pData->gprmc_data.mag_var_dir != 'E' && pData->gprmc_data.mag_var_dir != 'W') { @@ -271,13 +269,13 @@ sprintf(msg,"Magnetic Var. Direction:\t[ %c ]\n\r", pData->gprmc_data.mag_var_dir); } - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); // sprintf(msg,"Checksum:\t\t[ *%x ]\n\r", // pData->gprmc_data.checksum); -// TESEO_APP_LOG_INFO(msg); +// TESEO_GNSS_LOG("%s", msg); - TESEO_APP_LOG_INFO("\n\n\r"); + TESEO_GNSS_LOG("\n\n\r"); return; } @@ -292,74 +290,74 @@ { // char msg[256]; - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); sprintf(msg, "Constellation:\t\t[ %s ]\t", pData->gsa_data.constellation); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); if (strcmp(pData->gsa_data.constellation, "$GPGSA") == 0) { - TESEO_APP_LOG_INFO("-- only GPS constellation is enabled\n\r"); + TESEO_GNSS_LOG("-- only GPS constellation is enabled\n\r"); } else if (strcmp(pData->gsa_data.constellation, "$GLGSA") == 0) { - TESEO_APP_LOG_INFO("-- only GLONASS constellation is enabled\n\r"); + TESEO_GNSS_LOG("-- only GLONASS constellation is enabled\n\r"); } else if (strcmp(pData->gsa_data.constellation, "$GAGSA") == 0) { - TESEO_APP_LOG_INFO("-- only GALILEO constellation is enabled\n\r"); + TESEO_GNSS_LOG("-- only GALILEO constellation is enabled\n\r"); } else if (strcmp(pData->gsa_data.constellation, "$BDGSA") == 0) { - TESEO_APP_LOG_INFO("-- only BEIDOU constellation is enabled\n\r"); + TESEO_GNSS_LOG("-- only BEIDOU constellation is enabled\n\r"); } else if (strcmp(pData->gsa_data.constellation, "$GNGSA") == 0) { - TESEO_APP_LOG_INFO("-- more than one constellation is enabled\n\r"); + TESEO_GNSS_LOG("-- more than one constellation is enabled\n\r"); } sprintf(msg, "Operating Mode:\t\t[ %c ]\t\t", pData->gsa_data.operating_mode); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); if (pData->gsa_data.operating_mode == 'A') { - TESEO_APP_LOG_INFO("-- Auto (2D/3D)\n\r"); + TESEO_GNSS_LOG("-- Auto (2D/3D)\n\r"); } else if (pData->gsa_data.operating_mode == 'M') { - TESEO_APP_LOG_INFO("-- Manual\n\r"); + TESEO_GNSS_LOG("-- Manual\n\r"); } sprintf(msg,"Current Mode:\t\t[ %d ]\t\t", pData->gsa_data.current_mode); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); if (pData->gsa_data.current_mode == 1) { - TESEO_APP_LOG_INFO("-- no fix available\n\r"); + TESEO_GNSS_LOG("-- no fix available\n\r"); } else if (pData->gsa_data.current_mode == 2) { - TESEO_APP_LOG_INFO("-- 2D\n\r"); + TESEO_GNSS_LOG("-- 2D\n\r"); } else if (pData->gsa_data.current_mode == 3) { - TESEO_APP_LOG_INFO("-- 3D\n\r"); + TESEO_GNSS_LOG("-- 3D\n\r"); } for (uint8_t i=0; i<12; i++) { sprintf(msg,"SatPRN%02d:\t\t[ %d ]\n\r", i+1, pData->gsa_data.sat_prn[i]); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); } sprintf(msg,"PDOP:\t\t\t[ %.01f ]\n\r", pData->gsa_data.pdop); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"HDOP:\t\t\t[ %.01f ]\n\r", pData->gsa_data.hdop); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"VDOP:\t\t\t[ %.01f ]\n\r", pData->gsa_data.vdop); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); // sprintf(msg,"ID - Checksum:\t\t[ *%x ]\n\r", // pData->gsa_data.checksum); -// TESEO_APP_LOG_INFO(msg); +// TESEO_GNSS_LOG("%s", msg); - TESEO_APP_LOG_INFO("\n\n\r"); + TESEO_GNSS_LOG("\n\n\r"); } @@ -377,66 +375,66 @@ char degree_sym = 248; - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); sprintf(msg, "Constellation:\t\t[ %s ]\t", pData->gsv_data.constellation); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); if (strcmp(pData->gsv_data.constellation, "$GPGSV") == 0) { - TESEO_APP_LOG_INFO("-- message to report all GPS satellites\n\r"); + TESEO_GNSS_LOG("-- message to report all GPS satellites\n\r"); } else if (strcmp(pData->gsv_data.constellation, "$GLGSV") == 0) { - TESEO_APP_LOG_INFO("-- message to report all GLONASS satellites\n\r"); + TESEO_GNSS_LOG("-- message to report all GLONASS satellites\n\r"); } else if (strcmp(pData->gsv_data.constellation, "$GAGSV") == 0) { - TESEO_APP_LOG_INFO("-- message to report all GALILEO satellites\n\r"); + TESEO_GNSS_LOG("-- message to report all GALILEO satellites\n\r"); } else if (strcmp(pData->gsv_data.constellation, "$BDGSV") == 0) { - TESEO_APP_LOG_INFO("-- message to report all BEIDOU satellites\n\r"); + TESEO_GNSS_LOG("-- message to report all BEIDOU satellites\n\r"); } else if (strcmp(pData->gsv_data.constellation, "$QZGSV") == 0) { - TESEO_APP_LOG_INFO("-- message to report all QZSS satellites\n\r"); + TESEO_GNSS_LOG("-- message to report all QZSS satellites\n\r"); } else if (strcmp(pData->gsv_data.constellation, "$GNGSV") == 0) { - TESEO_APP_LOG_INFO("-- message to report all satellites for all enabled constellations\n\r"); + TESEO_GNSS_LOG("-- message to report all satellites for all enabled constellations\n\r"); } /* debug */ // sprintf(msg,"Tot Messages:\t\t[ %d ]\n\r", // ((tTeseoData *)(handle->pData))->gsv_data.amount); -// TESEO_APP_LOG_INFO(msg); +// TESEO_GNSS_LOG("%s", msg); // // sprintf(msg,"Message Num:\t\t[ %d ]\n\r", // ((tTeseoData *)(handle->pData))->gsv_data.number); -// TESEO_APP_LOG_INFO(msg); +// TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Num of Satellites:\t[ %d ]\n\r", tot_sats); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); - TESEO_APP_LOG_INFO("\n\r"); + TESEO_GNSS_LOG("\n\r"); for (i=0; i<tot_sats; i++) { sprintf(msg,"Sat%02dPRN:\t\t[ %03d ]\n\r", i+1, pData->gsv_data.gsv_sat_i[i].prn); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Sat%02dElev (%c):\t\t[ %03d ]\n\r", i+1, degree_sym, pData->gsv_data.gsv_sat_i[i].elev); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Sat%02dAzim (%c):\t\t[ %03d ]\n\r", i+1, degree_sym, pData->gsv_data.gsv_sat_i[i].azim); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); sprintf(msg,"Sat%02dCN0 (dB):\t\t[ %03d ]\n\r", i+1, pData->gsv_data.gsv_sat_i[i].cn0); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); - TESEO_APP_LOG_INFO("\n\r"); + TESEO_GNSS_LOG("\n\r"); } - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); } @@ -450,24 +448,24 @@ { // char msg[256]; - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); if(pData->geofence_data.op == GNSS_FEATURE_EN_MSG) { sprintf(msg, "Geofence Enabling:\t\t[ %s ]\t", pData->geofence_data.result ? "ERROR" : "OK"); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); } if(pData->geofence_data.op == GNSS_GEOFENCE_CFG_MSG) { sprintf(msg, "Geofence Configuration:\t\t[ %s ]\t", pData->geofence_data.result ? "ERROR" : "OK"); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); } if(pData->geofence_data.op == GNSS_GEOFENCE_STATUS_MSG) { sprintf(msg, "Geofence Status:\t\t[ %s ]\t", pData->geofence_data.result ? "ERROR" : "OK"); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); if(pData->geofence_data.result == 0) { - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); sprintf(msg, "Time/Date:\t\t%02d:%02d:%02d %02d/%02d/%04d\n", pData->geofence_data.timestamp.hh, pData->geofence_data.timestamp.mm, @@ -475,33 +473,33 @@ pData->geofence_data.timestamp.day, pData->geofence_data.timestamp.month, pData->geofence_data.timestamp.year); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); for(uint8_t i = 0; i<MAX_GEOFENCES_NUM; i++) { sprintf(msg, "Position circle[%d]:\t%s\n", i, geofenceCirclePosition[pData->geofence_data.status[i]]); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); } } } if(pData->geofence_data.op == GNSS_GEOFENCE_ALARM_MSG) { sprintf(msg, "Geofence Alarm:\t\t[ %s ]\t", pData->geofence_data.result ? "ERROR" : "OK"); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); if(pData->geofence_data.result == 0) { - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); sprintf(msg, "Time:\t\t%02d:%02d:%02d\n", pData->geofence_data.timestamp.hh, pData->geofence_data.timestamp.mm, pData->geofence_data.timestamp.ss); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); int i = pData->geofence_data.idAlarm; sprintf(msg, "Position circle[%d]:\t%s\n", i, geofenceCirclePosition[pData->geofence_data.status[i]]); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); } } - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); } @@ -515,20 +513,20 @@ { // char msg[256]; - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); if(pData->odo_data.op == GNSS_FEATURE_EN_MSG) { sprintf(msg, "Odometer Enabling:\t\t[ %s ]\t", pData->odo_data.result ? "ERROR" : "OK"); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); } if((pData->odo_data.op == GNSS_ODO_START_MSG) || (pData->odo_data.op == GNSS_ODO_STOP_MSG)) { sprintf(msg, "Odometer Operation:\t\t[ %s ]\t", pData->odo_data.result ? "ERROR" : "OK"); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); } - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); } @@ -542,34 +540,34 @@ { // char msg[256]; - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); if(pData->datalog_data.op == GNSS_FEATURE_EN_MSG) { sprintf(msg, "Datalog Enabling:\t\t[ %s ]\t", pData->datalog_data.result ? "ERROR" : "OK"); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); } if(pData->datalog_data.op == GNSS_DATALOG_CFG_MSG) { sprintf(msg, "Datalog Configuring:\t\t[ %s ]\t", pData->datalog_data.result ? "ERROR" : "OK"); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); } if(pData->datalog_data.op == GNSS_DATALOG_START_MSG) { sprintf(msg, "Datalog Start:\t\t[ %s ]\t", pData->datalog_data.result ? "ERROR" : "OK"); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); } if(pData->datalog_data.op == GNSS_DATALOG_STOP_MSG) { sprintf(msg, "Datalog Stop:\t\t[ %s ]\t", pData->datalog_data.result ? "ERROR" : "OK"); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); } if(pData->datalog_data.op == GNSS_DATALOG_ERASE_MSG) { sprintf(msg, "Datalog Erase:\t\t[ %s ]\t", pData->datalog_data.result ? "ERROR" : "OK"); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); } - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); } @@ -583,13 +581,13 @@ { // char msg[256]; - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); sprintf(msg, "Msg List config:\t\t[ %s ]\t", pData->ack ? "ERROR" : "OK"); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); } /** @@ -602,13 +600,13 @@ { // char msg[256]; - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); sprintf(msg, "Params configuration:\t\t[ %s ]\t", pData->ack ? "ERROR" : "OK"); - TESEO_APP_LOG_INFO(msg); + TESEO_GNSS_LOG("%s", msg); - TESEO_APP_LOG_INFO("\r\n"); + TESEO_GNSS_LOG("\r\n"); } void @@ -617,7 +615,7 @@ switch (msgId) { case LOC_OUTPUT_LOCATION: { // Output last location - TESEO_APP_LOG_INFO("Loc: lat=%lf, lon=%lf, alt=%f\r\n", pData->gpgga_data.xyz.lat, pData->gpgga_data.xyz.lon, pData->gpgga_data.xyz.alt); + TESEO_GNSS_LOG("Loc: lat=%lf, lon=%lf, alt=%f\r\n", pData->gpgga_data.xyz.lat, pData->gpgga_data.xyz.lon, pData->gpgga_data.xyz.alt); break; } case LOC_OUTPUT_NMEA: { @@ -695,16 +693,16 @@ switch (event) { case TESEO_LOC_EVENT_START_RESULT: if (data != 0) { - TESEO_APP_LOG_INFO("start failed.\r\n"); + TESEO_GNSS_LOG("start failed.\r\n"); } else { - TESEO_APP_LOG_INFO("start OK.\r\n"); + TESEO_GNSS_LOG("start OK.\r\n"); } break; case TESEO_LOC_EVENT_STOP_RESULT: if (data != 0) { - TESEO_APP_LOG_INFO("stop failed.\r\n"); + TESEO_GNSS_LOG("stop failed.\r\n"); } else { - TESEO_APP_LOG_INFO("stop OK.\r\n"); + TESEO_GNSS_LOG("stop OK.\r\n"); } break; default:
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mbed_lib.json Thu Jan 14 09:29:14 2021 +0000 @@ -0,0 +1,9 @@ +{ + "name": "teseo", + "config": { + "trace-enabled": { + "value": true, + "help": "Teseo trace utility" + } + } +} \ No newline at end of file