Working with the FLPR core
Note
The FLPR core support in the nRF Connect SDK is currently experimental.
The nRF54L15 SoC has a dedicated VPR CPU (RISC-V architecture), named fast lightweight peripheral processor (FLPR). The following peripherals are available for use with the FLPR core, and can be accessed through the appropriate Zephyr Device Driver API:
GPIO
GPIOTE
GRTC
TWIM
UARTE
VPR
Using FLPR with Zephyr multithreaded mode
FLPR can function as a generic core, operating under the full Zephyr kernel. In this configuration, building the FLPR target is similar to the application core. However, the application core build must incorporate an overlay that enables the FLPR core.
Bootstrapping the FLPR core
The nRF Connect SDK provides a FLPR snippet that adds an overlay required for bootstrapping the FLPR core. Snippet’s primary function is to enable the code that transfers the FLPR code to the designated region (if necessary) and to initiate the FLPR core.
When building for the nrf54l15dk/nrf54l15/cpuflpr
target, a minimal sample is automatically loaded onto the application core.
See more information on Building for the application and FLPR core.
Memory allocation
If a FLPR CPU is running, it can lead to increased latency when accessing RAM_01
.
Because of this, when FLPR is used in a project, you should utilize RAM_01
to store only the FLPR code, FLPR data, and the application CPU’s non-time-sensitive information.
Conversely, you should use RAM_00
to store data with strict access time requirements such as DMA buffers, and the application CPU data used in low-latency ISRs.