Developing with ZBOSS for Zigbee
NCP Host user guide

The ZBOSS stack embedded inside the NCP SoC firmware as a binary HEX file implements the Zigbee PRO protocol stack. The stack includes the following stack layers:

  • Application support sub-layer (APS)
  • Zigbee device objects (ZDO)
  • Zigbee device profile (ZDP)
  • Application framework (AF)
  • Network layer (NWK)
  • Zigbee Standard Security services

The NCP SoC firmware is provided as a set of precompiled binaries for nRF54L15 DK. It can be recompiled using the NCP sample, available in nRF Connect SDK.

ZBOSS libraries for NCP host application

The ZBOSS libraries for the NCP host include the following stack layers:

  • Zigbee cluster library (ZCL)
  • Commissioning logic (part of ZDO)
  • ZBOSS NCP serialization protocol
  • ZBOSS platform support layer for Linux-based OS

Additionally, the package contains source code for all parts of the ZBOSS library for NCP host. This allows you to recompile the library for the designated hardware platform.

Hardware and software requirements

You need the following hardware and software for using the ZBOSS NCP Host package:

  • Operating system compatible with the 64-bit Ubuntu 22.04 Linux OS, which was used for building and testing the precompiled ZBOSS libraries in the package
  • nRF54L15 DK

Package directory structure

The package has the following directory structure:

  • application - Application sample folder
  • include - Header files with the public ZBOSS API
  • ncp_fw - ZBOSS NCP SoC firmware files
  • lib - ZBOSS NCP Host libraries
  • src - ZBOSS sources needed for rebuilding ZBOSS libraries for NCP host application
    • aps - APS layer sources
    • common - Common ZBOSS sources
    • commissioning - ZBOSS commissioning files
    • include - Internal ZBOSS header files
    • ncp - ZBOSS NCP protocol sources
    • osif - ZBOSS platform support layer sources
    • secur - Security layer sources
    • zcl - ZCL layer sources
    • zdo - ZDO layer sources
    • Makefile - Makefile for building ZBOSS libraries
    • Makefile_zboss - Makefile for rebuilding ZBOSS libraries for NCP host
    • Options - Option file for ZBOSS libraries for NCP host
  • Makefile, Options, Platform_config - Linker scripts, options files and Makefile for the NCP host applications
  • readme.md - This guide

Building and running NCP host sample applications

Follow the instructions in this section to start using the ZBOSS NCP Host.

Programming the NCP SoC

Before running samples, you need to program the correct firmware onto the nRF54L15 DK. Refer to the Building and running section in NCP sample description in Zigbee R23 Add-on for nRF Connect SDK documentation.

Building applications

The application folder contains a readme file with the sample description.

All NCP host samples can be rebuilt by executing the make command from the package root folder::

make

Alternatively, each sample may be rebuild individually, if the make command is executed from the sample's directory.

Running applications

For running the application, specify the NCP_SLAVE_PTY environment variable. This variable should contain the path to the correct Linux device that will be used as the communication channel.

For example, to start the light_coordinator sample on the device and communicate through the /dev/ttyACM0 port, use the following command::

NCP_SLAVE_PTY=/dev/ttyACM0 ./application/light_sample/light_coordinator/light_zc

Rebuilding the ZBOSS libraries for host

To rebuild ZBOSS libraries for NCP host in the lib directory, use the source files from the src directory::

cd src make rebuild make zbosses