Skip to content

Latest commit

 

History

History
 
 

gnss

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Introduction

These directories provide examples that are specific to u-blox GNSS chips, e.g. NEO-M8, ZED-F9P etc. They are relevant if you are just using GNSS (i.e. not cellular or WiFi/BLE) and all you want to do is configure the GNSS device and exchange message of your choice with it.

Example

  • cfg_val_main.c contains an example of how to configure a GNSS chip using the uGnssCfgValXxx() API which can be found in u_gnss_cfg.h; note that this API is supported ONLY on M9 modules and later, not on M8 modules; for M8 modules there are simple configuration/information APIs in u_gnss_cfg.h/u_gnss_info.h that need no examples.
  • msg_main.c contains an example of how to exchange messages of your choice with a GNSS chip that is connected directly to this MCU, i.e. not via an intermediate [cellular] module. It uses the uGnssMsg API which can be found in u_gnss_msg.h.
  • dec_main.c contains an example of how to decode messages of your choice, messages not otherwise accessible from ubxlib, from a GNSS chip. It uses the uGnssDec API which can be found in u_gnss_dec.h.
  • pos_main.c contains an example of how to obtain streamed position fixes from a GNSS chip. It uses the uGnssPos API which can be found in u_gnss_pos.h.
  • assist_now_main.c contains an example of how achieve a faster time to first fix by using the u-blox AssistNow services. It uses the uGnssMga API which can be found in u_gnss_mga.h.
  • geofence_main.c contains an example of how to use the common geofence API with a GNSS chip; the conditional compilation flag U_CFG_GEOFENCE MUST be passed into your build for this exampe to do anything useful. Note that the same common geofence API can be used with cellular (CellLocate) and Wi-Fi (Google, Skyhook and Here). ZEPHYR USERS should note that the Zephyr minimal C library is NOT sufficient to build this example: maths functions are required and hence newlib MUST be used.

Usage: cfg_val_main.c, msg_main.c, dec_main.c And pos_main.c

To build and run these examples on a supported platform you need to travel down into the port/platform/<platform>/mcu/<mcu> directory of your choice and find the runner build. The instructions there will tell you how to set/override defines. The following #defines are relevant:

U_CFG_APP_FILTER: set this to exampleGnss (noting that NO quotation marks should be included) to run just these examples, as opposed to all the examples and unit tests.

U_CFG_TEST_GNSS_MODULE_TYPE: consult u_gnss_module_type.h to determine the type name for the GNSS chip you intend to use. For instance, to use a ZED-F9P you would set U_CFG_TEST_GNSS_MODULE_TYPE to U_GNSS_MODULE_TYPE_M9.

U_CFG_APP_GNSS_UART / U_CFG_APP_GNSS_I2C/ U_CFG_APP_GNSS_SPI: this sets the internal HW block that your chosen MCU will use to talk to the GNSS module. The default from the file port/platform/<platform>/mcu/<mcu>/cfg/cfg_app_platform_specific.h may be acceptable; if you wish to change it then consult the specification for your MCU and the file port/platform/<platform>/mcu/<mcu>/cfg/cfg_hw_platform_specific.h for other options.

For the remainder of the #defines you may either override their values in the same way or, if you are only running these examples, you may edit the values directly in the example source files before compiling.

U_CFG_APP_PIN_GNSS_xxx: the default values for the MCU pins connecting your GNSS module to your MCU are #defined in the file port/platform/<platform>/mcu/<mcu>/cfg/cfg_app_platform_specific.h. You should check if these are correct for your board and, if not, override the values of the #defines (where -1 means "not connected").

You will also need an antenna connected to the GNSS chip.

Usage: geofence_main.c

For this example, in addition to the GNSS settings above, you must pass the conditional compilation flag U_CFG_GEOFENCE into your build.

Usage: assist_now_main.c

For this example, in addition to the GNSS settings above, you will need a means of sending a HTTP request to a u-blox server. The example assumes you will do this using the uHttpClient with a cellular module.

U_CFG_APP_GNSS_ASSIST_NOW_AUTHENTICATION_TOKEN: must be set to a valid authentication token for the u-blox AssistNow service, obtainable from your Thingstream portal, noting that NO quotation marks should be included.

U_CFG_TEST_GNSS_ASSIST_NOW must be defined to include the body of the assist_now_main.c in your build.

U_CFG_TEST_CELL_MODULE_TYPE: consult u_cell_module_type.h to determine the type name for the cellular module you intend to use. For instance, to use SARA-R5 you would set U_CFG_TEST_CELL_MODULE_TYPE to CELL_CFG_MODULE_SARA_R5.

U_CFG_APP_PIN_CELL_xxx: the default values for the MCU pins connecting your cellular module to your MCU are #defined in the file port/platform/<platform>/mcu/<mcu>/cfg/cfg_app_platform_specific.h. You should check if these are correct for your board and, if not, override the values of the #defines (where -1 means "not connected").

U_CFG_APP_CELL_UART: this sets the internal HW UART block that your chosen MCU will use to talk to the cellular module. The default is usually acceptable but if you wish to change it then consult the file port/platform/<platform>/mcu/<mcu>/cfg/cfg_hw_platform_specific.h for other options.

Obviously you will need a SIM in your board, an antenna connected and you may need to know the APN associated with the SIM (though accepting the network default often works).