 66f9d946ae
			
		
	
	
		66f9d946ae
		
			
		
	
	
	
	
		
			
			* FuriHal: crypto layer * Furi: add crash routine. * FuriHal: crypto api. Crypto: cli command to manipulate secure enclave and encrypt/decrypt plain text. * DeviceInfo: secure enclave verification. * Rename original to enclave_valid * Update expected enclave signature to match production keys * F7: remove unused files
		
			
				
	
	
		
			36 lines
		
	
	
		
			927 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			36 lines
		
	
	
		
			927 B
		
	
	
	
		
			C
		
	
	
	
	
	
| #include "check.h"
 | |
| #include "furi-hal-task.h"
 | |
| #include <furi-hal-console.h>
 | |
| #include <stdio.h>
 | |
| 
 | |
| void __furi_print_name(void) {
 | |
|     if(task_is_isr_context()) {
 | |
|         furi_hal_console_puts("[ISR] ");
 | |
|     } else {
 | |
|         const char* name = osThreadGetName(osThreadGetId());
 | |
|         if(name == NULL) {
 | |
|             furi_hal_console_puts("[main] ");
 | |
|         } else {
 | |
|             furi_hal_console_puts("[");
 | |
|             furi_hal_console_puts(name);
 | |
|             furi_hal_console_puts("] ");
 | |
|         }
 | |
|     }
 | |
| }
 | |
| 
 | |
| void __furi_abort(void) {
 | |
|     __disable_irq();
 | |
|     asm("bkpt 1");
 | |
|     while(1) {
 | |
|     }
 | |
| }
 | |
| 
 | |
| void furi_crash(const char* message) {
 | |
|     furi_hal_console_puts("\r\n\033[0;31m[CRASH]");
 | |
|     __furi_print_name();
 | |
|     furi_hal_console_puts(message ? message : "Programming Error");
 | |
|     furi_hal_console_puts("\r\nSystem halted. Connect debugger for more info\r\n");
 | |
|     furi_hal_console_puts("\033[0m\r\n");
 | |
|     __furi_abort();
 | |
| }
 |