162306a36Sopenharmony_ci# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
262306a36Sopenharmony_ci%YAML 1.2
362306a36Sopenharmony_ci---
462306a36Sopenharmony_ci$id: http://devicetree.org/schemas/media/allegro,al5e.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: Allegro DVT Video IP Codecs
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Michael Tretter <m.tretter@pengutronix.de>
1162306a36Sopenharmony_ci
1262306a36Sopenharmony_cidescription: |-
1362306a36Sopenharmony_ci  Allegro DVT video IP codecs present in the Xilinx ZynqMP SoC. The IP core may
1462306a36Sopenharmony_ci  either be a H.264/H.265 encoder or H.264/H.265 decoder ip core.
1562306a36Sopenharmony_ci
1662306a36Sopenharmony_ci  Each actual codec engine is controlled by a microcontroller (MCU). Host
1762306a36Sopenharmony_ci  software uses a provided mailbox interface to communicate with the MCU. The
1862306a36Sopenharmony_ci  MCUs share an interrupt.
1962306a36Sopenharmony_ci
2062306a36Sopenharmony_ciproperties:
2162306a36Sopenharmony_ci  compatible:
2262306a36Sopenharmony_ci    oneOf:
2362306a36Sopenharmony_ci      - items:
2462306a36Sopenharmony_ci          - const: allegro,al5e-1.1
2562306a36Sopenharmony_ci          - const: allegro,al5e
2662306a36Sopenharmony_ci      - items:
2762306a36Sopenharmony_ci          - const: allegro,al5d-1.1
2862306a36Sopenharmony_ci          - const: allegro,al5d
2962306a36Sopenharmony_ci
3062306a36Sopenharmony_ci  reg:
3162306a36Sopenharmony_ci    items:
3262306a36Sopenharmony_ci      - description: The registers
3362306a36Sopenharmony_ci      - description: The SRAM
3462306a36Sopenharmony_ci
3562306a36Sopenharmony_ci  reg-names:
3662306a36Sopenharmony_ci    items:
3762306a36Sopenharmony_ci      - const: regs
3862306a36Sopenharmony_ci      - const: sram
3962306a36Sopenharmony_ci
4062306a36Sopenharmony_ci  interrupts:
4162306a36Sopenharmony_ci    maxItems: 1
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_ci  clocks:
4462306a36Sopenharmony_ci    items:
4562306a36Sopenharmony_ci      - description: Core clock
4662306a36Sopenharmony_ci      - description: MCU clock
4762306a36Sopenharmony_ci      - description: Core AXI master port clock
4862306a36Sopenharmony_ci      - description: MCU AXI master port clock
4962306a36Sopenharmony_ci      - description: AXI4-Lite slave port clock
5062306a36Sopenharmony_ci
5162306a36Sopenharmony_ci  clock-names:
5262306a36Sopenharmony_ci    items:
5362306a36Sopenharmony_ci      - const: core_clk
5462306a36Sopenharmony_ci      - const: mcu_clk
5562306a36Sopenharmony_ci      - const: m_axi_core_aclk
5662306a36Sopenharmony_ci      - const: m_axi_mcu_aclk
5762306a36Sopenharmony_ci      - const: s_axi_lite_aclk
5862306a36Sopenharmony_ci
5962306a36Sopenharmony_cirequired:
6062306a36Sopenharmony_ci  - compatible
6162306a36Sopenharmony_ci  - reg
6262306a36Sopenharmony_ci  - reg-names
6362306a36Sopenharmony_ci  - interrupts
6462306a36Sopenharmony_ci  - clocks
6562306a36Sopenharmony_ci  - clock-names
6662306a36Sopenharmony_ci
6762306a36Sopenharmony_ciadditionalProperties: False
6862306a36Sopenharmony_ci
6962306a36Sopenharmony_ciexamples:
7062306a36Sopenharmony_ci  - |
7162306a36Sopenharmony_ci    fpga {
7262306a36Sopenharmony_ci        #address-cells = <2>;
7362306a36Sopenharmony_ci        #size-cells = <2>;
7462306a36Sopenharmony_ci
7562306a36Sopenharmony_ci        al5e: video-codec@a0009000 {
7662306a36Sopenharmony_ci            compatible = "allegro,al5e-1.1", "allegro,al5e";
7762306a36Sopenharmony_ci            reg = <0 0xa0009000 0 0x1000>,
7862306a36Sopenharmony_ci            <0 0xa0000000 0 0x8000>;
7962306a36Sopenharmony_ci            reg-names = "regs", "sram";
8062306a36Sopenharmony_ci            interrupts = <0 96 4>;
8162306a36Sopenharmony_ci            clocks = <&xlnx_vcu 0>, <&xlnx_vcu 1>,
8262306a36Sopenharmony_ci            <&clkc 71>, <&clkc 71>, <&clkc 71>;
8362306a36Sopenharmony_ci            clock-names = "core_clk", "mcu_clk", "m_axi_core_aclk",
8462306a36Sopenharmony_ci            "m_axi_mcu_aclk", "s_axi_lite_aclk";
8562306a36Sopenharmony_ci        };
8662306a36Sopenharmony_ci    };
8762306a36Sopenharmony_ci  - |
8862306a36Sopenharmony_ci    fpga {
8962306a36Sopenharmony_ci        #address-cells = <2>;
9062306a36Sopenharmony_ci        #size-cells = <2>;
9162306a36Sopenharmony_ci
9262306a36Sopenharmony_ci        al5d: video-codec@a0029000 {
9362306a36Sopenharmony_ci            compatible = "allegro,al5d-1.1", "allegro,al5d";
9462306a36Sopenharmony_ci            reg = <0 0xa0029000 0 0x1000>,
9562306a36Sopenharmony_ci                  <0 0xa0020000 0 0x8000>;
9662306a36Sopenharmony_ci            reg-names = "regs", "sram";
9762306a36Sopenharmony_ci            interrupts = <0 96 4>;
9862306a36Sopenharmony_ci            clocks = <&xlnx_vcu 2>, <&xlnx_vcu 3>,
9962306a36Sopenharmony_ci                     <&clkc 71>, <&clkc 71>, <&clkc 71>;
10062306a36Sopenharmony_ci            clock-names = "core_clk", "mcu_clk", "m_axi_core_aclk",
10162306a36Sopenharmony_ci            "m_axi_mcu_aclk", "s_axi_lite_aclk";
10262306a36Sopenharmony_ci        };
10362306a36Sopenharmony_ci    };
10462306a36Sopenharmony_ci
10562306a36Sopenharmony_ci...
106