162306a36Sopenharmony_ci# SPDX-License-Identifier: GPL-2.0
262306a36Sopenharmony_ci%YAML 1.2
362306a36Sopenharmony_ci---
462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/spi/spi-sifive.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: SiFive SPI controller
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Pragnesh Patel <pragnesh.patel@sifive.com>
1162306a36Sopenharmony_ci  - Paul Walmsley  <paul.walmsley@sifive.com>
1262306a36Sopenharmony_ci  - Palmer Dabbelt <palmer@sifive.com>
1362306a36Sopenharmony_ci
1462306a36Sopenharmony_ciallOf:
1562306a36Sopenharmony_ci  - $ref: spi-controller.yaml#
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_ciproperties:
1862306a36Sopenharmony_ci  compatible:
1962306a36Sopenharmony_ci    items:
2062306a36Sopenharmony_ci      - enum:
2162306a36Sopenharmony_ci          - sifive,fu540-c000-spi
2262306a36Sopenharmony_ci          - sifive,fu740-c000-spi
2362306a36Sopenharmony_ci      - const: sifive,spi0
2462306a36Sopenharmony_ci
2562306a36Sopenharmony_ci    description:
2662306a36Sopenharmony_ci      Should be "sifive,<chip>-spi" and "sifive,spi<version>".
2762306a36Sopenharmony_ci      Supported compatible strings are -
2862306a36Sopenharmony_ci      "sifive,fu540-c000-spi" and "sifive,fu740-c000-spi" for the SiFive SPI v0
2962306a36Sopenharmony_ci      as integrated onto the SiFive FU540 and FU740 chip resp, and "sifive,spi0"
3062306a36Sopenharmony_ci      for the SiFive SPI v0 IP block with no chip integration tweaks.
3162306a36Sopenharmony_ci      Please refer to sifive-blocks-ip-versioning.txt for details
3262306a36Sopenharmony_ci
3362306a36Sopenharmony_ci      SPI RTL that corresponds to the IP block version numbers can be found here -
3462306a36Sopenharmony_ci      https://github.com/sifive/sifive-blocks/tree/master/src/main/scala/devices/spi
3562306a36Sopenharmony_ci
3662306a36Sopenharmony_ci  reg:
3762306a36Sopenharmony_ci    minItems: 1
3862306a36Sopenharmony_ci    items:
3962306a36Sopenharmony_ci      - description: SPI registers region
4062306a36Sopenharmony_ci      - description: Memory mapped flash region
4162306a36Sopenharmony_ci
4262306a36Sopenharmony_ci  interrupts:
4362306a36Sopenharmony_ci    maxItems: 1
4462306a36Sopenharmony_ci
4562306a36Sopenharmony_ci  clocks:
4662306a36Sopenharmony_ci    maxItems: 1
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_ci    description:
4962306a36Sopenharmony_ci      Must reference the frequency given to the controller
5062306a36Sopenharmony_ci
5162306a36Sopenharmony_ci  sifive,fifo-depth:
5262306a36Sopenharmony_ci    description:
5362306a36Sopenharmony_ci      Depth of hardware queues; defaults to 8
5462306a36Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/uint32
5562306a36Sopenharmony_ci    enum: [8]
5662306a36Sopenharmony_ci    default: 8
5762306a36Sopenharmony_ci
5862306a36Sopenharmony_ci  sifive,max-bits-per-word:
5962306a36Sopenharmony_ci    description:
6062306a36Sopenharmony_ci      Maximum bits per word; defaults to 8
6162306a36Sopenharmony_ci    $ref: /schemas/types.yaml#/definitions/uint32
6262306a36Sopenharmony_ci    enum: [0, 1, 2, 3, 4, 5, 6, 7, 8]
6362306a36Sopenharmony_ci    default: 8
6462306a36Sopenharmony_ci
6562306a36Sopenharmony_cirequired:
6662306a36Sopenharmony_ci  - compatible
6762306a36Sopenharmony_ci  - reg
6862306a36Sopenharmony_ci  - interrupts
6962306a36Sopenharmony_ci  - clocks
7062306a36Sopenharmony_ci
7162306a36Sopenharmony_ciunevaluatedProperties: false
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_ciexamples:
7462306a36Sopenharmony_ci  - |
7562306a36Sopenharmony_ci    spi: spi@10040000 {
7662306a36Sopenharmony_ci      compatible = "sifive,fu540-c000-spi", "sifive,spi0";
7762306a36Sopenharmony_ci      reg = <0x10040000 0x1000>, <0x20000000 0x10000000>;
7862306a36Sopenharmony_ci      interrupt-parent = <&plic>;
7962306a36Sopenharmony_ci      interrupts = <51>;
8062306a36Sopenharmony_ci      clocks = <&tlclk>;
8162306a36Sopenharmony_ci      #address-cells = <1>;
8262306a36Sopenharmony_ci      #size-cells = <0>;
8362306a36Sopenharmony_ci      sifive,fifo-depth = <8>;
8462306a36Sopenharmony_ci      sifive,max-bits-per-word = <8>;
8562306a36Sopenharmony_ci    };
8662306a36Sopenharmony_ci
8762306a36Sopenharmony_ci...
88