furi_hal_resources.c 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  1. #include <furi_hal_resources.h>
  2. #include <furi.h>
  3. #include <stm32wbxx_ll_rcc.h>
  4. #include <stm32wbxx_ll_pwr.h>
  5. const GpioPin vibro_gpio = {.port = VIBRO_GPIO_Port, .pin = VIBRO_Pin};
  6. const GpioPin ibutton_gpio = {.port = iBTN_GPIO_Port, .pin = iBTN_Pin};
  7. const GpioPin gpio_cc1101_g0 = {.port = CC1101_G0_GPIO_Port, .pin = CC1101_G0_Pin};
  8. const GpioPin gpio_rf_sw_0 = {.port = RF_SW_0_GPIO_Port, .pin = RF_SW_0_Pin};
  9. const GpioPin gpio_subghz_cs = {.port = CC1101_CS_GPIO_Port, .pin = CC1101_CS_Pin};
  10. const GpioPin gpio_display_cs = {.port = DISPLAY_CS_GPIO_Port, .pin = DISPLAY_CS_Pin};
  11. const GpioPin gpio_display_rst_n = {.port = DISPLAY_RST_GPIO_Port, .pin = DISPLAY_RST_Pin};
  12. const GpioPin gpio_display_di = {.port = DISPLAY_DI_GPIO_Port, .pin = DISPLAY_DI_Pin};
  13. const GpioPin gpio_sdcard_cs = {.port = SD_CS_GPIO_Port, .pin = SD_CS_Pin};
  14. const GpioPin gpio_sdcard_cd = {.port = SD_CD_GPIO_Port, .pin = SD_CD_Pin};
  15. const GpioPin gpio_nfc_cs = {.port = NFC_CS_GPIO_Port, .pin = NFC_CS_Pin};
  16. const GpioPin gpio_button_up = {.port = GPIOB, .pin = LL_GPIO_PIN_10};
  17. const GpioPin gpio_button_down = {.port = GPIOC, .pin = LL_GPIO_PIN_6};
  18. const GpioPin gpio_button_right = {.port = GPIOB, .pin = LL_GPIO_PIN_12};
  19. const GpioPin gpio_button_left = {.port = GPIOB, .pin = LL_GPIO_PIN_11};
  20. const GpioPin gpio_button_ok = {.port = GPIOH, .pin = LL_GPIO_PIN_3};
  21. const GpioPin gpio_button_back = {.port = GPIOC, .pin = LL_GPIO_PIN_13};
  22. const GpioPin gpio_spi_d_miso = {.port = SPI_D_MISO_GPIO_Port, .pin = SPI_D_MISO_Pin};
  23. const GpioPin gpio_spi_d_mosi = {.port = SPI_D_MOSI_GPIO_Port, .pin = SPI_D_MOSI_Pin};
  24. const GpioPin gpio_spi_d_sck = {.port = SPI_D_SCK_GPIO_Port, .pin = SPI_D_SCK_Pin};
  25. const GpioPin gpio_spi_r_miso = {.port = SPI_R_MISO_GPIO_Port, .pin = SPI_R_MISO_Pin};
  26. const GpioPin gpio_spi_r_mosi = {.port = SPI_R_MOSI_GPIO_Port, .pin = SPI_R_MOSI_Pin};
  27. const GpioPin gpio_spi_r_sck = {.port = SPI_R_SCK_GPIO_Port, .pin = SPI_R_SCK_Pin};
  28. const GpioPin gpio_ext_pc0 = {.port = GPIOC, .pin = LL_GPIO_PIN_0};
  29. const GpioPin gpio_ext_pc1 = {.port = GPIOC, .pin = LL_GPIO_PIN_1};
  30. const GpioPin gpio_ext_pc3 = {.port = GPIOC, .pin = LL_GPIO_PIN_3};
  31. const GpioPin gpio_ext_pb2 = {.port = GPIOB, .pin = LL_GPIO_PIN_2};
  32. const GpioPin gpio_ext_pb3 = {.port = GPIOB, .pin = LL_GPIO_PIN_3};
  33. const GpioPin gpio_ext_pa4 = {.port = GPIOA, .pin = LL_GPIO_PIN_4};
  34. const GpioPin gpio_ext_pa6 = {.port = GPIOA, .pin = LL_GPIO_PIN_6};
  35. const GpioPin gpio_ext_pa7 = {.port = GPIOA, .pin = LL_GPIO_PIN_7};
  36. const GpioPin gpio_rfid_pull = {.port = RFID_PULL_GPIO_Port, .pin = RFID_PULL_Pin};
  37. const GpioPin gpio_rfid_carrier_out = {.port = RFID_OUT_GPIO_Port, .pin = RFID_OUT_Pin};
  38. const GpioPin gpio_rfid_data_in = {.port = RFID_RF_IN_GPIO_Port, .pin = RFID_RF_IN_Pin};
  39. const GpioPin gpio_rfid_carrier = {.port = RFID_CARRIER_GPIO_Port, .pin = RFID_CARRIER_Pin};
  40. const GpioPin gpio_infrared_rx = {.port = IR_RX_GPIO_Port, .pin = IR_RX_Pin};
  41. const GpioPin gpio_infrared_tx = {.port = IR_TX_GPIO_Port, .pin = IR_TX_Pin};
  42. const GpioPin gpio_usart_tx = {.port = USART1_TX_Port, .pin = USART1_TX_Pin};
  43. const GpioPin gpio_usart_rx = {.port = USART1_RX_Port, .pin = USART1_RX_Pin};
  44. const GpioPin gpio_i2c_power_sda = {.port = GPIOA, .pin = LL_GPIO_PIN_10};
  45. const GpioPin gpio_i2c_power_scl = {.port = GPIOA, .pin = LL_GPIO_PIN_9};
  46. const GpioPin gpio_speaker = {.port = GPIOB, .pin = LL_GPIO_PIN_8};
  47. const GpioPin periph_power = {.port = PERIPH_POWER_GPIO_Port, .pin = PERIPH_POWER_Pin};
  48. const GpioPin gpio_usb_dm = {.port = GPIOA, .pin = LL_GPIO_PIN_11};
  49. const GpioPin gpio_usb_dp = {.port = GPIOA, .pin = LL_GPIO_PIN_12};
  50. const InputPin input_pins[] = {
  51. {.gpio = &gpio_button_up, .key = InputKeyUp, .inverted = true, .name = "Up"},
  52. {.gpio = &gpio_button_down, .key = InputKeyDown, .inverted = true, .name = "Down"},
  53. {.gpio = &gpio_button_right, .key = InputKeyRight, .inverted = true, .name = "Right"},
  54. {.gpio = &gpio_button_left, .key = InputKeyLeft, .inverted = true, .name = "Left"},
  55. {.gpio = &gpio_button_ok, .key = InputKeyOk, .inverted = false, .name = "Ok"},
  56. {.gpio = &gpio_button_back, .key = InputKeyBack, .inverted = true, .name = "Back"},
  57. };
  58. const size_t input_pins_count = sizeof(input_pins) / sizeof(InputPin);
  59. void furi_hal_resources_init_early() {
  60. furi_hal_gpio_init(&gpio_button_left, GpioModeInput, GpioPullUp, GpioSpeedLow);
  61. // Display pins
  62. furi_hal_gpio_write(&gpio_display_rst_n, 1);
  63. furi_hal_gpio_init_simple(&gpio_display_rst_n, GpioModeOutputPushPull);
  64. furi_hal_gpio_init_simple(&gpio_display_di, GpioModeOutputPushPull);
  65. // Alternative pull configuration for shutdown
  66. SET_BIT(PWR->PUCRB, DISPLAY_RST_Pin);
  67. CLEAR_BIT(PWR->PDCRB, DISPLAY_RST_Pin);
  68. SET_BIT(PWR->CR3, PWR_CR3_APC);
  69. // Hard reset USB
  70. furi_hal_gpio_init_simple(&gpio_usb_dm, GpioModeOutputOpenDrain);
  71. furi_hal_gpio_init_simple(&gpio_usb_dp, GpioModeOutputOpenDrain);
  72. furi_hal_gpio_write(&gpio_usb_dm, 0);
  73. furi_hal_gpio_write(&gpio_usb_dp, 0);
  74. // External header pins
  75. furi_hal_gpio_init(&gpio_ext_pc0, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
  76. furi_hal_gpio_init(&gpio_ext_pc1, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
  77. furi_hal_gpio_init(&gpio_ext_pc3, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
  78. furi_hal_gpio_init(&gpio_ext_pb2, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
  79. furi_hal_gpio_init(&gpio_ext_pb3, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
  80. furi_hal_gpio_init(&gpio_ext_pa4, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
  81. furi_hal_gpio_init(&gpio_ext_pa6, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
  82. furi_hal_gpio_init(&gpio_ext_pa7, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
  83. }
  84. void furi_hal_resources_deinit_early() {
  85. }
  86. void furi_hal_resources_init() {
  87. // Button pins
  88. for(size_t i = 0; i < input_pins_count; i++) {
  89. furi_hal_gpio_init(
  90. input_pins[i].gpio, GpioModeInterruptRiseFall, GpioPullUp, GpioSpeedLow);
  91. }
  92. // Display pins
  93. furi_hal_gpio_init(&gpio_display_rst_n, GpioModeOutputPushPull, GpioPullNo, GpioSpeedLow);
  94. furi_hal_gpio_write(&gpio_display_rst_n, 0);
  95. furi_hal_gpio_init(&gpio_display_di, GpioModeOutputPushPull, GpioPullNo, GpioSpeedLow);
  96. furi_hal_gpio_write(&gpio_display_di, 0);
  97. // SD pins
  98. furi_hal_gpio_init(&gpio_sdcard_cd, GpioModeInput, GpioPullNo, GpioSpeedLow);
  99. furi_hal_gpio_write(&gpio_sdcard_cd, 0);
  100. furi_hal_gpio_init(&vibro_gpio, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
  101. furi_hal_gpio_init(&ibutton_gpio, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
  102. furi_hal_gpio_init(&gpio_rfid_pull, GpioModeInterruptRise, GpioPullNo, GpioSpeedLow);
  103. furi_hal_gpio_init(&gpio_rf_sw_0, GpioModeOutputPushPull, GpioPullNo, GpioSpeedLow);
  104. furi_hal_gpio_init(&periph_power, GpioModeOutputOpenDrain, GpioPullNo, GpioSpeedLow);
  105. NVIC_SetPriority(EXTI0_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(), 5, 0));
  106. NVIC_EnableIRQ(EXTI0_IRQn);
  107. NVIC_SetPriority(EXTI1_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(), 5, 0));
  108. NVIC_EnableIRQ(EXTI1_IRQn);
  109. NVIC_SetPriority(EXTI2_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(), 5, 0));
  110. NVIC_EnableIRQ(EXTI2_IRQn);
  111. NVIC_SetPriority(EXTI3_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(), 5, 0));
  112. NVIC_EnableIRQ(EXTI3_IRQn);
  113. NVIC_SetPriority(EXTI4_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(), 5, 0));
  114. NVIC_EnableIRQ(EXTI4_IRQn);
  115. NVIC_SetPriority(EXTI9_5_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(), 5, 0));
  116. NVIC_EnableIRQ(EXTI9_5_IRQn);
  117. NVIC_SetPriority(EXTI15_10_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(), 5, 0));
  118. NVIC_EnableIRQ(EXTI15_10_IRQn);
  119. }