IPM on ESP32
Overview
This simple example can be used with multicore ESP32 Soc, and demonstrates the software intercore messaging mechanism to be used in AMP applications.
ESP32 has two CPU named APP and PRO, in this simple example PRO send a message to the APP using the IPM driver, and waits for the APP response message and prints its contents on console.
ESP32 intercore messaging has up two four channels, the 0 and 1 are reserved for BT and WIFI messages, and channels 2 and 3 is free to any application, each channel supports up to 64 bytes of data per message, so high level protocol is responsible to fragment larger messages in chunks of 64 bytes.
Building and Running the Zephyr Code
Build the ESP32 IPM sample code as follows:
west build -b esp32_devkitc_wroom samples/drivers/ipm/ipm_esp32
Sample Output
To check the output of this sample, run west espressif monitor
or any other serial
console program (e.g., minicom, putty, screen, etc).
*** Booting Zephyr OS build v3.3.0-rc3-38-gc9225e4365b9 ***
PRO_CPU is sending a fake request, waiting remote response...
PRO_CPU received a message from APP_CPU : APP_CPU: This is a response
PRO_CPU is sending a fake request, waiting remote response...
PRO_CPU received a message from APP_CPU : APP_CPU: This is a response
PRO_CPU is sending a fake request, waiting remote response...
PRO_CPU received a message from APP_CPU : APP_CPU: This is a response
PRO_CPU is sending a fake request, waiting remote response...
PRO_CPU received a message from APP_CPU : APP_CPU: This is a response
PRO_CPU is sending a fake request, waiting remote response...
PRO_CPU received a message from APP_CPU : APP_CPU: This is a response
PRO_CPU is sending a fake request, waiting remote response...
PRO_CPU received a message from APP_CPU : APP_CPU: This is a response
PRO_CPU is sending a fake request, waiting remote response...
PRO_CPU received a message from APP_CPU : APP_CPU: This is a response