rusefi/firmware/hw_layer/adc_subscription.cpp

65 lines
1.3 KiB
C++
Raw Normal View History

#include "adc_subscription.h"
#include "adc_inputs.h"
#include "engine.h"
2019-10-11 17:43:21 -07:00
#include "perf_trace.h"
#include <iterator>
EXTERN_ENGINE;
#if !EFI_UNIT_TEST
struct AdcSubscriptionEntry {
FunctionalSensor *Sensor;
float VoltsPerAdcVolt;
adc_channel_e Channel;
};
static size_t s_nextEntry = 0;
static AdcSubscriptionEntry s_entries[8];
void AdcSubscription::SubscribeSensor(FunctionalSensor &sensor,
adc_channel_e channel,
float voltsPerAdcVolt /*= 0.0f*/) {
// Don't subscribe null channels
if (channel == EFI_ADC_NONE) {
return;
}
// bounds check
if (s_nextEntry >= std::size(s_entries)) {
return;
}
// if 0, default to the board's divider coefficient
if (voltsPerAdcVolt == 0) {
voltsPerAdcVolt = engineConfiguration->analogInputDividerCoefficient;
}
// Populate the entry
auto &entry = s_entries[s_nextEntry];
entry.Sensor = &sensor;
entry.VoltsPerAdcVolt = voltsPerAdcVolt;
entry.Channel = channel;
s_nextEntry++;
}
void AdcSubscription::UpdateSubscribers() {
2019-10-11 17:43:21 -07:00
ScopePerf perf(PE::AdcSubscriptionUpdateSubscribers);
auto timestamp = getTimeNowNt();
for (size_t i = 0; i < s_nextEntry; i++) {
auto &entry = s_entries[i];
float mcuVolts = getVoltage("sensor", entry.Channel);
float sensorVolts = mcuVolts * entry.VoltsPerAdcVolt;
entry.Sensor->postRawValue(sensorVolts, timestamp);
}
}
#endif // !EFI_UNIT_TEST