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