Skip to content

A Zephyr based departure board that frequently GETs & displays bus stop departure times over LTE-M

License

Notifications You must be signed in to change notification settings

umts/embedded-departure-board

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

embedded-departure-board

Development

Requirements

Setup

  1. Clone and enter the repo
  2. Create a Python virtual environment
    python3 -m venv ./.venv
  3. Activate your Python virtual environment
    source .venv/bin/activate
    # Or, if you're a direnv user, leave and come back
    cd
    cd -
  4. Install West
    pip install west
  5. Run
    west update
  6. Install Python dependencies
    pip install -r zephyr/scripts/requirements.txt
    pip install -r nrf/scripts/requirements.txt
    pip install -r bootloader/mcuboot/scripts/requirements.txt

Recomended

Docker

Zephyr supplies various Docker images for development.

Our Github Actions build workflow uses the Base Image (ci-base).

Building

Testing

west build --sysbuild ./app -b circuitdojo_feather/nrf9160/ns

Release

You need a copy of the MCUBoot key file placed here: app/keys/private/boot-ecdsa-p256.pem

west build --sysbuild ./app -b circuitdojo_feather/nrf9160/ns -- -DFILE_SUFFIX=release

Programming

Flashing

Flashing the device with an external programmer is quicker than using a bootloader. More importantly, it's the easiest way (and currently the only tested way) to secure the bootloader, update the modem firmware, and use the cortex-debugger.

Requirements

Running

west flash -r nrfjprog --erase --softreset

Uploading via the bootloader

The only way to flash the device without an external programming device, uses serial over the builtin USB port.

Requirements

Setup

  1. Create a "serial" profile in newtmgr:
newtmgr conn add serial type=serial connstring="dev=/dev/ttyUSB0,baud=1000000"
  1. Put the device into bootloader mode.

Run

newtmgr -c serial image upload ./build/app/zephyr/zephyr.signed.bin

VSCode

This repo includes .vscode/tasks.json to make develpoment easier. The included tasks are:

  • Build
  • Load image via bootloader
    • Expects a connection profile named "serial" in newtmgr
  • Serial Monitor
    • Uses pyserial-miniterm, which should already be installed in your venv
    • Assumes the device is connected at /dev/ttyUSB0
  • West Flash
  • West Flash and Monitor
  • Build AT Client
    • Builds the At Client sample provided by nrf.
    • Useful for debugging via AT commands. Use a serial console to send AT commands

Creating a Release

Update the VERSION file. On a successful push to the main branch the release workflow will; create a new release, generate release notes, and upload the freshly built hex/bin files to the release.

About

A Zephyr based departure board that frequently GETs & displays bus stop departure times over LTE-M

Topics

Resources

License

Stars

Watchers

Forks

Languages