1# SPDX-License-Identifier: (GPL-2.0+ OR BSD-2-Clause)
2# Copyright (C) 2019 Texas Instruments Incorporated
3%YAML 1.2
4---
5$id: http://devicetree.org/schemas/sound/tlv320adcx140.yaml#
6$schema: http://devicetree.org/meta-schemas/core.yaml#
7
8title: Texas Instruments TLV320ADCX140 Quad Channel Analog-to-Digital Converter
9
10maintainers:
11  - Dan Murphy <dmurphy@ti.com>
12
13description: |
14  The TLV320ADCX140 are multichannel (4-ch analog recording or 8-ch digital
15  PDM microphones recording), high-performance audio, analog-to-digital
16  converter (ADC) with analog inputs supporting up to 2V RMS. The TLV320ADCX140
17  family supports line and  microphone Inputs, and offers a programmable
18  microphone bias or supply voltage generation.
19
20  Specifications can be found at:
21    http://www.ti.com/lit/ds/symlink/tlv320adc3140.pdf
22    http://www.ti.com/lit/ds/symlink/tlv320adc5140.pdf
23    http://www.ti.com/lit/ds/symlink/tlv320adc6140.pdf
24
25properties:
26  compatible:
27    oneOf:
28      - const: ti,tlv320adc3140
29      - const: ti,tlv320adc5140
30      - const: ti,tlv320adc6140
31
32  reg:
33    maxItems: 1
34    description: |
35       I2C addresss of the device can be one of these 0x4c, 0x4d, 0x4e or 0x4f
36
37  reset-gpios:
38    description: |
39       GPIO used for hardware reset.
40
41  areg-supply:
42      description: |
43       Regulator with AVDD at 3.3V.  If not defined then the internal regulator
44       is enabled.
45
46  ti,mic-bias-source:
47    description: |
48       Indicates the source for MIC Bias.
49       0 - Mic bias is set to VREF
50       1 - Mic bias is set to VREF × 1.096
51       6 - Mic bias is set to AVDD
52    $ref: /schemas/types.yaml#/definitions/uint32
53    enum: [0, 1, 6]
54
55  ti,vref-source:
56    description: |
57       Indicates the source for MIC Bias.
58       0 - Set VREF to 2.75V
59       1 - Set VREF to 2.5V
60       2 - Set VREF to 1.375V
61    $ref: /schemas/types.yaml#/definitions/uint32
62    enum: [0, 1, 2]
63
64  ti,pdm-edge-select:
65    description: |
66       Defines the PDMCLK sampling edge configuration for the PDM inputs.  This
67       array is defined as <PDMIN1 PDMIN2 PDMIN3 PDMIN4>.
68
69       0 - (default) Odd channel is latched on the negative edge and even
70       channel is latched on the the positive edge.
71       1 - Odd channel is latched on the positive edge and even channel is
72       latched on the the negative edge.
73
74       PDMIN1 - PDMCLK latching edge used for channel 1 and 2 data
75       PDMIN2 - PDMCLK latching edge used for channel 3 and 4 data
76       PDMIN3 - PDMCLK latching edge used for channel 5 and 6 data
77       PDMIN4 - PDMCLK latching edge used for channel 7 and 8 data
78
79    allOf:
80      - $ref: /schemas/types.yaml#/definitions/uint32-array
81      - minItems: 1
82        maxItems: 4
83        items:
84          maximum: 1
85        default: [0, 0, 0, 0]
86
87  ti,gpi-config:
88    description: |
89       Defines the configuration for the general purpose input pins (GPI).
90       The array is defined as <GPI1 GPI2 GPI3 GPI4>.
91
92       0 - (default) disabled
93       1 - GPIX is configured as a general-purpose input (GPI)
94       2 - GPIX is configured as a master clock input (MCLK)
95       3 - GPIX is configured as an ASI input for daisy-chain (SDIN)
96       4 - GPIX is configured as a PDM data input for channel 1 and channel
97            (PDMDIN1)
98       5 - GPIX is configured as a PDM data input for channel 3 and channel
99            (PDMDIN2)
100       6 - GPIX is configured as a PDM data input for channel 5 and channel
101            (PDMDIN3)
102       7 - GPIX is configured as a PDM data input for channel 7 and channel
103            (PDMDIN4)
104
105    allOf:
106      - $ref: /schemas/types.yaml#/definitions/uint32-array
107      - minItems: 1
108        maxItems: 4
109        items:
110          maximum: 7
111        default: [0, 0, 0, 0]
112
113required:
114  - compatible
115  - reg
116
117examples:
118  - |
119    #include <dt-bindings/gpio/gpio.h>
120    i2c0 {
121      #address-cells = <1>;
122      #size-cells = <0>;
123      codec: codec@4c {
124        compatible = "ti,tlv320adc5140";
125        reg = <0x4c>;
126        ti,mic-bias-source = <6>;
127        ti,pdm-edge-select = <0 1 0 1>;
128        ti,gpi-config = <4 5 6 7>;
129        reset-gpios = <&gpio0 14 GPIO_ACTIVE_HIGH>;
130      };
131    };
132