#include <linux/clk.h>
#include <linux/device.h>
#include <linux/dma-mapping.h>
#include <linux/err.h>
#include <linux/interrupt.h>
#include <linux/module.h>
#include <linux/platform_device.h>
#include <linux/pm_runtime.h>
#include <linux/spi/spi.h>
#include <linux/of.h>
#define SPIS_IRQ_EN_REG …
#define SPIS_IRQ_CLR_REG …
#define SPIS_IRQ_ST_REG …
#define SPIS_IRQ_MASK_REG …
#define SPIS_CFG_REG …
#define SPIS_RX_DATA_REG …
#define SPIS_TX_DATA_REG …
#define SPIS_RX_DST_REG …
#define SPIS_TX_SRC_REG …
#define SPIS_DMA_CFG_REG …
#define SPIS_SOFT_RST_REG …
#define DMA_DONE_EN …
#define DATA_DONE_EN …
#define RSTA_DONE_EN …
#define CMD_INVALID_EN …
#define DMA_DONE_ST …
#define DATA_DONE_ST …
#define RSTA_DONE_ST …
#define CMD_INVALID_ST …
#define DMA_DONE_MASK …
#define DATA_DONE_MASK …
#define RSTA_DONE_MASK …
#define CMD_INVALID_MASK …
#define SPIS_TX_ENDIAN …
#define SPIS_RX_ENDIAN …
#define SPIS_TXMSBF …
#define SPIS_RXMSBF …
#define SPIS_CPHA …
#define SPIS_CPOL …
#define SPIS_TX_EN …
#define SPIS_RX_EN …
#define TX_DMA_TRIG_EN …
#define TX_DMA_EN …
#define RX_DMA_EN …
#define TX_DMA_LEN …
#define SPIS_DMA_ADDR_EN …
#define SPIS_SOFT_RST …
struct mtk_spi_slave { … };
struct mtk_spi_compatible { … };
static const struct mtk_spi_compatible mt2712_compat = …;
static const struct mtk_spi_compatible mt8195_compat = …;
static const struct of_device_id mtk_spi_slave_of_match[] = …;
MODULE_DEVICE_TABLE(of, mtk_spi_slave_of_match);
static void mtk_spi_slave_disable_dma(struct mtk_spi_slave *mdata)
{ … }
static void mtk_spi_slave_disable_xfer(struct mtk_spi_slave *mdata)
{ … }
static int mtk_spi_slave_wait_for_completion(struct mtk_spi_slave *mdata)
{ … }
static int mtk_spi_slave_prepare_message(struct spi_controller *ctlr,
struct spi_message *msg)
{ … }
static int mtk_spi_slave_fifo_transfer(struct spi_controller *ctlr,
struct spi_device *spi,
struct spi_transfer *xfer)
{ … }
static int mtk_spi_slave_dma_transfer(struct spi_controller *ctlr,
struct spi_device *spi,
struct spi_transfer *xfer)
{ … }
static int mtk_spi_slave_transfer_one(struct spi_controller *ctlr,
struct spi_device *spi,
struct spi_transfer *xfer)
{ … }
static int mtk_spi_slave_setup(struct spi_device *spi)
{ … }
static int mtk_target_abort(struct spi_controller *ctlr)
{ … }
static irqreturn_t mtk_spi_slave_interrupt(int irq, void *dev_id)
{ … }
static int mtk_spi_slave_probe(struct platform_device *pdev)
{ … }
static void mtk_spi_slave_remove(struct platform_device *pdev)
{ … }
#ifdef CONFIG_PM_SLEEP
static int mtk_spi_slave_suspend(struct device *dev)
{ … }
static int mtk_spi_slave_resume(struct device *dev)
{ … }
#endif
#ifdef CONFIG_PM
static int mtk_spi_slave_runtime_suspend(struct device *dev)
{ … }
static int mtk_spi_slave_runtime_resume(struct device *dev)
{ … }
#endif
static const struct dev_pm_ops mtk_spi_slave_pm = …;
static struct platform_driver mtk_spi_slave_driver = …;
module_platform_driver(…) …;
MODULE_DESCRIPTION(…) …;
MODULE_AUTHOR(…) …;
MODULE_LICENSE(…) …;
MODULE_ALIAS(…) …;