1 /* 2 * Copyright (c) 2020 Espressif Systems (Shanghai) Co., Ltd. 3 * 4 * SPDX-License-Identifier: Apache-2.0 5 */ 6 7 #ifndef ZEPHYR_DRIVERS_SPI_ESP32_SPIM_H_ 8 #define ZEPHYR_DRIVERS_SPI_ESP32_SPIM_H_ 9 10 #include <zephyr/drivers/pinctrl.h> 11 #include <hal/spi_hal.h> 12 #ifdef SOC_GDMA_SUPPORTED 13 #include <hal/gdma_hal.h> 14 #endif 15 16 #define SPI_MASTER_FREQ_8M (APB_CLK_FREQ/10) 17 #define SPI_MASTER_FREQ_9M (APB_CLK_FREQ/9) /* 8.89MHz */ 18 #define SPI_MASTER_FREQ_10M (APB_CLK_FREQ/8) /* 10MHz */ 19 #define SPI_MASTER_FREQ_11M (APB_CLK_FREQ/7) /* 11.43MHz */ 20 #define SPI_MASTER_FREQ_13M (APB_CLK_FREQ/6) /* 13.33MHz */ 21 #define SPI_MASTER_FREQ_16M (APB_CLK_FREQ/5) /* 16MHz */ 22 #define SPI_MASTER_FREQ_20M (APB_CLK_FREQ/4) /* 20MHz */ 23 #define SPI_MASTER_FREQ_26M (APB_CLK_FREQ/3) /* 26.67MHz */ 24 #define SPI_MASTER_FREQ_40M (APB_CLK_FREQ/2) /* 40MHz */ 25 #define SPI_MASTER_FREQ_80M (APB_CLK_FREQ/1) /* 80MHz */ 26 27 struct spi_esp32_config { 28 spi_dev_t *spi; 29 const struct device *clock_dev; 30 int duty_cycle; 31 int input_delay_ns; 32 int irq_source; 33 int irq_priority; 34 int irq_flags; 35 const struct pinctrl_dev_config *pcfg; 36 clock_control_subsys_t clock_subsys; 37 bool use_iomux; 38 bool dma_enabled; 39 int dma_clk_src; 40 int dma_host; 41 int cs_setup; 42 int cs_hold; 43 bool line_idle_low; 44 spi_clock_source_t clock_source; 45 }; 46 47 struct spi_esp32_data { 48 struct spi_context ctx; 49 spi_hal_context_t hal; 50 spi_hal_config_t hal_config; 51 #ifdef SOC_GDMA_SUPPORTED 52 gdma_hal_context_t hal_gdma; 53 #endif 54 spi_hal_timing_conf_t timing_config; 55 spi_hal_dev_config_t dev_config; 56 spi_hal_trans_config_t trans_config; 57 uint8_t dfs; 58 lldesc_t dma_desc_tx; 59 lldesc_t dma_desc_rx; 60 uint32_t clock_source_hz; 61 }; 62 63 #endif /* ZEPHYR_DRIVERS_SPI_ESP32_SPIM_H_ */ 64