1 /* SPDX-License-Identifier: GPL-2.0 */ 2 /* 3 * Header File for Altera SPI Driver. 4 */ 5 #ifndef __LINUX_SPI_ALTERA_H 6 #define __LINUX_SPI_ALTERA_H 7 8 #include <linux/interrupt.h> 9 #include <linux/regmap.h> 10 #include <linux/spi/spi.h> 11 #include <linux/types.h> 12 13 #define ALTERA_SPI_MAX_CS 32 14 15 /** 16 * struct altera_spi_platform_data - Platform data of the Altera SPI driver 17 * @mode_bits: Mode bits of SPI master. 18 * @num_chipselect: Number of chipselects. 19 * @bits_per_word_mask: bitmask of supported bits_per_word for transfers. 20 * @num_devices: Number of devices that shall be added when the driver 21 * is probed. 22 * @devices: The devices to add. 23 */ 24 struct altera_spi_platform_data { 25 u16 mode_bits; 26 u16 num_chipselect; 27 u32 bits_per_word_mask; 28 u16 num_devices; 29 struct spi_board_info *devices; 30 }; 31 32 struct altera_spi { 33 int irq; 34 int len; 35 int count; 36 int bytes_per_word; 37 u32 imr; 38 39 /* data buffers */ 40 const unsigned char *tx; 41 unsigned char *rx; 42 43 struct regmap *regmap; 44 u32 regoff; 45 struct device *dev; 46 }; 47 48 extern irqreturn_t altera_spi_irq(int irq, void *dev); 49 extern void altera_spi_init_master(struct spi_master *master); 50 #endif /* __LINUX_SPI_ALTERA_H */ 51