mbox series

[v2,0/4] pinctrl: tegra: Separate Tegra194 instances

Message ID 20220704165802.129717-1-thierry.reding@gmail.com
Headers show
Series pinctrl: tegra: Separate Tegra194 instances | expand

Message

Thierry Reding July 4, 2022, 4:57 p.m. UTC
From: Thierry Reding <treding@nvidia.com>

This patch series changes the pin controller DT description on Tegra194
in order to properly describe how the hardware works. Currently a
simplified description is used that merges two pin controller instances
(called AON and main) into a single DT node. This has some disadvantages
such as creating a complicated mapping between the pins in those pin
controllers and the corresponding GPIO controllers (which are already
separated).

As a prerequisite, the first patch in this series converts the device
tree bindings to json-schema. A second patch then adds an additional
compatible string for the AON instance (along with more details about
each controller's pins) and finally patch 3 converts the driver to
cope with these changes. A fourth patch makes the corresponding
changes in the Tegra194 DTS file.

Note that while this changes the DT node in an incompatible way, this
doesn't have any practical implications for backwards-compatibility. The
reason for this is that device trees have only reconfigured a very
narrow subset of pins of the main controller, so the new driver will
remain backwards-compatible with old device trees.

Changes in v2:
- address Rob's review comments on the DT bindings

Thierry

Thierry Reding (4):
  dt-bindings: pinctrl: tegra: Convert to json-schema
  dt-bindings: pinctrl: tegra194: Separate instances
  pinctrl: tegra: Separate Tegra194 instances
  arm64: tegra: Separate AON pinmux from main pinmux on Tegra194

 .../bindings/clock/nvidia,tegra124-dfll.yaml  |   2 +-
 .../pinctrl/nvidia,tegra-pinmux-common.yaml   | 195 ++++++++++++
 .../pinctrl/nvidia,tegra114-pinmux.txt        | 131 --------
 .../pinctrl/nvidia,tegra114-pinmux.yaml       | 162 ++++++++++
 .../pinctrl/nvidia,tegra124-pinmux.txt        | 153 ----------
 .../pinctrl/nvidia,tegra124-pinmux.yaml       | 182 +++++++++++
 .../pinctrl/nvidia,tegra194-pinmux.txt        | 107 -------
 .../pinctrl/nvidia,tegra194-pinmux.yaml       | 285 +++++++++++++++++
 .../pinctrl/nvidia,tegra20-pinmux.txt         | 143 ---------
 .../pinctrl/nvidia,tegra20-pinmux.yaml        | 107 +++++++
 .../pinctrl/nvidia,tegra210-pinmux.txt        | 166 ----------
 .../pinctrl/nvidia,tegra210-pinmux.yaml       | 146 +++++++++
 .../pinctrl/nvidia,tegra30-pinmux.txt         | 144 ---------
 .../pinctrl/nvidia,tegra30-pinmux.yaml        | 176 +++++++++++
 arch/arm64/boot/dts/nvidia/tegra194.dtsi      |  13 +-
 drivers/pinctrl/tegra/pinctrl-tegra.c         |  33 +-
 drivers/pinctrl/tegra/pinctrl-tegra.h         |   2 +
 drivers/pinctrl/tegra/pinctrl-tegra194.c      | 286 ++++++++++--------
 18 files changed, 1437 insertions(+), 996 deletions(-)
 create mode 100644 Documentation/devicetree/bindings/pinctrl/nvidia,tegra-pinmux-common.yaml
 delete mode 100644 Documentation/devicetree/bindings/pinctrl/nvidia,tegra114-pinmux.txt
 create mode 100644 Documentation/devicetree/bindings/pinctrl/nvidia,tegra114-pinmux.yaml
 delete mode 100644 Documentation/devicetree/bindings/pinctrl/nvidia,tegra124-pinmux.txt
 create mode 100644 Documentation/devicetree/bindings/pinctrl/nvidia,tegra124-pinmux.yaml
 delete mode 100644 Documentation/devicetree/bindings/pinctrl/nvidia,tegra194-pinmux.txt
 create mode 100644 Documentation/devicetree/bindings/pinctrl/nvidia,tegra194-pinmux.yaml
 delete mode 100644 Documentation/devicetree/bindings/pinctrl/nvidia,tegra20-pinmux.txt
 create mode 100644 Documentation/devicetree/bindings/pinctrl/nvidia,tegra20-pinmux.yaml
 delete mode 100644 Documentation/devicetree/bindings/pinctrl/nvidia,tegra210-pinmux.txt
 create mode 100644 Documentation/devicetree/bindings/pinctrl/nvidia,tegra210-pinmux.yaml
 delete mode 100644 Documentation/devicetree/bindings/pinctrl/nvidia,tegra30-pinmux.txt
 create mode 100644 Documentation/devicetree/bindings/pinctrl/nvidia,tegra30-pinmux.yaml

Comments

Linus Walleij July 9, 2022, 11:21 p.m. UTC | #1
On Mon, Jul 4, 2022 at 6:58 PM Thierry Reding <thierry.reding@gmail.com> wrote:

> From: Thierry Reding <treding@nvidia.com>
>
> Tegra194 has two separate instances of the pin controller, one called
> AON (in the always-on domain) and another called "main".

Maybe this information should be in the bindings themselves
too?

Other than that:
Acked-by: Linus Walleij <linus.walleij@linaro.org>

Yours,
Linus Walleij
Linus Walleij July 9, 2022, 11:24 p.m. UTC | #2
On Mon, Jul 4, 2022 at 6:58 PM Thierry Reding <thierry.reding@gmail.com> wrote:

> From: Thierry Reding <treding@nvidia.com>
>
> This patch series changes the pin controller DT description on Tegra194
> in order to properly describe how the hardware works. Currently a
> simplified description is used that merges two pin controller instances
> (called AON and main) into a single DT node. This has some disadvantages
> such as creating a complicated mapping between the pins in those pin
> controllers and the corresponding GPIO controllers (which are already
> separated).
>
> As a prerequisite, the first patch in this series converts the device
> tree bindings to json-schema. A second patch then adds an additional
> compatible string for the AON instance (along with more details about
> each controller's pins) and finally patch 3 converts the driver to
> cope with these changes. A fourth patch makes the corresponding
> changes in the Tegra194 DTS file.
>
> Note that while this changes the DT node in an incompatible way, this
> doesn't have any practical implications for backwards-compatibility. The
> reason for this is that device trees have only reconfigured a very
> narrow subset of pins of the main controller, so the new driver will
> remain backwards-compatible with old device trees.

Works for me, this is much closer to the hardware and therefore
better (fixing a bug in the old bindings essentially).

The whole set:
Acked-by: Linus Walleij <linus.walleij@linaro.org>

I can merge patches 1-3 whenever we have Rob's ACK.
I assume you will take patch 4 thru the SoC tree?

Yours,
Linus Walleij
Thierry Reding Aug. 16, 2022, 11:33 a.m. UTC | #3
On Tue, Jul 12, 2022 at 03:45:04PM -0600, Rob Herring wrote:
> On Wed, Jul 06, 2022 at 10:28:34PM +0200, Thierry Reding wrote:
> > All of the ones that are separate definitions are properties that appear
> > for only a subset of the IP generations. So the idea was to create a
> > definition and then derived bindings could cherry-pick these as
> > necessary to complement the pinconf-node definition.
> > 
> > If I move these definitions to the top level, then they'll end up
> > validating properly on devices where they shouldn't exist. Alternatively
> > I'd have to duplicate all of these across various derivative bindings
> > which gets us mostly back to the previous version of the patch (i.e. we
> > don't save very much by only factoring out the truly common properties).
> 
> Not if you use 'additionalProperties: false'. Since it doesn't see into 
> $ref's like unevaluatedProperties does, you have to list out which 
> properties you are using in the derived binding:
> 
> $ref: list-of-common-props.yaml#
> 
> properties:
>   high-speed-mode: true
> 
> additionalProperties: false
> 
> list-of-common-props.yaml could have a gazillion properties in 
> it, but anything not listed locally will be disallowed.

I tried to restructure as you suggested and things do look better.
Unfortunately I can't find a way to get the result to validate properly.
The problem I'm running into is that these are vendor-specific
properties (with the "nvidia," prefix) and therefore the tools complain
when I list them as above, like so:

	.../Documentation/devicetree/bindings/pinctrl/nvidia,tegra194-pinmux.yaml: patternProperties:^pinmux(-[a-z0-9-_]+)?$:properties:nvidia,drive-type: True is not of type 'object'
	hint: Vendor specific properties must have a type and description unless they have a defined, common suffix.
	from schema $id: http://devicetree.org/meta-schemas/vendor-props.yaml#
	.../Documentation/devicetree/bindings/pinctrl/nvidia,tegra194-pinmux.yaml: patternProperties:^pinmux(-[a-z0-9-_]+)?$:properties:nvidia,drive-type: More than one condition true in oneOf schema:
	{'description': 'Vendor specific properties must have a type and '
	                'description unless they have a defined, common '
	                'suffix.',
	 'oneOf': [{'additionalProperties': False,
	            'description': 'A vendor boolean property can use "type: '
	                           'boolean"',
	            'properties': {'deprecated': True,
	                           'description': True,
	                           'type': {'const': 'boolean'}},
	            'required': ['type', 'description']},
	           {'additionalProperties': False,
	            'description': 'A vendor string property with exact values '
	                           'has an implicit type',
	            'oneOf': [{'required': ['enum']}, {'required': ['const']}],
	            'properties': {'const': {'type': 'string'},
	                           'deprecated': True,
	                           'description': True,
	                           'enum': {'items': {'type': 'string'}}},
	            'required': ['description']},
	           {'description': 'A vendor property needs a $ref to '
	                           'types.yaml',
	            'oneOf': [{'required': ['$ref']}, {'required': ['allOf']}],
	            'properties': {'$ref': {'pattern': 'types.yaml#/definitions/'},
	                           'allOf': {'items': [{'properties': {'$ref': {'pattern': 'types.yaml#/definitions/'}},
	                                                'required': ['$ref']}]}},
	            'required': ['description']},
	           {'description': 'A vendor property can have a $ref to a a '
	                           '$defs schema',
	            'properties': {'$ref': {'pattern': '^#/(definitions|\\$defs)/'}},
	            'required': ['$ref']}],
	 'type': 'object'}
	hint: Vendor specific properties must have a type and description unless they have a defined, common suffix.
	from schema $id: http://devicetree.org/meta-schemas/vendor-props.yaml#

I'm attaching two example files (not the actual patch, because that'd
make this a bit more difficult to review) but this happens for all the
derivatives.

I've been scratching my head for a while now and tried different
combinations, but I can't think of a way to make this work. I'm also not
sure if I'm reading that error report right, but it sounds like the
tooling wants the vendor properties to be fully defined, even for the
simple cases where I just want to mark them as valid (i.e. cancel out
the effect of 'additionalProperties: false'). Is there some special
mechanism that I could somehow enable regular behaviour for these
vendor-specific properties?

Any other ideas on how to fix this?

Thierry
# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
%YAML 1.2
---
$id: http://devicetree.org/schemas/pinctrl/nvidia,tegra-pinmux-common.yaml#
$schema: http://devicetree.org/meta-schemas/core.yaml#

title: NVIDIA Tegra Pinmux Controller

maintainers:
  - Thierry Reding <thierry.reding@gmail.com>
  - Jonathan Hunter <jonathanh@nvidia.com>

description: |
  Please refer to pinctrl-bindings.txt in this directory for details of the
  common pinctrl bindings used by client devices, including the meaning of
  the phrase "pin configuration node".

  Tegra's pin configuration nodes act as a container for an arbitrary number
  of subnodes. Each of these subnodes represents some desired configuration
  for a pin, a group, or a list of pins or groups. This configuration can
  include the mux function to select on those pin(s)/ group(s), and various
  pin configuration parameters, such as pull-up, tristate, drive strength,
  etc.

  The name of each subnode is not important; all subnodes should be
  enumerated and processed purely based on their content.

  Each subnode only affects those parameters that are explicitly listed. In
  other words, a subnode that lists a mux function but no pin configuration
  parameters implies no information about any pin configuration parameters.

  Similarly, a pin subnode that describes a pullup parameter implies no
  information about e.g.  the mux function or tristate parameter. For this
  reason, even seemingly boolean values are actually tristates in this
  binding: unspecified, off, or on. Unspecified is represented as an absent
  property, and off/on are represented as integer values 0 and 1.

  Note that many of these properties are only valid for certain specific pins
  or groups. See the Tegra TRM and various pinmux spreadsheets for complete
  details regarding which groups support which functionality. The Linux
  pinctrl driver may also be a useful reference, since it consolidates,
  disambiguates, and corrects data from all those sources.

properties:
  nvidia,pins:
    $ref: /schemas/types.yaml#/definitions/string-array
    description: An array of strings. Each string contains the name of a pin
      or group.  Valid values for these names are listed below.

  nvidia,function:
    $ref: /schemas/types.yaml#/definitions/string
    description: A string containing the name of the function to mux to the
      pin or group. Valid values for function names are listed below. See the
      Tegra TRM to determine which are valid for each pin or group.

  nvidia,pull:
    description: Pull-down/up setting to apply to the pin.
    $ref: /schemas/types.yaml#/definitions/uint32
    oneOf:
      - description: none
        const: 0
      - description: down
        const: 1
      - description: up
        const: 2

  nvidia,tristate:
    description: Tristate setting to apply to the pin.
    $ref: /schemas/types.yaml#/definitions/uint32
    oneOf:
      - description: drive
        const: 0
      - description: tristate
        const: 1

  nvidia,schmitt:
    description: Enable Schmitt trigger on the input.
    $ref: /schemas/types.yaml#/definitions/uint32
    oneOf:
      - description: disable Schmitt trigger on the input
        const: 0
      - description: enable Schmitt trigger on the input
        const: 1

  nvidia,pull-down-strength:
    description: Controls drive strength. 0 is weakest. The range of valid
      values depends on the pingroup. See "CAL_DRVDN" in the Tegra TRM.
    $ref: /schemas/types.yaml#/definitions/uint32

  nvidia,pull-up-strength:
    description: Controls drive strength. 0 is weakest. The range of valid
      values depends on the pingroup. See "CAL_DRVUP" in the Tegra TRM.
    $ref: /schemas/types.yaml#/definitions/uint32

  nvidia,high-speed-mode:
    description: Enable high speed mode the pins.
    $ref: /schemas/types.yaml#/definitions/uint32
    oneOf:
      - description: normal speed mode
        const: 0
      - description: high speed mode
        const: 1

  nvidia,low-power-mode:
    description: Controls the drive power or current. Valid values are from 0
      through 3, where 0 specifies the least power and 3 specifies the most
      power. See "Low Power Mode" or "LPMD1" and "LPMD0" in the Tegra TRM.
    $ref: /schemas/types.yaml#/definitions/uint32
    enum: [ 0, 1, 2, 3 ]

  nvidia,enable-input:
    description: Enable the pin's input path.
    $ref: /schemas/types.yaml#/definitions/uint32
    oneOf:
      - description: disable input (i.e. output only)
        const: 0
      - description: enable input
        const: 1

  nvidia,open-drain:
    description: Open-drain configuration for the pin.
    $ref: /schemas/types.yaml#/definitions/uint32
    oneOf:
      - description: disable open-drain
        const: 0
      - description: enable open-drain
        const: 1

  nvidia,lock:
    description: Lock the pin configuration against further changes until
      reset.
    $ref: /schemas/types.yaml#/definitions/uint32
    oneOf:
      - description: disable pin configuration lock
        const: 0
      - description: enable pin configuration lock
        const: 1

  nvidia,io-reset:
    description: reset the I/O path
    $ref: /schemas/types.yaml#/definitions/uint32
    enum: [ 0, 1 ]

  nvidia,rcv-sel:
    description: select VIL/VIH receivers
    $ref: /schemas/types.yaml#/definitions/uint32
    oneOf:
      - description: normal receivers
        const: 0
      - description: high-voltage receivers
        const: 1

  nvidia,drive-type:
    description: Drive type to configure for the pin.
    $ref: /schemas/types.yaml#/definitions/uint32
    enum: [ 0, 1, 2, 3 ]

  nvidia,io-hv:
    description: Select high-voltage receivers.
    $ref: /schemas/types.yaml#/definitions/uint32
    oneOf:
      - description: Use normal receivers.
        const: 0
      - description: Use high-voltage receivers.
        const: 1

  nvidia,slew-rate-rising:
    description: Controls rising signal slew rate. 0 is fastest. The range of
      valid values depends on the pingroup. See "DRVDN_SLWR" in the Tegra TRM.
    $ref: /schemas/types.yaml#/definitions/uint32

  nvidia,slew-rate-falling:
    description: Controls falling signal slew rate. 0 is fastest. The range of
      valid values depends on the pingroup. See "DRVUP_SLWF" in the Tegra TRM.
    $ref: /schemas/types.yaml#/definitions/uint32

additionalProperties: true
...
# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
%YAML 1.2
---
$id: http://devicetree.org/schemas/pinctrl/nvidia,tegra194-pinmux.yaml#
$schema: http://devicetree.org/meta-schemas/core.yaml#

title: NVIDIA Tegra194 Pinmux Controller

maintainers:
  - Thierry Reding <thierry.reding@gmail.com>
  - Jon Hunter <jonathanh@nvidia.com>

properties:
  compatible:
    enum:
      - nvidia,tegra194-pinmux
      - nvidia,tegra194-pinmux-aon

  reg:
    items:
      - description: pinmux registers

patternProperties:
  "^pinmux(-[a-z0-9-_]+)?$":
    $ref: nvidia,tegra-pinmux-common.yaml
    additionalProperties: false
    properties:
      nvidia,function:
        enum: [ aud, can0, can1, ccla, dca, dcb, dgpu, directdc, directdc1,
                displaya, displayb, dmic1, dmic2, dmic3, dmic4, dmic5, dp,
                dspk0, dspk1, eqos, extperiph1, extperiph2, extperiph3,
                extperiph4, gp, gpio, hdmi, i2c1, i2c2, i2c3, i2c5, i2c8,
                i2s1, i2s2, i2s3, i2s4, i2s5, i2s6, igpu, iqc1, iqc2, mipi,
                nv, pe0, pe1, pe2, pe3, pe4, pe5, qspi, qspi0, qspi1, rsvd0,
                rsvd1, rsvd2, rsvd3, sata, sce, sdmmc1, sdmmc3, sdmmc4, slvs,
                soc, spdif, spi1, spi2, spi3, touch, uarta, uartb, uartc,
                uartd, uarte, uartg, ufs0, usb, vgp1, vgp2, vgp3, vgp4, vgp5,
                vgp6, wdt ]

      nvidia,enable-input: true
      nvidia,open-drain: true
      nvidia,lock: true
      nvidia,io-hv: true
      nvidia,drive-type: true

    required:
      - nvidia,pins

additionalProperties: false

allOf:
  - if:
      properties:
        compatible:
          const: nvidia,tegra194-pinmux
    then:
      patternProperties:
        "^pinmux(-[a-z0-9-_]+)?$":
          type: object
          properties:
            nvidia,pins:
              description: An array of strings. Each string contains the name
                of a pin or group. Valid values for these names are listed
                below.

                Note that the pex_l5_clkreq_n_pgg0 and pex_l5_rst_n_pgg1 pins
                are part of PCIE C5 power partition. Client devices must
                enable this partition before accessing the configuration for
                these pins.
              items:
                enum: [ dap6_sclk_pa0, dap6_dout_pa1, dap6_din_pa2,
                        dap6_fs_pa3, dap4_sclk_pa4, dap4_dout_pa5,
                        dap4_din_pa6, dap4_fs_pa7, cpu_pwr_req_0_pb0,
                        cpu_pwr_req_1_pb1, qspi0_sck_pc0, qspi0_cs_n_pc1,
                        qspi0_io0_pc2, qspi0_io1_pc3, qspi0_io2_pc4,
                        qspi0_io3_pc5, qspi1_sck_pc6, qspi1_cs_n_pc7,
                        qspi1_io0_pd0, qspi1_io1_pd1, qspi1_io2_pd2,
                        qspi1_io3_pd3, eqos_txc_pe0, eqos_td0_pe1,
                        eqos_td1_pe2, eqos_td2_pe3, eqos_td3_pe4,
                        eqos_tx_ctl_pe5, eqos_rd0_pe6, eqos_rd1_pe7,
                        eqos_rd2_pf0, eqos_rd3_pf1, eqos_rx_ctl_pf2,
                        eqos_rxc_pf3, eqos_sma_mdio_pf4, eqos_sma_mdc_pf5,
                        soc_gpio00_pg0, soc_gpio01_pg1, soc_gpio02_pg2,
                        soc_gpio03_pg3, soc_gpio08_pg4, soc_gpio09_pg5,
                        soc_gpio10_pg6, soc_gpio11_pg7, soc_gpio12_ph0,
                        soc_gpio13_ph1, soc_gpio14_ph2, uart4_tx_ph3,
                        uart4_rx_ph4, uart4_rts_ph5, uart4_cts_ph6,
                        dap2_sclk_ph7, dap2_dout_pi0, dap2_din_pi1,
                        dap2_fs_pi2, gen1_i2c_scl_pi3, gen1_i2c_sda_pi4,
                        sdmmc1_clk_pj0, sdmmc1_cmd_pj1, sdmmc1_dat0_pj2,
                        sdmmc1_dat1_pj3, sdmmc1_dat2_pj4, sdmmc1_dat3_pj5,
                        pex_l0_clkreq_n_pk0, pex_l0_rst_n_pk1,
                        pex_l1_clkreq_n_pk2, pex_l1_rst_n_pk3,
                        pex_l2_clkreq_n_pk4, pex_l2_rst_n_pk5,
                        pex_l3_clkreq_n_pk6, pex_l3_rst_n_pk7,
                        pex_l4_clkreq_n_pl0, pex_l4_rst_n_pl1,
                        pex_wake_n_pl2, sata_dev_slp_pl3, dp_aux_ch0_hpd_pm0,
                        dp_aux_ch1_hpd_pm1, dp_aux_ch2_hpd_pm2,
                        dp_aux_ch3_hpd_pm3, hdmi_cec_pm4, soc_gpio50_pm5,
                        soc_gpio51_pm6, soc_gpio52_pm7, soc_gpio53_pn0,
                        soc_gpio54_pn1, soc_gpio55_pn2, sdmmc3_clk_po0,
                        sdmmc3_cmd_po1, sdmmc3_dat0_po2, sdmmc3_dat1_po3,
                        sdmmc3_dat2_po4, sdmmc3_dat3_po5, extperiph1_clk_pp0,
                        extperiph2_clk_pp1, cam_i2c_scl_pp2, cam_i2c_sda_pp3,
                        soc_gpio04_pp4, soc_gpio05_pp5, soc_gpio06_pp6,
                        soc_gpio07_pp7, soc_gpio20_pq0, soc_gpio21_pq1,
                        soc_gpio22_pq2, soc_gpio23_pq3, soc_gpio40_pq4,
                        soc_gpio41_pq5, soc_gpio42_pq6, soc_gpio43_pq7,
                        soc_gpio44_pr0, soc_gpio45_pr1, uart1_tx_pr2,
                        uart1_rx_pr3, uart1_rts_pr4, uart1_cts_pr5,
                        dap1_sclk_ps0, dap1_dout_ps1, dap1_din_ps2,
                        dap1_fs_ps3, aud_mclk_ps4, soc_gpio30_ps5,
                        soc_gpio31_ps6, soc_gpio32_ps7, soc_gpio33_pt0,
                        dap3_sclk_pt1, dap3_dout_pt2, dap3_din_pt3,
                        dap3_fs_pt4, dap5_sclk_pt5, dap5_dout_pt6,
                        dap5_din_pt7, dap5_fs_pu0, directdc1_clk_pv0,
                        directdc1_in_pv1, directdc1_out0_pv2,
                        directdc1_out1_pv3, directdc1_out2_pv4,
                        directdc1_out3_pv5, directdc1_out4_pv6,
                        directdc1_out5_pv7, directdc1_out6_pw0,
                        directdc1_out7_pw1, gpu_pwr_req_px0, cv_pwr_req_px1,
                        gp_pwm2_px2, gp_pwm3_px3, uart2_tx_px4, uart2_rx_px5,
                        uart2_rts_px6, uart2_cts_px7, spi3_sck_py0,
                        spi3_miso_py1, spi3_mosi_py2, spi3_cs0_py3,
                        spi3_cs1_py4, uart5_tx_py5, uart5_rx_py6,
                        uart5_rts_py7, uart5_cts_pz0, usb_vbus_en0_pz1,
                        usb_vbus_en1_pz2, spi1_sck_pz3, spi1_miso_pz4,
                        spi1_mosi_pz5, spi1_cs0_pz6, spi1_cs1_pz7,
                        ufs0_ref_clk_pff0, ufs0_rst_pff1,
                        pex_l5_clkreq_n_pgg0, pex_l5_rst_n_pgg1,
                        directdc_comp, sdmmc4_clk, sdmmc4_cmd, sdmmc4_dqs,
                        sdmmc4_dat7, sdmmc4_dat6, sdmmc4_dat5, sdmmc4_dat4,
                        sdmmc4_dat3, sdmmc4_dat2, sdmmc4_dat1, sdmmc4_dat0,
                        sdmmc1_comp, sdmmc1_hv_trim, sdmmc3_comp,
                        sdmmc3_hv_trim, eqos_comp, qspi_comp,
                        # drive groups
                        drive_soc_gpio33_pt0, drive_soc_gpio32_ps7,
                        drive_soc_gpio31_ps6, drive_soc_gpio30_ps5,
                        drive_aud_mclk_ps4, drive_dap1_fs_ps3,
                        drive_dap1_din_ps2, drive_dap1_dout_ps1,
                        drive_dap1_sclk_ps0, drive_dap3_fs_pt4,
                        drive_dap3_din_pt3, drive_dap3_dout_pt2,
                        drive_dap3_sclk_pt1, drive_dap5_fs_pu0,
                        drive_dap5_din_pt7, drive_dap5_dout_pt6,
                        drive_dap5_sclk_pt5, drive_dap6_fs_pa3,
                        drive_dap6_din_pa2, drive_dap6_dout_pa1,
                        drive_dap6_sclk_pa0, drive_dap4_fs_pa7,
                        drive_dap4_din_pa6, drive_dap4_dout_pa5,
                        drive_dap4_sclk_pa4, drive_extperiph2_clk_pp1,
                        drive_extperiph1_clk_pp0, drive_cam_i2c_sda_pp3,
                        drive_cam_i2c_scl_pp2, drive_soc_gpio40_pq4,
                        drive_soc_gpio41_pq5, drive_soc_gpio42_pq6,
                        drive_soc_gpio43_pq7, drive_soc_gpio44_pr0,
                        drive_soc_gpio45_pr1, drive_soc_gpio20_pq0,
                        drive_soc_gpio21_pq1, drive_soc_gpio22_pq2,
                        drive_soc_gpio23_pq3, drive_soc_gpio04_pp4,
                        drive_soc_gpio05_pp5, drive_soc_gpio06_pp6,
                        drive_soc_gpio07_pp7, drive_uart1_cts_pr5,
                        drive_uart1_rts_pr4, drive_uart1_rx_pr3,
                        drive_uart1_tx_pr2, drive_dap2_din_pi1,
                        drive_dap2_dout_pi0, drive_dap2_fs_pi2,
                        drive_dap2_sclk_ph7, drive_uart4_cts_ph6,
                        drive_uart4_rts_ph5, drive_uart4_rx_ph4,
                        drive_uart4_tx_ph3, drive_soc_gpio03_pg3,
                        drive_soc_gpio02_pg2, drive_soc_gpio01_pg1,
                        drive_soc_gpio00_pg0, drive_gen1_i2c_scl_pi3,
                        drive_gen1_i2c_sda_pi4, drive_soc_gpio08_pg4,
                        drive_soc_gpio09_pg5, drive_soc_gpio10_pg6,
                        drive_soc_gpio11_pg7, drive_soc_gpio12_ph0,
                        drive_soc_gpio13_ph1, drive_soc_gpio14_ph2,
                        drive_soc_gpio50_pm5, drive_soc_gpio51_pm6,
                        drive_soc_gpio52_pm7, drive_soc_gpio53_pn0,
                        drive_soc_gpio54_pn1, drive_soc_gpio55_pn2,
                        drive_dp_aux_ch0_hpd_pm0, drive_dp_aux_ch1_hpd_pm1,
                        drive_dp_aux_ch2_hpd_pm2, drive_dp_aux_ch3_hpd_pm3,
                        drive_hdmi_cec_pm4, drive_pex_l2_clkreq_n_pk4,
                        drive_pex_wake_n_pl2, drive_pex_l1_clkreq_n_pk2,
                        drive_pex_l1_rst_n_pk3, drive_pex_l0_clkreq_n_pk0,
                        drive_pex_l0_rst_n_pk1, drive_pex_l2_rst_n_pk5,
                        drive_pex_l3_clkreq_n_pk6, drive_pex_l3_rst_n_pk7,
                        drive_pex_l4_clkreq_n_pl0, drive_pex_l4_rst_n_pl1,
                        drive_sata_dev_slp_pl3, drive_pex_l5_clkreq_n_pgg0,
                        drive_pex_l5_rst_n_pgg1, drive_cpu_pwr_req_1_pb1,
                        drive_cpu_pwr_req_0_pb0, drive_sdmmc1_clk_pj0,
                        drive_sdmmc1_cmd_pj1, drive_sdmmc1_dat3_pj5,
                        drive_sdmmc1_dat2_pj4, drive_sdmmc1_dat1_pj3,
                        drive_sdmmc1_dat0_pj2, drive_sdmmc3_dat3_po5,
                        drive_sdmmc3_dat2_po4, drive_sdmmc3_dat1_po3,
                        drive_sdmmc3_dat0_po2, drive_sdmmc3_cmd_po1,
                        drive_sdmmc3_clk_po0, drive_gpu_pwr_req_px0,
                        drive_spi3_miso_py1, drive_spi1_cs0_pz6,
                        drive_spi3_cs0_py3, drive_spi1_miso_pz4,
                        drive_spi3_cs1_py4, drive_gp_pwm3_px3,
                        drive_gp_pwm2_px2, drive_spi1_sck_pz3,
                        drive_spi3_sck_py0, drive_spi1_cs1_pz7,
                        drive_spi1_mosi_pz5, drive_spi3_mosi_py2,
                        drive_cv_pwr_req_px1, drive_uart2_tx_px4,
                        drive_uart2_rx_px5, drive_uart2_rts_px6,
                        drive_uart2_cts_px7, drive_uart5_rx_py6,
                        drive_uart5_tx_py5, drive_uart5_rts_py7,
                        drive_uart5_cts_pz0, drive_usb_vbus_en0_pz1,
                        drive_usb_vbus_en1_pz2, drive_ufs0_rst_pff1,
                        drive_ufs0_ref_clk_pff0 ]

  - if:
      properties:
        compatible:
          const: nvidia,tegra194-pinmux-aon
    then:
      patternProperties:
        "^pinmux(-[a-z0-9-_]+)?$":
          type: object
          properties:
            nvidia,pins:
              items:
                enum: [ can1_dout_paa0, can1_din_paa1, can0_dout_paa2,
                        can0_din_paa3, can0_stb_paa4, can0_en_paa5,
                        can0_wake_paa6, can0_err_paa7, can1_stb_pbb0,
                        can1_en_pbb1, can1_wake_pbb2, can1_err_pbb3,
                        spi2_sck_pcc0, spi2_miso_pcc1, spi2_mosi_pcc2,
                        spi2_cs0_pcc3, touch_clk_pcc4, uart3_tx_pcc5,
                        uart3_rx_pcc6, gen2_i2c_scl_pcc7, gen2_i2c_sda_pdd0,
                        gen8_i2c_scl_pdd1, gen8_i2c_sda_pdd2,
                        safe_state_pee0, vcomp_alert_pee1,
                        ao_retention_n_pee2, batt_oc_pee3, power_on_pee4,
                        pwr_i2c_scl_pee5, pwr_i2c_sda_pee6, sys_reset_n,
                        shutdown_n, pmu_int_n, soc_pwr_req, clk_32k_in,
                        # drive groups
                        drive_shutdown_n, drive_pmu_int_n,
                        drive_safe_state_pee0, drive_vcomp_alert_pee1,
                        drive_soc_pwr_req, drive_batt_oc_pee3,
                        drive_clk_32k_in, drive_power_on_pee4,
                        drive_pwr_i2c_scl_pee5, drive_pwr_i2c_sda_pee6,
                        drive_ao_retention_n_pee2, drive_touch_clk_pcc4,
                        drive_uart3_rx_pcc6, drive_uart3_tx_pcc5,
                        drive_gen8_i2c_sda_pdd2, drive_gen8_i2c_scl_pdd1,
                        drive_spi2_mosi_pcc2, drive_gen2_i2c_scl_pcc7,
                        drive_spi2_cs0_pcc3, drive_gen2_i2c_sda_pdd0,
                        drive_spi2_sck_pcc0, drive_spi2_miso_pcc1,
                        drive_can1_dout_paa0, drive_can1_din_paa1,
                        drive_can0_dout_paa2, drive_can0_din_paa3,
                        drive_can0_stb_paa4, drive_can0_en_paa5,
                        drive_can0_wake_paa6, drive_can0_err_paa7,
                        drive_can1_stb_pbb0, drive_can1_en_pbb1,
                        drive_can1_wake_pbb2, drive_can1_err_pbb3 ]

required:
  - compatible
  - reg

examples:
  - |
    #include <dt-bindings/pinctrl/pinctrl-tegra.h>

    pinmux@2430000 {
      compatible = "nvidia,tegra194-pinmux";
      reg = <0x2430000 0x17000>;

      pinctrl-names = "pex_rst";
      pinctrl-0 = <&pex_rst_c5_out_state>;

      pex_rst_c5_out_state: pex_rst_c5_out {
        pex_rst {
          nvidia,pins = "pex_l5_rst_n_pgg1";
          nvidia,schmitt = <TEGRA_PIN_DISABLE>;
          nvidia,enable-input = <TEGRA_PIN_DISABLE>;
          nvidia,io-hv = <TEGRA_PIN_ENABLE>;
          nvidia,tristate = <TEGRA_PIN_DISABLE>;
          nvidia,pull = <TEGRA_PIN_PULL_NONE>;
        };
      };
    };
...