2022-12-26 15:48:07 +08:00
|
|
|
/*
|
|
|
|
* SPDX-FileCopyrightText: 2021-2022 Espressif Systems (Shanghai) CO LTD
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "esp_openthread_lock.h"
|
2023-04-14 14:36:42 +08:00
|
|
|
#include "esp_openthread_common_macro.h"
|
2022-12-26 15:48:07 +08:00
|
|
|
|
2023-04-14 14:36:42 +08:00
|
|
|
#include "esp_check.h"
|
2022-12-26 15:48:07 +08:00
|
|
|
#include "esp_err.h"
|
2023-04-14 14:36:42 +08:00
|
|
|
#include "esp_log.h"
|
2022-12-26 15:48:07 +08:00
|
|
|
#include "freertos/FreeRTOS.h"
|
|
|
|
#include "freertos/semphr.h"
|
|
|
|
|
|
|
|
static SemaphoreHandle_t s_openthread_task_mutex = NULL;
|
|
|
|
static SemaphoreHandle_t s_openthread_mutex = NULL;
|
|
|
|
|
|
|
|
bool esp_openthread_lock_acquire(TickType_t block_ticks)
|
|
|
|
{
|
2023-04-14 14:36:42 +08:00
|
|
|
ESP_RETURN_ON_FALSE(s_openthread_mutex && s_openthread_task_mutex, false, OT_PLAT_LOG_TAG,
|
|
|
|
"Failed to acquire the lock because the mutex is not ready");
|
2022-12-26 15:48:07 +08:00
|
|
|
BaseType_t ret = xSemaphoreTakeRecursive(s_openthread_mutex, block_ticks) &&
|
|
|
|
xSemaphoreTakeRecursive(s_openthread_task_mutex, block_ticks);
|
|
|
|
return (ret == pdTRUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
void esp_openthread_lock_release(void)
|
|
|
|
{
|
2023-04-14 14:36:42 +08:00
|
|
|
ESP_RETURN_ON_FALSE(s_openthread_mutex && s_openthread_task_mutex, , OT_PLAT_LOG_TAG,
|
|
|
|
"Failed to release the lock because the mutex is not ready");
|
2022-12-26 15:48:07 +08:00
|
|
|
xSemaphoreGiveRecursive(s_openthread_task_mutex);
|
|
|
|
xSemaphoreGiveRecursive(s_openthread_mutex);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool esp_openthread_task_switching_lock_acquire(TickType_t block_ticks)
|
|
|
|
{
|
2023-04-14 14:36:42 +08:00
|
|
|
ESP_RETURN_ON_FALSE(s_openthread_task_mutex, false, OT_PLAT_LOG_TAG,
|
|
|
|
"Failed to acquire the lock because the mutex is not ready");
|
2022-12-26 15:48:07 +08:00
|
|
|
BaseType_t ret = xSemaphoreTakeRecursive(s_openthread_task_mutex, block_ticks);
|
|
|
|
return (ret == pdTRUE);
|
|
|
|
}
|
|
|
|
|
|
|
|
void esp_openthread_task_switching_lock_release(void)
|
|
|
|
{
|
2023-04-14 14:36:42 +08:00
|
|
|
ESP_RETURN_ON_FALSE(s_openthread_task_mutex, , OT_PLAT_LOG_TAG,
|
|
|
|
"Failed to release the lock because the mutex is not ready");
|
2022-12-26 15:48:07 +08:00
|
|
|
xSemaphoreGiveRecursive(s_openthread_task_mutex);
|
|
|
|
}
|
|
|
|
|
|
|
|
esp_err_t esp_openthread_lock_init(void)
|
|
|
|
{
|
|
|
|
if (s_openthread_mutex != NULL || s_openthread_task_mutex != NULL) {
|
|
|
|
return ESP_ERR_INVALID_STATE;
|
|
|
|
}
|
|
|
|
s_openthread_mutex = xSemaphoreCreateRecursiveMutex();
|
|
|
|
s_openthread_task_mutex = xSemaphoreCreateRecursiveMutex();
|
|
|
|
if (s_openthread_mutex == NULL || s_openthread_task_mutex == NULL) {
|
|
|
|
return ESP_ERR_NO_MEM;
|
|
|
|
}
|
|
|
|
return ESP_OK;
|
|
|
|
}
|
|
|
|
|
|
|
|
void esp_openthread_lock_deinit(void)
|
|
|
|
{
|
|
|
|
if (s_openthread_mutex) {
|
|
|
|
vSemaphoreDelete(s_openthread_mutex);
|
|
|
|
s_openthread_mutex = NULL;
|
|
|
|
}
|
|
|
|
if (s_openthread_task_mutex) {
|
|
|
|
vSemaphoreDelete(s_openthread_task_mutex);
|
|
|
|
s_openthread_task_mutex = NULL;
|
|
|
|
}
|
|
|
|
}
|