mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
Merge branch 'bugfix/freertos_hook_reg_invalid_arg_pr6275' into 'master'
freertos_hooks: Fix unbalance lock in deregistration for cpu functions Closes IDFGH-4472 See merge request espressif/esp-idf!11855
This commit is contained in:
commit
16291ba7f5
@ -109,10 +109,10 @@ esp_err_t esp_register_freertos_tick_hook(esp_freertos_tick_cb_t new_tick_cb)
|
||||
|
||||
void esp_deregister_freertos_idle_hook_for_cpu(esp_freertos_idle_cb_t old_idle_cb, UBaseType_t cpuid)
|
||||
{
|
||||
portENTER_CRITICAL(&hooks_spinlock);
|
||||
if(cpuid >= portNUM_PROCESSORS){
|
||||
return;
|
||||
}
|
||||
portENTER_CRITICAL(&hooks_spinlock);
|
||||
for(int n = 0; n < MAX_HOOKS; n++){
|
||||
if(idle_cb[cpuid][n] == old_idle_cb) idle_cb[cpuid][n] = NULL;
|
||||
}
|
||||
@ -130,10 +130,10 @@ void esp_deregister_freertos_idle_hook(esp_freertos_idle_cb_t old_idle_cb)
|
||||
|
||||
void esp_deregister_freertos_tick_hook_for_cpu(esp_freertos_tick_cb_t old_tick_cb, UBaseType_t cpuid)
|
||||
{
|
||||
portENTER_CRITICAL(&hooks_spinlock);
|
||||
if(cpuid >= portNUM_PROCESSORS){
|
||||
return;
|
||||
}
|
||||
portENTER_CRITICAL(&hooks_spinlock);
|
||||
for(int n = 0; n < MAX_HOOKS; n++){
|
||||
if(tick_cb[cpuid][n] == old_tick_cb) tick_cb[cpuid][n] = NULL;
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user