2021-08-03 19:05:01 -07:00
|
|
|
|
#include "pch.h"
|
|
|
|
|
|
2021-10-04 14:18:08 -07:00
|
|
|
|
#include "adc_subscription.h"
|
|
|
|
|
#include "linear_func.h"
|
|
|
|
|
#include "fallback_sensor.h"
|
|
|
|
|
#include "functional_sensor.h"
|
2020-12-30 05:43:49 -08:00
|
|
|
|
#include "function_pointer_sensor.h"
|
2021-10-04 14:18:08 -07:00
|
|
|
|
#include "identity_func.h"
|
2020-12-30 05:43:49 -08:00
|
|
|
|
|
2022-01-23 06:42:11 -08:00
|
|
|
|
static LinearFunc baroConverter;
|
|
|
|
|
static FunctionalSensor baroSensor(SensorType::BarometricPressure, MS2NT(50));
|
2021-02-07 15:54:41 -08:00
|
|
|
|
|
2021-10-04 14:18:08 -07:00
|
|
|
|
// This converter is shared between both fast and slow: the only difference is
|
|
|
|
|
// how the *voltage* is determined, not how its converted to a pressure.
|
|
|
|
|
static LinearFunc mapConverter;
|
|
|
|
|
static FunctionalSensor slowMapSensor(SensorType::MapSlow, MS2NT(50));
|
|
|
|
|
|
|
|
|
|
// lowest reasonable idle is maybe 600 rpm
|
|
|
|
|
// one sample per cycle (1 cylinder, or "sample one cyl" mode) gives a period of 100ms
|
|
|
|
|
// add some margin -> 200ms timeout for fast MAP sampling
|
|
|
|
|
static FunctionalSensor fastMapSensor(SensorType::MapFast, MS2NT(200));
|
|
|
|
|
|
|
|
|
|
// This is called from the fast ADC completion callback
|
|
|
|
|
void onMapAveraged(float mapKpa, efitick_t nowNt) {
|
|
|
|
|
// This sensor uses identity function, so it's kPa in, kPa out
|
|
|
|
|
fastMapSensor.postRawValue(mapKpa, nowNt);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
SensorResult convertMap(float volts) {
|
|
|
|
|
return mapConverter.convert(volts);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// Combine MAP sensors: prefer fast sensor, but use slow if fast is unavailable.
|
|
|
|
|
static FallbackSensor mapCombiner(SensorType::Map, SensorType::MapFast, SensorType::MapSlow);
|
|
|
|
|
|
|
|
|
|
// helper struct for the local getMapCfg function
|
|
|
|
|
struct MapCfg {
|
2021-10-06 13:07:55 -07:00
|
|
|
|
float v1;
|
|
|
|
|
float map1;
|
|
|
|
|
float v2;
|
|
|
|
|
float map2;
|
2021-10-04 14:18:08 -07:00
|
|
|
|
};
|
|
|
|
|
|
2022-01-23 06:42:11 -08:00
|
|
|
|
static MapCfg getMapCfg(air_pressure_sensor_type_e sensorType) {
|
2021-10-04 14:18:08 -07:00
|
|
|
|
switch (sensorType) {
|
|
|
|
|
case MT_DENSO183:
|
|
|
|
|
return {0, -6.64, 5, 182.78};
|
|
|
|
|
case MT_MPX4100:
|
2021-10-16 09:31:40 -07:00
|
|
|
|
return {0.306, 20, 4.897, 105};
|
|
|
|
|
case MT_MPX4250:
|
2021-10-04 14:18:08 -07:00
|
|
|
|
case MT_MPX4250A:
|
2021-10-16 09:31:40 -07:00
|
|
|
|
return {0.204, 20, 4.896, 250};
|
2021-10-04 14:18:08 -07:00
|
|
|
|
case MT_HONDA3BAR:
|
|
|
|
|
return {0.5, 91.422, 3.0, 0};
|
|
|
|
|
case MT_DODGE_NEON_2003:
|
|
|
|
|
return {0.4, 15.34, 4.5, 100};
|
|
|
|
|
case MT_SUBY_DENSO:
|
|
|
|
|
return {0, 0, 5, 200};
|
|
|
|
|
case MT_GM_3_BAR:
|
|
|
|
|
return {0.631, 40, 4.914, 304};
|
|
|
|
|
case MT_GM_2_BAR:
|
|
|
|
|
return {0, 8.8, 5, 208};
|
|
|
|
|
case MT_GM_1_BAR:
|
|
|
|
|
return {0, 10, 5, 105};
|
|
|
|
|
case MT_TOYOTA_89420_02010:
|
|
|
|
|
return {3.7 - 2, 33.32, 3.7, 100};
|
|
|
|
|
case MT_MAZDA_1_BAR:
|
|
|
|
|
return {0, 2.5, 5, 117};
|
|
|
|
|
case MT_BOSCH_2_5:
|
2021-10-16 17:15:59 -07:00
|
|
|
|
// kpa=54.11764705882353v−1.6470588235294201
|
2021-10-04 14:18:08 -07:00
|
|
|
|
return {0.4 , 20 , 4.65, 250};
|
|
|
|
|
case MT_MPXH6400:
|
2021-10-16 09:31:40 -07:00
|
|
|
|
return {0.2, 20, 4.8, 400};
|
2021-10-04 14:18:08 -07:00
|
|
|
|
default:
|
|
|
|
|
firmwareError(CUSTOM_ERR_MAP_TYPE, "Unknown MAP type: decoder %d", sensorType);
|
|
|
|
|
// falls through to custom
|
|
|
|
|
return {};
|
|
|
|
|
case MT_CUSTOM: {
|
|
|
|
|
auto& mapConfig = engineConfiguration->map.sensor;
|
|
|
|
|
return {
|
|
|
|
|
engineConfiguration->mapLowValueVoltage,
|
|
|
|
|
mapConfig.lowValue,
|
|
|
|
|
engineConfiguration->mapHighValueVoltage,
|
|
|
|
|
mapConfig.highValue
|
|
|
|
|
};
|
|
|
|
|
}}
|
|
|
|
|
}
|
|
|
|
|
|
2022-01-23 06:42:11 -08:00
|
|
|
|
void configureMapFunction(LinearFunc& converter, air_pressure_sensor_type_e sensorType) {
|
|
|
|
|
auto cfg = getMapCfg(engineConfiguration->map.sensor.type);
|
2021-10-04 14:18:08 -07:00
|
|
|
|
|
2022-01-23 06:42:11 -08:00
|
|
|
|
converter.configure(
|
2021-10-04 14:18:08 -07:00
|
|
|
|
cfg.v1,
|
|
|
|
|
cfg.map1,
|
|
|
|
|
cfg.v2,
|
|
|
|
|
cfg.map2,
|
|
|
|
|
engineConfiguration->mapErrorDetectionTooLow,
|
|
|
|
|
engineConfiguration->mapErrorDetectionTooHigh
|
|
|
|
|
);
|
|
|
|
|
}
|
|
|
|
|
|
2021-11-16 01:15:29 -08:00
|
|
|
|
void initMap() {
|
2021-10-04 14:18:08 -07:00
|
|
|
|
auto mapChannel = engineConfiguration->map.sensor.hwChannel;
|
|
|
|
|
if (isAdcChannelValid(mapChannel)) {
|
|
|
|
|
// Set up the conversion function
|
2022-01-23 06:42:11 -08:00
|
|
|
|
configureMapFunction(mapConverter, engineConfiguration->map.sensor.type);
|
2021-10-04 14:18:08 -07:00
|
|
|
|
|
|
|
|
|
slowMapSensor.setFunction(mapConverter);
|
|
|
|
|
fastMapSensor.setFunction(identityFunction);
|
|
|
|
|
|
|
|
|
|
slowMapSensor.Register();
|
|
|
|
|
fastMapSensor.Register();
|
|
|
|
|
mapCombiner.Register();
|
|
|
|
|
|
|
|
|
|
// Configure slow MAP as a normal analog sensor
|
|
|
|
|
AdcSubscription::SubscribeSensor(slowMapSensor, mapChannel, 100);
|
|
|
|
|
}
|
2021-02-07 15:54:41 -08:00
|
|
|
|
|
2022-01-23 06:42:11 -08:00
|
|
|
|
auto baroChannel = engineConfiguration->baroSensor.hwChannel;
|
|
|
|
|
if (isAdcChannelValid(baroChannel)) {
|
|
|
|
|
configureMapFunction(baroConverter, engineConfiguration->baroSensor.type);
|
|
|
|
|
|
|
|
|
|
baroSensor.setFunction(baroConverter);
|
2021-02-07 15:54:41 -08:00
|
|
|
|
baroSensor.Register();
|
2022-01-23 06:42:11 -08:00
|
|
|
|
|
|
|
|
|
AdcSubscription::SubscribeSensor(baroSensor, baroChannel, 10);
|
2021-02-07 15:54:41 -08:00
|
|
|
|
}
|
2020-12-30 05:43:49 -08:00
|
|
|
|
}
|
2021-10-04 14:18:08 -07:00
|
|
|
|
|
|
|
|
|
void deinitMap() {
|
|
|
|
|
AdcSubscription::UnsubscribeSensor(slowMapSensor);
|
2022-01-23 06:42:11 -08:00
|
|
|
|
AdcSubscription::UnsubscribeSensor(baroSensor);
|
2021-10-04 14:18:08 -07:00
|
|
|
|
}
|