OpenThread co-processor

Overview

OpenThread Co-Processor allows building a Thread Border Router. The code in this sample is only the MCU target part of a complete Thread Border Router. The Co-Processor can act in two variants: Network Co-Processor (NCP) and Radio Co-Processor (RCP), see https://openthread.io/platforms/co-processor.

Additional required host-side tools (e.g. otbr-agent) to build a Thread Border Router can be obtained by following https://openthread.io/guides/border-router/build#set-up-the-border-router.

The preferred Co-Processor configuration of OpenThread is RCP now.

The source code for this sample application can be found at: samples/net/openthread/coprocessor.

Building and Running

Build the OpenThread NCP sample application like this:

west build -b <board to use> samples/net/openthread/coprocessor -- -DCONF_FILE=<config file to use>

Build the OpenThread NCP sample application which uses CDC ACM UART device:

west build -b nrf52840dk/nrf52840 samples/net/openthread/coprocessor -- -DDTC_OVERLAY_FILE=usb.overlay -DEXTRA_CONF_FILE=overlay-usb-nrf-br.conf
west flash

Example building for the nrf52840dk/nrf52840 for RCP:

west build -b nrf52840dk/nrf52840 samples/net/openthread/coprocessor -- -DCONF_FILE="prj.conf overlay-rcp.conf"
west build -t run

There are configuration files for different boards and setups in the coprocessor directory:

  • prj.conf Generic NCP config file. Use this, if you want the NCP configuration.

  • overlay-rcp.conf

    RCP overlay file. Use this in combination with prj.conf, if you want the RCP configuration.

  • overlay-tri-n4m-br.conf This is an overlay for the dedicated Thread Border Router hardware https://www.tridonic.com/com/en/download/data_sheets/net4more_Borderrouter_PoE-Thread_en.pdf. The board support is not part of the Zephyr repositories, but the product is based on NXP K64 and AT86RF233. This file can be used as an example for a development set-up based on development boards.

See also

OpenThread L2 abstraction layer