Flash Image API on Network Core

Hi,

When I try to use the Flash Image API on the Network Core I get build errors. The problem seems to be that some symbols are not defined, as there is no MCUboot bootloader on the Network Core (but there is one on the Application Core).

What is the intended way to use the Flash Image API to write image data from the Network Core to an image slot of the Application Core?

(Additional info: I tried defining the missing symbols (PM_MCUBOOT_PRIMARY_ID and PM_MCUBOOT_SECONDARY_ID) wherever they are needed, just to see if the build succeeds. Indeed it does, but the init function of the Flash Image API then fails, which is not surprising as these symbols were defined manually and seem to be missing in the project setup.)

Parents
  • Hi nkost,

    Thank you for your patience. 

    Coming to your query: 

    When I try to use the Flash Image API on the Network Core I get build errors. The problem seems to be that some symbols are not defined, as there is no MCUboot bootloader on the Network Core (but there is one on the Application Core).

    Well, we have two bootloaders for 5340 as it has two cores, one for the app core (called MCUboot) and other for the network-core, called b0n which is an immutable first-stage bootloader that can update the application firmware on the network core of the nRF5340 SoC.

    I suggest to look at netboot sample to see the use-case and the configurations.

    What is the intended way to use the Flash Image API to write image data from the Network Core to an image slot of the Application Core?

    Flash Image Api is specific example use. Let us talk about writing image from the network core to an image slot of the app core. For such a purpose, you need to do a multi-image build. It is well described here: Multi-Image Build

    Hope it helps,

    Regards,

    Naeem

  • Hi Naeem

    Thanks four your answer. The setup you described is the one I use. I now need to write to the "Secondary Slot" in the AppCore Flash from the "Net core app". The problem is that the address of the "Secondary Slot" is not known in the "Net core app".

    This flash should be accessible from the NetCore (according to the Product Specification of nRF5340, Section 3.2 Fig. 2 Memory Map and Section 6.4 Memory: "The network core can access application core resources (flash, RAM, and peripherals) when granted permission through the application's DCNF and SPU settings.") When I try to write to this address using the function flash_area_write, it returns with an error "invalid address" (Permissions are not the problem).

    How can I access the flash of the AppCore from the NetCore?

  • Hi nkost,

    Thank you for being patient. I have gone through documentation again.

    - Yes, writing flash is managed by the NVMC

    - For the nrf4350, the application core memory is mapped to the network core memory map

    - This means that the network core CPU can access and use the application core memory for shared memory communication.

    - Even then, the application core can restrict network core access through the domain configuration (DCNF) PROTECT registers. Access to secure memory or peripherals is also prevented when the network core is marked as non-secure

    The network core can access application core resources (flash, RAM, and peripherals) when granted permission through the application's DCNF and SPU settings. A small portion of the application core RAM is dedicated to the exchange of messages between the application and network cores.

    - We have IPC (interprocessor communication) periphereal that is used to send and receive events between MCUs.

    - An IPC event often does not contain any data itself, it is used to signal other MCUs that something has occurred.

    - Data can be shared through shared memory, for example in the form of a software implemented mailbox, or command/event queues.

    - It is up to software to assign a logical functionality to an IPC channel. For instance, one IPC channel can be used to signal that a command is ready to be executed, and any processor in the system can subscribe to that particular IPC channel and decode/execute the command.

    You can look more into the IPC and using OpenAmp.

    Regards,

    Naeem

  • Hi Naeem,

    Thank you for your answer.

    The network core can access application core resources (flash, RAM, and peripherals) when granted permission through the application's DCNF and SPU settings.

    This is what I need but does not yet work (the access to the flash, I don't need access to the RAM and the peripherals).

    I know about the IPC, but that is not what I need. I want to access the flash directly from the network core and not to send the data from the network core through IPC to the application core.

    Did you find a way to get the example from above to work?

  • Hi nkost,

    I was not able to do it successfully, and we don't have any specific example/sample for your case as well.

  • I've found a way to do what I want, but there are still open questions.

    It works when I access the AppCore's NVMC over its Secure base address (0x50039000) from the NetCore using the nrfx HAL. From my understanding it should also work, when accessing the AppCore's NVMC over its Non-Secure base address (0x40039000), when the DCNF and SPU settings are configured accordingly, but I can't get that to work properly (meaning, I can access and configure the peripheral, but when trying to write to the flash, I get the above described fault).

    From the information in the documentation, both ways should work. The question that remains is: How does it work?

  • Hi nkost,

    Can you please share your project/code where you are successfully accessing the app-core flash region using the secure nvmc.

Reply Children
Related