Skip to content

Commit

Permalink
examples: zephyr: location: wifi: add README
Browse files Browse the repository at this point in the history
Signed-off-by: Marcin Niestroj <[email protected]>
  • Loading branch information
mniestroj committed Jan 10, 2025
1 parent 8a08831 commit a0996d7
Showing 1 changed file with 210 additions and 0 deletions.
210 changes: 210 additions & 0 deletions examples/zephyr/location/wifi/README.md
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)
```

0 comments on commit a0996d7

Please sign in to comment.