/* SPDX-License-Identifier: GPL-2.0 */ #ifndef __MACH_SPI_H_ #define __MACH_SPI_H_ /* * struct spi_imx_master - device.platform_data for SPI controller devices. * @chipselect: Array of chipselects for this master or NULL. Numbers >= 0 * mean GPIO pins, -ENOENT means internal CSPI chipselect * matching the position in the array. E.g., if chipselect[1] = * -ENOENT then a SPI slave using chip select 1 will use the * native SS1 line of the CSPI. Omitting the array will use * all native chip selects. * Normally you want to use gpio based chip selects as the CSPI * module tries to be intelligent about when to assert the * chipselect: The CSPI module deasserts the chipselect once it * runs out of input data. The other problem is that it is not * possible to mix between high active and low active chipselects * on one single bus using the internal chipselects. * Unfortunately, on some SoCs, Freescale decided to put some * chipselects on dedicated pins which are not usable as gpios, * so we have to support the internal chipselects. * * @num_chipselect: If @chipselect is specified, ARRAY_SIZE(chipselect), * otherwise the number of native chip selects. */ struct spi_imx_master { int *chipselect; int num_chipselect; }; #endif /* __MACH_SPI_H_*/ |