* FuriHal: port spi to ll. Bootloader: add spi and display. * Makefile: rollback disabled freertos introspection * FuriHal: spi lock asserts. F6: minor cleanup port sdcard shenanigans to furi_hal_gpio. * SdCard: port missing bits to furi-hal-gpio * FuriHal: fix broken RX in SPI, update SPI API usage. RFAL: more asserts in SPI platform code. * GUI: clear canvas on start. FuriHal: no pullup on radio spi bus. * FuriHal: use check instead of assert in spi lock routines * FuriHal: remove timeouts * SdHal: add guard time to SDCARD CS PIN control. * FuriHal: proper name for SPI device reconfigure routine. SdHal: one more enterprise delay and better documentation. * Bootloader: update DFU text and add image. * FuriHal: drop unused ST HAL modules. * SdHal: fixed swapped hal_gpio_init_ex arguments * SpiHal: fixed swapped hal_gpio_init_ex arguments * IrdaHal: use hal_gpio_init instead of hal_gpio_init_ex * RfidHal: fixed swapped hal_gpio_init_ex arguments Co-authored-by: DrZlo13 <who.just.the.doctor@gmail.com>
		
			
				
	
	
		
			115 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			115 lines
		
	
	
		
			3.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#include <furi-hal-spi-config.h>
 | 
						|
#include <furi-hal-resources.h>
 | 
						|
 | 
						|
#define SPI_R SPI1
 | 
						|
#define SPI_D SPI2
 | 
						|
 | 
						|
const LL_SPI_InitTypeDef furi_hal_spi_config_nfc = {
 | 
						|
    .Mode = LL_SPI_MODE_MASTER,
 | 
						|
    .TransferDirection = LL_SPI_FULL_DUPLEX,
 | 
						|
    .DataWidth = LL_SPI_DATAWIDTH_8BIT,
 | 
						|
    .ClockPolarity = LL_SPI_POLARITY_LOW,
 | 
						|
    .ClockPhase = LL_SPI_PHASE_2EDGE,
 | 
						|
    .NSS = LL_SPI_NSS_SOFT,
 | 
						|
    .BaudRate = LL_SPI_BAUDRATEPRESCALER_DIV8,
 | 
						|
    .BitOrder = LL_SPI_MSB_FIRST,
 | 
						|
    .CRCCalculation = LL_SPI_CRCCALCULATION_DISABLE,
 | 
						|
    .CRCPoly = 7,
 | 
						|
};
 | 
						|
 | 
						|
const LL_SPI_InitTypeDef furi_hal_spi_config_subghz = {
 | 
						|
    .Mode = LL_SPI_MODE_MASTER,
 | 
						|
    .TransferDirection = LL_SPI_FULL_DUPLEX,
 | 
						|
    .DataWidth = LL_SPI_DATAWIDTH_8BIT,
 | 
						|
    .ClockPolarity = LL_SPI_POLARITY_LOW,
 | 
						|
    .ClockPhase = LL_SPI_PHASE_1EDGE,
 | 
						|
    .NSS = LL_SPI_NSS_SOFT,
 | 
						|
    .BaudRate = LL_SPI_BAUDRATEPRESCALER_DIV8,
 | 
						|
    .BitOrder = LL_SPI_MSB_FIRST,
 | 
						|
    .CRCCalculation = LL_SPI_CRCCALCULATION_DISABLE,
 | 
						|
    .CRCPoly = 7,
 | 
						|
};
 | 
						|
 | 
						|
const LL_SPI_InitTypeDef furi_hal_spi_config_display = {
 | 
						|
    .Mode = LL_SPI_MODE_MASTER,
 | 
						|
    .TransferDirection = LL_SPI_FULL_DUPLEX,
 | 
						|
    .DataWidth = LL_SPI_DATAWIDTH_8BIT,
 | 
						|
    .ClockPolarity = LL_SPI_POLARITY_LOW,
 | 
						|
    .ClockPhase = LL_SPI_PHASE_1EDGE,
 | 
						|
    .NSS = LL_SPI_NSS_SOFT,
 | 
						|
    .BaudRate = LL_SPI_BAUDRATEPRESCALER_DIV16,
 | 
						|
    .BitOrder = LL_SPI_MSB_FIRST,
 | 
						|
    .CRCCalculation = LL_SPI_CRCCALCULATION_DISABLE,
 | 
						|
    .CRCPoly = 7,
 | 
						|
};
 | 
						|
 | 
						|
/**
 | 
						|
 * SD Card in fast mode (after init)
 | 
						|
 */
 | 
						|
const LL_SPI_InitTypeDef furi_hal_spi_config_sd_fast = {
 | 
						|
    .Mode = LL_SPI_MODE_MASTER,
 | 
						|
    .TransferDirection = LL_SPI_FULL_DUPLEX,
 | 
						|
    .DataWidth = LL_SPI_DATAWIDTH_8BIT,
 | 
						|
    .ClockPolarity = LL_SPI_POLARITY_LOW,
 | 
						|
    .ClockPhase = LL_SPI_PHASE_1EDGE,
 | 
						|
    .NSS = LL_SPI_NSS_SOFT,
 | 
						|
    .BaudRate = LL_SPI_BAUDRATEPRESCALER_DIV2,
 | 
						|
    .BitOrder = LL_SPI_MSB_FIRST,
 | 
						|
    .CRCCalculation = LL_SPI_CRCCALCULATION_DISABLE,
 | 
						|
    .CRCPoly = 7,
 | 
						|
};
 | 
						|
 | 
						|
/**
 | 
						|
 * SD Card in slow mode (before init)
 | 
						|
 */
 | 
						|
const LL_SPI_InitTypeDef furi_hal_spi_config_sd_slow = {
 | 
						|
    .Mode = LL_SPI_MODE_MASTER,
 | 
						|
    .TransferDirection = LL_SPI_FULL_DUPLEX,
 | 
						|
    .DataWidth = LL_SPI_DATAWIDTH_8BIT,
 | 
						|
    .ClockPolarity = LL_SPI_POLARITY_LOW,
 | 
						|
    .ClockPhase = LL_SPI_PHASE_1EDGE,
 | 
						|
    .NSS = LL_SPI_NSS_SOFT,
 | 
						|
    .BaudRate = LL_SPI_BAUDRATEPRESCALER_DIV32,
 | 
						|
    .BitOrder = LL_SPI_MSB_FIRST,
 | 
						|
    .CRCCalculation = LL_SPI_CRCCALCULATION_DISABLE,
 | 
						|
    .CRCPoly = 7,
 | 
						|
};
 | 
						|
 | 
						|
const FuriHalSpiBus spi_r = {
 | 
						|
    .spi = SPI_R,
 | 
						|
    .miso = &gpio_spi_r_miso,
 | 
						|
    .mosi = &gpio_spi_r_mosi,
 | 
						|
    .clk = &gpio_spi_r_sck,
 | 
						|
};
 | 
						|
 | 
						|
const FuriHalSpiBus spi_d = {
 | 
						|
    .spi = SPI_D,
 | 
						|
    .miso = &gpio_spi_d_miso,
 | 
						|
    .mosi = &gpio_spi_d_mosi,
 | 
						|
    .clk = &gpio_spi_d_sck,
 | 
						|
};
 | 
						|
 | 
						|
const FuriHalSpiDevice furi_hal_spi_devices[FuriHalSpiDeviceIdMax] = {
 | 
						|
    {
 | 
						|
        .bus = &spi_r,
 | 
						|
        .config = &furi_hal_spi_config_subghz,
 | 
						|
        .chip_select = &gpio_subghz_cs,
 | 
						|
    },
 | 
						|
    {
 | 
						|
        .bus = &spi_d,
 | 
						|
        .config = &furi_hal_spi_config_display,
 | 
						|
        .chip_select = &gpio_display_cs,
 | 
						|
    },
 | 
						|
    {
 | 
						|
        .bus = &spi_d,
 | 
						|
        .config = &furi_hal_spi_config_sd_fast,
 | 
						|
        .chip_select = &gpio_sdcard_cs,
 | 
						|
    },
 | 
						|
    {
 | 
						|
        .bus = &spi_d,
 | 
						|
        .config = &furi_hal_spi_config_sd_slow,
 | 
						|
        .chip_select = &gpio_sdcard_cs,
 | 
						|
    },
 | 
						|
    {.bus = &spi_r, .config = &furi_hal_spi_config_nfc, .chip_select = &gpio_nfc_cs},
 | 
						|
};
 |