libxr  1.0
Want to be the best embedded framework
Loading...
Searching...
No Matches
stm32_adc.hpp
1#pragma once
2
3#include "main.h"
4
5#ifdef HAL_ADC_MODULE_ENABLED
6
7#ifdef ADC
8#undef ADC
9#endif
10
11#include "adc.hpp"
12#include "libxr.hpp"
13
14namespace LibXR
15{
16
23{
30 template <typename, typename = void>
32 {
33 float Get(ADC_HandleTypeDef* hadc)
34 {
35 UNUSED(hadc);
36 return 4095.0f;
37 }
38 };
39
45 template <typename T>
46 struct GetADCResolution<T, std::void_t<decltype(std::declval<T>().Init.Resolution)>>
47 {
48 float Get(T* hadc)
49 {
50 switch (hadc->Init.Resolution)
51 {
52#ifdef ADC_RESOLUTION_16B
53 case ADC_RESOLUTION_16B:
54 return 65535.0f;
55#endif
56#ifdef ADC_RESOLUTION_12B
57 case ADC_RESOLUTION_12B:
58 return 4095.0f;
59#endif
60#ifdef ADC_RESOLUTION_10B
61 case ADC_RESOLUTION_10B:
62 return 1023.0f;
63#endif
64#ifdef ADC_RESOLUTION_8B
65 case ADC_RESOLUTION_8B:
66 return 255.0f;
67#endif
68#ifdef ADC_RESOLUTION_6B
69 case ADC_RESOLUTION_6B:
70 return 63.0f;
71#endif
72 default:
73 return 4095.0f;
74 }
75 }
76 };
77
78 public:
83 class Channel : public ADC
84 {
85 public:
94 Channel(STM32ADC* adc, uint8_t index, uint32_t ch) : adc_(adc), index_(index), ch_(ch)
95 {
96 }
97
104 float Read() override { return adc_->ReadChannel(index_); }
105
106 private:
107 Channel() {};
108 STM32ADC* adc_;
109 uint8_t index_;
110 uint32_t ch_;
111
112 friend class STM32ADC;
113 };
114
124 template <size_t NumChannels>
125 STM32ADC(ADC_HandleTypeDef* hadc, RawData dma_buff,
126 const std::array<uint32_t, NumChannels>& channels, float vref = 3.3f)
127 : hadc_(hadc),
128 NUM_CHANNELS(NumChannels),
129 filter_size_(dma_buff.size_ / NumChannels / 2),
130 use_dma_(hadc_->DMA_Handle != nullptr),
131 dma_buffer_(dma_buff),
132 resolution_(GetADCResolution<ADC_HandleTypeDef>{}.Get(hadc)),
133 channels_(new Channel[NumChannels]),
134 vref_(vref)
135 {
136 for (uint8_t i = 0; i < NUM_CHANNELS; ++i)
137 {
138 channels_[i] = Channel(this, i, channels[i]);
139 }
140
141 use_dma_ ? HAL_ADC_Start_DMA(hadc_, reinterpret_cast<uint32_t*>(dma_buffer_.addr_),
142 NUM_CHANNELS * filter_size_)
143 : HAL_ADC_Start(hadc_);
144 }
145
146 ~STM32ADC()
147 {
148 use_dma_ ? HAL_ADC_Stop_DMA(hadc_) : HAL_ADC_Stop(hadc_);
149 delete[] channels_;
150 }
151
158 Channel& GetChannel(uint8_t index) { return channels_[index]; }
159
166 float ReadChannel(uint8_t channel)
167 {
168 if (channel >= NUM_CHANNELS)
169 {
170 ASSERT(false);
171 return -1.0f;
172 }
173
174 uint16_t* buffer = reinterpret_cast<uint16_t*>(dma_buffer_.addr_);
175 if (use_dma_)
176 {
177#if __DCACHE_PRESENT
178 SCB_InvalidateDCache_by_Addr(buffer, filter_size_ * NUM_CHANNELS * 2);
179#endif
180 uint32_t sum = 0;
181 for (uint8_t i = 0; i < filter_size_; ++i)
182 {
183 sum += buffer[channel + i * NUM_CHANNELS];
184 }
185 return ConvertToVoltage(static_cast<float>(sum) / static_cast<float>(filter_size_));
186 }
187
188 ADC_ChannelConfTypeDef config = {};
189 uint32_t time = 0;
190 UNUSED(time);
191#if defined(ADC_SAMPLETIME_16CYCLES)
192 time = ADC_SAMPLETIME_16CYCLES;
193#elif defined(ADC_SAMPLETIME_16CYCLES_5)
194 time = ADC_SAMPLETIME_16CYCLES_5;
195#elif defined(ADC_SAMPLETIME_17CYCLES)
196 time = ADC_SAMPLETIME_17CYCLES;
197#elif defined(ADC_SAMPLETIME_17CYCLES_5)
198 time = ADC_SAMPLETIME_17CYCLES_5;
199#elif defined(ADC_SAMPLETIME_18CYCLES)
200 time = ADC_SAMPLETIME_18CYCLES;
201#elif defined(ADC_SAMPLETIME_18CYCLES_5)
202 time = ADC_SAMPLETIME_18CYCLES_5;
203#elif defined(ADC_SAMPLETIME_19CYCLES)
204 time = ADC_SAMPLETIME_19CYCLES;
205#elif defined(ADC_SAMPLETIME_19CYCLES_5)
206 time = ADC_SAMPLETIME_19CYCLES_5;
207#elif defined(ADC_SAMPLETIME_20CYCLES)
208 time = ADC_SAMPLETIME_20CYCLES;
209#elif defined(ADC_SAMPLETIME_20CYCLES_5)
210 time = ADC_SAMPLETIME_20CYCLES_5;
211#elif defined(ADC_SAMPLETIME_21CYCLES)
212 time = ADC_SAMPLETIME_21CYCLES;
213#elif defined(ADC_SAMPLETIME_21CYCLES_5)
214 time = ADC_SAMPLETIME_21CYCLES_5;
215#elif defined(ADC_SAMPLETIME_22CYCLES)
216 time = ADC_SAMPLETIME_22CYCLES;
217#elif defined(ADC_SAMPLETIME_22CYCLES_5)
218 time = ADC_SAMPLETIME_22CYCLES_5;
219#elif defined(ADC_SAMPLETIME_23CYCLES)
220 time = ADC_SAMPLETIME_23CYCLES;
221#elif defined(ADC_SAMPLETIME_23CYCLES_5)
222 time = ADC_SAMPLETIME_23CYCLES_5;
223#elif defined(ADC_SAMPLETIME_24CYCLES)
224 time = ADC_SAMPLETIME_24CYCLES;
225#elif defined(ADC_SAMPLETIME_24CYCLES_5)
226 time = ADC_SAMPLETIME_24CYCLES_5;
227#elif defined(ADC_SAMPLETIME_25CYCLES)
228 time = ADC_SAMPLETIME_25CYCLES;
229#elif defined(ADC_SAMPLETIME_25CYCLES_5)
230 time = ADC_SAMPLETIME_25CYCLES_5;
231#elif defined(ADC_SAMPLETIME_26CYCLES)
232 time = ADC_SAMPLETIME_26CYCLES;
233#elif defined(ADC_SAMPLETIME_26CYCLES_5)
234 time = ADC_SAMPLETIME_26CYCLES_5;
235#elif defined(ADC_SAMPLETIME_27CYCLES)
236 time = ADC_SAMPLETIME_27CYCLES;
237#elif defined(ADC_SAMPLETIME_27CYCLES_5)
238 time = ADC_SAMPLETIME_27CYCLES_5;
239#elif defined(ADC_SAMPLETIME_28CYCLES)
240 time = ADC_SAMPLETIME_28CYCLES;
241#elif defined(ADC_SAMPLETIME_28CYCLES_5)
242 time = ADC_SAMPLETIME_28CYCLES_5;
243#elif defined(ADC_SAMPLETIME_29CYCLES)
244 time = ADC_SAMPLETIME_29CYCLES;
245#elif defined(ADC_SAMPLETIME_29CYCLES_5)
246 time = ADC_SAMPLETIME_29CYCLES_5;
247#elif defined(ADC_SAMPLETIME_30CYCLES)
248 time = ADC_SAMPLETIME_30CYCLES;
249#elif defined(ADC_SAMPLETIME_30CYCLES_5)
250 time = ADC_SAMPLETIME_30CYCLES_5;
251#elif defined(ADC_SAMPLETIME_31CYCLES)
252 time = ADC_SAMPLETIME_31CYCLES;
253#elif defined(ADC_SAMPLETIME_31CYCLES_5)
254 time = ADC_SAMPLETIME_31CYCLES_5;
255#elif defined(ADC_SAMPLETIME_32CYCLES)
256 time = ADC_SAMPLETIME_32CYCLES;
257#elif defined(ADC_SAMPLETIME_32CYCLES_5)
258 time = ADC_SAMPLETIME_32CYCLES_5;
259#error "Unsupported sample time"
260#endif
261
262 config.Channel = channels_[channel].ch_;
263 config.Rank = 1;
264#if !defined(STM32L0)
265 config.SamplingTime = time;
266#endif
267
268 HAL_ADC_ConfigChannel(hadc_, &config);
269
270 uint32_t sum = 0;
271 for (uint8_t i = 0; i < filter_size_; ++i)
272 {
273 HAL_ADC_Start(hadc_);
274 HAL_ADC_PollForConversion(hadc_, 20);
275 buffer[channel + i * NUM_CHANNELS] = HAL_ADC_GetValue(hadc_);
276 sum += buffer[channel + i * NUM_CHANNELS];
277 }
278 return ConvertToVoltage(static_cast<float>(sum) / static_cast<float>(filter_size_));
279 }
280
281 private:
282 ADC_HandleTypeDef* hadc_;
283 const uint8_t NUM_CHANNELS;
284 uint8_t filter_size_;
285 bool use_dma_;
286 RawData dma_buffer_;
287 float resolution_;
288 Channel* channels_;
289 float vref_;
290
291 float ConvertToVoltage(float adc_value) { return adc_value * vref_ / resolution_; }
292};
293
294} // namespace LibXR
295
296#endif
模拟数字转换器(ADC)基类
Definition adc.hpp:18
原始数据封装类。 A class for encapsulating raw data.
void * addr_
数据存储地址。 The storage address of the data.
STM32ADC 类,用于处理 STM32 系统的 ADC 通道。 Provides handling for STM32 ADC.
Definition stm32_adc.hpp:84
Channel(STM32ADC *adc, uint8_t index, uint32_t ch)
STM32ADC 类,用于处理 STM32 系统的 ADC 通道。 Provides handling for STM32 ADC.
Definition stm32_adc.hpp:94
float Read() override
读取 ADC 值
STM32ADC 类,用于处理 STM32 系统的 ADC 通道。 Provides handling for STM32 ADC channels.
Definition stm32_adc.hpp:23
float ReadChannel(uint8_t channel)
读取 ADC 值
STM32ADC(ADC_HandleTypeDef *hadc, RawData dma_buff, const std::array< uint32_t, NumChannels > &channels, float vref=3.3f)
STM32ADC 类,用于处理 STM32 系统的 ADC 通道。 Provides handling for STM32.
Channel & GetChannel(uint8_t index)
获取 ADC 通道对象 Get ADC channel object
LibXR 命名空间
Definition ch32_gpio.hpp:9
获取 ADC 分辨率 Get ADC resolution
Definition stm32_adc.hpp:32