aboutsummaryrefslogtreecommitdiffstats
blob: 328f670d10bd731b81e0a2bf3edecc819cfb3d26 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
/* 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_*/