NVIDIA Tegra194 pinmux controller Required properties: - compatible: "nvidia,tegra194-pinmux" - reg: Should contain a list of base address and size pairs for: - first entry: The APB_MISC_GP_*_PADCTRL registers (pad control) - second entry: The PINMUX_AUX_* registers (pinmux) 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. See the TRM to determine which properties and values apply to each pin/group. Macro values for property values are defined in include/dt-binding/pinctrl/pinctrl-tegra.h. Required subnode-properties: - nvidia,pins : An array of strings. Each string contains the name of a pin or group. Valid values for these names are listed below. Optional subnode-properties: - nvidia,function: A string containing the name of the function to mux to the pin or group. - nvidia,pull: Integer, representing the pull-down/up to apply to the pin. 0: none, 1: down, 2: up. - nvidia,tristate: Integer. 0: drive, 1: tristate. - nvidia,enable-input: Integer. Enable the pin's input path. enable :TEGRA_PIN_ENABLE and disable or output only: TEGRA_PIN_DISABLE. - nvidia,open-drain: Integer. enable: TEGRA_PIN_ENABLE. disable: TEGRA_PIN_DISABLE. - nvidia,lock: Integer. Lock the pin configuration against further changes until reset. enable: TEGRA_PIN_ENABLE. disable: TEGRA_PIN_DISABLE. - nvidia,io-hv: Integer. Select high-voltage receivers. normal: TEGRA_PIN_DISABLE high: TEGRA_PIN_ENABLE - nvidia,schmitt: Integer. Enables Schmitt Trigger on the input. normal: TEGRA_PIN_DISABLE high: TEGRA_PIN_ENABLE - nvidia,drive-type: Integer. Valid range 0...3. - nvidia,pull-down-strength: Integer. Controls drive strength. 0 is weakest. The range of valid values depends on the pingroup. See "CAL_DRVDN" in the Tegra TRM. - nvidia,pull-up-strength: Integer. Controls drive strength. 0 is weakest. The range of valid values depends on the pingroup. See "CAL_DRVUP" in the Tegra TRM. Valid values for pin and group names (nvidia,pin) are: These correspond to Tegra PADCTL_* (pinmux) registers. Mux groups: These correspond to Tegra PADCTL_* (pinmux) registers. Any property that exists in those registers may be set for the following pin names. pex_l5_clkreq_n_pgg0, pex_l5_rst_n_pgg1 Drive groups: These registers controls a single pin for which a mux group exists. See the list above for the pin name to use when configuring the pinmux. pex_l5_clkreq_n_pgg0, pex_l5_rst_n_pgg1 Valid values for nvidia,functions are: pe5 Power Domain: pex_l5_clkreq_n_pgg0 and pex_l5_rst_n_pgg1 are part of PCIE C5 power partition. Client devices must enable this partition before accessing these pins here. Example: tegra_pinctrl: pinmux: pinmux@2430000 { compatible = "nvidia,tegra194-pinmux"; reg = <0x2430000 0x17000 0xc300000 0x4000>; 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 = ; nvidia,lpdr = ; nvidia,enable-input = ; nvidia,io-high-voltage = ; nvidia,tristate = ; nvidia,pull = ; }; }; };