-
Notifications
You must be signed in to change notification settings - Fork 14
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
examples: zephyr: location: wifi: add README
Signed-off-by: Marcin Niestroj <[email protected]>
- Loading branch information
Showing
1 changed file
with
210 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,210 @@ | ||
# Golioth WiFi location demo | ||
|
||
## Overview | ||
|
||
This sample demonstrates how to connect to Golioth and get location | ||
using scanned WiFi networks. | ||
|
||
## Requirements | ||
|
||
* Golioth credentials | ||
* Network connectivity | ||
|
||
## Building and Running | ||
|
||
### Authentication specific configuration | ||
|
||
#### PSK based auth - Hardcoded | ||
|
||
Configure the following Kconfig options based on your Golioth | ||
credentials: | ||
|
||
* GOLIOTH_SAMPLE_PSK_ID - PSK ID of registered device | ||
* GOLIOTH_SAMPLE_PSK - PSK of registered device | ||
|
||
by adding these lines to configuration file (e.g. `prj.conf`): | ||
|
||
```cfg | ||
CONFIG_GOLIOTH_SAMPLE_PSK_ID="my-psk-id" | ||
CONFIG_GOLIOTH_SAMPLE_PSK="my-psk" | ||
``` | ||
|
||
#### PSK based auth - Runtime | ||
|
||
We provide an option for setting Golioth credentials through the Zephyr | ||
shell. This is based on the Zephyr Settings subsystem. | ||
|
||
Enable the settings shell by including the following configuration overlay | ||
file: | ||
|
||
```sh | ||
$ west build -- -DEXTRA_CONF_FILE=../../common/runtime_settings.conf | ||
``` | ||
|
||
Alternatively, you can add the following options to ``prj.conf``: | ||
|
||
```cfg | ||
CONFIG_GOLIOTH_SAMPLE_HARDCODED_CREDENTIALS=n | ||
CONFIG_FLASH=y | ||
CONFIG_FLASH_MAP=y | ||
CONFIG_NVS=y | ||
CONFIG_SETTINGS=y | ||
CONFIG_SETTINGS_RUNTIME=y | ||
CONFIG_GOLIOTH_SAMPLE_SETTINGS=y | ||
CONFIG_GOLIOTH_SAMPLE_WIFI_SETTINGS=y | ||
CONFIG_GOLIOTH_SAMPLE_SETTINGS_AUTOLOAD=y | ||
CONFIG_GOLIOTH_SAMPLE_SETTINGS_SHELL=y | ||
``` | ||
|
||
At runtime, configure PSK-ID and PSK using the device shell based on your | ||
Golioth credentials: | ||
|
||
```sh | ||
uart:~$ settings set golioth/psk-id <my-psk-id@my-project> | ||
uart:~$ settings set golioth/psk <my-psk> | ||
uart:-$ kernel reboot cold | ||
``` | ||
|
||
#### Certificate based auth | ||
|
||
Configure the following Kconfig options based on your Golioth | ||
credentials: | ||
|
||
* CONFIG_GOLIOTH_AUTH_METHOD_CERT - use certificate-based | ||
authentication | ||
* CONFIG_GOLIOTH_SAMPLE_HARDCODED_CRT_PATH - device certificate | ||
* CONFIG_GOLIOTH_SAMPLE_HARDCODED_KEY_PATH - device private key | ||
|
||
by adding these lines to configuration file (e.g. `prj.conf`): | ||
|
||
```cfg | ||
CONFIG_GOLIOTH_AUTH_METHOD_CERT=y | ||
CONFIG_GOLIOTH_SAMPLE_HARDCODED_CRT_PATH="keys/device.crt.der" | ||
CONFIG_GOLIOTH_SAMPLE_HARDCODED_KEY_PATH="keys/device.key.der" | ||
``` | ||
|
||
### Platform specific configuration | ||
|
||
#### Native Simulator | ||
|
||
This application has been built and tested with Native Simulator | ||
(native_sim). | ||
|
||
On your Linux host computer, open a terminal window, locate the source | ||
code of this sample application (i.e., `examples/zephyr/location/wifi`) | ||
and type: | ||
|
||
```console | ||
$ west build -b native_sim examples/zephyr/location/wifi | ||
$ west build -t run | ||
``` | ||
|
||
#### ESP32-DevKitC-WROVER | ||
|
||
Configure the following Kconfig options based on your WiFi AP | ||
credentials: | ||
|
||
- GOLIOTH_SAMPLE_WIFI_SSID - WiFi SSID | ||
- GOLIOTH_SAMPLE_WIFI_PSK - WiFi PSK | ||
|
||
by adding these lines to configuration file (e.g. `prj.conf`): | ||
|
||
```cfg | ||
CONFIG_GOLIOTH_SAMPLE_WIFI_SSID="my-wifi" | ||
CONFIG_GOLIOTH_SAMPLE_WIFI_PSK="my-psk" | ||
``` | ||
|
||
On your host computer open a terminal window, locate the source code of | ||
this sample application (i.e., `examples/zephyr/location/wifi`) and type: | ||
|
||
```console | ||
$ west build -b esp32_devkitc_wrover/esp32/procpu examples/zephyr/location/wifi | ||
$ west flash | ||
``` | ||
|
||
#### nRF52840 DK + ESP32-WROOM-32 | ||
|
||
This subsection documents using nRF52840 DK running Zephyr with | ||
offloaded ESP-AT WiFi driver and ESP32-WROOM-32 module based board (such | ||
as ESP32 DevkitC rev. 4) running WiFi stack. See [AT Binary | ||
Lists](https://docs.espressif.com/projects/esp-at/en/latest/AT_Binary_Lists/index.html) | ||
for links to ESP-AT binaries and details on how to flash ESP-AT image on | ||
ESP chip. Flash ESP chip with following command: | ||
|
||
```console | ||
esptool.py write_flash --verify 0x0 PATH_TO_ESP_AT/factory/factory_WROOM-32.bin | ||
``` | ||
|
||
Connect nRF52840 DK and ESP32-DevKitC V4 (or other ESP32-WROOM-32 based | ||
board) using wires: | ||
|
||
| nRF52840 DK | ESP32-WROOM-32 | ESP32-WROVER-32 | | ||
| ----------- | --------------- | ----------------| | ||
| P1.01 (RX) | IO17 (TX) | IO22 (TX) | | ||
| P1.02 (TX) | IO16 (RX) | IO19 (RX) | | ||
| P1.03 (CTS) | IO14 (RTS) | IO14 (RTS) | | ||
| P1.04 (RTS) | IO15 (CTS) | IO15 (CTS) | | ||
| P1.05 | EN | EN | | ||
| GND | GND | GND | | ||
|
||
Configure the following Kconfig options based on your WiFi AP | ||
credentials: | ||
|
||
* GOLIOTH_SAMPLE_WIFI_SSID - WiFi SSID | ||
* GOLIOTH_SAMPLE_WIFI_PSK - WiFi PSK | ||
|
||
by adding these lines to configuration file (e.g. `prj.conf` or | ||
`board/nrf52840dk_nrf52840.conf`): | ||
|
||
```cfg | ||
CONFIG_GOLIOTH_SAMPLE_WIFI_SSID="my-wifi" | ||
CONFIG_GOLIOTH_SAMPLE_WIFI_PSK="my-psk" | ||
``` | ||
|
||
On your host computer open a terminal window, locate the source code of | ||
this sample application (i.e., `examples/zephyr/location/wifi`) and type: | ||
|
||
```console | ||
$ west build -b nrf52840dk/nrf52840 examples/zephyr/location/wifi | ||
$ west flash | ||
``` | ||
|
||
### Sample output | ||
|
||
This is the output from the serial console: | ||
|
||
```console | ||
*** Booting Zephyr OS build v4.0.0-1-gb39d67f51986 *** | ||
[00:00:00.000,000] <inf> net_config: Initializing network | ||
[00:00:00.000,000] <inf> net_config: IPv4 address: 192.0.2.1 | ||
[00:00:00.000,000] <dbg> location_wifi_main: main: Start WiFi location sample | ||
[00:00:00.000,000] <inf> golioth_mbox: Mbox created, bufsize: 1848, num_items: 10, item_size: 168 | ||
[00:00:00.400,003] <inf> golioth_coap_client_zephyr: Golioth CoAP client connected | ||
[00:00:00.400,003] <inf> location_wifi_main: Golioth client connected | ||
[00:00:00.400,003] <inf> golioth_coap_client_zephyr: Entering CoAP I/O loop | ||
[00:00:00.580,002] <inf> location_wifi_main: 50.663974800 17.942322850 (32) | ||
[00:00:00.760,001] <inf> location_wifi_main: 50.664181170 17.942337360 (23) | ||
[00:00:01.170,001] <inf> location_wifi_main: 50.664464180 17.942332180 (22) | ||
[00:00:01.700,001] <inf> location_wifi_main: 50.665216090 17.942386110 (26) | ||
[00:00:02.190,001] <inf> location_wifi_main: 50.665924320 17.942342850 (17) | ||
[00:00:02.690,001] <inf> location_wifi_main: 50.666588620 17.942297690 (21) | ||
[00:00:03.180,001] <inf> location_wifi_main: 50.667436140 17.942253480 (25) | ||
[00:00:03.680,001] <inf> location_wifi_main: 50.667930110 17.942142910 (27) | ||
[00:00:04.170,001] <inf> location_wifi_main: 50.668083230 17.942170380 (33) | ||
[00:00:04.670,001] <inf> location_wifi_main: 50.669921000 17.948761000 (569) | ||
[00:00:05.170,001] <inf> location_wifi_main: 50.667979840 17.942204310 (36) | ||
[00:00:05.660,001] <inf> location_wifi_main: 50.665045000 17.947862000 (604) | ||
[00:00:06.170,001] <inf> location_wifi_main: 50.668312550 17.942551440 (31) | ||
[00:00:06.670,001] <inf> location_wifi_main: 50.668242700 17.942328220 (52) | ||
[00:00:07.170,001] <inf> location_wifi_main: 50.668386960 17.942680660 (46) | ||
[00:00:07.670,001] <inf> location_wifi_main: 50.668344030 17.943467020 (37) | ||
[00:00:08.180,001] <inf> location_wifi_main: 50.668361530 17.943982820 (50) | ||
[00:00:08.680,001] <inf> location_wifi_main: 50.668426910 17.945390790 (58) | ||
[00:00:09.170,001] <inf> location_wifi_main: 50.668490680 17.947672650 (43) | ||
[00:00:09.780,001] <inf> location_wifi_main: 50.668505260 17.947435020 (34) | ||
[00:00:10.160,001] <inf> location_wifi_main: 50.668612950 17.948811810 (71) | ||
[00:00:10.670,001] <inf> location_wifi_main: 50.668666040 17.948747050 (107) | ||
[00:00:11.270,001] <inf> location_wifi_main: 50.664927000 17.947822000 (593) | ||
``` |