rusefi/firmware/hw_layer/AdcConfiguration.h

58 lines
1.6 KiB
C
Raw Normal View History

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
#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:
explicit AdcDevice(ADCConversionGroup* hwConfig);
2016-07-19 18:04:11 -07:00
void enableChannel(adc_channel_e hwChannelIndex);
void enableChannelAndPin(adc_channel_e hwChannelIndex);
adc_channel_e getAdcHardwareIndexByInternalIndex(int index) const;
2015-07-10 06:01:56 -07:00
int internalAdcIndexByHardwareIndex[20];
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;
int getAdcValueByIndex(int internalIndex) const;
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.
// 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
__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
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
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_ */