2015-07-10 06:01:56 -07:00
|
|
|
/**
|
|
|
|
* @file AdcConfiguration.h
|
|
|
|
*
|
|
|
|
* @date May 3, 2014
|
2017-01-03 03:05:22 -08:00
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2017
|
2015-07-10 06:01:56 -07:00
|
|
|
*/
|
|
|
|
#ifndef ADCCONFIGURATION_H_
|
|
|
|
#define ADCCONFIGURATION_H_
|
|
|
|
|
2019-04-12 17:52:51 -07:00
|
|
|
#if HAL_USE_ADC
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2019-07-05 17:34:41 -07:00
|
|
|
#define ADC_MAX_CHANNELS_COUNT 16
|
|
|
|
|
|
|
|
// this structure contains one multi-channel ADC state snapshot
|
|
|
|
typedef struct {
|
|
|
|
volatile adcsample_t adc_data[ADC_MAX_CHANNELS_COUNT];
|
|
|
|
} adc_state;
|
|
|
|
|
2015-07-10 06:01:56 -07:00
|
|
|
class AdcDevice {
|
|
|
|
public:
|
2019-06-08 06:51:36 -07:00
|
|
|
explicit AdcDevice(ADCConversionGroup* hwConfig);
|
2016-07-19 18:04:11 -07:00
|
|
|
void enableChannel(adc_channel_e hwChannelIndex);
|
|
|
|
void enableChannelAndPin(adc_channel_e hwChannelIndex);
|
2019-06-08 06:51:36 -07:00
|
|
|
adc_channel_e getAdcHardwareIndexByInternalIndex(int index) const;
|
2015-07-10 06:01:56 -07:00
|
|
|
int internalAdcIndexByHardwareIndex[20];
|
2019-06-08 06:51:36 -07:00
|
|
|
bool isHwUsed(adc_channel_e hwChannel) const;
|
|
|
|
int size() const;
|
2015-07-10 06:01:56 -07:00
|
|
|
void init(void);
|
|
|
|
int conversionCount;
|
|
|
|
int errorsCount;
|
2019-06-08 06:51:36 -07:00
|
|
|
int getAdcValueByIndex(int internalIndex) const;
|
2019-06-23 06:21:12 -07:00
|
|
|
void invalidateSamplesCache();
|
|
|
|
|
2019-06-23 06:23:20 -07:00
|
|
|
// on F7 this must be aligned on a 32-byte boundary, and be a multiple of 32 bytes long.
|
2019-06-23 06:21:12 -07:00
|
|
|
// When we invalidate the cache line(s) for ADC samples, we don't want to nuke any
|
2019-06-23 06:23:20 -07:00
|
|
|
// adjacent data.
|
|
|
|
// F4 does not care
|
2019-06-23 06:21:12 -07:00
|
|
|
__ALIGNED(32) adcsample_t samples[ADC_MAX_CHANNELS_COUNT * MAX_ADC_GRP_BUF_DEPTH];
|
|
|
|
// Assert multiple of 32 bytes long so we don't stomp on the data after the buffer
|
2019-12-11 06:28:11 -08:00
|
|
|
static_assert(sizeof(samples) % 32 == 0, "ADC sample buffer size must be a multiple of 32 bytes");
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2019-06-08 06:51:36 -07:00
|
|
|
int getAdcValueByHwChannel(int hwChannel) const;
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
adc_state values;
|
|
|
|
int channelCount;
|
|
|
|
private:
|
|
|
|
ADCConversionGroup* hwConfig;
|
|
|
|
/**
|
|
|
|
* Number of ADC channels in use
|
|
|
|
*/
|
|
|
|
|
|
|
|
adc_channel_e hardwareIndexByIndernalAdcIndex[20];
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* HAL_USE_ADC */
|
|
|
|
|
|
|
|
#endif /* ADCCONFIGURATION_H_ */
|