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.