mirror of
https://github.com/espressif/esp-idf.git
synced 2025-07-30 10:47:19 +02:00
driver/timer: only re-enable alarm in callback when auto reload is true
closes https://github.com/espressif/esp-idf/issues/7001
This commit is contained in:
@ -216,8 +216,12 @@ static void IRAM_ATTR timer_isr_default(void *arg)
|
|||||||
is_awoken = timer_obj->timer_isr_fun.fn(timer_obj->timer_isr_fun.args);
|
is_awoken = timer_obj->timer_isr_fun.fn(timer_obj->timer_isr_fun.args);
|
||||||
//Clear intrrupt status
|
//Clear intrrupt status
|
||||||
timer_hal_clear_intr_status(&(timer_obj->hal));
|
timer_hal_clear_intr_status(&(timer_obj->hal));
|
||||||
//After the alarm has been triggered, we need enable it again, so it is triggered the next time.
|
//If the timer is set to auto reload, we need enable it again, so it is triggered the next time.
|
||||||
timer_hal_set_alarm_enable(&(timer_obj->hal), TIMER_ALARM_EN);
|
if (timer_hal_get_auto_reload(&timer_obj->hal)) {
|
||||||
|
timer_hal_set_alarm_enable(&(timer_obj->hal), TIMER_ALARM_EN);
|
||||||
|
} else {
|
||||||
|
timer_hal_set_alarm_enable(&(timer_obj->hal), TIMER_ALARM_DIS);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
TIMER_EXIT_CRITICAL(&timer_spinlock[timer_obj->timer_isr_fun.isr_timer_group]);
|
TIMER_EXIT_CRITICAL(&timer_spinlock[timer_obj->timer_isr_fun.isr_timer_group]);
|
||||||
|
Reference in New Issue
Block a user