check.c 1.7 KB

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