2019-05-27 06:55:06 +00:00
|
|
|
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
2006-03-08 07:53:24 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2005 Stephen Street / StreetFire Sound Labs
|
|
|
|
*/
|
2021-04-23 18:24:32 +00:00
|
|
|
#ifndef __LINUX_SPI_PXA2XX_SPI_H
|
|
|
|
#define __LINUX_SPI_PXA2XX_SPI_H
|
2006-03-08 07:53:24 +00:00
|
|
|
|
2021-04-23 18:24:31 +00:00
|
|
|
#include <linux/types.h>
|
|
|
|
|
2010-11-23 01:12:15 +00:00
|
|
|
#include <linux/pxa2xx_ssp.h>
|
2006-03-08 07:53:24 +00:00
|
|
|
|
|
|
|
#define PXA2XX_CS_ASSERT (0x01)
|
|
|
|
#define PXA2XX_CS_DEASSERT (0x02)
|
|
|
|
|
2014-08-19 17:29:19 +00:00
|
|
|
struct dma_chan;
|
|
|
|
|
2021-05-17 14:03:49 +00:00
|
|
|
/*
|
|
|
|
* The platform data for SSP controller devices
|
|
|
|
* (resides in device.platform_data).
|
|
|
|
*/
|
2019-01-16 15:13:31 +00:00
|
|
|
struct pxa2xx_spi_controller {
|
2006-03-08 07:53:24 +00:00
|
|
|
u16 num_chipselect;
|
|
|
|
u8 enable_dma;
|
2019-03-19 15:48:42 +00:00
|
|
|
u8 dma_burst_size;
|
2018-11-13 10:22:25 +00:00
|
|
|
bool is_slave;
|
2013-01-07 10:44:33 +00:00
|
|
|
|
2013-01-22 10:26:29 +00:00
|
|
|
/* DMA engine specific config */
|
2014-08-19 17:29:19 +00:00
|
|
|
bool (*dma_filter)(struct dma_chan *chan, void *param);
|
|
|
|
void *tx_param;
|
|
|
|
void *rx_param;
|
2013-01-22 10:26:29 +00:00
|
|
|
|
2013-01-07 10:44:33 +00:00
|
|
|
/* For non-PXA arches */
|
|
|
|
struct ssp_device ssp;
|
2006-03-08 07:53:24 +00:00
|
|
|
};
|
|
|
|
|
2021-05-17 14:03:49 +00:00
|
|
|
/*
|
|
|
|
* The controller specific data for SPI slave devices
|
|
|
|
* (resides in spi_board_info.controller_data),
|
|
|
|
* copied to spi_device.platform_data ... mostly for
|
|
|
|
* DMA tuning.
|
2006-03-08 07:53:24 +00:00
|
|
|
*/
|
|
|
|
struct pxa2xx_spi_chip {
|
|
|
|
u8 tx_threshold;
|
2013-01-22 10:26:32 +00:00
|
|
|
u8 tx_hi_threshold;
|
2006-03-08 07:53:24 +00:00
|
|
|
u8 rx_threshold;
|
|
|
|
u8 dma_burst_size;
|
2006-12-10 10:18:54 +00:00
|
|
|
u32 timeout;
|
2006-03-08 07:53:24 +00:00
|
|
|
u8 enable_loopback;
|
2009-04-07 02:00:54 +00:00
|
|
|
int gpio_cs;
|
2006-03-08 07:53:24 +00:00
|
|
|
void (*cs_control)(u32 command);
|
|
|
|
};
|
|
|
|
|
2012-06-04 02:41:03 +00:00
|
|
|
#if defined(CONFIG_ARCH_PXA) || defined(CONFIG_ARCH_MMP)
|
2010-11-24 09:17:14 +00:00
|
|
|
|
|
|
|
#include <linux/clk.h>
|
|
|
|
|
2019-01-16 15:13:31 +00:00
|
|
|
extern void pxa2xx_set_spi_info(unsigned id, struct pxa2xx_spi_controller *info);
|
2008-06-13 08:17:31 +00:00
|
|
|
|
2010-11-24 09:17:14 +00:00
|
|
|
#endif
|
2021-04-23 18:24:32 +00:00
|
|
|
|
|
|
|
#endif /* __LINUX_SPI_PXA2XX_SPI_H */
|