Imt.Base C++ API V4.1.1.0
Loading...
Searching...
No Matches
ADC3Registers.h
Go to the documentation of this file.
1// (c) IMT - Information Management Technology AG, CH-9470 Buchs, www.imt.ch.
2
3#ifndef STM32H730_ADC3REGISTERS_H
4#define STM32H730_ADC3REGISTERS_H
5
8
9namespace imt {
10namespace base {
11namespace hal {
12namespace stm32h730 {
13namespace registers {
14
25 struct ADC_ISR {
26 uint32_t volatile ADRDY : 1; // ADC ready
27 uint32_t volatile EOSMP : 1; // End of sampling flag
28 uint32_t volatile EOC : 1; // End of conversion flag
29 uint32_t volatile EOS : 1; // End of regular sequence flag
30 uint32_t volatile OVR : 1; // Overrun
31 uint32_t volatile JEOC : 1; // Injected channel end of conversion.
32 uint32_t volatile JEOS : 1; // Injected channel end of sequence flag
33 uint32_t volatile AWD1 : 1; // Analog watchdog 1 flag
34 uint32_t volatile AWD2 : 1; // Analog watchdog 2 flag
35 uint32_t volatile AWD3 : 1; // Analog watchdog 3 flag
36 uint32_t volatile JQOVF : 1; // Injected context queue overflow
37 uint32_t volatile : 21; // - reserved
38 };
39
43 struct ADC_IER {
44 uint32_t volatile ADRDYIE : 1; // ADC ready interrupt enable
45 uint32_t volatile EOSMPIE : 1; // End of sampling flag interrupt enable for regular conversions
46 uint32_t volatile EOCIE : 1; // End of regular conversion interrupt enable
47 uint32_t volatile EOSIE : 1; // End of regular sequence of conversions interrupt enable
48 uint32_t volatile OVRIE : 1; // Overrun interrupt enable
49 uint32_t volatile JEOCIE : 1; // End of injected conversion interrupt enable
50 uint32_t volatile JEOSIE : 1; // End of injected sequence of conversions interrupt enable
51 uint32_t volatile AWD1IE : 1; // Analog watchdog 1 interrupt enable
52 uint32_t volatile AWD2IE : 1; // Analog watchdog 2 interrupt enable
53 uint32_t volatile AWD3IE : 1; // Analog watchdog 3 interrupt enable
54 uint32_t volatile JQOVFIE : 1; // Injected context queue overflow interrupt enable
55 uint32_t volatile : 21; // - reserved
56 };
57
61 struct ADC_CR {
62 uint32_t volatile ADEN : 1; // ADC enable control
63 uint32_t volatile ADDIS : 1; // ADC disable command
64 uint32_t volatile ADSTART : 1; // ADC start of regular conversion
65 uint32_t volatile JADSTART : 1; // ADC start of injected conversion
66 uint32_t volatile ADSTP : 1; // ADC stop of regular conversion command
67 uint32_t volatile JADSTP : 1; // ADC stop of injected conversion command
68 uint32_t volatile : 22; // - reserved
69 uint32_t volatile ADVREGEN : 1; // ADC voltage regulator enable
70 uint32_t volatile DEEPPWD : 1; // Deep-power-down enable
71 uint32_t volatile ADCALDIF : 1; // Differential mode for calibration
72 uint32_t volatile ADCAL : 1; // ADC calibration
73 };
74
78 struct ADC_CFGR {
79 uint32_t volatile DMAEN : 1; // Direct memory access enable
80 uint32_t volatile DMACFG : 1; // Direct memory access configuration
81 uint32_t volatile DFSDMCFG : 1; // DFSDM mode configuration
82 uint32_t volatile RES : 2; // Data resolution
83 uint32_t volatile EXTSEL : 5; // External trigger selection for regular group
84 uint32_t volatile EXTEN : 2; // External trigger enable and polarity selection for regular channels
85 uint32_t volatile OVRMOD : 1; // Overrun mode
86 uint32_t volatile CONT : 1; // Single / Continuous conversion mode for regular conversions
87 uint32_t volatile AUTDLY : 1; // Delayed conversion mode
88 uint32_t volatile ALIGN : 1; // Data alignment
89 uint32_t volatile DISCEN : 1; // Discontinuous mode for regular channels
90 uint32_t volatile DISCNUM : 3; // Discontinuous mode channel count
91 uint32_t volatile JDISCEN : 1; // Discontinuous mode on injected channels
92 uint32_t volatile JQM : 1; // JSQR queue mode
93 uint32_t volatile AWD1SGL : 1; // Enable the watchdog 1 on a single channel or on all channels
94 uint32_t volatile AWD1EN : 1; // Analog watchdog 1 enable on regular channels
95 uint32_t volatile JAWD1EN : 1; // Analog watchdog 1 enable on injected channels
96 uint32_t volatile JAUTO : 1; // Automatic injected group conversion
97 uint32_t volatile AWD1CH : 5; // Analog watchdog 1 channel selection
98 uint32_t volatile JQDIS : 1; // Injected Queue disable
99 };
100
104 struct ADC_CFGR2 {
105 uint32_t volatile ROVSE : 1; // Regular Oversampling Enable
106 uint32_t volatile JOVSE : 1; // Injected Oversampling Enable
107 uint32_t volatile OVSR : 3; // Oversampling ratio
108 uint32_t volatile OVSS : 4; // Oversampling right shift
109 uint32_t volatile TROVS : 1; // Triggered Regular Oversampling
110 uint32_t volatile ROVSM : 1; // Regular Oversampling mode
111 uint32_t volatile : 14; // - reserved
112 uint32_t volatile SWTRIG : 1; // Software trigger bit for sampling time control trigger mode
113 uint32_t volatile BULB : 1; // Bulb sampling mode
114 uint32_t volatile SMPTRIG : 1; // Sampling time control trigger mode
115 uint32_t volatile : 4; // - reserved
116 };
117
121 struct ADC_SMPR1 {
122 uint32_t volatile SMP0 : 3; // Channel x sampling time selection (x = 0 to 9)
123 uint32_t volatile SMP1 : 3; // Channel x sampling time selection (x = 0 to 9)
124 uint32_t volatile SMP2 : 3; // Channel x sampling time selection (x = 0 to 9)
125 uint32_t volatile SMP3 : 3; // Channel x sampling time selection (x = 0 to 9)
126 uint32_t volatile SMP4 : 3; // Channel x sampling time selection (x = 0 to 9)
127 uint32_t volatile SMP5 : 3; // Channel x sampling time selection (x = 0 to 9)
128 uint32_t volatile SMP6 : 3; // Channel x sampling time selection (x = 0 to 9)
129 uint32_t volatile SMP7 : 3; // Channel x sampling time selection (x = 0 to 9)
130 uint32_t volatile SMP8 : 3; // Channel x sampling time selection (x = 0 to 9)
131 uint32_t volatile SMP9 : 3; // Channel x sampling time selection (x = 0 to 9)
132 uint32_t volatile : 1; // - reserved
133 uint32_t volatile SMPPLUS : 1; // Addition of one clock cycle to the sampling time
134 };
135
139 struct ADC_SMPR2 {
140 uint32_t volatile SMP10 : 3; // Channel x sampling time selection (x = 10 to 19)
141 uint32_t volatile SMP11 : 3; // Channel x sampling time selection (x = 10 to 19)
142 uint32_t volatile SMP12 : 3; // Channel x sampling time selection (x = 10 to 19)
143 uint32_t volatile SMP13 : 3; // Channel x sampling time selection (x = 10 to 19)
144 uint32_t volatile SMP14 : 3; // Channel x sampling time selection (x = 10 to 19)
145 uint32_t volatile SMP15 : 3; // Channel x sampling time selection (x = 10 to 19)
146 uint32_t volatile SMP16 : 3; // Channel x sampling time selection (x = 10 to 19)
147 uint32_t volatile SMP17 : 3; // Channel x sampling time selection (x = 10 to 19)
148 uint32_t volatile SMP18 : 3; // Channel x sampling time selection (x = 10 to 19)
149 uint32_t volatile : 5; // - reserved
150 };
151
155 struct ADC_TR1 {
156 uint32_t volatile LT1 : 12; // Analog watchdog 1 lower threshold
157 uint32_t volatile AWDFILT : 3; // Analog watchdog filtering parameter
158 uint32_t volatile : 1; // - reserved
159 uint32_t volatile HT1 : 12; // Analog watchdog 1 higher threshold
160 uint32_t volatile : 4; // - reserved
161 };
162
166 struct ADC_TR2 {
167 uint32_t volatile LT2 : 8; // Analog watchdog 2 lower threshold
168 uint32_t volatile : 8; // - reserved
169 uint32_t volatile HT2 : 8; // Analog watchdog 2 higher threshold
170 uint32_t volatile : 8; // - reserved
171 };
172
176 struct ADC_TR3 {
177 uint32_t volatile LT3 : 8; // Analog watchdog 3 lower threshold
178 uint32_t volatile : 8; // - reserved
179 uint32_t volatile HT3 : 8; // Analog watchdog 3 higher threshold
180 uint32_t volatile : 8; // - reserved
181 };
182
186 struct ADC_SQR1 {
187 uint32_t volatile L : 4; // Regular channel sequence length
188 uint32_t volatile : 2; // - reserved
189 uint32_t volatile SQ1 : 5; // 1st conversion in regular sequence
190 uint32_t volatile : 1; // - reserved
191 uint32_t volatile SQ2 : 5; // 2nd conversion in regular sequence
192 uint32_t volatile : 1; // - reserved
193 uint32_t volatile SQ3 : 5; // 3rd conversion in regular sequence
194 uint32_t volatile : 1; // - reserved
195 uint32_t volatile SQ4 : 5; // 4th conversion in regular sequence
196 uint32_t volatile : 3; // - reserved
197 };
198
202 struct ADC_SQR2 {
203 uint32_t volatile SQ5 : 5; // 5th conversion in regular sequence
204 uint32_t volatile : 1; // - reserved
205 uint32_t volatile SQ6 : 5; // 6th conversion in regular sequence
206 uint32_t volatile : 1; // - reserved
207 uint32_t volatile SQ7 : 5; // 7th conversion in regular sequence
208 uint32_t volatile : 1; // - reserved
209 uint32_t volatile SQ8 : 5; // 8th conversion in regular sequence
210 uint32_t volatile : 1; // - reserved
211 uint32_t volatile SQ9 : 5; // 9th conversion in regular sequence
212 uint32_t volatile : 3; // - reserved
213 };
214
218 struct ADC_SQR3 {
219 uint32_t volatile SQ10 : 5; // 10th conversion in regular sequence
220 uint32_t volatile : 1; // - reserved
221 uint32_t volatile SQ11 : 5; // 11th conversion in regular sequence
222 uint32_t volatile : 1; // - reserved
223 uint32_t volatile SQ12 : 5; // 12th conversion in regular sequence
224 uint32_t volatile : 1; // - reserved
225 uint32_t volatile SQ13 : 5; // 13th conversion in regular sequence
226 uint32_t volatile : 1; // - reserved
227 uint32_t volatile SQ14 : 5; // 14th conversion in regular sequence
228 uint32_t volatile : 3; // - reserved
229 };
230
234 struct ADC_SQR4 {
235 uint32_t volatile SQ15 : 5; // 15th conversion in regular sequence
236 uint32_t volatile : 1; // - reserved
237 uint32_t volatile SQ16 : 5; // 16th conversion in regular sequence
238 uint32_t volatile : 21; // - reserved
239 };
240
244 struct ADC_DR {
245 uint32_t volatile RDATA : 16; // Regular data converted
246 uint32_t volatile : 16; // - reserved
247 };
248
252 struct ADC_JSQR {
253 uint32_t volatile JL : 2; // Injected channel sequence length
254 uint32_t volatile JEXTSEL : 5; // External trigger selection for injected group
255 uint32_t volatile JEXTEN : 2; // External trigger enable and polarity selection for injected channels
256 uint32_t volatile JSQ1 : 5; // 1st conversion in the injected sequence
257 uint32_t volatile : 1; // - reserved
258 uint32_t volatile JSQ2 : 5; // 2nd conversion in the injected sequence
259 uint32_t volatile : 1; // - reserved
260 uint32_t volatile JSQ3 : 5; // 3rd conversion in the injected sequence
261 uint32_t volatile : 1; // - reserved
262 uint32_t volatile JSQ4 : 5; // 4th conversion in the injected sequence
263 };
264
268 struct ADC_OFRy {
269 uint32_t volatile OFFSETy : 12; // 1Data offset y for the channel programmed into bits OFFSETy_CH[4:0]
270 uint32_t volatile : 12; // - reserved
271 uint32_t volatile OFFSETPOS : 1; // Positive offset
272 uint32_t volatile SATEN : 1; // Saturation enable
273 uint32_t volatile OFFSETy_CH : 5; // Channel selection for the data offset y
274 uint32_t volatile OFFSETy_EN : 1; // Offset y enable
275 };
276
280 struct ADC_JDRy {
281 uint32_t volatile JDATA : 16; // Injected data
282 uint32_t volatile : 16; // - reserved
283 };
284
288 struct ADC_AWDxCR {
289 uint32_t volatile AWDxCH : 19; // Analog watchdog x channel selection
290 uint32_t volatile : 13; // - reserved
291 };
292
296 struct ADC_DIFSEL {
297 uint32_t volatile DIFSEL : 19; // Differential mode for channels 19 to 0
298 uint32_t volatile : 13; // - reserved
299 };
300
304 struct ADC_CALFACT {
305 uint32_t volatile CALFACT_S : 7; // Calibration Factors In Single-Ended mode
306 uint32_t volatile : 9; // - reserved
307 uint32_t volatile CALFACT_D : 7; // Calibration Factors In differential mode
308 uint32_t volatile : 9; // - reserved
309 };
310
315 return *reinterpret_cast<ADC3Registers*>(module);
316 }
317
318 // Registers
319 volatile ADC_ISR ISR; // Offset 0x00
320 volatile ADC_IER IER; // Offset 0x04
321 volatile ADC_CR CR; // Offset 0x08
322 volatile ADC_CFGR CFGR; // Offset 0x0C
323 volatile ADC_CFGR2 CFGR2; // Offset 0x10
324 volatile ADC_SMPR1 SMPR1; // Offset 0x14
325 volatile ADC_SMPR2 SMPR2; // Offset 0x18
327 volatile ADC_TR1 TR1; // Offset 0x20
328 volatile ADC_TR2 TR2; // Offset 0x24
329 volatile ADC_TR3 TR3; // Offset 0x28
331 volatile ADC_SQR1 SQR1; // Offset 0x30
332 volatile ADC_SQR2 SQR2; // Offset 0x34
333 volatile ADC_SQR3 SQR3; // Offset 0x38
334 volatile ADC_SQR4 SQR4; // Offset 0x3C
335 volatile ADC_DR DR; // Offset 0x40
336 uint32_t volatile _reserved2[2U];
337 volatile ADC_JSQR JSQR; // Offset 0x4C
338 uint32_t volatile _reserved3[4U];
339 ADC_OFRy volatile OFR1; // Offset 0x60
340 ADC_OFRy volatile OFR2; // Offset 0x64
341 ADC_OFRy volatile OFR3; // Offset 0x68
342 ADC_OFRy volatile OFR4; // Offset 0x6C
343 uint32_t volatile _reserved4[4U];
344 ADC_JDRy volatile JDR1; // Offset 0x80
345 ADC_JDRy volatile JDR2; // Offset 0x84
346 ADC_JDRy volatile JDR3; // Offset 0x88
347 ADC_JDRy volatile JDR4; // Offset 0x8C
348 uint32_t volatile _reserved5[4U];
349 ADC_AWDxCR volatile AWD2CR; // Offset 0xA0
350 ADC_AWDxCR volatile AWD3CR; // Offset 0xA4
351 uint32_t volatile _reserved6[2U];
352 volatile ADC_DIFSEL DIFSEL; // Offset 0xB0
353 volatile ADC_CALFACT CALFACT; // Offset 0xB4
354
355private:
356
361
365 ADC3Registers(ADC3Registers const& other);
366
370 ADC3Registers& operator=(ADC3Registers const& other);
371};
372
373} // namespace registers
374} // namespace stm32h730
375} // namespace hal
376} // namespace base
377} // namespace imt
378
379#endif // STM32H730_ADC3REGISTERS_H
ADCModuleAddress
Enumeration of the available ADC modules identifiers.
This is a application specific file which is used to configure Imt.Base.Core.Math.
unsigned __int32 uint32_t
Definition stdint.h:64
ADC analog watchdog x configuration register (ADC_AWDxCR) (x=2.3), chapter 29.6.19,...
ADC calibration factors register (ADC_CALFACT), chapter 29.6.22.
ADC configuration register 2 (ADC_CFGR2), chapter 29.6.5.
ADC configuration register (ADC_CFGR), chapter 29.6.4.
ADC control register (ADC_CR), chapter 29.6.3.
ADC differential mode selection register (ADC_DIFSEL), chapter 29.6.21.
ADC reguler data register (ADC_DR), chapter 29.6.15.
ADC interrupt enable register (ADC_IER), chapter 29.6.2.
ADC interrupt and status register (ADC_ISR), chapter 29.6.1.
ADC injected channel y data register (ADC_JDRy), chapter 29.6.18.
ADC injected sequence register (ADC_JSQR), chapter 29.6.16.
ADC injected channel y offset register (ADC_OFRy), chapter 29.6.17.
ADC sample time register 1 (ADC_SMPR1), chapter 29.6.6.
ADC sample time register 2 (ADC_SMPR2), chapter 29.6.7.
ADC regular sequence register 1 (ADC_SQR1), chapter 29.6.11.
ADC regular sequence register 2 (ADC_SQR2), chapter 29.6.12.
ADC regular sequence register 3 (ADC_SQR3), chapter 29.6.13.
ADC regular sequence register 4 (ADC_SQR4), chapter 29.6.14.
ADC watchdog threshold register x (ADC_LTRx) (x=1-3), chapter 29.6.8.
ADC watchdog threshold register x (ADC_HTRx) (x=1-3), chapter 29.6.9.
ADC watchdog threshold register 3 (ADC_TR3), 29.6.10.
Analog digital converter (ADC) register structure.
static ADC3Registers & getInstance(ADCModuleAddress const module)
Gets the instance of the registers for a given ADC module in memory.