187 lines
4.4 KiB
YAML
187 lines
4.4 KiB
YAML
|
# SPDX-License-Identifier: GPL-2.0-only
|
||
|
%YAML 1.2
|
||
|
---
|
||
|
$id: http://devicetree.org/schemas/spi/snps,dw-apb-ssi.yaml#
|
||
|
$schema: http://devicetree.org/meta-schemas/core.yaml#
|
||
|
|
||
|
title: Synopsys DesignWare AMBA 2.0 Synchronous Serial Interface
|
||
|
|
||
|
maintainers:
|
||
|
- Mark Brown <broonie@kernel.org>
|
||
|
|
||
|
allOf:
|
||
|
- $ref: "spi-controller.yaml#"
|
||
|
- if:
|
||
|
properties:
|
||
|
compatible:
|
||
|
contains:
|
||
|
enum:
|
||
|
- mscc,ocelot-spi
|
||
|
- mscc,jaguar2-spi
|
||
|
then:
|
||
|
properties:
|
||
|
reg:
|
||
|
minItems: 2
|
||
|
- if:
|
||
|
properties:
|
||
|
compatible:
|
||
|
contains:
|
||
|
enum:
|
||
|
- baikal,bt1-sys-ssi
|
||
|
then:
|
||
|
properties:
|
||
|
mux-controls:
|
||
|
maxItems: 1
|
||
|
required:
|
||
|
- mux-controls
|
||
|
else:
|
||
|
required:
|
||
|
- interrupts
|
||
|
|
||
|
properties:
|
||
|
compatible:
|
||
|
oneOf:
|
||
|
- description: Generic DW SPI Controller
|
||
|
enum:
|
||
|
- snps,dw-apb-ssi
|
||
|
- snps,dwc-ssi-1.01a
|
||
|
- description: Microsemi Ocelot/Jaguar2 SoC SPI Controller
|
||
|
items:
|
||
|
- enum:
|
||
|
- mscc,ocelot-spi
|
||
|
- mscc,jaguar2-spi
|
||
|
- const: snps,dw-apb-ssi
|
||
|
- description: Microchip Sparx5 SoC SPI Controller
|
||
|
const: microchip,sparx5-spi
|
||
|
- description: Amazon Alpine SPI Controller
|
||
|
const: amazon,alpine-dw-apb-ssi
|
||
|
- description: Renesas RZ/N1 SPI Controller
|
||
|
items:
|
||
|
- const: renesas,rzn1-spi
|
||
|
- const: snps,dw-apb-ssi
|
||
|
- description: Intel Keem Bay SPI Controller
|
||
|
const: intel,keembay-ssi
|
||
|
- description: Intel Thunder Bay SPI Controller
|
||
|
const: intel,thunderbay-ssi
|
||
|
- description: Baikal-T1 SPI Controller
|
||
|
const: baikal,bt1-ssi
|
||
|
- description: Baikal-T1 System Boot SPI Controller
|
||
|
const: baikal,bt1-sys-ssi
|
||
|
- description: Canaan Kendryte K210 SoS SPI Controller
|
||
|
const: canaan,k210-spi
|
||
|
- description: Renesas RZ/N1 SPI Controller
|
||
|
items:
|
||
|
- enum:
|
||
|
- renesas,r9a06g032-spi # RZ/N1D
|
||
|
- renesas,r9a06g033-spi # RZ/N1S
|
||
|
- const: renesas,rzn1-spi # RZ/N1
|
||
|
|
||
|
reg:
|
||
|
minItems: 1
|
||
|
items:
|
||
|
- description: DW APB SSI controller memory mapped registers
|
||
|
- description: SPI MST region map or directly mapped SPI ROM
|
||
|
|
||
|
interrupts:
|
||
|
maxItems: 1
|
||
|
|
||
|
clocks:
|
||
|
minItems: 1
|
||
|
items:
|
||
|
- description: SPI Controller reference clock source
|
||
|
- description: APB interface clock source
|
||
|
|
||
|
clock-names:
|
||
|
minItems: 1
|
||
|
items:
|
||
|
- const: ssi_clk
|
||
|
- const: pclk
|
||
|
|
||
|
resets:
|
||
|
maxItems: 1
|
||
|
|
||
|
reset-names:
|
||
|
const: spi
|
||
|
|
||
|
reg-io-width:
|
||
|
description: I/O register width (in bytes) implemented by this device
|
||
|
default: 4
|
||
|
enum: [ 2, 4 ]
|
||
|
|
||
|
num-cs:
|
||
|
default: 4
|
||
|
minimum: 1
|
||
|
maximum: 4
|
||
|
|
||
|
dmas:
|
||
|
items:
|
||
|
- description: TX DMA Channel
|
||
|
- description: RX DMA Channel
|
||
|
|
||
|
dma-names:
|
||
|
items:
|
||
|
- const: tx
|
||
|
- const: rx
|
||
|
|
||
|
rx-sample-delay-ns:
|
||
|
default: 0
|
||
|
description: |
|
||
|
Default value of the rx-sample-delay-ns property.
|
||
|
This value will be used if the property is not explicitly defined
|
||
|
for a SPI slave device.
|
||
|
|
||
|
SPI Rx sample delay offset, unit is nanoseconds.
|
||
|
The delay from the default sample time before the actual sample of the
|
||
|
rxd input signal occurs. The "rx_sample_delay" is an optional feature
|
||
|
of the designware controller, and the upper limit is also subject to
|
||
|
controller configuration.
|
||
|
|
||
|
patternProperties:
|
||
|
"^.*@[0-9a-f]+$":
|
||
|
type: object
|
||
|
properties:
|
||
|
reg:
|
||
|
minimum: 0
|
||
|
maximum: 3
|
||
|
|
||
|
unevaluatedProperties: false
|
||
|
|
||
|
required:
|
||
|
- compatible
|
||
|
- reg
|
||
|
- "#address-cells"
|
||
|
- "#size-cells"
|
||
|
- clocks
|
||
|
|
||
|
examples:
|
||
|
- |
|
||
|
spi@fff00000 {
|
||
|
compatible = "snps,dw-apb-ssi";
|
||
|
reg = <0xfff00000 0x1000>;
|
||
|
#address-cells = <1>;
|
||
|
#size-cells = <0>;
|
||
|
interrupts = <0 154 4>;
|
||
|
clocks = <&spi_m_clk>;
|
||
|
num-cs = <2>;
|
||
|
cs-gpios = <&gpio0 13 0>,
|
||
|
<&gpio0 14 0>;
|
||
|
rx-sample-delay-ns = <3>;
|
||
|
flash@1 {
|
||
|
compatible = "spi-nand";
|
||
|
reg = <1>;
|
||
|
rx-sample-delay-ns = <7>;
|
||
|
};
|
||
|
};
|
||
|
- |
|
||
|
spi@1f040100 {
|
||
|
compatible = "baikal,bt1-sys-ssi";
|
||
|
reg = <0x1f040100 0x900>,
|
||
|
<0x1c000000 0x1000000>;
|
||
|
#address-cells = <1>;
|
||
|
#size-cells = <0>;
|
||
|
mux-controls = <&boot_mux>;
|
||
|
clocks = <&ccu_sys>;
|
||
|
clock-names = "ssi_clk";
|
||
|
};
|
||
|
...
|