furi_hal.c 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. #include <furi_hal.h>
  2. #include <stm32wbxx_ll_cortex.h>
  3. #include <fatfs.h>
  4. #define TAG "FuriHal"
  5. void furi_hal_init_early() {
  6. furi_hal_clock_init_early();
  7. furi_hal_delay_init();
  8. furi_hal_resources_init_early();
  9. furi_hal_os_init();
  10. furi_hal_spi_init_early();
  11. furi_hal_i2c_init_early();
  12. furi_hal_light_init();
  13. furi_hal_rtc_init_early();
  14. }
  15. void furi_hal_deinit_early() {
  16. furi_hal_rtc_deinit_early();
  17. furi_hal_i2c_deinit_early();
  18. furi_hal_spi_deinit_early();
  19. furi_hal_resources_deinit_early();
  20. furi_hal_clock_deinit_early();
  21. }
  22. void furi_hal_init() {
  23. furi_hal_clock_init();
  24. furi_hal_console_init();
  25. furi_hal_rtc_init();
  26. furi_hal_interrupt_init();
  27. furi_hal_flash_init();
  28. furi_hal_resources_init();
  29. FURI_LOG_I(TAG, "GPIO OK");
  30. furi_hal_version_init();
  31. furi_hal_spi_init();
  32. furi_hal_ibutton_init();
  33. FURI_LOG_I(TAG, "iButton OK");
  34. furi_hal_speaker_init();
  35. FURI_LOG_I(TAG, "Speaker OK");
  36. furi_hal_crypto_init();
  37. // USB
  38. #ifndef FURI_RAM_EXEC
  39. furi_hal_usb_init();
  40. FURI_LOG_I(TAG, "USB OK");
  41. #endif
  42. furi_hal_i2c_init();
  43. // High Level
  44. furi_hal_power_init();
  45. furi_hal_light_init();
  46. #ifndef FURI_RAM_EXEC
  47. furi_hal_vibro_init();
  48. furi_hal_subghz_init();
  49. furi_hal_nfc_init();
  50. furi_hal_rfid_init();
  51. #endif
  52. furi_hal_bt_init();
  53. furi_hal_compress_icon_init();
  54. // FatFS driver initialization
  55. MX_FATFS_Init();
  56. FURI_LOG_I(TAG, "FATFS OK");
  57. // Partial null pointer dereference protection
  58. LL_MPU_Disable();
  59. LL_MPU_ConfigRegion(
  60. LL_MPU_REGION_NUMBER0,
  61. 0x00,
  62. 0x0,
  63. LL_MPU_REGION_SIZE_1MB | LL_MPU_REGION_PRIV_RO_URO | LL_MPU_ACCESS_BUFFERABLE |
  64. LL_MPU_ACCESS_CACHEABLE | LL_MPU_ACCESS_SHAREABLE | LL_MPU_TEX_LEVEL1 |
  65. LL_MPU_INSTRUCTION_ACCESS_ENABLE);
  66. LL_MPU_Enable(LL_MPU_CTRL_PRIVILEGED_DEFAULT);
  67. }
  68. void furi_hal_switch(void* address) {
  69. __set_BASEPRI(0);
  70. asm volatile("ldr r3, [%0] \n"
  71. "msr msp, r3 \n"
  72. "ldr r3, [%1] \n"
  73. "mov pc, r3 \n"
  74. :
  75. : "r"(address), "r"(address + 0x4)
  76. : "r3");
  77. }