162306a36Sopenharmony_ci# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
262306a36Sopenharmony_ci%YAML 1.2
362306a36Sopenharmony_ci---
462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/spi/atmel,quadspi.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Atmel Quad Serial Peripheral Interface (QSPI)
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Tudor Ambarus <tudor.ambarus@linaro.org>
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_ciallOf:
1362306a36Sopenharmony_ci  - $ref: spi-controller.yaml#
1462306a36Sopenharmony_ci
1562306a36Sopenharmony_ciproperties:
1662306a36Sopenharmony_ci  compatible:
1762306a36Sopenharmony_ci    enum:
1862306a36Sopenharmony_ci      - atmel,sama5d2-qspi
1962306a36Sopenharmony_ci      - microchip,sam9x60-qspi
2062306a36Sopenharmony_ci      - microchip,sama7g5-qspi
2162306a36Sopenharmony_ci      - microchip,sama7g5-ospi
2262306a36Sopenharmony_ci
2362306a36Sopenharmony_ci  reg:
2462306a36Sopenharmony_ci    items:
2562306a36Sopenharmony_ci      - description: base registers
2662306a36Sopenharmony_ci      - description: mapped memory
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_ci  reg-names:
2962306a36Sopenharmony_ci    items:
3062306a36Sopenharmony_ci      - const: qspi_base
3162306a36Sopenharmony_ci      - const: qspi_mmap
3262306a36Sopenharmony_ci
3362306a36Sopenharmony_ci  clocks:
3462306a36Sopenharmony_ci    minItems: 1
3562306a36Sopenharmony_ci    items:
3662306a36Sopenharmony_ci      - description: peripheral clock
3762306a36Sopenharmony_ci      - description: system clock or generic clock, if available
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ci  clock-names:
4062306a36Sopenharmony_ci    minItems: 1
4162306a36Sopenharmony_ci    items:
4262306a36Sopenharmony_ci      - const: pclk
4362306a36Sopenharmony_ci      - enum: [ qspick, gclk ]
4462306a36Sopenharmony_ci
4562306a36Sopenharmony_ci  interrupts:
4662306a36Sopenharmony_ci    maxItems: 1
4762306a36Sopenharmony_ci
4862306a36Sopenharmony_ci  dmas:
4962306a36Sopenharmony_ci    items:
5062306a36Sopenharmony_ci      - description: tx DMA channel
5162306a36Sopenharmony_ci      - description: rx DMA channel
5262306a36Sopenharmony_ci
5362306a36Sopenharmony_ci  dma-names:
5462306a36Sopenharmony_ci    items:
5562306a36Sopenharmony_ci      - const: tx
5662306a36Sopenharmony_ci      - const: rx
5762306a36Sopenharmony_ci
5862306a36Sopenharmony_ci  '#address-cells':
5962306a36Sopenharmony_ci    const: 1
6062306a36Sopenharmony_ci
6162306a36Sopenharmony_ci  '#size-cells':
6262306a36Sopenharmony_ci    const: 0
6362306a36Sopenharmony_ci
6462306a36Sopenharmony_cirequired:
6562306a36Sopenharmony_ci  - compatible
6662306a36Sopenharmony_ci  - reg
6762306a36Sopenharmony_ci  - reg-names
6862306a36Sopenharmony_ci  - interrupts
6962306a36Sopenharmony_ci  - clocks
7062306a36Sopenharmony_ci  - clock-names
7162306a36Sopenharmony_ci  - '#address-cells'
7262306a36Sopenharmony_ci  - '#size-cells'
7362306a36Sopenharmony_ci
7462306a36Sopenharmony_ciunevaluatedProperties: false
7562306a36Sopenharmony_ci
7662306a36Sopenharmony_ciexamples:
7762306a36Sopenharmony_ci  - |
7862306a36Sopenharmony_ci    #include <dt-bindings/interrupt-controller/irq.h>
7962306a36Sopenharmony_ci    #include <dt-bindings/clock/at91.h>
8062306a36Sopenharmony_ci    spi@f0020000 {
8162306a36Sopenharmony_ci        compatible = "atmel,sama5d2-qspi";
8262306a36Sopenharmony_ci        reg = <0xf0020000 0x100>, <0xd0000000 0x8000000>;
8362306a36Sopenharmony_ci        reg-names = "qspi_base", "qspi_mmap";
8462306a36Sopenharmony_ci        interrupts = <52 IRQ_TYPE_LEVEL_HIGH 7>;
8562306a36Sopenharmony_ci        clocks = <&pmc PMC_TYPE_PERIPHERAL 52>;
8662306a36Sopenharmony_ci        clock-names = "pclk";
8762306a36Sopenharmony_ci        #address-cells = <1>;
8862306a36Sopenharmony_ci        #size-cells = <0>;
8962306a36Sopenharmony_ci        pinctrl-names = "default";
9062306a36Sopenharmony_ci        pinctrl-0 = <&pinctrl_spi0_default>;
9162306a36Sopenharmony_ci
9262306a36Sopenharmony_ci        flash@0 {
9362306a36Sopenharmony_ci            compatible = "jedec,spi-nor";
9462306a36Sopenharmony_ci            spi-max-frequency = <50000000>;
9562306a36Sopenharmony_ci            reg = <0>;
9662306a36Sopenharmony_ci            spi-rx-bus-width = <4>;
9762306a36Sopenharmony_ci            spi-tx-bus-width = <4>;
9862306a36Sopenharmony_ci        };
9962306a36Sopenharmony_ci    };
100