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/display/tegra/nvidia,tegra124-dpaux.yaml#
562306a36Sopenharmony_ci$schema: http://devicetree.org/meta-schemas/core.yaml#
662306a36Sopenharmony_ci
762306a36Sopenharmony_cititle: NVIDIA Tegra DisplayPort AUX Interface
862306a36Sopenharmony_ci
962306a36Sopenharmony_cimaintainers:
1062306a36Sopenharmony_ci  - Thierry Reding <thierry.reding@gmail.com>
1162306a36Sopenharmony_ci  - Jon Hunter <jonathanh@nvidia.com>
1262306a36Sopenharmony_ci
1362306a36Sopenharmony_cidescription: |
1462306a36Sopenharmony_ci  The Tegra Display Port Auxiliary (DPAUX) pad controller manages two
1562306a36Sopenharmony_ci  pins which can be assigned to either the DPAUX channel or to an I2C
1662306a36Sopenharmony_ci  controller.
1762306a36Sopenharmony_ci
1862306a36Sopenharmony_ci  When configured for DisplayPort AUX operation, the DPAUX controller
1962306a36Sopenharmony_ci  can also be used to communicate with a DisplayPort device using the
2062306a36Sopenharmony_ci  AUX channel.
2162306a36Sopenharmony_ci
2262306a36Sopenharmony_ciproperties:
2362306a36Sopenharmony_ci  $nodename:
2462306a36Sopenharmony_ci    pattern: "^dpaux@[0-9a-f]+$"
2562306a36Sopenharmony_ci
2662306a36Sopenharmony_ci  compatible:
2762306a36Sopenharmony_ci    oneOf:
2862306a36Sopenharmony_ci      - enum:
2962306a36Sopenharmony_ci          - nvidia,tegra124-dpaux
3062306a36Sopenharmony_ci          - nvidia,tegra210-dpaux
3162306a36Sopenharmony_ci          - nvidia,tegra186-dpaux
3262306a36Sopenharmony_ci          - nvidia,tegra194-dpaux
3362306a36Sopenharmony_ci
3462306a36Sopenharmony_ci      - items:
3562306a36Sopenharmony_ci          - const: nvidia,tegra132-dpaux
3662306a36Sopenharmony_ci          - const: nvidia,tegra124-dpaux
3762306a36Sopenharmony_ci
3862306a36Sopenharmony_ci  reg:
3962306a36Sopenharmony_ci    maxItems: 1
4062306a36Sopenharmony_ci
4162306a36Sopenharmony_ci  interrupts:
4262306a36Sopenharmony_ci    maxItems: 1
4362306a36Sopenharmony_ci
4462306a36Sopenharmony_ci  clocks:
4562306a36Sopenharmony_ci    items:
4662306a36Sopenharmony_ci      - description: clock input for the DPAUX hardware
4762306a36Sopenharmony_ci      - description: reference clock
4862306a36Sopenharmony_ci
4962306a36Sopenharmony_ci  clock-names:
5062306a36Sopenharmony_ci    items:
5162306a36Sopenharmony_ci      - const: dpaux
5262306a36Sopenharmony_ci      - const: parent
5362306a36Sopenharmony_ci
5462306a36Sopenharmony_ci  resets:
5562306a36Sopenharmony_ci    items:
5662306a36Sopenharmony_ci      - description: module reset
5762306a36Sopenharmony_ci
5862306a36Sopenharmony_ci  reset-names:
5962306a36Sopenharmony_ci    items:
6062306a36Sopenharmony_ci      - const: dpaux
6162306a36Sopenharmony_ci
6262306a36Sopenharmony_ci  power-domains:
6362306a36Sopenharmony_ci    maxItems: 1
6462306a36Sopenharmony_ci
6562306a36Sopenharmony_ci  i2c-bus:
6662306a36Sopenharmony_ci    description: Subnode where I2C slave devices are listed. This
6762306a36Sopenharmony_ci      subnode must be always present. If there are no I2C slave
6862306a36Sopenharmony_ci      devices, an empty node should be added. See ../../i2c/i2c.yaml
6962306a36Sopenharmony_ci      for more information.
7062306a36Sopenharmony_ci    type: object
7162306a36Sopenharmony_ci
7262306a36Sopenharmony_ci  aux-bus:
7362306a36Sopenharmony_ci    $ref: /schemas/display/dp-aux-bus.yaml#
7462306a36Sopenharmony_ci
7562306a36Sopenharmony_ci  vdd-supply:
7662306a36Sopenharmony_ci    description: phandle of a supply that powers the DisplayPort
7762306a36Sopenharmony_ci      link
7862306a36Sopenharmony_ci
7962306a36Sopenharmony_cipatternProperties:
8062306a36Sopenharmony_ci  "^pinmux-[a-z0-9]+$":
8162306a36Sopenharmony_ci    description:
8262306a36Sopenharmony_ci      Since only three configurations are possible, only three child
8362306a36Sopenharmony_ci      nodes are needed to describe the pin mux'ing options for the
8462306a36Sopenharmony_ci      DPAUX pads. Furthermore, given that the pad functions are only
8562306a36Sopenharmony_ci      applicable to a single set of pads, the child nodes only need
8662306a36Sopenharmony_ci      to describe the pad group the functions are being applied to
8762306a36Sopenharmony_ci      rather than the individual pads.
8862306a36Sopenharmony_ci    type: object
8962306a36Sopenharmony_ci    properties:
9062306a36Sopenharmony_ci      groups:
9162306a36Sopenharmony_ci        const: dpaux-io
9262306a36Sopenharmony_ci
9362306a36Sopenharmony_ci      function:
9462306a36Sopenharmony_ci        enum:
9562306a36Sopenharmony_ci          - aux
9662306a36Sopenharmony_ci          - i2c
9762306a36Sopenharmony_ci          - off
9862306a36Sopenharmony_ci
9962306a36Sopenharmony_ci    additionalProperties: false
10062306a36Sopenharmony_ci
10162306a36Sopenharmony_ci    required:
10262306a36Sopenharmony_ci      - groups
10362306a36Sopenharmony_ci      - function
10462306a36Sopenharmony_ci
10562306a36Sopenharmony_ciadditionalProperties: false
10662306a36Sopenharmony_ci
10762306a36Sopenharmony_cirequired:
10862306a36Sopenharmony_ci  - compatible
10962306a36Sopenharmony_ci  - reg
11062306a36Sopenharmony_ci  - interrupts
11162306a36Sopenharmony_ci  - clocks
11262306a36Sopenharmony_ci  - clock-names
11362306a36Sopenharmony_ci  - resets
11462306a36Sopenharmony_ci  - reset-names
11562306a36Sopenharmony_ci
11662306a36Sopenharmony_ciexamples:
11762306a36Sopenharmony_ci  - |
11862306a36Sopenharmony_ci    #include <dt-bindings/clock/tegra210-car.h>
11962306a36Sopenharmony_ci    #include <dt-bindings/interrupt-controller/arm-gic.h>
12062306a36Sopenharmony_ci
12162306a36Sopenharmony_ci    dpaux: dpaux@545c0000 {
12262306a36Sopenharmony_ci        compatible = "nvidia,tegra210-dpaux";
12362306a36Sopenharmony_ci        reg = <0x545c0000 0x00040000>;
12462306a36Sopenharmony_ci        interrupts = <GIC_SPI 159 IRQ_TYPE_LEVEL_HIGH>;
12562306a36Sopenharmony_ci        clocks = <&tegra_car TEGRA210_CLK_DPAUX>,
12662306a36Sopenharmony_ci                 <&tegra_car TEGRA210_CLK_PLL_DP>;
12762306a36Sopenharmony_ci        clock-names = "dpaux", "parent";
12862306a36Sopenharmony_ci        resets = <&tegra_car 181>;
12962306a36Sopenharmony_ci        reset-names = "dpaux";
13062306a36Sopenharmony_ci        power-domains = <&pd_sor>;
13162306a36Sopenharmony_ci
13262306a36Sopenharmony_ci        state_dpaux_aux: pinmux-aux {
13362306a36Sopenharmony_ci            groups = "dpaux-io";
13462306a36Sopenharmony_ci            function = "aux";
13562306a36Sopenharmony_ci        };
13662306a36Sopenharmony_ci
13762306a36Sopenharmony_ci        state_dpaux_i2c: pinmux-i2c {
13862306a36Sopenharmony_ci            groups = "dpaux-io";
13962306a36Sopenharmony_ci            function = "i2c";
14062306a36Sopenharmony_ci        };
14162306a36Sopenharmony_ci
14262306a36Sopenharmony_ci        state_dpaux_off: pinmux-off {
14362306a36Sopenharmony_ci            groups = "dpaux-io";
14462306a36Sopenharmony_ci            function = "off";
14562306a36Sopenharmony_ci        };
14662306a36Sopenharmony_ci
14762306a36Sopenharmony_ci        i2c-bus {
14862306a36Sopenharmony_ci            #address-cells = <1>;
14962306a36Sopenharmony_ci            #size-cells = <0>;
15062306a36Sopenharmony_ci        };
15162306a36Sopenharmony_ci    };
152