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