/* * Copyright (c) 2020 Espressif Systems (Shanghai) Co., Ltd. * * SPDX-License-Identifier: Apache-2.0 */ #ifndef ZEPHYR_DRIVERS_SPI_ESP32_SPIM_H_ #define ZEPHYR_DRIVERS_SPI_ESP32_SPIM_H_ #include #include #ifdef SOC_GDMA_SUPPORTED #include #endif #define SPI_MASTER_FREQ_8M (APB_CLK_FREQ/10) #define SPI_MASTER_FREQ_9M (APB_CLK_FREQ/9) /* 8.89MHz */ #define SPI_MASTER_FREQ_10M (APB_CLK_FREQ/8) /* 10MHz */ #define SPI_MASTER_FREQ_11M (APB_CLK_FREQ/7) /* 11.43MHz */ #define SPI_MASTER_FREQ_13M (APB_CLK_FREQ/6) /* 13.33MHz */ #define SPI_MASTER_FREQ_16M (APB_CLK_FREQ/5) /* 16MHz */ #define SPI_MASTER_FREQ_20M (APB_CLK_FREQ/4) /* 20MHz */ #define SPI_MASTER_FREQ_26M (APB_CLK_FREQ/3) /* 26.67MHz */ #define SPI_MASTER_FREQ_40M (APB_CLK_FREQ/2) /* 40MHz */ #define SPI_MASTER_FREQ_80M (APB_CLK_FREQ/1) /* 80MHz */ struct spi_esp32_config { spi_dev_t *spi; const struct device *clock_dev; int duty_cycle; int input_delay_ns; int irq_source; int irq_priority; int irq_flags; const struct pinctrl_dev_config *pcfg; clock_control_subsys_t clock_subsys; bool use_iomux; bool dma_enabled; int dma_clk_src; int dma_host; int cs_setup; int cs_hold; bool line_idle_low; spi_clock_source_t clock_source; }; struct spi_esp32_data { struct spi_context ctx; spi_hal_context_t hal; spi_hal_config_t hal_config; #ifdef SOC_GDMA_SUPPORTED gdma_hal_context_t hal_gdma; #endif spi_hal_timing_conf_t timing_config; spi_hal_dev_config_t dev_config; spi_hal_trans_config_t trans_config; uint8_t dfs; lldesc_t dma_desc_tx; lldesc_t dma_desc_rx; uint32_t clock_source_hz; }; #endif /* ZEPHYR_DRIVERS_SPI_ESP32_SPIM_H_ */