blob: 995cbf8cefc66f71ec5768b05c14c98e8619f8ce [file] [log] [blame]
Tom Rini53633a82024-02-29 12:33:36 -05001# 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...