This converts the Freescale SPI master driver to use GPIO descriptors for chip select handling. The Freescale (fsl) driver has a lot of quirks to look up "gpios" rather than "cs-gpios" from the device tree. After the prior patch that will make gpiolib return the GPIO descriptor for "gpios" in response to a request for "cs-gpios", this code can be cut down quite a bit. The driver has custom handling of chip select rather than using the core (which may be possible but not done in this patch) so it still needs to refer directly to spi->cs_gpiod to set the chip select. Cc: Shawn Guo <shawnguo@kernel.org> Cc: Sascha Hauer <s.hauer@pengutronix.de> Cc: Pengutronix Kernel Team <kernel@pengutronix.de> Cc: Fabio Estevam <festevam@gmail.com> Cc: NXP Linux Team <linux-imx@nxp.com> Signed-off-by: Linus Walleij <linus.walleij@linaro.org> Link: https://lore.kernel.org/r/20190804003539.985-1-linus.walleij@linaro.org Signed-off-by: Mark Brown <broonie@kernel.org>
		
			
				
	
	
		
			115 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			115 lines
		
	
	
		
			3.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0-or-later */
 | |
| /*
 | |
|  * Freescale SPI/eSPI controller driver library.
 | |
|  *
 | |
|  * Maintainer: Kumar Gala
 | |
|  *
 | |
|  * Copyright 2010 Freescale Semiconductor, Inc.
 | |
|  * Copyright (C) 2006 Polycom, Inc.
 | |
|  *
 | |
|  * CPM SPI and QE buffer descriptors mode support:
 | |
|  * Copyright (c) 2009  MontaVista Software, Inc.
 | |
|  * Author: Anton Vorontsov <avorontsov@ru.mvista.com>
 | |
|  */
 | |
| #ifndef __SPI_FSL_LIB_H__
 | |
| #define __SPI_FSL_LIB_H__
 | |
| 
 | |
| #include <asm/io.h>
 | |
| 
 | |
| /* SPI/eSPI Controller driver's private data. */
 | |
| struct mpc8xxx_spi {
 | |
| 	struct device *dev;
 | |
| 	void __iomem *reg_base;
 | |
| 
 | |
| 	/* rx & tx bufs from the spi_transfer */
 | |
| 	const void *tx;
 | |
| 	void *rx;
 | |
| 
 | |
| 	int subblock;
 | |
| 	struct spi_pram __iomem *pram;
 | |
| #ifdef CONFIG_FSL_SOC
 | |
| 	struct cpm_buf_desc __iomem *tx_bd;
 | |
| 	struct cpm_buf_desc __iomem *rx_bd;
 | |
| #endif
 | |
| 
 | |
| 	struct spi_transfer *xfer_in_progress;
 | |
| 
 | |
| 	/* dma addresses for CPM transfers */
 | |
| 	dma_addr_t tx_dma;
 | |
| 	dma_addr_t rx_dma;
 | |
| 	bool map_tx_dma;
 | |
| 	bool map_rx_dma;
 | |
| 
 | |
| 	dma_addr_t dma_dummy_tx;
 | |
| 	dma_addr_t dma_dummy_rx;
 | |
| 
 | |
| 	/* functions to deal with different sized buffers */
 | |
| 	void (*get_rx) (u32 rx_data, struct mpc8xxx_spi *);
 | |
| 	u32(*get_tx) (struct mpc8xxx_spi *);
 | |
| 
 | |
| 	unsigned int count;
 | |
| 	unsigned int irq;
 | |
| 
 | |
| 	unsigned nsecs;		/* (clock cycle time)/2 */
 | |
| 
 | |
| 	u32 spibrg;		/* SPIBRG input clock */
 | |
| 	u32 rx_shift;		/* RX data reg shift when in qe mode */
 | |
| 	u32 tx_shift;		/* TX data reg shift when in qe mode */
 | |
| 
 | |
| 	unsigned int flags;
 | |
| 
 | |
| #if IS_ENABLED(CONFIG_SPI_FSL_SPI)
 | |
| 	int type;
 | |
| 	int native_chipselects;
 | |
| 	u8 max_bits_per_word;
 | |
| 
 | |
| 	void (*set_shifts)(u32 *rx_shift, u32 *tx_shift,
 | |
| 			   int bits_per_word, int msb_first);
 | |
| #endif
 | |
| 
 | |
| 	struct completion done;
 | |
| };
 | |
| 
 | |
| struct spi_mpc8xxx_cs {
 | |
| 	/* functions to deal with different sized buffers */
 | |
| 	void (*get_rx) (u32 rx_data, struct mpc8xxx_spi *);
 | |
| 	u32 (*get_tx) (struct mpc8xxx_spi *);
 | |
| 	u32 rx_shift;		/* RX data reg shift when in qe mode */
 | |
| 	u32 tx_shift;		/* TX data reg shift when in qe mode */
 | |
| 	u32 hw_mode;		/* Holds HW mode register settings */
 | |
| };
 | |
| 
 | |
| static inline void mpc8xxx_spi_write_reg(__be32 __iomem *reg, u32 val)
 | |
| {
 | |
| 	iowrite32be(val, reg);
 | |
| }
 | |
| 
 | |
| static inline u32 mpc8xxx_spi_read_reg(__be32 __iomem *reg)
 | |
| {
 | |
| 	return ioread32be(reg);
 | |
| }
 | |
| 
 | |
| struct mpc8xxx_spi_probe_info {
 | |
| 	struct fsl_spi_platform_data pdata;
 | |
| 	__be32 __iomem *immr_spi_cs;
 | |
| };
 | |
| 
 | |
| extern u32 mpc8xxx_spi_tx_buf_u8(struct mpc8xxx_spi *mpc8xxx_spi);
 | |
| extern u32 mpc8xxx_spi_tx_buf_u16(struct mpc8xxx_spi *mpc8xxx_spi);
 | |
| extern u32 mpc8xxx_spi_tx_buf_u32(struct mpc8xxx_spi *mpc8xxx_spi);
 | |
| extern void mpc8xxx_spi_rx_buf_u8(u32 data, struct mpc8xxx_spi *mpc8xxx_spi);
 | |
| extern void mpc8xxx_spi_rx_buf_u16(u32 data, struct mpc8xxx_spi *mpc8xxx_spi);
 | |
| extern void mpc8xxx_spi_rx_buf_u32(u32 data, struct mpc8xxx_spi *mpc8xxx_spi);
 | |
| 
 | |
| extern struct mpc8xxx_spi_probe_info *to_of_pinfo(
 | |
| 		struct fsl_spi_platform_data *pdata);
 | |
| extern int mpc8xxx_spi_bufs(struct mpc8xxx_spi *mspi,
 | |
| 		struct spi_transfer *t, unsigned int len);
 | |
| extern const char *mpc8xxx_spi_strmode(unsigned int flags);
 | |
| extern void mpc8xxx_spi_probe(struct device *dev, struct resource *mem,
 | |
| 		unsigned int irq);
 | |
| extern int mpc8xxx_spi_remove(struct device *dev);
 | |
| extern int of_mpc8xxx_spi_probe(struct platform_device *ofdev);
 | |
| 
 | |
| #endif /* __SPI_FSL_LIB_H__ */
 |