FuriHal: allow nulling null isr (#2846)
* FuriHal: allow nulling null isr * FuriHal: include interrupt priority 15 as allowed * Furi: prevent compiler from optimizing arg in r0 of RESTORE_REGISTERS_AND_HALT_MCU
This commit is contained in:
parent
97fbd84e08
commit
f3ae09cc16
@ -128,14 +128,13 @@ void furi_hal_interrupt_set_isr_ex(
|
|||||||
FuriHalInterruptISR isr,
|
FuriHalInterruptISR isr,
|
||||||
void* context) {
|
void* context) {
|
||||||
furi_check(index < FuriHalInterruptIdMax);
|
furi_check(index < FuriHalInterruptIdMax);
|
||||||
furi_check(priority < 15);
|
furi_check(priority <= 15);
|
||||||
|
|
||||||
if(isr) {
|
if(isr) {
|
||||||
// Pre ISR set
|
// Pre ISR set
|
||||||
furi_check(furi_hal_interrupt_isr[index].isr == NULL);
|
furi_check(furi_hal_interrupt_isr[index].isr == NULL);
|
||||||
} else {
|
} else {
|
||||||
// Pre ISR clear
|
// Pre ISR clear
|
||||||
furi_check(furi_hal_interrupt_isr[index].isr != NULL);
|
|
||||||
furi_hal_interrupt_disable(index);
|
furi_hal_interrupt_disable(index);
|
||||||
furi_hal_interrupt_clear_pending(index);
|
furi_hal_interrupt_clear_pending(index);
|
||||||
}
|
}
|
||||||
|
|||||||
@ -36,7 +36,7 @@ PLACE_IN_SECTION("MB_MEM2") uint32_t __furi_check_registers[13] = {0};
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
#define RESTORE_REGISTERS_AND_HALT_MCU(debug) \
|
#define RESTORE_REGISTERS_AND_HALT_MCU(debug) \
|
||||||
register const bool r0 asm("r0") = debug; \
|
register bool r0 asm("r0") = debug; \
|
||||||
asm volatile("cbnz r0, with_debugger%= \n" \
|
asm volatile("cbnz r0, with_debugger%= \n" \
|
||||||
"ldr r12, =__furi_check_registers\n" \
|
"ldr r12, =__furi_check_registers\n" \
|
||||||
"ldm r12, {r0-r11} \n" \
|
"ldm r12, {r0-r11} \n" \
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user