-
Notifications
You must be signed in to change notification settings - Fork 7.4k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge branch 'feature/ipc_noblocking_call_v5.0' into 'release/v5.0'
feat(ipc): Adds a new no blocking IPC call (v5.0) See merge request espressif/esp-idf!28447
- Loading branch information
Showing
5 changed files
with
168 additions
and
70 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
/* | ||
* SPDX-FileCopyrightText: 2024 Espressif Systems (Shanghai) CO LTD | ||
* | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
#pragma once | ||
|
||
#include "../esp_ipc.h" | ||
#include "sdkconfig.h" | ||
|
||
#ifdef __cplusplus | ||
extern "C" { | ||
#endif | ||
|
||
#if !defined(CONFIG_FREERTOS_UNICORE) || defined(CONFIG_APPTRACE_GCOV_ENABLE) | ||
|
||
/** | ||
* @brief Execute a callback on a given CPU without any blocking operations for the caller | ||
* | ||
* Since it does not have any blocking operations it is suitable to be run from interrupts | ||
* or even when the Scheduler on the current core is suspended. | ||
* | ||
* The function: | ||
* - does not wait for the callback to begin or complete execution, | ||
* - does not change the IPC priority. | ||
* The function returns after sending a notification to the IPC task to execute the callback. | ||
* | ||
* @param[in] cpu_id CPU where the given function should be executed (0 or 1) | ||
* @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 | ||
* | ||
* @return | ||
* - ESP_ERR_INVALID_ARG if cpu_id is invalid | ||
* - ESP_ERR_INVALID_STATE 1. IPC tasks have not been initialized yet, | ||
* 2. cpu_id requests IPC on the current core, but the FreeRTOS scheduler is not running on it | ||
* (the IPC task cannot be executed). | ||
* - ESP_FAIL IPC is busy due to a previous call was not completed. | ||
* - ESP_OK otherwise | ||
*/ | ||
esp_err_t esp_ipc_call_nonblocking(uint32_t cpu_id, esp_ipc_func_t func, void* arg); | ||
|
||
#endif // !defined(CONFIG_FREERTOS_UNICORE) || defined(CONFIG_APPTRACE_GCOV_ENABLE) | ||
|
||
#ifdef __cplusplus | ||
} | ||
#endif |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters