2022-01-05 19:10:18 +03:00
|
|
|
#include <furi_hal_resources.h>
|
2023-05-29 19:05:57 +03:00
|
|
|
#include <furi_hal_bus.h>
|
2021-09-10 05:19:02 +03:00
|
|
|
#include <furi.h>
|
|
|
|
|
[FL-2399, FL-2261] Tickless sleep shenanigans (#1168)
* Disable USART in sleep
* Restore UART state on suspend/resume
* FuriHal: Enable stop mode and add insomnia to I2C and SPI
* Remove IDLE interrupt
* FuriHal: add FPU isr and disable all FPU interrupt, add core2 stop mode configuration on deep sleep
* FuriHal: tie stop mode debug with debug rtc flag
* FuriHal: adjust flash latency on clock switch, tie mcu debug with RTC debug flag
* FuriHal: move resource init to early stage
* Add EXTI pending check, enable debug traps with compile-time flag
* Wrap sleep debug functions in conditional compilation
* Remove erroneous changed
* Do not use CSS, remove it from everywhere
* Enable/disable USB on VBUS connect (prototype)
* FuriHal: add LPMS and DEEPSLEEP magic, workaround state inconsistency between cores
* FuriHal: honor c1 LMPS
* USB mode switch fix
* Applications: add flags and insomnia bypass system
* Correct spelling
* FuriHal: cleanup insomnia usage, reset sleep flags on wakeup, add shutdown api
* FuriHal: extra check on reinit request
* FuriHal: rename gpio_display_rst pin to gpio_display_rst_n
* FuriHal: add debug HAL
* FuriHal: add some magic to core2 reload procedure, fix issue with crash on ble keyboard exit
* FuriHal: cleanup ble glue, add BLE_GLUE_DEBUG flag
* FuriHal: ble reinit API, move os timer to LPTIM1 for deep sleep capability, shutdown that works
* FuriHal: take insomnia while shutdown
* Remove USB switch on/off on VBUS change
* Better tick skew handling
* Improve tick consistency under load
* Add USB_HP dummy IRQ handler
* Move interrupt check closer to sleep
* Clean up includes
* Re-enable Insomnia globally
* FuriHal: enable CSS
* FuriHal: remove questionable core2 clock shenanigans
* FuriHal: use core1 RCC registers in idle timer config
* FuriHal: return back CSS handlers, add lptim isr dispatching
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
Co-authored-by: nminaylov <nm29719@gmail.com>
2022-04-29 16:29:51 +03:00
|
|
|
#include <stm32wbxx_ll_rcc.h>
|
|
|
|
#include <stm32wbxx_ll_pwr.h>
|
|
|
|
|
2023-03-22 20:00:48 +03:00
|
|
|
#define TAG "FuriHalResources"
|
|
|
|
|
2023-04-14 14:45:23 +03:00
|
|
|
const GpioPin gpio_swdio = {.port = GPIOA, .pin = LL_GPIO_PIN_13};
|
|
|
|
const GpioPin gpio_swclk = {.port = GPIOA, .pin = LL_GPIO_PIN_14};
|
|
|
|
|
2023-04-06 12:06:19 +03:00
|
|
|
const GpioPin gpio_vibro = {.port = VIBRO_GPIO_Port, .pin = VIBRO_Pin};
|
|
|
|
const GpioPin gpio_ibutton = {.port = iBTN_GPIO_Port, .pin = iBTN_Pin};
|
2021-09-10 05:19:02 +03:00
|
|
|
|
|
|
|
const GpioPin gpio_cc1101_g0 = {.port = CC1101_G0_GPIO_Port, .pin = CC1101_G0_Pin};
|
|
|
|
const GpioPin gpio_rf_sw_0 = {.port = RF_SW_0_GPIO_Port, .pin = RF_SW_0_Pin};
|
|
|
|
|
|
|
|
const GpioPin gpio_subghz_cs = {.port = CC1101_CS_GPIO_Port, .pin = CC1101_CS_Pin};
|
|
|
|
const GpioPin gpio_display_cs = {.port = DISPLAY_CS_GPIO_Port, .pin = DISPLAY_CS_Pin};
|
[FL-2399, FL-2261] Tickless sleep shenanigans (#1168)
* Disable USART in sleep
* Restore UART state on suspend/resume
* FuriHal: Enable stop mode and add insomnia to I2C and SPI
* Remove IDLE interrupt
* FuriHal: add FPU isr and disable all FPU interrupt, add core2 stop mode configuration on deep sleep
* FuriHal: tie stop mode debug with debug rtc flag
* FuriHal: adjust flash latency on clock switch, tie mcu debug with RTC debug flag
* FuriHal: move resource init to early stage
* Add EXTI pending check, enable debug traps with compile-time flag
* Wrap sleep debug functions in conditional compilation
* Remove erroneous changed
* Do not use CSS, remove it from everywhere
* Enable/disable USB on VBUS connect (prototype)
* FuriHal: add LPMS and DEEPSLEEP magic, workaround state inconsistency between cores
* FuriHal: honor c1 LMPS
* USB mode switch fix
* Applications: add flags and insomnia bypass system
* Correct spelling
* FuriHal: cleanup insomnia usage, reset sleep flags on wakeup, add shutdown api
* FuriHal: extra check on reinit request
* FuriHal: rename gpio_display_rst pin to gpio_display_rst_n
* FuriHal: add debug HAL
* FuriHal: add some magic to core2 reload procedure, fix issue with crash on ble keyboard exit
* FuriHal: cleanup ble glue, add BLE_GLUE_DEBUG flag
* FuriHal: ble reinit API, move os timer to LPTIM1 for deep sleep capability, shutdown that works
* FuriHal: take insomnia while shutdown
* Remove USB switch on/off on VBUS change
* Better tick skew handling
* Improve tick consistency under load
* Add USB_HP dummy IRQ handler
* Move interrupt check closer to sleep
* Clean up includes
* Re-enable Insomnia globally
* FuriHal: enable CSS
* FuriHal: remove questionable core2 clock shenanigans
* FuriHal: use core1 RCC registers in idle timer config
* FuriHal: return back CSS handlers, add lptim isr dispatching
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
Co-authored-by: nminaylov <nm29719@gmail.com>
2022-04-29 16:29:51 +03:00
|
|
|
const GpioPin gpio_display_rst_n = {.port = DISPLAY_RST_GPIO_Port, .pin = DISPLAY_RST_Pin};
|
2021-09-10 05:19:02 +03:00
|
|
|
const GpioPin gpio_display_di = {.port = DISPLAY_DI_GPIO_Port, .pin = DISPLAY_DI_Pin};
|
|
|
|
const GpioPin gpio_sdcard_cs = {.port = SD_CS_GPIO_Port, .pin = SD_CS_Pin};
|
2022-03-30 18:23:40 +03:00
|
|
|
const GpioPin gpio_sdcard_cd = {.port = SD_CD_GPIO_Port, .pin = SD_CD_Pin};
|
2021-09-10 05:19:02 +03:00
|
|
|
const GpioPin gpio_nfc_cs = {.port = NFC_CS_GPIO_Port, .pin = NFC_CS_Pin};
|
|
|
|
|
2022-03-30 18:23:40 +03:00
|
|
|
const GpioPin gpio_button_up = {.port = GPIOB, .pin = LL_GPIO_PIN_10};
|
|
|
|
const GpioPin gpio_button_down = {.port = GPIOC, .pin = LL_GPIO_PIN_6};
|
|
|
|
const GpioPin gpio_button_right = {.port = GPIOB, .pin = LL_GPIO_PIN_12};
|
|
|
|
const GpioPin gpio_button_left = {.port = GPIOB, .pin = LL_GPIO_PIN_11};
|
|
|
|
const GpioPin gpio_button_ok = {.port = GPIOH, .pin = LL_GPIO_PIN_3};
|
|
|
|
const GpioPin gpio_button_back = {.port = GPIOC, .pin = LL_GPIO_PIN_13};
|
|
|
|
|
2021-09-10 05:19:02 +03:00
|
|
|
const GpioPin gpio_spi_d_miso = {.port = SPI_D_MISO_GPIO_Port, .pin = SPI_D_MISO_Pin};
|
|
|
|
const GpioPin gpio_spi_d_mosi = {.port = SPI_D_MOSI_GPIO_Port, .pin = SPI_D_MOSI_Pin};
|
|
|
|
const GpioPin gpio_spi_d_sck = {.port = SPI_D_SCK_GPIO_Port, .pin = SPI_D_SCK_Pin};
|
|
|
|
const GpioPin gpio_spi_r_miso = {.port = SPI_R_MISO_GPIO_Port, .pin = SPI_R_MISO_Pin};
|
|
|
|
const GpioPin gpio_spi_r_mosi = {.port = SPI_R_MOSI_GPIO_Port, .pin = SPI_R_MOSI_Pin};
|
|
|
|
const GpioPin gpio_spi_r_sck = {.port = SPI_R_SCK_GPIO_Port, .pin = SPI_R_SCK_Pin};
|
|
|
|
|
2022-03-30 18:23:40 +03:00
|
|
|
const GpioPin gpio_ext_pc0 = {.port = GPIOC, .pin = LL_GPIO_PIN_0};
|
|
|
|
const GpioPin gpio_ext_pc1 = {.port = GPIOC, .pin = LL_GPIO_PIN_1};
|
|
|
|
const GpioPin gpio_ext_pc3 = {.port = GPIOC, .pin = LL_GPIO_PIN_3};
|
|
|
|
const GpioPin gpio_ext_pb2 = {.port = GPIOB, .pin = LL_GPIO_PIN_2};
|
|
|
|
const GpioPin gpio_ext_pb3 = {.port = GPIOB, .pin = LL_GPIO_PIN_3};
|
|
|
|
const GpioPin gpio_ext_pa4 = {.port = GPIOA, .pin = LL_GPIO_PIN_4};
|
|
|
|
const GpioPin gpio_ext_pa6 = {.port = GPIOA, .pin = LL_GPIO_PIN_6};
|
|
|
|
const GpioPin gpio_ext_pa7 = {.port = GPIOA, .pin = LL_GPIO_PIN_7};
|
2021-09-10 05:19:02 +03:00
|
|
|
|
2022-06-20 17:54:48 +03:00
|
|
|
const GpioPin gpio_nfc_irq_rfid_pull = {.port = RFID_PULL_GPIO_Port, .pin = RFID_PULL_Pin};
|
2021-09-10 05:19:02 +03:00
|
|
|
const GpioPin gpio_rfid_carrier_out = {.port = RFID_OUT_GPIO_Port, .pin = RFID_OUT_Pin};
|
|
|
|
const GpioPin gpio_rfid_data_in = {.port = RFID_RF_IN_GPIO_Port, .pin = RFID_RF_IN_Pin};
|
|
|
|
const GpioPin gpio_rfid_carrier = {.port = RFID_CARRIER_GPIO_Port, .pin = RFID_CARRIER_Pin};
|
|
|
|
|
2022-02-25 18:22:58 +03:00
|
|
|
const GpioPin gpio_infrared_rx = {.port = IR_RX_GPIO_Port, .pin = IR_RX_Pin};
|
|
|
|
const GpioPin gpio_infrared_tx = {.port = IR_TX_GPIO_Port, .pin = IR_TX_Pin};
|
2021-09-10 05:19:02 +03:00
|
|
|
|
|
|
|
const GpioPin gpio_usart_tx = {.port = USART1_TX_Port, .pin = USART1_TX_Pin};
|
|
|
|
const GpioPin gpio_usart_rx = {.port = USART1_RX_Port, .pin = USART1_RX_Pin};
|
2021-11-28 21:28:19 +03:00
|
|
|
|
|
|
|
const GpioPin gpio_i2c_power_sda = {.port = GPIOA, .pin = LL_GPIO_PIN_10};
|
|
|
|
const GpioPin gpio_i2c_power_scl = {.port = GPIOA, .pin = LL_GPIO_PIN_9};
|
2022-03-23 20:59:20 +03:00
|
|
|
|
|
|
|
const GpioPin gpio_speaker = {.port = GPIOB, .pin = LL_GPIO_PIN_8};
|
2022-03-29 20:37:23 +03:00
|
|
|
|
2023-04-06 12:06:19 +03:00
|
|
|
const GpioPin gpio_periph_power = {.port = GPIOA, .pin = LL_GPIO_PIN_3};
|
2022-03-29 20:37:23 +03:00
|
|
|
|
2022-04-13 23:50:25 +03:00
|
|
|
const GpioPin gpio_usb_dm = {.port = GPIOA, .pin = LL_GPIO_PIN_11};
|
|
|
|
const GpioPin gpio_usb_dp = {.port = GPIOA, .pin = LL_GPIO_PIN_12};
|
|
|
|
|
2023-02-07 19:33:05 +03:00
|
|
|
const GpioPinRecord gpio_pins[] = {
|
|
|
|
{.pin = &gpio_ext_pa7, .name = "PA7", .debug = false},
|
|
|
|
{.pin = &gpio_ext_pa6, .name = "PA6", .debug = false},
|
|
|
|
{.pin = &gpio_ext_pa4, .name = "PA4", .debug = false},
|
|
|
|
{.pin = &gpio_ext_pb3, .name = "PB3", .debug = false},
|
|
|
|
{.pin = &gpio_ext_pb2, .name = "PB2", .debug = false},
|
|
|
|
{.pin = &gpio_ext_pc3, .name = "PC3", .debug = false},
|
|
|
|
{.pin = &gpio_ext_pc1, .name = "PC1", .debug = false},
|
|
|
|
{.pin = &gpio_ext_pc0, .name = "PC0", .debug = false},
|
|
|
|
|
|
|
|
/* Dangerous pins, may damage hardware */
|
|
|
|
{.pin = &gpio_usart_rx, .name = "PB7", .debug = true},
|
|
|
|
{.pin = &gpio_speaker, .name = "PB8", .debug = true},
|
2023-06-06 20:52:49 +03:00
|
|
|
{.pin = &gpio_infrared_tx, .name = "PB9", .debug = true},
|
2023-02-07 19:33:05 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
const size_t gpio_pins_count = sizeof(gpio_pins) / sizeof(GpioPinRecord);
|
|
|
|
|
2022-03-29 20:37:23 +03:00
|
|
|
const InputPin input_pins[] = {
|
2022-03-30 18:23:40 +03:00
|
|
|
{.gpio = &gpio_button_up, .key = InputKeyUp, .inverted = true, .name = "Up"},
|
|
|
|
{.gpio = &gpio_button_down, .key = InputKeyDown, .inverted = true, .name = "Down"},
|
|
|
|
{.gpio = &gpio_button_right, .key = InputKeyRight, .inverted = true, .name = "Right"},
|
|
|
|
{.gpio = &gpio_button_left, .key = InputKeyLeft, .inverted = true, .name = "Left"},
|
2022-05-19 19:07:45 +03:00
|
|
|
{.gpio = &gpio_button_ok, .key = InputKeyOk, .inverted = false, .name = "OK"},
|
2022-03-30 18:23:40 +03:00
|
|
|
{.gpio = &gpio_button_back, .key = InputKeyBack, .inverted = true, .name = "Back"},
|
2022-03-29 20:37:23 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
const size_t input_pins_count = sizeof(input_pins) / sizeof(InputPin);
|
2022-03-30 18:23:40 +03:00
|
|
|
|
2023-02-07 18:35:49 +03:00
|
|
|
static void furi_hal_resources_init_input_pins(GpioMode mode) {
|
|
|
|
for(size_t i = 0; i < input_pins_count; i++) {
|
|
|
|
furi_hal_gpio_init(
|
|
|
|
input_pins[i].gpio,
|
|
|
|
mode,
|
|
|
|
(input_pins[i].inverted) ? GpioPullUp : GpioPullDown,
|
|
|
|
GpioSpeedLow);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-04-13 23:50:25 +03:00
|
|
|
void furi_hal_resources_init_early() {
|
2023-05-29 19:05:57 +03:00
|
|
|
furi_hal_bus_enable(FuriHalBusGPIOA);
|
|
|
|
furi_hal_bus_enable(FuriHalBusGPIOB);
|
|
|
|
furi_hal_bus_enable(FuriHalBusGPIOC);
|
|
|
|
furi_hal_bus_enable(FuriHalBusGPIOD);
|
|
|
|
furi_hal_bus_enable(FuriHalBusGPIOE);
|
|
|
|
furi_hal_bus_enable(FuriHalBusGPIOH);
|
|
|
|
|
2023-02-07 18:35:49 +03:00
|
|
|
furi_hal_resources_init_input_pins(GpioModeInput);
|
[FL-2399, FL-2261] Tickless sleep shenanigans (#1168)
* Disable USART in sleep
* Restore UART state on suspend/resume
* FuriHal: Enable stop mode and add insomnia to I2C and SPI
* Remove IDLE interrupt
* FuriHal: add FPU isr and disable all FPU interrupt, add core2 stop mode configuration on deep sleep
* FuriHal: tie stop mode debug with debug rtc flag
* FuriHal: adjust flash latency on clock switch, tie mcu debug with RTC debug flag
* FuriHal: move resource init to early stage
* Add EXTI pending check, enable debug traps with compile-time flag
* Wrap sleep debug functions in conditional compilation
* Remove erroneous changed
* Do not use CSS, remove it from everywhere
* Enable/disable USB on VBUS connect (prototype)
* FuriHal: add LPMS and DEEPSLEEP magic, workaround state inconsistency between cores
* FuriHal: honor c1 LMPS
* USB mode switch fix
* Applications: add flags and insomnia bypass system
* Correct spelling
* FuriHal: cleanup insomnia usage, reset sleep flags on wakeup, add shutdown api
* FuriHal: extra check on reinit request
* FuriHal: rename gpio_display_rst pin to gpio_display_rst_n
* FuriHal: add debug HAL
* FuriHal: add some magic to core2 reload procedure, fix issue with crash on ble keyboard exit
* FuriHal: cleanup ble glue, add BLE_GLUE_DEBUG flag
* FuriHal: ble reinit API, move os timer to LPTIM1 for deep sleep capability, shutdown that works
* FuriHal: take insomnia while shutdown
* Remove USB switch on/off on VBUS change
* Better tick skew handling
* Improve tick consistency under load
* Add USB_HP dummy IRQ handler
* Move interrupt check closer to sleep
* Clean up includes
* Re-enable Insomnia globally
* FuriHal: enable CSS
* FuriHal: remove questionable core2 clock shenanigans
* FuriHal: use core1 RCC registers in idle timer config
* FuriHal: return back CSS handlers, add lptim isr dispatching
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
Co-authored-by: nminaylov <nm29719@gmail.com>
2022-04-29 16:29:51 +03:00
|
|
|
|
2022-07-04 17:26:02 +03:00
|
|
|
// SD Card stepdown control
|
2023-04-06 12:06:19 +03:00
|
|
|
furi_hal_gpio_write(&gpio_periph_power, 1);
|
|
|
|
furi_hal_gpio_init(&gpio_periph_power, GpioModeOutputOpenDrain, GpioPullNo, GpioSpeedLow);
|
2022-07-04 17:26:02 +03:00
|
|
|
|
[FL-2399, FL-2261] Tickless sleep shenanigans (#1168)
* Disable USART in sleep
* Restore UART state on suspend/resume
* FuriHal: Enable stop mode and add insomnia to I2C and SPI
* Remove IDLE interrupt
* FuriHal: add FPU isr and disable all FPU interrupt, add core2 stop mode configuration on deep sleep
* FuriHal: tie stop mode debug with debug rtc flag
* FuriHal: adjust flash latency on clock switch, tie mcu debug with RTC debug flag
* FuriHal: move resource init to early stage
* Add EXTI pending check, enable debug traps with compile-time flag
* Wrap sleep debug functions in conditional compilation
* Remove erroneous changed
* Do not use CSS, remove it from everywhere
* Enable/disable USB on VBUS connect (prototype)
* FuriHal: add LPMS and DEEPSLEEP magic, workaround state inconsistency between cores
* FuriHal: honor c1 LMPS
* USB mode switch fix
* Applications: add flags and insomnia bypass system
* Correct spelling
* FuriHal: cleanup insomnia usage, reset sleep flags on wakeup, add shutdown api
* FuriHal: extra check on reinit request
* FuriHal: rename gpio_display_rst pin to gpio_display_rst_n
* FuriHal: add debug HAL
* FuriHal: add some magic to core2 reload procedure, fix issue with crash on ble keyboard exit
* FuriHal: cleanup ble glue, add BLE_GLUE_DEBUG flag
* FuriHal: ble reinit API, move os timer to LPTIM1 for deep sleep capability, shutdown that works
* FuriHal: take insomnia while shutdown
* Remove USB switch on/off on VBUS change
* Better tick skew handling
* Improve tick consistency under load
* Add USB_HP dummy IRQ handler
* Move interrupt check closer to sleep
* Clean up includes
* Re-enable Insomnia globally
* FuriHal: enable CSS
* FuriHal: remove questionable core2 clock shenanigans
* FuriHal: use core1 RCC registers in idle timer config
* FuriHal: return back CSS handlers, add lptim isr dispatching
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
Co-authored-by: nminaylov <nm29719@gmail.com>
2022-04-29 16:29:51 +03:00
|
|
|
// Display pins
|
|
|
|
furi_hal_gpio_write(&gpio_display_rst_n, 1);
|
|
|
|
furi_hal_gpio_init_simple(&gpio_display_rst_n, GpioModeOutputPushPull);
|
2022-04-13 23:50:25 +03:00
|
|
|
furi_hal_gpio_init_simple(&gpio_display_di, GpioModeOutputPushPull);
|
|
|
|
|
[FL-2399, FL-2261] Tickless sleep shenanigans (#1168)
* Disable USART in sleep
* Restore UART state on suspend/resume
* FuriHal: Enable stop mode and add insomnia to I2C and SPI
* Remove IDLE interrupt
* FuriHal: add FPU isr and disable all FPU interrupt, add core2 stop mode configuration on deep sleep
* FuriHal: tie stop mode debug with debug rtc flag
* FuriHal: adjust flash latency on clock switch, tie mcu debug with RTC debug flag
* FuriHal: move resource init to early stage
* Add EXTI pending check, enable debug traps with compile-time flag
* Wrap sleep debug functions in conditional compilation
* Remove erroneous changed
* Do not use CSS, remove it from everywhere
* Enable/disable USB on VBUS connect (prototype)
* FuriHal: add LPMS and DEEPSLEEP magic, workaround state inconsistency between cores
* FuriHal: honor c1 LMPS
* USB mode switch fix
* Applications: add flags and insomnia bypass system
* Correct spelling
* FuriHal: cleanup insomnia usage, reset sleep flags on wakeup, add shutdown api
* FuriHal: extra check on reinit request
* FuriHal: rename gpio_display_rst pin to gpio_display_rst_n
* FuriHal: add debug HAL
* FuriHal: add some magic to core2 reload procedure, fix issue with crash on ble keyboard exit
* FuriHal: cleanup ble glue, add BLE_GLUE_DEBUG flag
* FuriHal: ble reinit API, move os timer to LPTIM1 for deep sleep capability, shutdown that works
* FuriHal: take insomnia while shutdown
* Remove USB switch on/off on VBUS change
* Better tick skew handling
* Improve tick consistency under load
* Add USB_HP dummy IRQ handler
* Move interrupt check closer to sleep
* Clean up includes
* Re-enable Insomnia globally
* FuriHal: enable CSS
* FuriHal: remove questionable core2 clock shenanigans
* FuriHal: use core1 RCC registers in idle timer config
* FuriHal: return back CSS handlers, add lptim isr dispatching
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
Co-authored-by: nminaylov <nm29719@gmail.com>
2022-04-29 16:29:51 +03:00
|
|
|
// Alternative pull configuration for shutdown
|
|
|
|
SET_BIT(PWR->PUCRB, DISPLAY_RST_Pin);
|
|
|
|
CLEAR_BIT(PWR->PDCRB, DISPLAY_RST_Pin);
|
|
|
|
SET_BIT(PWR->CR3, PWR_CR3_APC);
|
|
|
|
|
2022-04-13 23:50:25 +03:00
|
|
|
// Hard reset USB
|
2022-05-05 12:49:59 +03:00
|
|
|
furi_hal_gpio_write(&gpio_usb_dm, 1);
|
|
|
|
furi_hal_gpio_write(&gpio_usb_dp, 1);
|
2022-04-13 23:50:25 +03:00
|
|
|
furi_hal_gpio_init_simple(&gpio_usb_dm, GpioModeOutputOpenDrain);
|
|
|
|
furi_hal_gpio_init_simple(&gpio_usb_dp, GpioModeOutputOpenDrain);
|
|
|
|
furi_hal_gpio_write(&gpio_usb_dm, 0);
|
|
|
|
furi_hal_gpio_write(&gpio_usb_dp, 0);
|
2022-07-20 13:56:33 +03:00
|
|
|
furi_delay_us(5); // Device Driven disconnect: 2.5us + extra to compensate cables
|
2022-05-05 12:49:59 +03:00
|
|
|
furi_hal_gpio_write(&gpio_usb_dm, 1);
|
|
|
|
furi_hal_gpio_write(&gpio_usb_dp, 1);
|
|
|
|
furi_hal_gpio_init_simple(&gpio_usb_dm, GpioModeAnalog);
|
|
|
|
furi_hal_gpio_init_simple(&gpio_usb_dp, GpioModeAnalog);
|
|
|
|
furi_hal_gpio_write(&gpio_usb_dm, 0);
|
|
|
|
furi_hal_gpio_write(&gpio_usb_dp, 0);
|
[FL-2399, FL-2261] Tickless sleep shenanigans (#1168)
* Disable USART in sleep
* Restore UART state on suspend/resume
* FuriHal: Enable stop mode and add insomnia to I2C and SPI
* Remove IDLE interrupt
* FuriHal: add FPU isr and disable all FPU interrupt, add core2 stop mode configuration on deep sleep
* FuriHal: tie stop mode debug with debug rtc flag
* FuriHal: adjust flash latency on clock switch, tie mcu debug with RTC debug flag
* FuriHal: move resource init to early stage
* Add EXTI pending check, enable debug traps with compile-time flag
* Wrap sleep debug functions in conditional compilation
* Remove erroneous changed
* Do not use CSS, remove it from everywhere
* Enable/disable USB on VBUS connect (prototype)
* FuriHal: add LPMS and DEEPSLEEP magic, workaround state inconsistency between cores
* FuriHal: honor c1 LMPS
* USB mode switch fix
* Applications: add flags and insomnia bypass system
* Correct spelling
* FuriHal: cleanup insomnia usage, reset sleep flags on wakeup, add shutdown api
* FuriHal: extra check on reinit request
* FuriHal: rename gpio_display_rst pin to gpio_display_rst_n
* FuriHal: add debug HAL
* FuriHal: add some magic to core2 reload procedure, fix issue with crash on ble keyboard exit
* FuriHal: cleanup ble glue, add BLE_GLUE_DEBUG flag
* FuriHal: ble reinit API, move os timer to LPTIM1 for deep sleep capability, shutdown that works
* FuriHal: take insomnia while shutdown
* Remove USB switch on/off on VBUS change
* Better tick skew handling
* Improve tick consistency under load
* Add USB_HP dummy IRQ handler
* Move interrupt check closer to sleep
* Clean up includes
* Re-enable Insomnia globally
* FuriHal: enable CSS
* FuriHal: remove questionable core2 clock shenanigans
* FuriHal: use core1 RCC registers in idle timer config
* FuriHal: return back CSS handlers, add lptim isr dispatching
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
Co-authored-by: nminaylov <nm29719@gmail.com>
2022-04-29 16:29:51 +03:00
|
|
|
|
|
|
|
// External header pins
|
|
|
|
furi_hal_gpio_init(&gpio_ext_pc0, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
|
|
|
|
furi_hal_gpio_init(&gpio_ext_pc1, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
|
|
|
|
furi_hal_gpio_init(&gpio_ext_pc3, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
|
|
|
|
furi_hal_gpio_init(&gpio_ext_pb2, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
|
|
|
|
furi_hal_gpio_init(&gpio_ext_pb3, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
|
|
|
|
furi_hal_gpio_init(&gpio_ext_pa4, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
|
|
|
|
furi_hal_gpio_init(&gpio_ext_pa6, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
|
|
|
|
furi_hal_gpio_init(&gpio_ext_pa7, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
|
2022-04-13 23:50:25 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
void furi_hal_resources_deinit_early() {
|
2023-02-07 18:35:49 +03:00
|
|
|
furi_hal_resources_init_input_pins(GpioModeAnalog);
|
2023-05-29 19:05:57 +03:00
|
|
|
furi_hal_bus_disable(FuriHalBusGPIOA);
|
|
|
|
furi_hal_bus_disable(FuriHalBusGPIOB);
|
|
|
|
furi_hal_bus_disable(FuriHalBusGPIOC);
|
|
|
|
furi_hal_bus_disable(FuriHalBusGPIOD);
|
|
|
|
furi_hal_bus_disable(FuriHalBusGPIOE);
|
|
|
|
furi_hal_bus_disable(FuriHalBusGPIOH);
|
2022-04-13 23:50:25 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
void furi_hal_resources_init() {
|
2022-03-30 18:23:40 +03:00
|
|
|
// Button pins
|
2023-02-07 18:35:49 +03:00
|
|
|
furi_hal_resources_init_input_pins(GpioModeInterruptRiseFall);
|
2022-03-30 18:23:40 +03:00
|
|
|
|
2023-04-12 14:45:13 +03:00
|
|
|
// Explicit, surviving reset, pulls
|
|
|
|
LL_PWR_EnablePUPDCfg();
|
|
|
|
LL_PWR_EnableGPIOPullDown(LL_PWR_GPIO_B, LL_PWR_GPIO_BIT_9); // gpio_infrared_tx
|
|
|
|
LL_PWR_EnableGPIOPullDown(LL_PWR_GPIO_B, LL_PWR_GPIO_BIT_8); // gpio_speaker
|
|
|
|
LL_PWR_EnableGPIOPullDown(LL_PWR_GPIO_A, LL_PWR_GPIO_BIT_8); // gpio_vibro
|
2023-04-06 12:06:19 +03:00
|
|
|
|
2022-03-30 18:23:40 +03:00
|
|
|
// Display pins
|
[FL-2399, FL-2261] Tickless sleep shenanigans (#1168)
* Disable USART in sleep
* Restore UART state on suspend/resume
* FuriHal: Enable stop mode and add insomnia to I2C and SPI
* Remove IDLE interrupt
* FuriHal: add FPU isr and disable all FPU interrupt, add core2 stop mode configuration on deep sleep
* FuriHal: tie stop mode debug with debug rtc flag
* FuriHal: adjust flash latency on clock switch, tie mcu debug with RTC debug flag
* FuriHal: move resource init to early stage
* Add EXTI pending check, enable debug traps with compile-time flag
* Wrap sleep debug functions in conditional compilation
* Remove erroneous changed
* Do not use CSS, remove it from everywhere
* Enable/disable USB on VBUS connect (prototype)
* FuriHal: add LPMS and DEEPSLEEP magic, workaround state inconsistency between cores
* FuriHal: honor c1 LMPS
* USB mode switch fix
* Applications: add flags and insomnia bypass system
* Correct spelling
* FuriHal: cleanup insomnia usage, reset sleep flags on wakeup, add shutdown api
* FuriHal: extra check on reinit request
* FuriHal: rename gpio_display_rst pin to gpio_display_rst_n
* FuriHal: add debug HAL
* FuriHal: add some magic to core2 reload procedure, fix issue with crash on ble keyboard exit
* FuriHal: cleanup ble glue, add BLE_GLUE_DEBUG flag
* FuriHal: ble reinit API, move os timer to LPTIM1 for deep sleep capability, shutdown that works
* FuriHal: take insomnia while shutdown
* Remove USB switch on/off on VBUS change
* Better tick skew handling
* Improve tick consistency under load
* Add USB_HP dummy IRQ handler
* Move interrupt check closer to sleep
* Clean up includes
* Re-enable Insomnia globally
* FuriHal: enable CSS
* FuriHal: remove questionable core2 clock shenanigans
* FuriHal: use core1 RCC registers in idle timer config
* FuriHal: return back CSS handlers, add lptim isr dispatching
Co-authored-by: Aleksandr Kutuzov <alleteam@gmail.com>
Co-authored-by: nminaylov <nm29719@gmail.com>
2022-04-29 16:29:51 +03:00
|
|
|
furi_hal_gpio_init(&gpio_display_rst_n, GpioModeOutputPushPull, GpioPullNo, GpioSpeedLow);
|
|
|
|
furi_hal_gpio_write(&gpio_display_rst_n, 0);
|
2022-03-30 18:23:40 +03:00
|
|
|
|
|
|
|
furi_hal_gpio_init(&gpio_display_di, GpioModeOutputPushPull, GpioPullNo, GpioSpeedLow);
|
|
|
|
furi_hal_gpio_write(&gpio_display_di, 0);
|
|
|
|
|
|
|
|
// SD pins
|
|
|
|
furi_hal_gpio_init(&gpio_sdcard_cd, GpioModeInput, GpioPullNo, GpioSpeedLow);
|
|
|
|
furi_hal_gpio_write(&gpio_sdcard_cd, 0);
|
|
|
|
|
2023-04-06 12:06:19 +03:00
|
|
|
furi_hal_gpio_init(&gpio_ibutton, GpioModeAnalog, GpioPullNo, GpioSpeedLow);
|
2022-03-30 18:23:40 +03:00
|
|
|
|
2022-06-20 17:54:48 +03:00
|
|
|
furi_hal_gpio_init(&gpio_nfc_irq_rfid_pull, GpioModeInterruptRise, GpioPullNo, GpioSpeedLow);
|
2022-03-30 18:23:40 +03:00
|
|
|
|
|
|
|
furi_hal_gpio_init(&gpio_rf_sw_0, GpioModeOutputPushPull, GpioPullNo, GpioSpeedLow);
|
|
|
|
|
|
|
|
NVIC_SetPriority(EXTI0_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(), 5, 0));
|
|
|
|
NVIC_EnableIRQ(EXTI0_IRQn);
|
|
|
|
|
|
|
|
NVIC_SetPriority(EXTI1_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(), 5, 0));
|
|
|
|
NVIC_EnableIRQ(EXTI1_IRQn);
|
|
|
|
|
|
|
|
NVIC_SetPriority(EXTI2_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(), 5, 0));
|
|
|
|
NVIC_EnableIRQ(EXTI2_IRQn);
|
|
|
|
|
|
|
|
NVIC_SetPriority(EXTI3_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(), 5, 0));
|
|
|
|
NVIC_EnableIRQ(EXTI3_IRQn);
|
|
|
|
|
|
|
|
NVIC_SetPriority(EXTI4_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(), 5, 0));
|
|
|
|
NVIC_EnableIRQ(EXTI4_IRQn);
|
|
|
|
|
|
|
|
NVIC_SetPriority(EXTI9_5_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(), 5, 0));
|
|
|
|
NVIC_EnableIRQ(EXTI9_5_IRQn);
|
|
|
|
|
|
|
|
NVIC_SetPriority(EXTI15_10_IRQn, NVIC_EncodePriority(NVIC_GetPriorityGrouping(), 5, 0));
|
|
|
|
NVIC_EnableIRQ(EXTI15_10_IRQn);
|
2023-03-22 20:00:48 +03:00
|
|
|
|
|
|
|
FURI_LOG_I(TAG, "Init OK");
|
2022-03-30 18:23:40 +03:00
|
|
|
}
|
2023-02-08 08:40:44 +03:00
|
|
|
|
|
|
|
int32_t furi_hal_resources_get_ext_pin_number(const GpioPin* gpio) {
|
|
|
|
if(gpio == &gpio_ext_pa7)
|
|
|
|
return 2;
|
|
|
|
else if(gpio == &gpio_ext_pa6)
|
|
|
|
return 3;
|
|
|
|
else if(gpio == &gpio_ext_pa4)
|
|
|
|
return 4;
|
|
|
|
else if(gpio == &gpio_ext_pb3)
|
|
|
|
return 5;
|
|
|
|
else if(gpio == &gpio_ext_pb2)
|
|
|
|
return 6;
|
|
|
|
else if(gpio == &gpio_ext_pc3)
|
|
|
|
return 7;
|
|
|
|
else if(gpio == &gpio_ext_pc1)
|
|
|
|
return 15;
|
|
|
|
else if(gpio == &gpio_ext_pc0)
|
|
|
|
return 16;
|
2023-04-06 12:06:19 +03:00
|
|
|
else if(gpio == &gpio_ibutton)
|
2023-02-08 08:40:44 +03:00
|
|
|
return 17;
|
|
|
|
else
|
|
|
|
return -1;
|
|
|
|
}
|