[FL-1490] FuriHal: crypto api. Crypto cli tool. (#702)
* 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
This commit is contained in:
@@ -3,10 +3,7 @@
|
||||
#include <furi-hal-console.h>
|
||||
#include <stdio.h>
|
||||
|
||||
void __furi_abort(void);
|
||||
|
||||
void __furi_print_name(void) {
|
||||
furi_hal_console_puts("\r\n\033[0;31m[E]");
|
||||
if(task_is_isr_context()) {
|
||||
furi_hal_console_puts("[ISR] ");
|
||||
} else {
|
||||
@@ -19,13 +16,6 @@ void __furi_print_name(void) {
|
||||
furi_hal_console_puts("] ");
|
||||
}
|
||||
}
|
||||
furi_hal_console_puts("\033[0m");
|
||||
}
|
||||
|
||||
void __furi_check(void) {
|
||||
__furi_print_name();
|
||||
furi_hal_console_puts("assertion failed\r\n");
|
||||
__furi_abort();
|
||||
}
|
||||
|
||||
void __furi_abort(void) {
|
||||
@@ -33,4 +23,13 @@ void __furi_abort(void) {
|
||||
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();
|
||||
}
|
||||
|
@@ -4,40 +4,18 @@
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
// Find how to how get function's pretty name
|
||||
#ifndef __FURI_CHECK_FUNC
|
||||
// Use g++'s demangled names in C++
|
||||
#if defined __cplusplus && defined __GNUC__
|
||||
#define __FURI_CHECK_FUNC __PRETTY_FUNCTION__
|
||||
|
||||
// C99 requires the use of __func__
|
||||
#elif __STDC_VERSION__ >= 199901L
|
||||
#define __FURI_CHECK_FUNC __func__
|
||||
|
||||
// Older versions of gcc don't have __func__ but can use __FUNCTION__
|
||||
#elif __GNUC__ >= 2
|
||||
#define __FURI_CHECK_FUNC __FUNCTION__
|
||||
|
||||
// failed to detect __func__ support
|
||||
#else
|
||||
#define __FURI_CHECK_FUNC ((char*)0)
|
||||
#endif
|
||||
#endif
|
||||
// !__FURI_CHECK_FUNC
|
||||
|
||||
// We have two levels of assertion
|
||||
// One - furi_check, which always runs, the only difference is in the level of debug information
|
||||
// The second is furi_assert, which doesn't compile in release mode
|
||||
#define furi_check(__e) ((__e) ? (void)0 : __furi_check())
|
||||
/** Check condition and crash if check failed */
|
||||
#define furi_check(__e) ((__e) ? (void)0 : furi_crash("fury_check failed\r\n"))
|
||||
|
||||
/** Only in debug build: Assert condition and crash if assert failed */
|
||||
#ifdef NDEBUG
|
||||
#define furi_assert(__e) ((void)0)
|
||||
#else
|
||||
#define furi_assert(__e) ((__e) ? (void)0 : __furi_check())
|
||||
#define furi_assert(__e) ((__e) ? (void)0 : furi_crash("furi_assert failed\r\n"))
|
||||
#endif
|
||||
// !NDEBUG
|
||||
|
||||
void __furi_check(void);
|
||||
/** Crash system */
|
||||
void furi_crash(const char* message);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
|
Reference in New Issue
Block a user