69b921acae
The MPC8309 has a dedicated signal, SPISEL_BOOT, usually used as chip select for the flash device from which the bootloader is loaded. It is not an ordinary gpio, but is simply controlled via the SPI_CS register in the system configuration. To allow accessing such a spi slave, we need to teach fsl_spi_cs_control() how to control the SPISEL_BOOT signal. To distinguish the gpio-controlled slaves, continue to have those use chip_select values of 0..ngpios-1, and use chip_select == ngpios for the boot flash. I'm not too happy with all the ifdeffery, but it seems to be necessary for guarding the sysdev/fsl_soc.h and use of get_immrbase() (spi-fsl-lib.c already contains similar ifdeffery). Googling suggests that the MPC8306 is similar, with the SPI_CS register at the same offset. Signed-off-by: Rasmus Villemoes <rasmus.villemoes@prevas.dk> Signed-off-by: Mark Brown <broonie@kernel.org>
63 lines
2.1 KiB
Plaintext
63 lines
2.1 KiB
Plaintext
* SPI (Serial Peripheral Interface)
|
|
|
|
Required properties:
|
|
- cell-index : QE SPI subblock index.
|
|
0: QE subblock SPI1
|
|
1: QE subblock SPI2
|
|
- compatible : should be "fsl,spi" or "aeroflexgaisler,spictrl".
|
|
- mode : the SPI operation mode, it can be "cpu" or "cpu-qe".
|
|
- reg : Offset and length of the register set for the device
|
|
- interrupts : <a b> where a is the interrupt number and b is a
|
|
field that represents an encoding of the sense and level
|
|
information for the interrupt. This should be encoded based on
|
|
the information in section 2) depending on the type of interrupt
|
|
controller you have.
|
|
- clock-frequency : input clock frequency to non FSL_SOC cores
|
|
|
|
Optional properties:
|
|
- gpios : specifies the gpio pins to be used for chipselects.
|
|
The gpios will be referred to as reg = <index> in the SPI child nodes.
|
|
If unspecified, a single SPI device without a chip select can be used.
|
|
- fsl,spisel_boot : for the MPC8306 and MPC8309, specifies that the
|
|
SPISEL_BOOT signal is used as chip select for a slave device. Use
|
|
reg = <number of gpios> in the corresponding child node, i.e. 0 if
|
|
the gpios property is not present.
|
|
|
|
Example:
|
|
spi@4c0 {
|
|
cell-index = <0>;
|
|
compatible = "fsl,spi";
|
|
reg = <4c0 40>;
|
|
interrupts = <82 0>;
|
|
interrupt-parent = <700>;
|
|
mode = "cpu";
|
|
gpios = <&gpio 18 1 // device reg=<0>
|
|
&gpio 19 1>; // device reg=<1>
|
|
};
|
|
|
|
|
|
* eSPI (Enhanced Serial Peripheral Interface)
|
|
|
|
Required properties:
|
|
- compatible : should be "fsl,mpc8536-espi".
|
|
- reg : Offset and length of the register set for the device.
|
|
- interrupts : should contain eSPI interrupt, the device has one interrupt.
|
|
- fsl,espi-num-chipselects : the number of the chipselect signals.
|
|
|
|
Optional properties:
|
|
- fsl,csbef: chip select assertion time in bits before frame starts
|
|
- fsl,csaft: chip select negation time in bits after frame ends
|
|
|
|
Example:
|
|
spi@110000 {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
compatible = "fsl,mpc8536-espi";
|
|
reg = <0x110000 0x1000>;
|
|
interrupts = <53 0x2>;
|
|
interrupt-parent = <&mpic>;
|
|
fsl,espi-num-chipselects = <4>;
|
|
fsl,csbef = <1>;
|
|
fsl,csaft = <1>;
|
|
};
|