1*a869153bSKrzysztof Kozlowski# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause) 2*a869153bSKrzysztof Kozlowski%YAML 1.2 3*a869153bSKrzysztof Kozlowski--- 4*a869153bSKrzysztof Kozlowski$id: http://devicetree.org/schemas/pinctrl/qcom,qcm2290-tlmm.yaml# 5*a869153bSKrzysztof Kozlowski$schema: http://devicetree.org/meta-schemas/core.yaml# 6*a869153bSKrzysztof Kozlowski 7*a869153bSKrzysztof Kozlowskititle: Qualcomm Technologies, Inc. QCM2290 TLMM block 8*a869153bSKrzysztof Kozlowski 9*a869153bSKrzysztof Kozlowskimaintainers: 10*a869153bSKrzysztof Kozlowski - Shawn Guo <shawn.guo@linaro.org> 11*a869153bSKrzysztof Kozlowski 12*a869153bSKrzysztof Kozlowskidescription: 13*a869153bSKrzysztof Kozlowski Top Level Mode Multiplexer pin controller in Qualcomm QCM2290 SoC. 14*a869153bSKrzysztof Kozlowski 15*a869153bSKrzysztof Kozlowskiproperties: 16*a869153bSKrzysztof Kozlowski compatible: 17*a869153bSKrzysztof Kozlowski const: qcom,qcm2290-tlmm 18*a869153bSKrzysztof Kozlowski 19*a869153bSKrzysztof Kozlowski reg: 20*a869153bSKrzysztof Kozlowski maxItems: 1 21*a869153bSKrzysztof Kozlowski 22*a869153bSKrzysztof Kozlowski interrupts: true 23*a869153bSKrzysztof Kozlowski interrupt-controller: true 24*a869153bSKrzysztof Kozlowski "#interrupt-cells": true 25*a869153bSKrzysztof Kozlowski gpio-controller: true 26*a869153bSKrzysztof Kozlowski "#gpio-cells": true 27*a869153bSKrzysztof Kozlowski gpio-ranges: true 28*a869153bSKrzysztof Kozlowski wakeup-parent: true 29*a869153bSKrzysztof Kozlowski 30*a869153bSKrzysztof KozlowskipatternProperties: 31*a869153bSKrzysztof Kozlowski "-state$": 32*a869153bSKrzysztof Kozlowski oneOf: 33*a869153bSKrzysztof Kozlowski - $ref: "#/$defs/qcom-qcm2290-tlmm-state" 34*a869153bSKrzysztof Kozlowski - patternProperties: 35*a869153bSKrzysztof Kozlowski "-pins$": 36*a869153bSKrzysztof Kozlowski $ref: "#/$defs/qcom-qcm2290-tlmm-state" 37*a869153bSKrzysztof Kozlowski additionalProperties: false 38*a869153bSKrzysztof Kozlowski 39*a869153bSKrzysztof Kozlowski$defs: 40*a869153bSKrzysztof Kozlowski qcom-qcm2290-tlmm-state: 41*a869153bSKrzysztof Kozlowski type: object 42*a869153bSKrzysztof Kozlowski description: 43*a869153bSKrzysztof Kozlowski Pinctrl node's client devices use subnodes for desired pin configuration. 44*a869153bSKrzysztof Kozlowski Client device subnodes use below standard properties. 45*a869153bSKrzysztof Kozlowski $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state 46*a869153bSKrzysztof Kozlowski 47*a869153bSKrzysztof Kozlowski properties: 48*a869153bSKrzysztof Kozlowski pins: 49*a869153bSKrzysztof Kozlowski description: 50*a869153bSKrzysztof Kozlowski List of gpio pins affected by the properties specified in this 51*a869153bSKrzysztof Kozlowski subnode. 52*a869153bSKrzysztof Kozlowski items: 53*a869153bSKrzysztof Kozlowski oneOf: 54*a869153bSKrzysztof Kozlowski - pattern: "^gpio([0-9]|[1-9][0-9]|1[0-1][0-9]|12[0-6])$" 55*a869153bSKrzysztof Kozlowski - enum: [ sdc1_rclk, sdc1_clk, sdc1_cmd, sdc1_data, 56*a869153bSKrzysztof Kozlowski sdc2_clk, sdc2_cmd, sdc2_data ] 57*a869153bSKrzysztof Kozlowski minItems: 1 58*a869153bSKrzysztof Kozlowski maxItems: 36 59*a869153bSKrzysztof Kozlowski 60*a869153bSKrzysztof Kozlowski function: 61*a869153bSKrzysztof Kozlowski description: 62*a869153bSKrzysztof Kozlowski Specify the alternative function to be configured for the specified 63*a869153bSKrzysztof Kozlowski pins. 64*a869153bSKrzysztof Kozlowski 65*a869153bSKrzysztof Kozlowski enum: [ adsp_ext, agera_pll, atest, cam_mclk, cci_async, cci_i2c, 66*a869153bSKrzysztof Kozlowski cci_timer0, cci_timer1, cci_timer2, cci_timer3, char_exec, 67*a869153bSKrzysztof Kozlowski cri_trng, cri_trng0, cri_trng1, dac_calib, dbg_out, ddr_bist, 68*a869153bSKrzysztof Kozlowski ddr_pxi0, ddr_pxi1, ddr_pxi2, ddr_pxi3, gcc_gp1, gcc_gp2, 69*a869153bSKrzysztof Kozlowski gcc_gp3, gpio, gp_pdm0, gp_pdm1, gp_pdm2, gsm0_tx, gsm1_tx, 70*a869153bSKrzysztof Kozlowski jitter_bist, mdp_vsync, mdp_vsync_out_0, mdp_vsync_out_1, 71*a869153bSKrzysztof Kozlowski mpm_pwr, mss_lte, m_voc, nav_gpio, pa_indicator, pbs0, pbs1, 72*a869153bSKrzysztof Kozlowski pbs2, pbs3, pbs4, pbs5, pbs6, pbs7, pbs8, pbs9, pbs10, pbs11, 73*a869153bSKrzysztof Kozlowski pbs12, pbs13, pbs14, pbs15, pbs_out, phase_flag, pll_bist, 74*a869153bSKrzysztof Kozlowski pll_bypassnl, pll_reset, prng_rosc, pwm_0, pwm_1, pwm_2, pwm_3, 75*a869153bSKrzysztof Kozlowski pwm_4, pwm_5, pwm_6, pwm_7, pwm_8, pwm_9, qdss_cti, qdss_gpio, 76*a869153bSKrzysztof Kozlowski qup0, qup1, qup2, qup3, qup4, qup5, sdc1_tb, sdc2_tb, sd_write, 77*a869153bSKrzysztof Kozlowski ssbi_wtr1, tgu_ch0, tgu_ch1, tgu_ch2, tgu_ch3, tsense_pwm, 78*a869153bSKrzysztof Kozlowski uim1_clk, uim1_data, uim1_present, uim1_reset, uim2_clk, 79*a869153bSKrzysztof Kozlowski uim2_data, uim2_present, uim2_reset, usb_phy, vfr_1, 80*a869153bSKrzysztof Kozlowski vsense_trigger, wlan1_adc0, wlan1_adc1 ] 81*a869153bSKrzysztof Kozlowski 82*a869153bSKrzysztof Kozlowski bias-pull-down: true 83*a869153bSKrzysztof Kozlowski bias-pull-up: true 84*a869153bSKrzysztof Kozlowski bias-disable: true 85*a869153bSKrzysztof Kozlowski drive-strength: true 86*a869153bSKrzysztof Kozlowski output-high: true 87*a869153bSKrzysztof Kozlowski output-low: true 88*a869153bSKrzysztof Kozlowski 89*a869153bSKrzysztof Kozlowski required: 90*a869153bSKrzysztof Kozlowski - pins 91*a869153bSKrzysztof Kozlowski 92*a869153bSKrzysztof Kozlowski additionalProperties: false 93*a869153bSKrzysztof Kozlowski 94*a869153bSKrzysztof KozlowskiallOf: 95*a869153bSKrzysztof Kozlowski - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml# 96*a869153bSKrzysztof Kozlowski 97*a869153bSKrzysztof Kozlowskirequired: 98*a869153bSKrzysztof Kozlowski - compatible 99*a869153bSKrzysztof Kozlowski - reg 100*a869153bSKrzysztof Kozlowski 101*a869153bSKrzysztof KozlowskiadditionalProperties: false 102*a869153bSKrzysztof Kozlowski 103*a869153bSKrzysztof Kozlowskiexamples: 104*a869153bSKrzysztof Kozlowski - | 105*a869153bSKrzysztof Kozlowski #include <dt-bindings/interrupt-controller/arm-gic.h> 106*a869153bSKrzysztof Kozlowski tlmm: pinctrl@500000 { 107*a869153bSKrzysztof Kozlowski compatible = "qcom,qcm2290-tlmm"; 108*a869153bSKrzysztof Kozlowski reg = <0x500000 0x300000>; 109*a869153bSKrzysztof Kozlowski interrupts = <GIC_SPI 227 IRQ_TYPE_LEVEL_HIGH>; 110*a869153bSKrzysztof Kozlowski gpio-controller; 111*a869153bSKrzysztof Kozlowski #gpio-cells = <2>; 112*a869153bSKrzysztof Kozlowski interrupt-controller; 113*a869153bSKrzysztof Kozlowski #interrupt-cells = <2>; 114*a869153bSKrzysztof Kozlowski gpio-ranges = <&tlmm 0 0 127>; 115*a869153bSKrzysztof Kozlowski 116*a869153bSKrzysztof Kozlowski sdc2_on_state: sdc2-on-state { 117*a869153bSKrzysztof Kozlowski clk-pins { 118*a869153bSKrzysztof Kozlowski pins = "sdc2_clk"; 119*a869153bSKrzysztof Kozlowski bias-disable; 120*a869153bSKrzysztof Kozlowski drive-strength = <16>; 121*a869153bSKrzysztof Kozlowski }; 122*a869153bSKrzysztof Kozlowski 123*a869153bSKrzysztof Kozlowski cmd-pins { 124*a869153bSKrzysztof Kozlowski pins = "sdc2_cmd"; 125*a869153bSKrzysztof Kozlowski bias-pull-up; 126*a869153bSKrzysztof Kozlowski drive-strength = <10>; 127*a869153bSKrzysztof Kozlowski }; 128*a869153bSKrzysztof Kozlowski 129*a869153bSKrzysztof Kozlowski data-pins { 130*a869153bSKrzysztof Kozlowski pins = "sdc2_data"; 131*a869153bSKrzysztof Kozlowski bias-pull-up; 132*a869153bSKrzysztof Kozlowski drive-strength = <10>; 133*a869153bSKrzysztof Kozlowski }; 134*a869153bSKrzysztof Kozlowski }; 135*a869153bSKrzysztof Kozlowski }; 136