Device SDK for Spotflow embedded observability platform.
This SDK provides a set of tools and libraries for Zephyr RTOS to send your logs to the Spotflow observability platform.
Device SDK is integrated with Zephyr as a module that contains the Spotflow logging backend that seamlessly integrates with the Zephyr logging subsystem.
Our solution was tested on the following Zephyr boards (more are coming soon):
We currently support Zephyr v4.1.0 and nRF Connect SDK v3.0.0, v3.0.1 and v3.0.2. For more information, check Spotflow or Spotflow documentation.
Register and get your Ingest key at Spotflow.
Follow the Quickstart guide that is available in our portal after registration.
Alternatively, you can check sample applications in the samples.
The device SDK is meant to be used as
a Zephyr module.
You can add it to your Zephyr project by adding the following line to your west.yml:
manifest:
projects:
- name: spotflow
path: modules/lib/spotflow
revision: main
url: https://github.com/spotflow-io/device-sdk---
title: Main log flow
---
flowchart LR
A[User Code] --> B[Zephyr RTOS]
B --> C[Spotflow Logging Backend]
C -- QoS 0 --> D[Spotflow Mqtt Broker]
D --> E[Spotflow Observability Platform]
Currently, the Spotflow backend uses MQTT QoS 0 only.
---
title: Spotflow Data Flow
---
flowchart LR
processor[Spotflow Backend Processor]
A[Zephyr logging] --> B[Spotflow Logging Backend]
B --> D[Encode CBOR]
D --> E[Log message Queue]
O[Extract Coredump] --> P[Coredumps Backend]
P[Coredumps Backend] --> Q[Encode CBOR]
Q --> R[Coredumps message Queue]
R --> processor
E --> processor
processor --> G[Send to MQTT]
Most properties of the device SDK are currently configured in build time using Kconfig - see the help text of each option for more information.
The device SDK also provides a way to dynamically configure certain properties from the cloud using the Spotflow portal. Currently, there is only one such property:
- Minimal severity of sent log messages (the level of sent log messages)
The configuration process uses the mechanism of desired and reported values that are stored for each device in the Spotflow platform and are synchronized using the MQTT protocol. If Zephyr Settings subsystem is enabled, the device SDK uses it to persist the last active configuration.
---
title: Configuration from the Spotflow Platform
---
sequenceDiagram
participant ZS as Zephyr Settings
participant SDK as Device SDK
participant PM as Spotflow Platform
Note left of SDK: On startup
SDK ->> ZS: Try load initial configuration
ZS ->> SDK: Configuration loaded / defaults used
Note right of SDK: On MQTT connection activation
SDK ->> PM: Send reported configuration
SDK ->> PM: Subscribe to desired configuration
loop When desired configuration changes
PM ->> SDK: Send desired configuration
SDK ->> ZS: Persist configuration
SDK ->> PM: Send reported configuration
end
In order to match core dumps with symbol files, our Zephyr module provides a piece of information called build ID.
The build ID is computed as a hash of the bytes loaded to the device; therefore, it uniquely identifies the firmware image.
Our Zephyr module adds a build command that computes the build ID and patches it into the .elf file as the following binary descriptor:
- ID:
0x5f0(5fresemblessf- Spotflow,0stands for our first binary descriptor ID) - Type:
bytes - Length:
20
You can retrieve the build ID from the .elf file using the following command:
west bindesc custom_search BYTES 0x5f0 zephyr.elfNote: If the architecture of the device doesn't support binary descriptors (notably, ESP32), retrieving the build ID from the
.elffile is more complex. In this case, it's necessary to use the symbol table, see the functionget_build_id_from_elfin script tests.
Because Zephyr doesn't allow to insert a post-build command between the compilation of zephyr.elf and the generation of derived files such as zephyr.hex and zephyr.bin, our build command patches these files as well.
In particular, the files with the following extensions are patched:
.elf.hex.bin.strip.exewhen not targeting native simulator (it's just a copy of the.elffile)
The files with the following extensions (and others that might be introduced in the future) are not patched, so the build IDs stored in them are filled with zeros:
.lst(assembly listing).uf2.s19.exewhen targeting native simulator
Any comments, suggestions, or issues are welcome. Create a Github issue or contact us at hello@spotflow.io, LinkedIn or Discord.