92ae112e47
On Armada 7K/8K we need to explicitly enable the bus clock. The bus clock is optional because not all the SoCs need them but at least for Armada 7K/8K it is actually mandatory. The binding documentation is updating accordingly as well as mentioning the mandatory clock which was also missing. Signed-off-by: Gregory CLEMENT <gregory.clement@free-electrons.com> Signed-off-by: Mark Brown <broonie@kernel.org>
80 lines
3.2 KiB
Plaintext
80 lines
3.2 KiB
Plaintext
Marvell Orion SPI device
|
|
|
|
Required properties:
|
|
- compatible : should be on of the following:
|
|
- "marvell,orion-spi" for the Orion, mv78x00, Kirkwood and Dove SoCs
|
|
- "marvell,armada-370-spi", for the Armada 370 SoCs
|
|
- "marvell,armada-375-spi", for the Armada 375 SoCs
|
|
- "marvell,armada-380-spi", for the Armada 38x SoCs
|
|
- "marvell,armada-390-spi", for the Armada 39x SoCs
|
|
- "marvell,armada-xp-spi", for the Armada XP SoCs
|
|
- reg : offset and length of the register set for the device.
|
|
This property can optionally have additional entries to configure
|
|
the SPI direct access mode that some of the Marvell SoCs support
|
|
additionally to the normal indirect access (PIO) mode. The values
|
|
for the MBus "target" and "attribute" are defined in the Marvell
|
|
SoC "Functional Specifications" Manual in the chapter "Marvell
|
|
Core Processor Address Decoding".
|
|
The eight register sets following the control registers refer to
|
|
chip-select lines 0 through 7 respectively.
|
|
- cell-index : Which of multiple SPI controllers is this.
|
|
- clocks : pointers to the reference clocks for this device, the first
|
|
one is the one used for the clock on the spi bus, the
|
|
second one is optional and is the clock used for the
|
|
functional part of the controller
|
|
|
|
Optional properties:
|
|
- interrupts : Is currently not used.
|
|
- clock-names : names of used clocks, mandatory if the second clock is
|
|
used, the name must be "core", and "axi" (the latter
|
|
is only for Armada 7K/8K).
|
|
|
|
|
|
Example:
|
|
spi@10600 {
|
|
compatible = "marvell,orion-spi";
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
cell-index = <0>;
|
|
reg = <0x10600 0x28>;
|
|
interrupts = <23>;
|
|
};
|
|
|
|
Example with SPI direct mode support (optionally):
|
|
spi0: spi@10600 {
|
|
compatible = "marvell,orion-spi";
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
cell-index = <0>;
|
|
reg = <MBUS_ID(0xf0, 0x01) 0x10600 0x28>, /* control */
|
|
<MBUS_ID(0x01, 0x1e) 0 0xffffffff>, /* CS0 */
|
|
<MBUS_ID(0x01, 0x5e) 0 0xffffffff>, /* CS1 */
|
|
<MBUS_ID(0x01, 0x9e) 0 0xffffffff>, /* CS2 */
|
|
<MBUS_ID(0x01, 0xde) 0 0xffffffff>, /* CS3 */
|
|
<MBUS_ID(0x01, 0x1f) 0 0xffffffff>, /* CS4 */
|
|
<MBUS_ID(0x01, 0x5f) 0 0xffffffff>, /* CS5 */
|
|
<MBUS_ID(0x01, 0x9f) 0 0xffffffff>, /* CS6 */
|
|
<MBUS_ID(0x01, 0xdf) 0 0xffffffff>; /* CS7 */
|
|
interrupts = <23>;
|
|
};
|
|
|
|
To enable the direct mode, the board specific 'ranges' property in the
|
|
'soc' node needs to add the entries for the desired SPI controllers
|
|
and its chip-selects that are used in the direct mode instead of PIO
|
|
mode. Here an example for this (SPI controller 0, device 1 and SPI
|
|
controller 1, device 2 are used in direct mode. All other SPI device
|
|
are used in the default indirect (PIO) mode):
|
|
soc {
|
|
/*
|
|
* Enable the SPI direct access by configuring an entry
|
|
* here in the board-specific ranges property
|
|
*/
|
|
ranges = <MBUS_ID(0xf0, 0x01) 0 0 0xf1000000 0x100000>, /* internal regs */
|
|
<MBUS_ID(0x01, 0x1d) 0 0 0xfff00000 0x100000>, /* BootROM */
|
|
<MBUS_ID(0x01, 0x5e) 0 0 0xf1100000 0x10000>, /* SPI0-DEV1 */
|
|
<MBUS_ID(0x01, 0x9a) 0 0 0xf1110000 0x10000>; /* SPI1-DEV2 */
|
|
|
|
For further information on the MBus bindings, please see the MBus
|
|
DT documentation:
|
|
Documentation/devicetree/bindings/bus/mvebu-mbus.txt
|