check.c 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  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. 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. void __furi_halt() {
  21. asm volatile(
  22. #ifdef FURI_DEBUG
  23. "bkpt 0x00 \n"
  24. #endif
  25. "loop: \n"
  26. "wfi \n"
  27. "b loop \n"
  28. :
  29. :
  30. : "memory");
  31. }
  32. void furi_crash(const char* message) {
  33. __disable_irq();
  34. if(message == NULL) {
  35. message = "Fatal Error";
  36. }
  37. furi_hal_console_puts("\r\n\033[0;31m[CRASH]");
  38. __furi_print_name();
  39. furi_hal_console_puts(message);
  40. #ifdef FURI_DEBUG
  41. furi_hal_console_puts("\r\nSystem halted. Connect debugger for more info\r\n");
  42. furi_hal_console_puts("\033[0m\r\n");
  43. __furi_halt();
  44. #else
  45. furi_hal_rtc_set_fault_data((uint32_t)message);
  46. furi_hal_console_puts("\r\nRebooting system.\r\n");
  47. furi_hal_console_puts("\033[0m\r\n");
  48. NVIC_SystemReset();
  49. #endif
  50. }
  51. void furi_halt(const char* message) {
  52. __disable_irq();
  53. if(message == NULL) {
  54. message = "System halt requested.";
  55. }
  56. furi_hal_console_puts("\r\n\033[0;31m[HALT]");
  57. __furi_print_name();
  58. furi_hal_console_puts(message);
  59. furi_hal_console_puts("\r\nSystem halted. Bye-bye!\r\n");
  60. furi_hal_console_puts("\033[0m\r\n");
  61. __furi_halt();
  62. }