check.c 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. #include "check.h"
  2. #include "furi_hal_task.h"
  3. #include <furi_hal_console.h>
  4. #include <furi_hal_rtc.h>
  5. #include <stdio.h>
  6. static void __furi_print_name() {
  7. if(task_is_isr_context()) {
  8. furi_hal_console_puts("[ISR] ");
  9. } else {
  10. const char* name = osThreadGetName(osThreadGetId());
  11. if(name == NULL) {
  12. furi_hal_console_puts("[main] ");
  13. } else {
  14. furi_hal_console_puts("[");
  15. furi_hal_console_puts(name);
  16. furi_hal_console_puts("] ");
  17. }
  18. }
  19. }
  20. static void __furi_halt() {
  21. asm volatile("loop: \n"
  22. "bkpt 0x00 \n"
  23. "wfi \n"
  24. "b loop \n"
  25. :
  26. :
  27. : "memory");
  28. }
  29. void furi_crash(const char* message) {
  30. __disable_irq();
  31. if(message == NULL) {
  32. message = "Fatal Error";
  33. }
  34. furi_hal_console_puts("\r\n\033[0;31m[CRASH]");
  35. __furi_print_name();
  36. furi_hal_console_puts(message);
  37. #ifdef FURI_DEBUG
  38. furi_hal_console_puts("\r\nSystem halted. Connect debugger for more info\r\n");
  39. furi_hal_console_puts("\033[0m\r\n");
  40. __furi_halt();
  41. #else
  42. furi_hal_rtc_set_fault_data((uint32_t)message);
  43. furi_hal_console_puts("\r\nRebooting system.\r\n");
  44. furi_hal_console_puts("\033[0m\r\n");
  45. NVIC_SystemReset();
  46. #endif
  47. }
  48. void furi_halt(const char* message) {
  49. __disable_irq();
  50. if(message == NULL) {
  51. message = "System halt requested.";
  52. }
  53. furi_hal_console_puts("\r\n\033[0;31m[HALT]");
  54. __furi_print_name();
  55. furi_hal_console_puts(message);
  56. furi_hal_console_puts("\r\nSystem halted. Bye-bye!\r\n");
  57. furi_hal_console_puts("\033[0m\r\n");
  58. __furi_halt();
  59. }