2021-08-03 19:05:01 -07:00
|
|
|
#include "pch.h"
|
|
|
|
|
2021-05-09 17:59:06 -07:00
|
|
|
#include "init.h"
|
|
|
|
#include "adc_subscription.h"
|
|
|
|
#include "functional_sensor.h"
|
|
|
|
#include "table_func.h"
|
|
|
|
|
|
|
|
static FunctionalSensor maf(SensorType::Maf, /* timeout = */ MS2NT(50));
|
|
|
|
|
|
|
|
#if !EFI_UNIT_TEST
|
|
|
|
// extract the type of the elements in the bin/value arrays
|
|
|
|
using BinType = std::remove_extent_t<decltype(config->mafDecodingBins)>;
|
|
|
|
using ValueType = std::remove_extent_t<decltype(config->mafDecoding)>;
|
|
|
|
|
|
|
|
// This function converts volts -> kg/h
|
2021-11-03 16:53:26 -07:00
|
|
|
static TableFunc mafCurve(config->mafDecodingBins, config->mafDecoding);
|
2021-05-09 17:59:06 -07:00
|
|
|
|
2021-11-16 01:15:29 -08:00
|
|
|
void initMaf() {
|
2021-11-17 00:54:21 -08:00
|
|
|
adc_channel_e channel = engineConfiguration->mafAdcChannel;
|
2021-05-09 17:59:06 -07:00
|
|
|
|
|
|
|
if (!isAdcChannelValid(channel)) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
maf.setFunction(mafCurve);
|
|
|
|
|
|
|
|
AdcSubscription::SubscribeSensor(maf, channel, /*lowpassCutoff =*/ 50);
|
|
|
|
maf.Register();
|
|
|
|
}
|
|
|
|
#endif // ! EFI_UNIT_TEST
|