These examples demonstrate how to establish location in three different configurations:
- locally using a GNSS chip that is attached directly to this MCU (main_loc_gnss.c),
- as above but continuously to a callback (main_loc_gnss_continuous.c),
- locally using a GNSS chip that is attached via a cellular module (main_loc_gnss_cell.c),
- as above but continuously to a callback (main_loc_gnss_cell_continuous.c),
- using cloud services such as Cell Locate via a cellular [and in future Wi-Fi] module (main_loc_cell_locate.c and main_loc_gnss_cloud_locate.c); the latter Cloud Locate service is focussed on applications where the cloud needs to know the position of the device but the device itself does not.
IMPORTANT: there will likely be modifications to this API as we introduce more location-type services, beware!
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 exampleLoc
(noting that NO quotation marks should be included) to run just these examples, as opposed to all the examples and unit tests.
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 main_loc_gnss.c, main_loc_gnss_cell.c and main_loc_cell_locate.c before compiling.
If you have a GNSS chip attached directly to this MCU then you can run the main_loc_gnss.c/main_loc_gnss_continuous.c examples and the following values should be set.
U_CFG_TEST_GNSS_MODULE_TYPE
: consult u_gnss_type.h to determine the type name for the GNSS module you intend to use. For instance, to use an M8 module you would set U_CFG_TEST_GNSS_MODULE_TYPE
to U_GNSS_MODULE_TYPE_M8
.
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").
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. For a UART the default is usually acceptable while for I2C and SPI we usually set our default value to -1 and so you must set a value yourself: consult the file port/platform/<platform>/mcu/<mcu>/cfg/cfg_hw_platform_specific.h
for options.
You will also need an antenna connected to the GNSS chip.
If you have a GNSS chip attached via a cellular module then you can run the main_loc_gnss_cell.c/main_loc_gnss_cell_continuous.c examples and the following values should be set. Note, however, that Cell Locate will in fact make use of a GNSS chip attached via a cellular module as well and hence it may be simpler to use the main_loc_cell_locate.c example unless you want to take control of, for instance, the configuration of the GNSS chip, yourself or you need a relatively high (e.g. each second) location rate.
U_CFG_TEST_GNSS_MODULE_TYPE
: consult u_gnss_type.h to determine the type name for the GNSS module you intend to use. For instance, to use an M8 module you would set U_CFG_TEST_GNSS_MODULE_TYPE
to U_GNSS_MODULE_TYPE_M8
.
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 U_CELL_MODULE_TYPE_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.
If you do not have a GNSS chip you may establish approximate location (e.g. within a kilometre) via a cellular module using the Cell Locate service as shown in the main_loc_cell_locate.c example.
For this example the settings of the GNSS Cellular Example above must be followed and then in addition:
U_CFG_APP_CELL_LOC_AUTHENTICATION_TOKEN
: must be set to a valid authentication token for the u-blox Cell Locate service, obtainable from your Thingstream portal, noting that NO quotation marks should be included.
U_CFG_TEST_CELL_LOCATE
must be defined to include the body of the main_loc_cell_locate.c in your build.
You will need a SIM in your board, a cellular antenna connected and you may need to know the APN associated with the SIM (though accepting the network default often works).
You may take advantage of positioning assistance information known to u-blox servers by using the u-blox Cloud Locate service with your GNSS chip, as shown in the main_loc_gnss_cloud_locate.c example. This example assumes a cellular module that includes a GNSS module inside it, e.g. SARA-R5180M8S or SARA-R422M8S.
First, you must log-in to your Thingstream account and, under Location Services, add a Cloud Locate thing (if you don't already have one). The thing will have a set of credentials associated with it; client ID, username and password. Edit main_loc_gnss_cloud_locate.c to put these credentials into the MY_THINGSTREAM_CLIENT_ID
, MY_THINGSTREAM_USERNAME
and MY_THINGSTREAM_PASSWORD
conditional compilation flags respectively.
Then perform the settings of the GNSS Cellular Example above.
You will need a SIM in your board, a cellular antenna connected and you may need to know the APN associated with the SIM (though accepting the network default often works).