~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/Documentation/devicetree/bindings/sound/ti,tlv320adc3xxx.yaml

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  1 # SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
  2 %YAML 1.2
  3 ---
  4 $id: http://devicetree.org/schemas/sound/ti,tlv320adc3xxx.yaml#
  5 $schema: http://devicetree.org/meta-schemas/core.yaml#
  6 
  7 title: Texas Instruments TLV320ADC3001/TLV320ADC3101 Stereo ADC
  8 
  9 maintainers:
 10   - Ricard Wanderlof <ricardw@axis.com>
 11 
 12 description: |
 13   Texas Instruments TLV320ADC3001 and TLV320ADC3101 Stereo ADC
 14   https://www.ti.com/product/TLV320ADC3001
 15   https://www.ti.com/product/TLV320ADC3101
 16 
 17 allOf:
 18   - $ref: dai-common.yaml#
 19 
 20 properties:
 21   compatible:
 22     enum:
 23       - ti,tlv320adc3001
 24       - ti,tlv320adc3101
 25 
 26   reg:
 27     maxItems: 1
 28     description: I2C address
 29 
 30   '#sound-dai-cells':
 31     const: 0
 32 
 33   '#gpio-cells':
 34     const: 2
 35 
 36   gpio-controller: true
 37 
 38   reset-gpios:
 39     maxItems: 1
 40     description: GPIO pin used for codec reset (RESET pin)
 41 
 42   clocks:
 43     maxItems: 1
 44     description: Master clock (MCLK)
 45 
 46   ti,dmdin-gpio1:
 47     $ref: /schemas/types.yaml#/definitions/uint32
 48     enum:
 49       - 0 # ADC3XXX_GPIO_DISABLED       - I/O buffers powered down and not used
 50       - 1 # ADC3XXX_GPIO_INPUT          - Various non-GPIO input functions
 51       - 2 # ADC3XXX_GPIO_GPI            - General purpose input
 52       - 3 # ADC3XXX_GPIO_GPO            - General purpose output
 53       - 4 # ADC3XXX_GPIO_CLKOUT         - Clock source set in CLKOUT_MUX reg
 54       - 5 # ADC3XXX_GPIO_INT1           - INT1 output
 55       - 6 # ADC3XXX_GPIO_SECONDARY_BCLK - Codec interface secondary BCLK
 56       - 7 # ADC3XXX_GPIO_SECONDARY_WCLK - Codec interface secondary WCLK
 57     default: 0
 58     description: |
 59       Configuration for DMDIN/GPIO1 pin.
 60 
 61       When ADC3XXX_GPIO_GPO is selected, the pin may be controlled via the
 62       GPIO framework, as pin number 0 on the device.
 63 
 64   ti,dmclk-gpio2:
 65     $ref: /schemas/types.yaml#/definitions/uint32
 66     enum:
 67       - 0 # ADC3XXX_GPIO_DISABLED       - I/O buffers powered down and not used
 68       - 1 # ADC3XXX_GPIO_INPUT          - Various non-GPIO input functions
 69       - 2 # ADC3XXX_GPIO_GPI            - General purpose input
 70       - 3 # ADC3XXX_GPIO_GPO            - General purpose output
 71       - 4 # ADC3XXX_GPIO_CLKOUT         - Clock source set in CLKOUT_MUX reg
 72       - 5 # ADC3XXX_GPIO_INT1           - INT1 output
 73       - 6 # ADC3XXX_GPIO_SECONDARY_BCLK - Codec interface secondary BCLK
 74       - 7 # ADC3XXX_GPIO_SECONDARY_WCLK - Codec interface secondary WCLK
 75     default: 0
 76     description: |
 77       Configuration for DMCLK/GPIO2 pin.
 78 
 79       When ADC3XXX_GPIO_GPO is selected, the pin may be controlled via the
 80       GPIO framework, as pin number 1 on the device.
 81 
 82       Note that there is currently no support for reading the GPIO pins as
 83       inputs.
 84 
 85   ti,micbias1-gpo:
 86     type: boolean
 87     description: |
 88       When set, the MICBIAS1 pin may be controlled via the GPIO framework,
 89       as pin number 3 on the device.
 90 
 91       In this mode, when the pin is activated, it will be set to the voltage
 92       specified by the ti,micbias1-vg property. When deactivated, the pin will
 93       float.
 94 
 95   ti,micbias2-gpo:
 96     type: boolean
 97     description: |
 98       When set, the MICBIAS2 pin may be controlled via the GPIO framework,
 99       as pin number 4 on the device.
100 
101       In this mode, when the pin is activated, it will be set to the voltage
102       specified by the ti,micbias2-vg property. When deactivated, the pin will
103       float.
104 
105   ti,micbias1-vg:
106     $ref: /schemas/types.yaml#/definitions/uint32
107     enum:
108       - 0 # ADC3XXX_MICBIAS_OFF         - Mic bias is powered down
109       - 1 # ADC3XXX_MICBIAS_2_0V        - Mic bias is set to 2.0V
110       - 2 # ADC3XXX_MICBIAS_2_5V        - Mic bias is set to 2.5V
111       - 3 # ADC3XXX_MICBIAS_AVDD        - Mic bias is same as AVDD supply
112     default: 0
113     description: |
114       Mic bias voltage output on MICBIAS1 pin
115 
116   ti,micbias2-vg:
117     $ref: /schemas/types.yaml#/definitions/uint32
118     enum:
119       - 0 # ADC3XXX_MICBIAS_OFF         - Mic bias is powered down
120       - 1 # ADC3XXX_MICBIAS_2_0V        - Mic bias is set to 2.0V
121       - 2 # ADC3XXX_MICBIAS_2_5V        - Mic bias is set to 2.5V
122       - 3 # ADC3XXX_MICBIAS_AVDD        - Mic bias is same as AVDD supply
123     default: 0
124     description: |
125       Mic bias voltage output on MICBIAS2 pin
126 
127 dependencies:
128   ti,micbias1-gpo: ['ti,micbias1-vg']
129   ti,micbias2-gpo: ['ti,micbias2-vg']
130 
131 required:
132   - compatible
133   - reg
134   - clocks
135 
136 unevaluatedProperties: false
137 
138 examples:
139   - |
140 
141     #include <dt-bindings/gpio/gpio.h>
142     #include <dt-bindings/sound/tlv320adc3xxx.h>
143 
144     i2c {
145         #address-cells = <1>;
146         #size-cells = <0>;
147         tlv320adc3101: audio-codec@18 {
148             compatible = "ti,tlv320adc3101";
149             reg = <0x18>;
150             reset-gpios = <&gpio_pc 3 GPIO_ACTIVE_LOW>;
151             clocks = <&audio_mclk>;
152             gpio-controller;
153             #gpio-cells = <2>;
154             ti,dmdin-gpio1 = <ADC3XXX_GPIO_GPO>;
155             ti,micbias1-vg = <ADC3XXX_MICBIAS_AVDD>;
156         };
157     };
158 
159     audio_mclk: clock {
160         compatible = "fixed-clock";
161         #clock-cells = <0>;
162         clock-frequency = <24576000>;
163     };
164 ...

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php