Skip to content

Latest commit

 

History

History
72 lines (59 loc) · 3.59 KB

README.md

File metadata and controls

72 lines (59 loc) · 3.59 KB

Exploring multi-core usage on Nucleo-H755 with embassy

This project contains various attempts at using both cores of the Nucleo-H755 board together with embassy.

Getting started

Optionally:

  • Install the "Debugger for probe-rs" extention in VS-Code

Notes

At the moment, there is an example checked in which shows coordination between the cores.

  • core0 contains the binary to be run on the M7.
  • core1 contains the binary to be run on the M4.
  • On power-up, both cores start executing their binary.
    • core1 sets up notifications for the semaphore and goes into Stop mode.
    • core0 waits for core1 to be in Stop mode, does most of the setup and wakes up core1 by unlocking one semaphore. It than waits for another semaphore which is controled by core 1.
    • core1 wakes up, initializes just its own clock and then unlocks the other semaphore.
    • Now, both cores run in parallel, coordinating via semaphores.

Todos

  1. Project structure for dual core? (M)

    • Main project
    • Core 0 project
    • Core 1 project
    • Shared project
  2. How to use a customized memory.x file? (S)

  3. How to upload a binary to the second core? Which address? Where to configure? (S)

    1. How do we need to configure embassy-stm32 for the second core (i.e. remove "rt" feature - the rt feature populates the NVIC table with the (default) interrupt handlers, which might not be what we want for the second core). This also raises the question how do we configure the NVIC with interrupt handlers for both cores.
  4. How do we use defmt for logging on the second core? What needs to be done to receive the output in probe-rs? (S)

    1. Could we write our own global Logger which waits for a hardware semaphore in Logger::acquire?
  5. Which build system do we use? Can we do everything with cargo or do we need something like cargo-make? Cargo only is preferred. (M)

  6. Define and implement start-up sequence for dual core. Startingpoint is the STM Cube SDK example. If we follow this approach, we should implement the required functions in a stm32h7xx_hal_dual_core supplement (assuming that the functionality required is mostly net new and not changes to existing HAL functionality) crate for the time being and decide later if we want to upstream it.

    Start-up sequence as provided in the STM Cube SDK example

  7. Integrate with hamoc

    1. Setup FreeRTOS config for the two cores
    2. Integrate into the hamoc workspace
  8. Define a concept for peripherals initialization and ownership

  9. Improve debugging

    1. Could we debug both cores at the same time using e.g. openocd?
    2. Could we debug both cores at the same time using VS-Code? (see e.g. multi-core debugging discussion in cortex-debug)