2015-12-31 13:02:30 -08:00
|
|
|
/**
|
2018-01-21 13:11:39 -08:00
|
|
|
* @file map.cpp
|
2017-06-21 23:23:42 -07:00
|
|
|
*
|
|
|
|
* See also map_averaging.cpp
|
|
|
|
*
|
2020-01-13 18:57:43 -08:00
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2020
|
2015-12-31 13:02:30 -08:00
|
|
|
*/
|
2021-07-25 22:05:17 -07:00
|
|
|
#include "pch.h"
|
|
|
|
|
2019-04-12 19:07:03 -07:00
|
|
|
#if EFI_ANALOG_SENSORS
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2018-01-03 04:47:44 -08:00
|
|
|
/**
|
|
|
|
* This function checks if Baro/MAP sensor value is inside of expected range
|
|
|
|
* @return unchanged mapKPa parameter or NaN
|
|
|
|
*/
|
2021-11-16 01:15:29 -08:00
|
|
|
static float validateBaroMap(float mapKPa) {
|
2022-01-23 06:42:11 -08:00
|
|
|
// Highest interstate is the Eisenhower Tunnel at 11158 feet -> 66 kpa
|
|
|
|
// Lowest point is the Dead Sea, -1411 feet -> 106 kpa
|
|
|
|
if (cisnan(mapKPa) || mapKPa > 110 || mapKPa < 60) {
|
2019-09-29 06:58:29 -07:00
|
|
|
warning(OBD_Barometric_Press_Circ, "Invalid start-up baro pressure = %.2fkPa", mapKPa);
|
2018-01-03 04:47:44 -08:00
|
|
|
return NAN;
|
2019-09-29 06:58:29 -07:00
|
|
|
}
|
2018-01-03 04:47:44 -08:00
|
|
|
return mapKPa;
|
|
|
|
}
|
|
|
|
|
2019-04-12 19:07:03 -07:00
|
|
|
#if EFI_PROD_CODE
|
2017-08-06 13:29:14 -07:00
|
|
|
|
|
|
|
extern int mapMinBufferLength;
|
|
|
|
|
2021-11-15 04:02:34 -08:00
|
|
|
static void printMAPInfo() {
|
2019-04-12 19:07:03 -07:00
|
|
|
#if EFI_ANALOG_SENSORS
|
2021-10-05 16:59:07 -07:00
|
|
|
efiPrintf("instant value=%.2fkPa", Sensor::getOrZero(SensorType::Map));
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2020-02-26 15:16:35 -08:00
|
|
|
#if EFI_MAP_AVERAGING
|
2021-09-29 21:20:21 -07:00
|
|
|
efiPrintf("map type=%d/%s MAP=%.2fkPa mapMinBufferLength=%d", engineConfiguration->map.sensor.type,
|
|
|
|
getAir_pressure_sensor_type_e(engineConfiguration->map.sensor.type),
|
2021-10-05 16:59:07 -07:00
|
|
|
Sensor::getOrZero(SensorType::Map),
|
2021-09-29 21:20:21 -07:00
|
|
|
mapMinBufferLength);
|
2020-02-26 15:16:35 -08:00
|
|
|
#endif // EFI_MAP_AVERAGING
|
2015-07-10 06:01:56 -07:00
|
|
|
|
2021-09-29 21:20:21 -07:00
|
|
|
adc_channel_e mapAdc = engineConfiguration->map.sensor.hwChannel;
|
|
|
|
char pinNameBuffer[16];
|
|
|
|
|
2021-11-16 01:15:29 -08:00
|
|
|
efiPrintf("MAP %.2fv @%s", getVoltage("mapinfo", mapAdc),
|
2021-09-29 21:20:21 -07:00
|
|
|
getPinNameByAdcChannel("map", mapAdc, pinNameBuffer));
|
|
|
|
if (engineConfiguration->map.sensor.type == MT_CUSTOM) {
|
|
|
|
efiPrintf("at %.2fv=%.2f at %.2fv=%.2f",
|
|
|
|
engineConfiguration->mapLowValueVoltage,
|
|
|
|
engineConfiguration->map.sensor.lowValue,
|
|
|
|
engineConfiguration->mapHighValueVoltage,
|
|
|
|
engineConfiguration->map.sensor.highValue);
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|
|
|
|
|
2021-02-07 15:54:41 -08:00
|
|
|
if (Sensor::hasSensor(SensorType::BarometricPressure)) {
|
2021-04-20 11:09:41 -07:00
|
|
|
efiPrintf("baro type=%d value=%.2f", engineConfiguration->baroSensor.type, Sensor::get(SensorType::BarometricPressure).value_or(-1));
|
2015-08-30 14:01:21 -07:00
|
|
|
if (engineConfiguration->baroSensor.type == MT_CUSTOM) {
|
2021-04-20 11:09:41 -07:00
|
|
|
efiPrintf("min=%.2f@%.2f max=%.2f@%.2f",
|
2016-06-25 16:03:02 -07:00
|
|
|
engineConfiguration->baroSensor.lowValue,
|
|
|
|
engineConfiguration->mapLowValueVoltage,
|
|
|
|
engineConfiguration->baroSensor.highValue,
|
|
|
|
engineConfiguration->mapHighValueVoltage);
|
2015-08-30 14:01:21 -07:00
|
|
|
}
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|
|
|
|
#endif /* EFI_ANALOG_SENSORS */
|
|
|
|
}
|
|
|
|
#endif /* EFI_PROD_CODE */
|
|
|
|
|
2021-11-16 01:15:29 -08:00
|
|
|
void initMapDecoder() {
|
2021-11-17 00:54:21 -08:00
|
|
|
if (engineConfiguration->useFixedBaroCorrFromMap) {
|
2018-01-03 04:47:44 -08:00
|
|
|
// Read initial MAP sensor value and store it for Baro correction.
|
2022-01-23 06:42:11 -08:00
|
|
|
float storedInitialBaroPressure = Sensor::get(SensorType::MapSlow).value_or(101.325);
|
2021-04-20 11:09:41 -07:00
|
|
|
efiPrintf("Get initial baro MAP pressure = %.2fkPa", storedInitialBaroPressure);
|
2018-01-03 04:47:44 -08:00
|
|
|
// validate if it's within a reasonable range (the engine should not be spinning etc.)
|
2021-11-16 01:15:29 -08:00
|
|
|
storedInitialBaroPressure = validateBaroMap(storedInitialBaroPressure);
|
2018-01-03 04:47:44 -08:00
|
|
|
if (!cisnan(storedInitialBaroPressure)) {
|
2021-04-20 11:09:41 -07:00
|
|
|
efiPrintf("Using this fixed MAP pressure to override the baro correction!");
|
2022-01-23 06:42:11 -08:00
|
|
|
|
|
|
|
// TODO: do literally anything other than this
|
|
|
|
Sensor::setMockValue(SensorType::BarometricPressure, storedInitialBaroPressure);
|
2018-01-03 04:47:44 -08:00
|
|
|
} else {
|
2021-04-20 11:09:41 -07:00
|
|
|
efiPrintf("The baro pressure is invalid. The fixed baro correction will be disabled!");
|
2018-01-03 04:47:44 -08:00
|
|
|
}
|
|
|
|
}
|
2022-01-23 06:42:11 -08:00
|
|
|
|
2019-11-03 19:02:52 -08:00
|
|
|
#if EFI_PROD_CODE
|
2015-07-10 06:01:56 -07:00
|
|
|
addConsoleAction("mapinfo", printMAPInfo);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
#else /* EFI_ANALOG_SENSORS */
|
|
|
|
|
2021-11-16 01:15:29 -08:00
|
|
|
void initMapDecoder() {
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* EFI_ANALOG_SENSORS */
|