1# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
2%YAML 1.2
3---
4$id: http://devicetree.org/schemas/iio/adc/st,stm32-adc.yaml#
5$schema: http://devicetree.org/meta-schemas/core.yaml#
6
7title: STMicroelectronics STM32 ADC
8
9description: |
10  STM32 ADC is a successive approximation analog-to-digital converter.
11  It has several multiplexed input channels. Conversions can be performed
12  in single, continuous, scan or discontinuous mode. Result of the ADC is
13  stored in a left-aligned or right-aligned 32-bit data register.
14  Conversions can be launched in software or using hardware triggers.
15
16  The analog watchdog feature allows the application to detect if the input
17  voltage goes beyond the user-defined, higher or lower thresholds.
18
19  Each STM32 ADC block can have up to 3 ADC instances.
20
21maintainers:
22  - Fabrice Gasnier <fabrice.gasnier@foss.st.com>
23
24properties:
25  compatible:
26    enum:
27      - st,stm32f4-adc-core
28      - st,stm32h7-adc-core
29      - st,stm32mp1-adc-core
30      - st,stm32mp13-adc-core
31
32  reg:
33    maxItems: 1
34
35  interrupts:
36    description: |
37      One or more interrupts for ADC block, depending on part used:
38        - stm32f4 and stm32h7 share a common ADC interrupt line.
39        - stm32mp1 has two separate interrupt lines, one for each ADC within
40          ADC block.
41        - stm32mp13 has an interrupt line per ADC block.
42    minItems: 1
43    maxItems: 2
44
45  clocks:
46    minItems: 1
47    maxItems: 2
48    description: |
49      Core can use up to two clocks, depending on part used:
50        - "adc" clock: for the analog circuitry, common to all ADCs.
51          It's required on stm32f4.
52          It's optional on stm32h7 and stm32mp1.
53        - "bus" clock: for registers access, common to all ADCs.
54          It's not present on stm32f4.
55          It's required on stm32h7 and stm32mp1.
56
57  clock-names: true
58
59  st,max-clk-rate-hz:
60    description:
61      Allow to specify desired max clock rate used by analog circuitry.
62
63  vdda-supply:
64    description: Phandle to the vdda input analog voltage.
65
66  vref-supply:
67    description: Phandle to the vref input analog reference voltage.
68
69  booster-supply:
70    description:
71      Phandle to the embedded booster regulator that can be used to supply ADC
72      analog input switches on stm32h7 and stm32mp1.
73
74  vdd-supply:
75    description:
76      Phandle to the vdd input voltage. It can be used to supply ADC analog
77      input switches on stm32mp1.
78
79  st,syscfg:
80    description:
81      Phandle to system configuration controller. It can be used to control the
82      analog circuitry on stm32mp1.
83    $ref: /schemas/types.yaml#/definitions/phandle-array
84
85  interrupt-controller: true
86
87  '#interrupt-cells':
88    const: 1
89
90  '#address-cells':
91    const: 1
92
93  '#size-cells':
94    const: 0
95
96allOf:
97  - if:
98      properties:
99        compatible:
100          contains:
101            const: st,stm32f4-adc-core
102
103    then:
104      properties:
105        clocks:
106          maxItems: 1
107
108        clock-names:
109          const: adc
110
111        interrupts:
112          items:
113            - description: interrupt line common for all ADCs
114
115        st,max-clk-rate-hz:
116          minimum: 600000
117          maximum: 36000000
118          default: 36000000
119
120        booster-supply: false
121
122        vdd-supply: false
123
124        st,syscfg: false
125
126  - if:
127      properties:
128        compatible:
129          contains:
130            const: st,stm32h7-adc-core
131
132    then:
133      properties:
134        clocks:
135          minItems: 1
136          maxItems: 2
137
138        clock-names:
139          items:
140            - const: bus
141            - const: adc
142          minItems: 1
143
144        interrupts:
145          items:
146            - description: interrupt line common for all ADCs
147
148        st,max-clk-rate-hz:
149          minimum: 120000
150          maximum: 36000000
151          default: 36000000
152
153        vdd-supply: false
154
155        st,syscfg: false
156
157  - if:
158      properties:
159        compatible:
160          contains:
161            const: st,stm32mp1-adc-core
162
163    then:
164      properties:
165        clocks:
166          minItems: 1
167          maxItems: 2
168
169        clock-names:
170          items:
171            - const: bus
172            - const: adc
173          minItems: 1
174
175        interrupts:
176          items:
177            - description: interrupt line for ADC1
178            - description: interrupt line for ADC2
179
180        st,max-clk-rate-hz:
181          minimum: 120000
182          maximum: 36000000
183          default: 36000000
184
185  - if:
186      properties:
187        compatible:
188          contains:
189            const: st,stm32mp13-adc-core
190
191    then:
192      properties:
193        clocks:
194          minItems: 1
195          maxItems: 2
196
197        clock-names:
198          items:
199            - const: bus
200            - const: adc
201          minItems: 1
202
203        interrupts:
204          items:
205            - description: ADC interrupt line
206
207        st,max-clk-rate-hz:
208          minimum: 150000
209          maximum: 75000000
210          default: 75000000
211
212additionalProperties: false
213
214required:
215  - compatible
216  - reg
217  - interrupts
218  - clocks
219  - clock-names
220  - vdda-supply
221  - vref-supply
222  - interrupt-controller
223  - '#interrupt-cells'
224  - '#address-cells'
225  - '#size-cells'
226
227patternProperties:
228  "^adc@[0-9]+$":
229    type: object
230    description:
231      An ADC block node should contain at least one subnode, representing an
232      ADC instance available on the machine.
233
234    properties:
235      compatible:
236        enum:
237          - st,stm32f4-adc
238          - st,stm32h7-adc
239          - st,stm32mp1-adc
240          - st,stm32mp13-adc
241
242      reg:
243        description: |
244          Offset of ADC instance in ADC block. Valid values are:
245            - 0x0:   ADC1
246            - 0x100: ADC2
247            - 0x200: ADC3 (stm32f4 only)
248        maxItems: 1
249
250      '#io-channel-cells':
251        const: 1
252
253      '#address-cells':
254        const: 1
255
256      '#size-cells':
257        const: 0
258
259      interrupts:
260        description: |
261          IRQ Line for the ADC instance. Valid values are:
262            - 0 for adc@0 (single adc for stm32mp13)
263            - 1 for adc@100
264            - 2 for adc@200 (stm32f4 only)
265        maxItems: 1
266
267      clocks:
268        description:
269          Input clock private to this ADC instance. It's required only on
270          stm32f4, that has per instance clock input for registers access.
271        maxItems: 1
272
273      dmas:
274        description: RX DMA Channel
275        maxItems: 1
276
277      dma-names:
278        const: rx
279
280      assigned-resolution-bits:
281        description: |
282          Resolution (bits) to use for conversions:
283            - can be 6, 8, 10 or 12 on stm32f4 and stm32mp13
284            - can be 8, 10, 12, 14 or 16 on stm32h7 and stm32mp1
285
286      st,adc-channels:
287        description: |
288          List of single-ended channels muxed for this ADC. It can have up to:
289            - 16 channels, numbered from 0 to 15 (for in0..in15) on stm32f4
290            - 19 channels, numbered from 0 to 18 (for in0..in18) on stm32mp13.
291            - 20 channels, numbered from 0 to 19 (for in0..in19) on stm32h7 and
292              stm32mp1.
293        $ref: /schemas/types.yaml#/definitions/uint32-array
294        deprecated: true
295
296      st,adc-diff-channels:
297        description: |
298          List of differential channels muxed for this ADC. Some channels can
299          be configured as differential instead of single-ended on stm32h7 and
300          on stm32mp1. Positive and negative inputs pairs are listed:
301          <vinp vinn>, <vinp vinn>,... vinp and vinn are numbered from 0 to 19.
302
303          Note: At least one of "st,adc-channels" or "st,adc-diff-channels" is
304          required if no adc generic channel is defined. These legacy channel
305          properties are exclusive with adc generic channel bindings.
306          Both properties can be used together. Some channels can be
307          used as single-ended and some other ones as differential (mixed). But
308          channels can't be configured both as single-ended and differential.
309        $ref: /schemas/types.yaml#/definitions/uint32-matrix
310        items:
311          items:
312            - description: |
313                "vinp" indicates positive input number
314              minimum: 0
315              maximum: 19
316            - description: |
317                "vinn" indicates negative input number
318              minimum: 0
319              maximum: 19
320        deprecated: true
321
322      st,min-sample-time-nsecs:
323        description:
324          Minimum sampling time in nanoseconds. Depending on hardware (board)
325          e.g. high/low analog input source impedance, fine tune of ADC
326          sampling time may be recommended. This can be either one value or an
327          array that matches "st,adc-channels" and/or "st,adc-diff-channels"
328          list, to set sample time resp. for all channels, or independently for
329          each channel.
330        $ref: /schemas/types.yaml#/definitions/uint32-array
331        deprecated: true
332
333      nvmem-cells:
334        items:
335          - description: Phandle to the calibration vrefint data provided by otp
336
337      nvmem-cell-names:
338        items:
339          - const: vrefint
340
341    patternProperties:
342      "^channel@([0-9]|1[0-9])$":
343        type: object
344        $ref: adc.yaml
345        description: Represents the external channels which are connected to the ADC.
346
347        properties:
348          reg:
349            items:
350              minimum: 0
351              maximum: 19
352
353          label:
354            description: |
355              Unique name to identify which channel this is.
356              Reserved label names "vddcore", "vddcpu", "vddq_ddr", "vrefint" and "vbat"
357              are used to identify internal channels with matching names.
358
359          diff-channels:
360            $ref: /schemas/types.yaml#/definitions/uint32-array
361            items:
362              minimum: 0
363              maximum: 19
364
365          st,min-sample-time-ns:
366            description: |
367              Minimum sampling time in nanoseconds. Depending on hardware (board)
368              e.g. high/low analog input source impedance, fine tune of ADC
369              sampling time may be recommended.
370
371        required:
372          - reg
373
374        additionalProperties: false
375
376    allOf:
377      - if:
378          properties:
379            compatible:
380              contains:
381                const: st,stm32f4-adc
382
383        then:
384          properties:
385            reg:
386              enum:
387                - 0x0
388                - 0x100
389                - 0x200
390
391            interrupts:
392              minimum: 0
393              maximum: 2
394
395            assigned-resolution-bits:
396              enum: [6, 8, 10, 12]
397              default: 12
398
399            st,adc-channels:
400              minItems: 1
401              maxItems: 16
402              items:
403                minimum: 0
404                maximum: 15
405
406            st,adc-diff-channels: false
407
408            st,min-sample-time-nsecs:
409              minItems: 1
410              maxItems: 16
411              items:
412                minimum: 80
413
414          required:
415            - clocks
416
417      - if:
418          properties:
419            compatible:
420              contains:
421                enum:
422                  - st,stm32h7-adc
423                  - st,stm32mp1-adc
424
425        then:
426          properties:
427            reg:
428              enum:
429                - 0x0
430                - 0x100
431
432            interrupts:
433              minimum: 0
434              maximum: 1
435
436            assigned-resolution-bits:
437              enum: [8, 10, 12, 14, 16]
438              default: 16
439
440            st,adc-channels:
441              minItems: 1
442              maxItems: 20
443              items:
444                minimum: 0
445                maximum: 19
446
447            st,min-sample-time-nsecs:
448              minItems: 1
449              maxItems: 20
450              items:
451                minimum: 40
452
453
454      - if:
455          properties:
456            compatible:
457              contains:
458                const: st,stm32mp13-adc
459
460        then:
461          properties:
462            reg:
463              const: 0x0
464
465            interrupts:
466              const: 0
467
468            assigned-resolution-bits:
469              enum: [6, 8, 10, 12]
470              default: 12
471
472            st,adc-channels:
473              minItems: 1
474              maxItems: 19
475              items:
476                minimum: 0
477                maximum: 18
478
479            st,min-sample-time-nsecs:
480              minItems: 1
481              maxItems: 19
482              items:
483                minimum: 40
484    additionalProperties: false
485
486    required:
487      - compatible
488      - reg
489      - interrupts
490      - '#io-channel-cells'
491
492examples:
493  - |
494    // Example 1: with stm32f429, ADC1, single-ended channel 8
495      adc123: adc@40012000 {
496        compatible = "st,stm32f4-adc-core";
497        reg = <0x40012000 0x400>;
498        interrupts = <18>;
499        clocks = <&rcc 0 168>;
500        clock-names = "adc";
501        st,max-clk-rate-hz = <36000000>;
502        vdda-supply = <&vdda>;
503        vref-supply = <&vref>;
504        interrupt-controller;
505        #interrupt-cells = <1>;
506        #address-cells = <1>;
507        #size-cells = <0>;
508        adc@0 {
509          compatible = "st,stm32f4-adc";
510          #io-channel-cells = <1>;
511          reg = <0x0>;
512          clocks = <&rcc 0 168>;
513          interrupt-parent = <&adc123>;
514          interrupts = <0>;
515          st,adc-channels = <8>;
516          dmas = <&dma2 0 0 0x400 0x0>;
517          dma-names = "rx";
518          assigned-resolution-bits = <8>;
519        };
520        // ...
521        // other adc child nodes follow...
522      };
523
524  - |
525    // Example 2: with stm32mp157c to setup ADC1 with:
526    // - channels 0 & 1 as single-ended
527    // - channels 2 & 3 as differential (with resp. 6 & 7 negative inputs)
528      #include <dt-bindings/interrupt-controller/arm-gic.h>
529      #include <dt-bindings/clock/stm32mp1-clks.h>
530      adc12: adc@48003000 {
531        compatible = "st,stm32mp1-adc-core";
532        reg = <0x48003000 0x400>;
533        interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>,
534                     <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
535        clocks = <&rcc ADC12>, <&rcc ADC12_K>;
536        clock-names = "bus", "adc";
537        booster-supply = <&booster>;
538        vdd-supply = <&vdd>;
539        vdda-supply = <&vdda>;
540        vref-supply = <&vref>;
541        st,syscfg = <&syscfg>;
542        interrupt-controller;
543        #interrupt-cells = <1>;
544        #address-cells = <1>;
545        #size-cells = <0>;
546        adc@0 {
547          compatible = "st,stm32mp1-adc";
548          #io-channel-cells = <1>;
549          reg = <0x0>;
550          interrupt-parent = <&adc12>;
551          interrupts = <0>;
552          st,adc-channels = <0 1>;
553          st,adc-diff-channels = <2 6>, <3 7>;
554          st,min-sample-time-nsecs = <5000>;
555          dmas = <&dmamux1 9 0x400 0x05>;
556          dma-names = "rx";
557        };
558        // ...
559        // other adc child node follow...
560      };
561
562  - |
563    // Example 3: with stm32mp157c to setup ADC2 with:
564    // - internal channels 13, 14, 15.
565      #include <dt-bindings/interrupt-controller/arm-gic.h>
566      #include <dt-bindings/clock/stm32mp1-clks.h>
567      adc122: adc@48003000 {
568        compatible = "st,stm32mp1-adc-core";
569        reg = <0x48003000 0x400>;
570        interrupts = <GIC_SPI 18 IRQ_TYPE_LEVEL_HIGH>,
571                     <GIC_SPI 90 IRQ_TYPE_LEVEL_HIGH>;
572        clocks = <&rcc ADC12>, <&rcc ADC12_K>;
573        clock-names = "bus", "adc";
574        booster-supply = <&booster>;
575        vdd-supply = <&vdd>;
576        vdda-supply = <&vdda>;
577        vref-supply = <&vref>;
578        st,syscfg = <&syscfg>;
579        interrupt-controller;
580        #interrupt-cells = <1>;
581        #address-cells = <1>;
582        #size-cells = <0>;
583        adc@100 {
584          compatible = "st,stm32mp1-adc";
585          #io-channel-cells = <1>;
586          reg = <0x100>;
587          interrupts = <1>;
588          #address-cells = <1>;
589          #size-cells = <0>;
590          channel@13 {
591            reg = <13>;
592            label = "vrefint";
593            st,min-sample-time-ns = <9000>;
594          };
595          channel@14 {
596            reg = <14>;
597            label = "vddcore";
598            st,min-sample-time-ns = <9000>;
599          };
600          channel@15 {
601            reg = <15>;
602            label = "vbat";
603            st,min-sample-time-ns = <9000>;
604          };
605        };
606      };
607
608...
609