99 lines
3.4 KiB
C
99 lines
3.4 KiB
C
|
/*
|
||
|
* Copyright (c) 2006-2023, RT-Thread Development Team
|
||
|
*
|
||
|
* SPDX-License-Identifier: Apache-2.0
|
||
|
*
|
||
|
* Change Logs:
|
||
|
* Date Author Notes
|
||
|
* 2021-01-13 Lyons first version
|
||
|
* 2021-06-23 RiceChen refactor
|
||
|
*/
|
||
|
|
||
|
#ifndef __DRV_SPI_H__
|
||
|
#define __DRV_SPI_H__
|
||
|
|
||
|
#include <board.h>
|
||
|
#include "drv_common.h"
|
||
|
|
||
|
#include "fsl_iomuxc.h"
|
||
|
#include "fsl_clock.h"
|
||
|
#include "fsl_ecspi.h"
|
||
|
|
||
|
struct imx6ull_spi_cs
|
||
|
{
|
||
|
rt_uint32_t pin;
|
||
|
};
|
||
|
|
||
|
struct imx6ull_spi_config
|
||
|
{
|
||
|
ECSPI_Type *ECSPI;
|
||
|
char *name;
|
||
|
|
||
|
rt_uint32_t clk_ip_name;
|
||
|
|
||
|
struct imx6ull_iomuxc clk_gpio;
|
||
|
struct imx6ull_iomuxc miso_gpio;
|
||
|
struct imx6ull_iomuxc mosi_gpio;
|
||
|
};
|
||
|
|
||
|
struct imx6ull_spi_bus
|
||
|
{
|
||
|
struct rt_spi_bus parent;
|
||
|
struct imx6ull_spi_config *config;
|
||
|
};
|
||
|
|
||
|
#ifdef BSP_USING_SPI1
|
||
|
#define SPI1_BUS_CONFIG \
|
||
|
{ \
|
||
|
.ECSPI = ECSPI1, \
|
||
|
.name = "spi1", \
|
||
|
.clk_ip_name = kCLOCK_Ecspi1, \
|
||
|
.clk_gpio = {IOMUXC_CSI_DATA04_ECSPI1_SCLK, 0, 0X10B1}, \
|
||
|
.miso_gpio = {IOMUXC_CSI_DATA07_ECSPI1_MISO, 0, 0X10B1}, \
|
||
|
.mosi_gpio = {IOMUXC_CSI_DATA06_ECSPI1_MOSI, 0, 0X10B1}, \
|
||
|
}
|
||
|
#endif /* BSP_USING_SPI1 */
|
||
|
|
||
|
#ifdef BSP_USING_SPI2
|
||
|
#define SPI2_BUS_CONFIG \
|
||
|
{ \
|
||
|
.ECSPI = ECSPI2, \
|
||
|
.name = "spi2", \
|
||
|
.clk_ip_name = kCLOCK_Ecspi2, \
|
||
|
.clk_gpio = {IOMUXC_UART4_TX_DATA_ECSPI2_SCLK, 0, 0X10B1}, \
|
||
|
.miso_gpio = {IOMUXC_UART5_RX_DATA_ECSPI2_MISO, 0, 0X10B1}, \
|
||
|
.mosi_gpio = {IOMUXC_UART5_TX_DATA_ECSPI2_MOSI, 0, 0X10B1}, \
|
||
|
}
|
||
|
|
||
|
#endif /* BSP_USING_SPI2 */
|
||
|
|
||
|
#ifdef BSP_USING_SPI3
|
||
|
#define SPI3_BUS_CONFIG \
|
||
|
{ \
|
||
|
.ECSPI = ECSPI3, \
|
||
|
.name = "spi3", \
|
||
|
.clk_ip_name = kCLOCK_Ecspi3, \
|
||
|
.clk_gpio = {IOMUXC_UART2_RX_DATA_ECSPI3_SCLK, 0, 0X10B1}, \
|
||
|
.miso_gpio = {IOMUXC_UART2_RTS_B_ECSPI3_MISO, 0, 0X10B1}, \
|
||
|
.mosi_gpio = {IOMUXC_UART2_CTS_B_ECSPI3_MOSI, 0, 0X10B1}, \
|
||
|
}
|
||
|
|
||
|
#endif /* BSP_USING_SPI3 */
|
||
|
|
||
|
#ifdef BSP_USING_SPI4
|
||
|
#define SPI4_BUS_CONFIG \
|
||
|
{ \
|
||
|
.ECSPI = ECSPI4, \
|
||
|
.name = "spi4", \
|
||
|
.clk_ip_name = kCLOCK_Ecspi4, \
|
||
|
.clk_gpio = {IOMUXC_ENET2_TX_DATA1_ECSPI4_SCLK, 0, 0X10B1}, \
|
||
|
.miso_gpio = {IOMUXC_ENET2_TX_CLK_ECSPI4_MISO, 0, 0X10B1}, \
|
||
|
.mosi_gpio = {IOMUXC_ENET2_TX_EN_ECSPI4_MOSI, 0, 0X10B1}, \
|
||
|
}
|
||
|
|
||
|
#endif /* BSP_USING_SPI4 */
|
||
|
|
||
|
rt_err_t rt_hw_spi_device_attach(const char *bus_name, const char *device_name, rt_uint32_t pin);
|
||
|
|
||
|
#endif
|