Build and configuration system
The nRF Connect SDK build and configuration system is based on the one from Zephyr, with some additions.
Overview of build and configuration system
The build and configuration system in Zephyr and the nRF Connect SDK uses the following building blocks as a foundation:
Source |
File types |
Usage |
Available dedicated editing tools |
Additional information |
---|---|---|---|---|
|
Build system generator. |
n/a |
CMake is used to build your application together with the Zephyr kernel. |
|
|
Hardware description language. |
Devicetree Visual Editor is part of the nRF Connect for VS Code extension. You still need to be familiar with the devicetree language to use it. |
||
|
Software configuration system also used in the Linux kernel. |
Kconfig GUI is part of the nRF Connect for VS Code extension.
The Kconfig Reference provides the documentation for each configuration option.
|
||
|
Memory layout configuration system. |
Partition Manager script |
Partition Manager is an nRF Connect SDK configuration system that is not available in Zephyr. |
Each of these systems comes with a specialized syntax and purpose. See the following sections for more information. To read more about Zephyr’s configuration system and its role in the application development, see Build and Configuration Systems and Application Development in the Zephyr documentation.
When you Create an application, the configuration files for each of these systems are created in the application directory: CMakeLists.txt
for CMake, app.overlay
for devicetree, prj.conf
for Kconfig, and partitions.yml
for Partition Manager (if enabled).
You can then edit them according to your needs (see Configuring and building an application).
When you start building, a CMake build is executed in two stages: configuration phase and building phase.
Configuration phase
During this phase, CMake executes build scripts from CMakeLists.txt
and gathers configuration from different sources, for example Custom build types, to generate the final build scripts and create a model of the build for the specified build target.
The result of this process is a build configuration, a set of files that will drive the build process.
For more information about this phase, see the respective sections on Zephyr’s Build System (CMake) page, which describes in-depth the usage of CMake for Zephyr-based applications.
Role of CMakeLists.txt
In Zephyr and the nRF Connect SDK, the application is a CMake project.
As such, the application controls the configuration and build process of itself, Zephyr, and sourced libraries.
The application’s CMakeLists.txt
file is the main CMake project file and the source of the build process configuration.
Zephyr provides a CMake package that must be loaded by the application into its CMakeLists.txt
file.
When loaded, the application can reference items provided by both Zephyr and the nRF Connect SDK.
Loading Zephyr’s CMake package creates the app
CMake target.
You can add application source files to this target from the application CMakeLists.txt
file.
See Adding source files to CMakeLists.txt for detailed information.
Memory layout configuration
The memory layout configuration is provided by the Partition Manager script, specific to the nRF Connect SDK.
The script must be enabled to provide the memory layout configuration. It is impacted by various elements, such as Kconfig configuration options or the presence of child images. Partition Manager ensures that all required partitions are in the correct place and have the correct size.
If enabled, the memory layout can be controlled in the following ways:
Dynamically (default) - In this scenario, the layout is impacted by various elements, such as Kconfig configuration options or the presence of child images. Partition Manager ensures that all required partitions are in the correct place and have the correct size.
Statically - In this scenario, you need to provide the static configuration. See Static configuration for information about how to do this.
After CMake has run, a partitions.yml
file with the memory layout will have been created in the build
directory.
This process also creates a set of header files that provides defines, which can be used to refer to memory layout elements.
Child images
The nRF Connect SDK build system allows the application project to become a root for the sub-applications known in the nRF Connect SDK as child images. Examples of child images are bootloader images, network core images, or security-related images. Each child image is a separate application.
For more information, see Multi-image builds.
Building phase
During this phase, the final build scripts are executed.
The build phase begins when the user invokes make
or ninja.
The compiler (for example, GCC compiler) then creates object files used to create the final executables.
You can customize this stage by Providing CMake options and using Advanced compiler settings.
The result of this process is a complete application in a format suitable for flashing on the desired target board. See output build files for details.
The build phase can be broken down, conceptually, into four stages: the pre-build, first-pass binary, final binary, and post-processing. To read about each of these stages, see Build System (CMake) in the Zephyr documentation.
Additions specific to the nRF Connect SDK
The nRF Connect SDK adds some functionality on top of the Zephyr build and configuration system. Those additions are automatically included into the Zephyr build system using a Zephyr Build Configuration CMake packages.
You must be aware of these additions when you start writing your own applications based on this SDK.
Experimental option enabled by default
Unlike in Zephyr, the Kconfig option CONFIG_WARN_EXPERIMENTAL
is enabled by default in the nRF Connect SDK.
It gives warnings at CMake configure time if any experimental feature is enabled.
For example, when building a sample that enables CONFIG_BT_EXT_ADV
, the following warning is printed at CMake configure time:
warning: Experimental symbol BT_EXT_ADV is enabled.
To disable these warnings, disable the CONFIG_WARN_EXPERIMENTAL
Kconfig option.
Custom build types
A build type is a feature that defines the way in which the configuration files are to be handled. For example, selecting a build type lets you generate different build configurations for release and debug versions of the application.
In the nRF Connect SDK, the build type is controlled using the configuration files, whose names can be suffixed to define specific build types. When you select a build type for the configuration phase, the compiler will use a specific set of files to create a specific build configuration for the application.
The prj.conf
file is the application-specific default, but many applications and samples include source files for generating the build configuration differently, for example prj_release.conf
or prj_debug.conf
.
Similarly, the build type can be included in file names for board configuration, Partition Manager’s static configuration, child image Kconfig configuration, and others.
In this way, these files are made dependent on the build type and will only be used when the corresponding build type is invoked.
For example, if an application uses pm_static_release.yml
to define Partition Manager’s static configuration, this file will only be used when the application’s prj_release.conf
file is used to select the release build type.
Many applications and samples in the nRF Connect SDK use build types to define more detailed build configurations.
The most common build types are release
and debug
, which correspond to CMake defaults, but other names can be defined as well.
For example, nRF Desktop features a wwcb
build type, while Matter weather station features the factory_data
build type.
See the application’s Configuration section for information if it includes any build types.
For more information about how to invoke and create build types, see Configuring build types.
Multi-image builds
The nRF Connect SDK build system extends Zephyr’s with support for multi-image builds. You can find out more about these in the Multi-image builds section.
The nRF Connect SDK allows you to create custom build type files instead of using a single prj.conf
file.
Boilerplate CMake file
The nRF Connect SDK provides an additional boilerplate.cmake
file that is automatically included when using the Zephyr CMake package in the CMakeLists.txt
file of your application:
find_package(Zephyr HINTS $ENV{ZEPHYR_BASE})
This file checks if the selected board is supported and, when available, if the selected build type is supported.
Partition Manager
The nRF Connect SDK adds the Partition Manager script, responsible for partitioning the available flash memory and creating the Memory layout configuration.
Binaries and images for nRF Cloud FOTA
The nRF Connect SDK build system generates output zip files containing binary images and a manifest for use with nRF Cloud FOTA.
An example of such a file is dfu_mcuboot.zip
.