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.
- 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 theuGnssDec
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.
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.
For this example, in addition to the GNSS settings above, you must pass the conditional compilation flag U_CFG_GEOFENCE
into your build.
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).