Skip to content

Latest commit

 

History

History
332 lines (199 loc) · 17.3 KB

CELLULAREXPLORER.md

File metadata and controls

332 lines (199 loc) · 17.3 KB

Zephyr logo

Zephyr - Coaps Demo Client with TinyDtls

** !!! Under Construction !!! **

Cellular Explorer

The Nordic Semiconductor, Thingy:91 comes with an Bluetooth Low Energy interface, that allows to connect the Thingy:91 to a smartphone and send locally commands to the Thingy:91. That helps to analyze network situations even without valid cellular connectivity of your SIM card. Thingy:91
The Circuit Dojo, nRF9160 feather v5 comes with a USB-C plug and if the smartphone is also equipped with USB-C, a simple USB-C to USB-C wire will do it. nRF9160-feather-v5

In the wild, the Bluetooth Low Energy interface is really very comfortable. If your device has only USB, that works also well, but is less comfortable. For some more sophisticated tests, e.g. adapting some lists on the SIM card, it may be easier to use a PC via a USB serial as well.

In order to enable this function, the uart-prj.conf must be used to build the app.

Enable Bluetooth Low Energy on a Thingy:91

If you connect the Thingy:91 via USB to your PC, a "local USB drive" pops up.

local USB drive.

Edit the "Config.txt" file.

==========================================
  Nordic Thingy:91 Configuration options
==========================================
The parameters below can be changed at runtime.

NOTE: For changes to take effect,
safely disconnect (unmount) the drive and disconnect the USB cable.
==========================================
BLE_ENABLED=1
BLE_NAME=Thingy:91-2 UART

Enable BLE by changing the BLE_ENABLED=0 to BLE_ENABLED=1. Also consider to change the BLE_NAME=Thingy:91 UART to a rather unique name. Save your changes. When done, unmount the "local USB drive" and disconnect the USB cable.

Smartphone App

In order to communication with the Thingy:91 via Bluetooth Low Energy you need a App which supports the Nordic BLE UART service.

{#android} For Android the "Serial Bluetooth Terminal 1.43" from Kai Morich works very well.

For iOS the "Bluefruit Connect" works.

If you want to use the USB serial, the "Serial USB Terminal 1.43" from Kai Morich works also very well for Android.

Install the App and connect the Thingy:91.

PC Software

If you want to use a PC to communicate with the device via the USB serial interface, you will need a serial terminal to do so. For Microsoft Windows Tera Term works well, for Linux gtkterm is a good choice.

Both applications requires a proper configuration. Generally select the right serial port (or test both), a baudrate of 115200, 8 data bits, no parity, 1 stop bit.

Usage

The most nRF9160 AT-commands or nRF91x1 AT-commands are supported. Additionally some shortcuts and extra functions are available as custom commands. For simple usage, these custom commands uses simple characters and digits, instead of control characters as '+', '%' or '='. Type help and press the "send button" arrow:

help

(The screenshot shows only the list of commands in August 2023, the current list contains the current list of commands.)

If the smart phone App offers macros, add you favorite AT-commands or commands as macro.

Explore the Cellular Network

Hopefully in the most areas the device should be able to connect to the network and to exchange data with the cloud. To test that, type send and press the "send button" arrow:

send

If that doesn't work or if you want to see, which cellular networks are available at your location, then type scan and press the "send button" arrow

The displayed list of networks will vary. As default, scan measure the currently already known channels. If you want to search for new channels, provide additional parameters. For such cases, a command comes also with a specific help. Type help scan and press the "send button" arrow (see screenshot above).

To perform a scan with searching for new channels, use scan 5 <n> where n is the maximum expected number of networks. It will take a while. The provided parameters will become the new default. if you decide to use scan 5 6, the next execution of scan will also use these parameters.

search

In some case you may get aware, that your modem connects to a network with less signal strenght than other available networks. With the net command you see, to which provider (the PLMN) the device is connected and which technology is used, LTE-M or NB-IoT. If you want to test the communication with an other provider and/or switching the technology, use to con command. Also this command has a specific help.

help cfg

To switch the network operator (e.g. 26202) and technology (m1 or nb), use con 26202 m1.

cfg

that requires some time. If the network operator rejects your SIM, you need to con to an other network operator again.

Locating a Device

Sometimes it may be interesting to know the current location of the device. If the App doesn't use GPS, you still may be able to get a rough location using the base station as reference. There are several web-sites which offers a service for that. One service fro non-commercial usage is cellmapper.

You will need the PLMN and the tower code (Cell devided by 256), e.g. PLMN 24008 and Cell 28609803 resulting in 111757. Open the cellmapper and first set the PLMN using Menu -> Provider.

CellMapper - Provider

Then close the Provider Menu and open the Search Menu.

CellMapper - Search

enter the calculated tower number and press <return>. I dialog will show up and, if the position of the tower is available, the entry of that tower will be shown.

CellMapper - Search

Select the entry (eNB <tower number>) and a map will be opened showing the position of the base station.

Test Functions and Parameter of a Cellular Network

If you have connected the device with the provider and technology you want to investigate, you may check with net, which functions are supported.

> net

I 60.855: Network: CAT-M1,roaming,Band 20,PLMN 26202,TAC 47490,Cell 52262913,EARFCN 6300
I 60.855: PDN: flolive.net,100.64.55.203
I 60.856: PSM: TAU 90000 [s], Act 0 [s], AS-RAI, Released: 2015 ms
I 60.856: !CE: down: 8, up: 1, RSRP: -108 dBm, CINR: -3 dB, SNR: -2 dB
I 60.865: Stat: tx 1 kB, rx 0 kB, max 748 B, avg 155 B
I 60.865: Cell updates 3, Network searchs 2 (8 s), PSM delays 0 (0 s), Restarts 0
I 60.865: Wakeups 1, 1 s, connected 11 s, asleep 0 s
OK

Each line may starts with a level ('E'rror, 'W'arning, 'I'nfo, or 'D'ebug), which is sometimes usefull for development. If the lines shows a 'b'usy, then the mode is currently executing a command and will reject further commands. After that level a relative time follows with seconds and milliseconds, e.g. "60.856".

That is followed by text, which explains itself a lot. E.g. CAT-M1, roaming, PLMN and so on.

For energy saving three function are available for cellular devices:

Mode Description
RAI Release Assistance Indication Indicates to switch from RRC active to idle earlier than using a timeout
eDRX Extended Discontinuous Reception Used in RRC idle mode to reduce power consumption. Usually seconds to a couple of minutes
PSM Power Saving Mode Enables the device to go from idle into deep sleep. Usually hours or a couple of days

rai Command

The device usually tries to request RAI support. If not available, then the timeout is used. Therefore rai is always enabled and if supported, the net command shows that in the PSM information.

I 60.856: PSM: TAU 90000 [s], Act 0 [s], AS-RAI, Released: 2015 ms

In this case, AS-RAI (Access Stratum RAI) is supported from LTE-M network provider.

To disble RAI for tests, you may use

rai off

and with

rai on

RAI is requested again.

edrx Command

To request or disable eDRX, use the edrx command:

edrx 600

requests eDRX with about 600s. Only selected values are supported, the network will assign the next larger value, in this case 655s.

I 14.984: eDRX enable, 655.36 s
edrx off

disables eDRX again.

psm Command

To request or disable PSM, the psm command is used.

I 78.096: > help psm:
I 78.096:   psm <act-time> <tau-time>[h] : request PSM times.
I 78.096:      <act-time>    : active time in s.
I 78.096:      <tau-time>    : tracking area update time in s.
I 78.096:      <tau-time>h   : tracking area update time in h.
I 78.096:   psm normal       : PSM handled by application.
psm 10 48h

requests psm with an active timeout of 10s and a tracking are update time of 48 hours or 2 days.

I 28.595: PSM enable, act: 10 s, tau: 50 h
...
I 29.265: PSM parameter update: TAU: 180000 s, Active time: 10 s

Also here, not all values are available and the next larger one is used.

psm normal

Switches the back to the application specific PSM parameters.

Firmware update Command

To update the application firmware, you classically have two options:

The downside of both options is, that you need to open the cover. For the McuBoot via USB serial you also need to start the device on the bootloader mode pressing and holding SW3 during switching on the power with SW1.

To simplify that process, that Cellular Explorer comes with an update command.

In order to use it, you need:

  • the application binary (the app_update.bin in the <build>/zephyr folder. The file is next to the app_signed.hex, which is used for the Nordic nRF Connect for Desktop / Programmer).
  • a serial terminal with XMODEM or XMODEM 1k support.
  • If a Thingy:91 is used, please update the nRF52840 to version thingy91_nrf52_connectivity_bridge_2023-03-02_8f26142b.hex or newer. Some older version show some instability which may break the file transfer. Caused by that, the transfers stucks and breaks the transmission from the Thingy:91 to your smartphone. You will even not see further messages from the Thingy:91 and a power on restart gets required. The thingy91_nrf52_connectivity_bridge is part of the Precompiled application and modem firmware package and can be downloaded from Nordic-Thingy-91/Download.

For Android both Serial Terminal 1.43 from Kai Morich are supporting XMODEM and may be used to update the firmware. That even works over Bluetooth Low Energy.

For Microsoft Windows Tera Term supports XMODEM, for Linux gtkterm and the unix sx shell command will do it.

Firmware update with Android

The update is started using the update command.

start update

This starts to erase the second flash slot to prepare that for the new application firmware. This takes about 10s and gives the time to start the XMODEM file transfer on the smartphone or PC.

For Serial Terminal 1.43 select the menu on the upper left, next to the trash can (see red rectangle in the screenshoot below) and then the "Upload File" submenu. The file dialog appears.

start xmodem

Select Xmodem 1k as protocol and the app_update.bin as file. Press OK and the file upload will start, when the 10 seconds are over.

update ready

Sometimes the 10 seconds are too short to select the file. Then just open the file dialog via the menu and "Upload File" submenu. Select the file at rest and choose the Xmodem 1k as protocol. Press OK and then CANCEL in the "Upload File" field, which appears at the top below the tools-line. That will set this values as default and the next time the file dialog is shown you may just press OK.

During the upload the Serial Terminal 1.43 shows some ^F indicating the progress. Finally, when all succeeds, the device reboots to apply the update. The reboot will take a while copying the firmware from the download slot to the active slot and the old firmware to that download slot. After that the device continues to start the new application firmware. To prevent the device from being bricked, the device verifies the application firmware with the first successful data exchange. If the device reboots again before that, the old firmware is actived again. For that, don't apply a firmware update with low network coverage.

Firmware update with Linux

Updating the firmware with linux is tricky. It requires two applications, gtkterm and the unix sx shell command. Both will access the serial device, e.g. "/dev/ttyACM0".

Connect the device via USB. Then start the gtkterm and open the "Configuration/Port" dialog.

gtkterm_serial_configuration

Select the serial port the device is connected to and also 115200 as "Baud Rate". Close the dialog again. Then select "Configuration/Local Echo" and "Configuration/CR-LF-Automatic". Test the configuration with the command "at" ot "dev".

gtkterm

Then open a command shell on the linux PC. Prepare to start the xmodem application with:

sx -k build_nrf9160dk_nrf9160_ns/zephyr/app_update.bin < /dev/ttyACM0 > /dev/ttyACM0

-k enables to use blocks with 1024 bytes instead of 128 bytes. The path to the "app_update.bin" follows. To use the serial/USB connecion redirect stdout/stdin with < /dev/ttyACM0 > /dev/ttyACM0. For other device a different serial interface may be required, e.g. /dev/ttyUSB0 for a nRF9160 feather.

sx -k build_feather_nrf9160_ns/zephyr/app_update.bin < /dev/ttyUSB0 > /dev/ttyUSB0

Once sx executes, the gtkterm must not be used, because that may cause conflicts on the serial device. Therefore first start the update on the device in the gtkterm with update:

gtkterm update

and then within the 10s the sx command on the linux command shell.

sx -k build_nrf9160dk_nrf9160_ns/zephyr/app_update.bin < /dev/ttyACM0 > /dev/ttyACM0
Sende build_nrf9160dk_nrf9160_ns/zephyr/app_update.bin, 2395 Blöcke:Starten Sie nun Ihr XMODEM-Empfangsprogramm.
Ymodem Sektoren/Kilobytes gesendet: 1928/241k

When the transfer starts, sx will report the progress and also when finished. And the device will report "ready" as well.

gtkterm update ready

Firmware update with Microsoft Windows

For Microsoft Windows Tera Term works well for comands and updates. First configure the "Serial port", select the menu "Setup" and "Serial port ..." there.

teraterm menu "Setup" -> "Serial port ..."

The serial port setup dialog appears. Select 115200 as baudrate and the COM port ( you may test both to see which is the right one).

teraterm "Serial port"

Test the serial communication by typing "at" and <return>.

teraterm test

If the device responds with ">at OK" as above, the communication works. If none of both COM port works, you may check the "Terminal setup" and select "Local echo" and adapt the "New-line" settings.

teraterm "Serial port"

If that works, it's recommended to prepare for the XMODEM file transfer before actually executing the update. Select in the menu "File", "Transfer", "XMOMDEM" and "Send ...".

teraterm transfer

The file select dialog appears. Check the "1K" Option and select the file to update. You will need the "build/zephyr/app_update.bin" file. Chose that and "cancel".

teraterm file dialog

Now type "update" in the terminal, the device will report that the update will start in 10s. Chose again "File", "Transfer", "XMOMDEM" and "Send ...", select the "app_update.bin" and start the transfer pressing "open. A progress dialog appears and when the transfer finished, the device will reboot and apply the update.

teraterm file transfer

** !!! Under Construction !!! **