2021-08-03 14:35:29 +08:00
|
|
|
/*
|
2023-09-06 19:33:39 +08:00
|
|
|
* SPDX-FileCopyrightText: 2015-2023 Espressif Systems (Shanghai) CO LTD
|
2021-08-03 14:35:29 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "sdkconfig.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef CONFIG_ESP_IPC_ISR_ENABLE
|
|
|
|
|
2021-10-26 21:12:26 +08:00
|
|
|
/**
|
|
|
|
* @brief IPC ISR Callback
|
|
|
|
*
|
2023-09-06 19:33:39 +08:00
|
|
|
* The callback must be written:
|
|
|
|
* - in assembly for XTENSA chips (such as ESP32, ESP32S3).
|
|
|
|
* - in C or assembly for RISCV chips (such as ESP32P4).
|
|
|
|
*
|
|
|
|
* A callback of this type should be provided as an argument when calling esp_ipc_isr_call() or
|
|
|
|
* esp_ipc_isr_call_blocking().
|
2021-10-26 21:12:26 +08:00
|
|
|
*/
|
2021-08-03 14:35:29 +08:00
|
|
|
typedef void (*esp_ipc_isr_func_t)(void* arg);
|
|
|
|
|
|
|
|
/**
|
2023-09-06 19:33:39 +08:00
|
|
|
* @brief Execute an ISR callback on the other CPU
|
2021-10-26 21:12:26 +08:00
|
|
|
*
|
|
|
|
* Execute a given callback on the other CPU in the context of a High Priority Interrupt.
|
|
|
|
*
|
|
|
|
* - This function will busy-wait in a critical section until the other CPU has started execution of the callback
|
2023-09-06 19:33:39 +08:00
|
|
|
* - The callback must be written:
|
|
|
|
* - in assembly for XTENSA chips (such as ESP32, ESP32S3).
|
|
|
|
* The function is invoked using a CALLX0 instruction and can use only a2, a3, a4 registers.
|
|
|
|
* See :doc:`IPC in Interrupt Context </api-reference/system/ipc>` doc for more details.
|
|
|
|
* - in C or assembly for RISCV chips (such as ESP32P4).
|
2021-08-03 14:35:29 +08:00
|
|
|
*
|
2021-10-26 21:12:26 +08:00
|
|
|
* @note This function is not available in single-core mode.
|
2021-08-03 14:35:29 +08:00
|
|
|
*
|
|
|
|
* @param[in] func Pointer to a function of type void func(void* arg) to be executed
|
|
|
|
* @param[in] arg Arbitrary argument of type void* to be passed into the function
|
|
|
|
*/
|
2023-09-06 19:33:39 +08:00
|
|
|
void esp_ipc_isr_call(esp_ipc_isr_func_t func, void* arg) ;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Execute an ISR callback on the other CPU
|
|
|
|
* See esp_ipc_isr_call().
|
|
|
|
*/
|
|
|
|
#define esp_ipc_isr_asm_call(func, arg) esp_ipc_isr_call(func, arg)
|
2021-08-03 14:35:29 +08:00
|
|
|
|
|
|
|
/**
|
2023-09-06 19:33:39 +08:00
|
|
|
* @brief Execute an ISR callback on the other CPU and busy-wait until it completes
|
2021-08-03 14:35:29 +08:00
|
|
|
*
|
2023-09-06 19:33:39 +08:00
|
|
|
* This function is identical to esp_ipc_isr_call() except that this function will busy-wait until the execution of
|
2021-10-26 21:12:26 +08:00
|
|
|
* the callback completes.
|
|
|
|
*
|
|
|
|
* @note This function is not available in single-core mode.
|
2021-08-03 14:35:29 +08:00
|
|
|
*
|
|
|
|
* @param[in] func Pointer to a function of type void func(void* arg) to be executed
|
|
|
|
* @param[in] arg Arbitrary argument of type void* to be passed into the function
|
|
|
|
*/
|
2023-09-06 19:33:39 +08:00
|
|
|
void esp_ipc_isr_call_blocking(esp_ipc_isr_func_t func, void* arg);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Execute an ISR callback on the other CPU and busy-wait until it completes
|
|
|
|
* See esp_ipc_isr_call_blocking().
|
|
|
|
*/
|
|
|
|
#define esp_ipc_isr_asm_call_blocking(func, arg) esp_ipc_isr_call_blocking(func, arg)
|
2021-08-03 14:35:29 +08:00
|
|
|
|
|
|
|
/**
|
2021-10-26 21:12:26 +08:00
|
|
|
* @brief Stall the other CPU
|
2021-08-03 14:35:29 +08:00
|
|
|
*
|
2021-10-26 21:12:26 +08:00
|
|
|
* This function will stall the other CPU. The other CPU is stalled by busy-waiting in the context of a High Priority
|
|
|
|
* Interrupt. The other CPU will not be resumed until esp_ipc_isr_release_other_cpu() is called.
|
2021-08-03 14:35:29 +08:00
|
|
|
*
|
2021-10-26 21:12:26 +08:00
|
|
|
* - This function is internally implemented using IPC ISR
|
|
|
|
* - This function is used for DPORT workaround.
|
|
|
|
* - If the stall feature is paused using esp_ipc_isr_stall_pause(), this function will have no effect
|
2021-08-03 14:35:29 +08:00
|
|
|
*
|
2021-10-26 21:12:26 +08:00
|
|
|
* @note This function is not available in single-core mode.
|
2022-07-28 14:20:16 +08:00
|
|
|
* @note It is the caller's responsibility to avoid deadlocking on spinlocks
|
2021-08-03 14:35:29 +08:00
|
|
|
*/
|
|
|
|
void esp_ipc_isr_stall_other_cpu(void);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Release the other CPU
|
|
|
|
*
|
2021-10-26 21:12:26 +08:00
|
|
|
* This function will release the other CPU that was previously stalled from calling esp_ipc_isr_stall_other_cpu()
|
|
|
|
*
|
|
|
|
* - This function is used for DPORT workaround.
|
|
|
|
* - If the stall feature is paused using esp_ipc_isr_stall_pause(), this function will have no effect
|
2021-08-03 14:35:29 +08:00
|
|
|
*
|
2021-10-26 21:12:26 +08:00
|
|
|
* @note This function is not available in single-core mode.
|
2021-08-03 14:35:29 +08:00
|
|
|
*/
|
|
|
|
void esp_ipc_isr_release_other_cpu(void);
|
|
|
|
|
|
|
|
/**
|
2021-10-26 21:12:26 +08:00
|
|
|
* @brief Puase the CPU stall feature
|
|
|
|
*
|
|
|
|
* This function will pause the CPU stall feature. Once paused, calls to esp_ipc_isr_stall_other_cpu() and
|
|
|
|
* esp_ipc_isr_release_other_cpu() will have no effect. If a IPC ISR call is already in progress, this function will
|
|
|
|
* busy-wait until the call completes before pausing the CPU stall feature.
|
2021-08-03 14:35:29 +08:00
|
|
|
*/
|
|
|
|
void esp_ipc_isr_stall_pause(void);
|
|
|
|
|
|
|
|
/**
|
2021-10-26 21:12:26 +08:00
|
|
|
* @brief Abort a CPU stall
|
2021-08-03 14:35:29 +08:00
|
|
|
*
|
2021-10-26 21:12:26 +08:00
|
|
|
* This function will abort any stalling routine of the other CPU due to a pervious call to
|
|
|
|
* esp_ipc_isr_stall_other_cpu(). This function aborts the stall in a non-recoverable manner, thus should only be called
|
|
|
|
* in case of a panic().
|
|
|
|
*
|
|
|
|
* - This function is used in panic handling code
|
2021-08-03 14:35:29 +08:00
|
|
|
*/
|
|
|
|
void esp_ipc_isr_stall_abort(void);
|
|
|
|
|
|
|
|
/**
|
2021-10-26 21:12:26 +08:00
|
|
|
* @brief Resume the CPU stall feature
|
|
|
|
*
|
|
|
|
* This function will resume the CPU stall feature that was previously paused by calling esp_ipc_isr_stall_pause(). Once
|
|
|
|
* resumed, calls to esp_ipc_isr_stall_other_cpu() and esp_ipc_isr_release_other_cpu() will have effect again.
|
2021-08-03 14:35:29 +08:00
|
|
|
*/
|
|
|
|
void esp_ipc_isr_stall_resume(void);
|
|
|
|
|
2021-10-26 21:12:26 +08:00
|
|
|
#else // CONFIG_ESP_IPC_ISR_ENABLE
|
2021-08-03 14:35:29 +08:00
|
|
|
|
|
|
|
#define esp_ipc_isr_stall_other_cpu()
|
|
|
|
#define esp_ipc_isr_release_other_cpu()
|
|
|
|
#define esp_ipc_isr_stall_pause()
|
|
|
|
#define esp_ipc_isr_stall_abort()
|
|
|
|
#define esp_ipc_isr_stall_resume()
|
|
|
|
|
|
|
|
#endif // CONFIG_ESP_IPC_ISR_ENABLE
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|