From 2b5fc79aa7470dfa29ee1ad3d88b57d214e4b9bf Mon Sep 17 00:00:00 2001 From: Andrey G Date: Sat, 5 Dec 2020 18:14:33 +0300 Subject: [PATCH] ADC: correctly calculate cache invalidate range for STM32F7xxx (#2021) Bug was introduced in 2312b0ae5755e47b0963586f3ae717537c57da4d when sample buffer was moved out of class. So sample become adcsample_t* instead of adcsample_t[] and sizeof returns 4. --- firmware/hw_layer/adc/AdcConfiguration.h | 3 ++- firmware/hw_layer/adc/adc_inputs.cpp | 9 +++++---- 2 files changed, 7 insertions(+), 5 deletions(-) diff --git a/firmware/hw_layer/adc/AdcConfiguration.h b/firmware/hw_layer/adc/AdcConfiguration.h index 96cbd94f92..d2f2a65e54 100644 --- a/firmware/hw_layer/adc/AdcConfiguration.h +++ b/firmware/hw_layer/adc/AdcConfiguration.h @@ -20,7 +20,7 @@ typedef struct { class AdcDevice { public: - explicit AdcDevice(ADCConversionGroup* hwConfig, adcsample_t *buf); + explicit AdcDevice(ADCConversionGroup* hwConfig, adcsample_t *buf, size_t buf_len); void enableChannel(adc_channel_e hwChannelIndex); void enableChannelAndPin(const char *msg, adc_channel_e hwChannelIndex); adc_channel_e getAdcHardwareIndexByInternalIndex(int index) const; @@ -34,6 +34,7 @@ public: void invalidateSamplesCache(); adcsample_t *samples; + size_t buf_len; int getAdcValueByHwChannel(adc_channel_e hwChannel) const; diff --git a/firmware/hw_layer/adc/adc_inputs.cpp b/firmware/hw_layer/adc/adc_inputs.cpp index 43d4735b61..e4a7bbbeca 100644 --- a/firmware/hw_layer/adc/adc_inputs.cpp +++ b/firmware/hw_layer/adc/adc_inputs.cpp @@ -61,9 +61,10 @@ float getVoltage(const char *msg, adc_channel_e hwChannel DECLARE_ENGINE_PARAMET return adcToVolts(getAdcValue(msg, hwChannel)); } -AdcDevice::AdcDevice(ADCConversionGroup* hwConfig, adcsample_t *buf) { +AdcDevice::AdcDevice(ADCConversionGroup* hwConfig, adcsample_t *buf, size_t buf_len) { this->hwConfig = hwConfig; this->samples = buf; + this->buf_len = buf_len; hwConfig->sqr1 = 0; hwConfig->sqr2 = 0; @@ -170,7 +171,7 @@ static ADCConversionGroup adcgrpcfgSlow = { #endif /* ADC_MAX_CHANNELS_COUNT */ }; -AdcDevice slowAdc(&adcgrpcfgSlow, slowAdcSampleBuf); +AdcDevice slowAdc(&adcgrpcfgSlow, slowAdcSampleBuf, ARRAY_SIZE(slowAdcSampleBuf)); void adc_callback_fast(ADCDriver *adcp, adcsample_t *buffer, size_t n); @@ -218,7 +219,7 @@ static ADCConversionGroup adcgrpcfgFast = { #endif /* ADC_MAX_CHANNELS_COUNT */ }; -AdcDevice fastAdc(&adcgrpcfgFast, fastAdcSampleBuf); +AdcDevice fastAdc(&adcgrpcfgFast, fastAdcSampleBuf, ARRAY_SIZE(fastAdcSampleBuf)); #if HAL_USE_GPT static void fast_adc_callback(GPTDriver*) { @@ -331,7 +332,7 @@ void AdcDevice::invalidateSamplesCache() { // anything like a CCI that maintains coherency across multiple bus masters. // As a result, we have to manually invalidate the D-cache any time we (the CPU) // would like to read something that somebody else wrote (ADC via DMA, in this case) - SCB_InvalidateDCache_by_Addr(reinterpret_cast(samples), sizeof(samples)); + SCB_InvalidateDCache_by_Addr(reinterpret_cast(samples), sizeof(*samples) * buf_len); #endif /* STM32F7XX */ }