rusefi/firmware/config/engines/vw_b6.cpp

440 lines
12 KiB
C++
Raw Normal View History

2019-12-26 18:33:12 -08:00
/*
* @file vw_b6.cpp
*
* @date Dec 26, 2019
2020-01-07 21:02:40 -08:00
* @author Andrey Belomutskiy, (c) 2012-2020
2019-12-26 18:33:12 -08:00
*/
#include "pch.h"
2019-12-26 18:33:12 -08:00
#include "vw_b6.h"
2020-10-21 21:57:11 -07:00
#include "table_helper.h"
2021-10-10 19:23:33 -07:00
#include "electronic_throttle_impl.h"
2021-12-30 22:44:28 -08:00
#include "mre_meta.h"
2022-10-29 20:38:22 -07:00
#include "defaults.h"
2022-05-20 23:25:43 -07:00
#include "proteus_meta.h"
2019-12-26 18:33:12 -08:00
2022-05-20 23:25:43 -07:00
static void commonPassatB6() {
setCrankOperationMode();
2020-08-29 07:06:28 -07:00
engineConfiguration->trigger.type = TT_TOOTHED_WHEEL_60_2;
2021-02-08 18:50:31 -08:00
engineConfiguration->vvtMode[0] = VVT_BOSCH_QUICK_START;
2020-10-22 21:39:22 -07:00
engineConfiguration->map.sensor.type = MT_BOSCH_2_5;
2019-12-26 18:33:12 -08:00
2022-09-18 15:22:55 -07:00
engineConfiguration->etbIdleThrottleRange = 10;
engineConfiguration->idlePidRpmDeadZone = 500;
engineConfiguration->idleMode = IM_AUTO;
2022-06-01 21:34:02 -07:00
engineConfiguration->specs.cylindersCount = 4;
engineConfiguration->specs.firingOrder = FO_1_3_4_2;
2022-06-02 20:28:30 -07:00
engineConfiguration->isPhaseSyncRequiredForIgnition = true;
2022-06-02 21:04:59 -07:00
engineConfiguration->disableEtbWhenEngineStopped = true;
2022-06-01 21:34:02 -07:00
for (int i = 4; i < MAX_CYLINDER_COUNT;i++) {
engineConfiguration->injectionPins[i] = Gpio::Unassigned;
engineConfiguration->ignitionPins[i] = Gpio::Unassigned;
}
2022-09-18 14:20:42 -07:00
// engineConfiguration->canNbcType = CAN_BUS_NBC_VAG;
engineConfiguration->enableAemXSeries = true;
engineConfiguration->afr.hwChannel = EFI_ADC_4;
2021-12-30 22:20:25 -08:00
// Injectors flow 1214 cc/min at 100 bar pressure
engineConfiguration->injector.flow = 1214;
// Use high pressure sensor
engineConfiguration->injectorPressureType = IPT_High;
// Automatic compensation of injector flow based on rail pressure
engineConfiguration->injectorCompensationMode = ICM_SensedRailPressure;
// Reference rail pressure is 10 000 kPa = 100 bar
engineConfiguration->fuelReferencePressure = 10000;
//setting "flat" 0.2 ms injector's lag time
setArrayValues(engineConfiguration->injector.battLagCorr, 0.2);
strcpy(engineConfiguration->engineMake, ENGINE_MAKE_VAG);
strcpy(engineConfiguration->engineCode, "BPY");
2022-01-10 10:53:02 -08:00
strcpy(engineConfiguration->vehicleName, "test");
2020-08-29 16:01:44 -07:00
2021-12-30 23:17:42 -08:00
engineConfiguration->throttlePedalUpVoltage = 0.36;
engineConfiguration->throttlePedalWOTVoltage = 2.13;
engineConfiguration->throttlePedalSecondaryUpVoltage = 0.73;
engineConfiguration->throttlePedalSecondaryWOTVoltage = 4.30;
2020-08-29 16:01:44 -07:00
engineConfiguration->invertCamVVTSignal = true;
2020-10-12 21:35:04 -07:00
2020-10-31 21:33:18 -07:00
/**
* PSS-140
*/
2020-10-27 22:01:54 -07:00
// todo: calibration
engineConfiguration->highPressureFuel.v1 = 0.5; /* volts */;
2020-10-31 21:33:18 -07:00
engineConfiguration->highPressureFuel.value1 = 0;
2020-10-27 22:01:54 -07:00
engineConfiguration->highPressureFuel.v2 = 4.5; /* volts */;
2020-10-31 21:33:18 -07:00
engineConfiguration->highPressureFuel.value2 = BAR2KPA(140);
2020-10-27 22:01:54 -07:00
2022-06-01 21:34:02 -07:00
engineConfiguration->lowPressureFuel.v1 = 0.5; /* volts */;
engineConfiguration->lowPressureFuel.value1 = PSI2KPA(0);
engineConfiguration->lowPressureFuel.v2 = 4.5; /* volts */;
// todo: what's the proper calibration of this Bosch sensor? is it really 200psi?
engineConfiguration->lowPressureFuel.value2 = PSI2KPA(200);
2022-05-20 23:25:43 -07:00
gppwm_channel *lowPressureFuelPumpControl = &engineConfiguration->gppwm[1];
strcpy(engineConfiguration->gpPwmNote[1], "LPFP");
lowPressureFuelPumpControl->pwmFrequency = 20;
lowPressureFuelPumpControl->loadAxis = GPPWM_FuelLoad;
lowPressureFuelPumpControl->dutyIfError = 50;
setTable(lowPressureFuelPumpControl->table, (uint8_t)50);
gppwm_channel *coolantControl = &engineConfiguration->gppwm[0];
strcpy(engineConfiguration->gpPwmNote[0], "Rad Fan");
2022-06-19 17:06:03 -07:00
coolantControl->loadAxis = GPPWM_Clt;
2022-05-20 23:25:43 -07:00
coolantControl->pwmFrequency = 25;
coolantControl->loadAxis = GPPWM_FuelLoad;
// Volkswage wants 10% for fan to be OFF, between pull-up and low side control we need to invert that value
// todo system lua for duty driven by CLT? (3, Gpio::E0, "0.15 90 coolant 120 min max 90 - 30 / 0.8 * +", 25);
int value = 100 - 10;
coolantControl->dutyIfError = value;
setTable(coolantControl->table, (uint8_t)value);
// for now I just want to stop radiator whine
// todo: enable cooling!
/*
for (int load = 0; load < GPPWM_LOAD_COUNT; load++) {
for (int r = 0; r < GPPWM_RPM_COUNT; r++) {
engineConfiguration->gppwm[0].table[load][r] = value;
}
}
*/
engineConfiguration->hpfpCamLobes = 3;
engineConfiguration->hpfpPumpVolume = 0.290;
engineConfiguration->hpfpMinAngle = 10;
engineConfiguration->hpfpActivationAngle = 30;
engineConfiguration->hpfpTargetDecay = 2000;
engineConfiguration->hpfpPidP = 0.01;
engineConfiguration->hpfpPidI = 0.0003;
engineConfiguration->hpfpPeakPos = 10;
setTable(config->veTable, 55);
setBoschVAGETB();
// random number just to take position away from zero
engineConfiguration->vvtOffsets[0] = 180;
// https://rusefi.com/forum/viewtopic.php?p=38235#p38235
engineConfiguration->injector.flow = 1200;
engineConfiguration->idle.solenoidPin = Gpio::Unassigned;
engineConfiguration->fanPin = Gpio::Unassigned;
engineConfiguration->useETBforIdleControl = true;
engineConfiguration->injectionMode = IM_SEQUENTIAL;
2022-06-01 21:34:02 -07:00
engineConfiguration->crankingInjectionMode = IM_SEQUENTIAL;
}
2022-05-20 23:25:43 -07:00
2022-10-24 19:54:42 -07:00
static const float hardCodedFreqBins[] = {139,
152,
180,
217,
280,
300,
365};
static const float hardCodedGperSValues[] {
3.58,
4.5,
6.7,
11,
22,
25,
40
};
2022-06-01 21:34:02 -07:00
/**
* set engine_type 39
*/
2022-05-20 23:25:43 -07:00
void setProteusVwPassatB6() {
#if HW_PROTEUS
2022-10-24 19:54:42 -07:00
static_assert(sizeof(hardCodedFreqBins) == sizeof(hardCodedGperSValues));
{
size_t mi = 0;
for (; mi < efi::size(hardCodedFreqBins); mi++) {
config->scriptCurve1Bins[mi] = hardCodedFreqBins[mi];
config->scriptCurve1[mi] = hardCodedGperSValues[mi];
}
for (; mi < SCRIPT_CURVE_16; mi++) {
config->scriptCurve1Bins[mi] = 3650 + mi;
config->scriptCurve1[mi] = 4000;
}
}
2022-05-20 23:25:43 -07:00
commonPassatB6();
2022-06-02 21:04:59 -07:00
engineConfiguration->triggerInputPins[0] = PROTEUS_VR_1;
engineConfiguration->camInputs[0] = PROTEUS_DIGITAL_2;
2022-05-31 20:02:04 -07:00
2022-10-24 17:29:46 -07:00
engineConfiguration->auxSpeedSensorInputPin[0] = PROTEUS_DIGITAL_5;
2022-06-01 21:34:02 -07:00
engineConfiguration->lowPressureFuel.hwChannel = PROTEUS_IN_ANALOG_VOLT_5;
engineConfiguration->highPressureFuel.hwChannel = PROTEUS_IN_ANALOG_VOLT_4;
2022-05-31 19:26:18 -07:00
gppwm_channel *coolantControl = &engineConfiguration->gppwm[0];
coolantControl->pin = PROTEUS_LS_5;
engineConfiguration->mainRelayPin = PROTEUS_LS_6;
gppwm_channel *lowPressureFuelPumpControl = &engineConfiguration->gppwm[1];
lowPressureFuelPumpControl->pin = PROTEUS_LS_7;
2022-06-02 19:40:30 -07:00
2022-06-02 22:26:16 -07:00
//engineConfiguration->boostControlPin = PROTEUS_LS_8;
engineConfiguration->vvtPins[0] = PROTEUS_LS_9;
engineConfiguration->hpfpValvePin = PROTEUS_LS_15;
2022-06-02 19:40:30 -07:00
engineConfiguration->tps1_2AdcChannel = PROTEUS_IN_TPS1_2;
2022-10-29 20:38:22 -07:00
setPPSInputs(PROTEUS_IN_ANALOG_VOLT_9, PROTEUS_IN_PPS2);
2022-06-20 05:26:28 -07:00
strncpy(config->luaScript, R"(
2022-06-20 11:01:39 -07:00
AIRBAG = 0x050
2022-07-29 14:26:49 -07:00
GRA = 0x388
2022-06-20 11:01:39 -07:00
TCU_1 = 0x440
TCU_2 = 0x540
BRAKE_2 = 0x5A0
2022-09-06 12:12:43 -07:00
MOTOR_1 = 0x280
MOTOR_3 = 0x380
2022-07-25 05:06:04 -07:00
MOTOR_INFO = 0x580
2022-07-29 14:26:49 -07:00
MOTOR_5 = 0x480
MOTOR_6 = 0x488
2022-06-25 10:26:21 -07:00
MOTOR_7 = 0x588
2022-06-20 11:01:39 -07:00
canRxAdd(AIRBAG)
canRxAdd(TCU_1)
canRxAdd(TCU_2)
canRxAdd(BRAKE_2)
2022-09-17 22:03:01 -07:00
fuelCounter = 0
2022-09-18 14:20:42 -07:00
function setBitRange(data, totalBitIndex, bitWidth, value)
local byteIndex = totalBitIndex >> 3
local bitInByteIndex = totalBitIndex - byteIndex * 8
if (bitInByteIndex + bitWidth > 8) then
bitsToHandleNow = 8 - bitInByteIndex
setBitRange(data, totalBitIndex + bitsToHandleNow, bitWidth - bitsToHandleNow, value >> bitsToHandleNow)
bitWidth = bitsToHandleNow
end
mask = (1 << bitWidth) - 1
data[1 + byteIndex] = data[1 + byteIndex] & (~(mask << bitInByteIndex))
maskedValue = value & mask
shiftedValue = maskedValue << bitInByteIndex
data[1 + byteIndex] = data[1 + byteIndex] | shiftedValue
end
2022-06-20 11:01:39 -07:00
function setTwoBytes(data, offset, value)
data[offset + 1] = value % 255
data[offset + 2] = (value >> 8) % 255
end
2022-06-20 05:26:28 -07:00
2022-06-25 10:26:21 -07:00
shallSleep = Timer.new()
2022-06-20 05:26:28 -07:00
-- we want to turn on with hardware switch while ignition key is off
2022-06-25 10:26:21 -07:00
hadIgnitionEvent = false
2022-06-20 05:26:28 -07:00
function onCanRx(bus, id, dlc, data)
2022-07-05 10:40:02 -07:00
if id == AIRBAG then
2022-06-20 05:26:28 -07:00
-- looks like we have ignition key do not sleep!
2022-06-25 10:26:21 -07:00
shallSleep : reset()
hadIgnitionEvent = true
2022-06-20 11:01:39 -07:00
else
2022-06-25 10:26:21 -07:00
print('got CAN id=' ..id ..' dlc=' ..dlc)
2022-06-20 11:01:39 -07:00
2022-06-20 05:26:28 -07:00
end
end
2022-06-25 10:26:21 -07:00
function setTwoBytes(data, offset, value)
value = math.floor(value)
data[offset + 2] = value >> 8
data[offset + 1] = value & 0xff
end
2022-09-04 08:29:18 -07:00
function xorChecksum(data, targetIndex)
local index = 1
local result = 0
while data[index] ~= nil do
if index ~= targetIndex then
result = result ~ data[index]
end
index = index + 1
end
data[targetIndex] = result
return result
end
function getBitRange(data, bitIndex, bitWidth)
byteIndex = bitIndex >> 3
shift = bitIndex - byteIndex * 8
value = data[1 + byteIndex]
if (shift + bitWidth > 8) then
value = value + data[2 + byteIndex] * 256
end
mask = (1 << bitWidth) - 1
return (value >> shift) & mask
2022-06-25 10:26:21 -07:00
end
2022-07-25 05:06:04 -07:00
canMotor1 = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }
canMotorInfo = { 0x00, 0x00, 0x00, 0x14, 0x1C, 0x93, 0x48, 0x14 }
2022-09-04 08:29:18 -07:00
canMotor3 = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }
2022-09-17 22:03:01 -07:00
motor5Data = { 0x1C, 0x08, 0xF3, 0x55, 0x19, 0x00, 0x00, 0xAD }
2022-09-04 08:29:18 -07:00
canMotor6 = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }
2022-07-25 05:06:04 -07:00
canMotor7 = { 0x1A, 0x66, 0x7E, 0x00, 0x00, 0x00, 0x00, 0x00 }
2022-06-25 10:26:21 -07:00
setTickRate(100)
2022-08-28 18:46:29 -07:00
everySecondTimer = Timer.new()
canMotorInfoCounter = 0
2022-06-25 10:26:21 -07:00
2022-09-18 14:20:42 -07:00
counter = 0
2022-06-20 05:26:28 -07:00
function onTick()
2022-06-25 10:26:21 -07:00
counter = (counter + 1) % 16
rpm = getSensor("RPM") or 0
2022-08-24 15:52:33 -07:00
clt = getSensor("CLT") or 0
2022-09-17 22:03:01 -07:00
iat = getSensor("IAT") or 0
tps = getSensor("TPS1") or 0
2022-09-18 15:55:57 -07:00
vbat = getSensor("BatteryVoltage") or 0
2022-09-17 22:03:01 -07:00
2022-09-18 14:20:42 -07:00
fakeTorque = interpolate(0, 6, 100, 60, tps)
2022-09-17 22:03:01 -07:00
2022-09-18 14:20:42 -07:00
engineTorque = fakeTorque
2022-09-17 22:03:01 -07:00
innerTorqWithoutExt = fakeTorque
torqueLoss = 10
requestedTorque = fakeTorque
2022-06-25 10:26:21 -07:00
2022-09-17 22:03:01 -07:00
canMotor1[2] = engineTorque / 0.39
canMotor1[5] = innerTorqWithoutExt / 0.4
canMotor1[6] = tps / 0.4
canMotor1[7] = torqueLoss / 0.39
canMotor1[8] = requestedTorque / 0.39
2022-06-25 10:26:21 -07:00
setTwoBytes(canMotor1, 2, 4 * rpm)
txCan(1, MOTOR_1, 0, canMotor1)
2022-06-20 05:26:28 -07:00
2022-09-17 22:03:01 -07:00
desired_wheel_torque = fakeTorque
canMotor3[2] = (iat + 48) / 0.75
canMotor3[3] = tps / 0.4
canMotor3[5] = 0x20
setBitRange(canMotor3, 24, 12, math.floor(desired_wheel_torque / 0.39))
canMotor3[8] = tps / 0.4
txCan(1, MOTOR_3, 0, canMotor3)
setBitRange(motor5Data, 5, 9, fuelCounter)
xorChecksum(motor5Data, 8)
txCan(1, MOTOR_5, 0, motor5Data)
2022-06-25 10:26:21 -07:00
txCan(1, MOTOR_7, 0, canMotor7)
2022-09-18 15:55:57 -07:00
local timeToTurnOff = shallSleep : getElapsedSeconds() > 2
local connectedToUsb = vbat < 4
if hadIgnitionEvent and timeToTurnOff then
2022-06-25 10:26:21 -07:00
-- looks like ignition key was removed
mcu_standby()
end
2022-08-28 18:46:29 -07:00
2022-09-18 14:20:42 -07:00
if everySecondTimer : getElapsedSeconds() > 1 then
everySecondTimer : reset()
2022-08-28 18:46:29 -07:00
2022-09-17 22:03:01 -07:00
fuelCounter = fuelCounter + 20
2022-09-18 14:20:42 -07:00
canMotorInfoCounter = (canMotorInfoCounter + 1) % 8
canMotorInfo[1] = 0x90 + (canMotorInfoCounter * 2)
txCan(1, MOTOR_INFO, 0, canMotorInfo)
end
2022-06-20 05:26:28 -07:00
end
)", efi::size(config->luaScript));
2022-05-31 20:02:04 -07:00
#endif
2022-05-20 23:25:43 -07:00
}
/**
* set engine_type 62
* VW_B6
* has to be microRusEFI 0.5.2
*/
void setMreVwPassatB6() {
#if HW_MICRO_RUSEFI
commonPassatB6();
engineConfiguration->tps1_2AdcChannel = MRE_IN_ANALOG_VOLT_9;
// EFI_ADC_7: "31 - AN volt 3" - PA7
// 36 - AN volt 8
2022-10-29 20:38:22 -07:00
setPPSInputs(MRE_IN_ANALOG_VOLT_3, MRE_IN_ANALOG_VOLT_8);
2022-05-20 23:25:43 -07:00
// "26 - AN volt 2"
engineConfiguration->highPressureFuel.hwChannel = MRE_IN_ANALOG_VOLT_2;
2020-10-17 11:53:56 -07:00
// "19 - AN volt 4"
engineConfiguration->lowPressureFuel.hwChannel = EFI_ADC_12;
2020-10-12 21:35:04 -07:00
engineConfiguration->isSdCardEnabled = false;
2020-10-12 21:35:04 -07:00
engineConfiguration->mc33816spiDevice = SPI_DEVICE_3;
2020-10-17 17:17:53 -07:00
// RED
engineConfiguration->spi3mosiPin = Gpio::C12;
2020-10-17 17:17:53 -07:00
// YELLOW
engineConfiguration->spi3misoPin = Gpio::C11;
2020-10-17 17:17:53 -07:00
// BROWN
engineConfiguration->spi3sckPin = Gpio::C10;
engineConfiguration->sdCardCsPin = Gpio::Unassigned;
engineConfiguration->is_enabled_spi_3 = true;
2020-10-12 21:35:04 -07:00
2020-10-17 17:17:53 -07:00
// J8 orange
engineConfiguration->mc33816_cs = Gpio::B8;
2020-10-17 17:17:53 -07:00
// J8 Grey
engineConfiguration->mc33816_rstb = Gpio::A15;
2020-10-17 17:17:53 -07:00
// J8 Dark BLUE
engineConfiguration->mc33816_driven = Gpio::B9;
2020-10-17 17:17:53 -07:00
// J9 violet
engineConfiguration->mc33816_flag0 = Gpio::C13;
2020-10-12 21:35:04 -07:00
2020-10-17 17:17:53 -07:00
// J10 Dark BLUE
engineConfiguration->injectionPins[0] = Gpio::E6;
2020-10-17 17:17:53 -07:00
// J11 green
engineConfiguration->injectionPins[1] = Gpio::E5;
2020-10-17 17:17:53 -07:00
// J18 grey
engineConfiguration->injectionPins[2] = Gpio::B7;
2020-10-17 17:17:53 -07:00
// J6 white
engineConfiguration->injectionPins[3] = Gpio::E0;
2020-10-19 20:25:23 -07:00
2020-10-21 22:48:28 -07:00
gppwm_channel *lowPressureFuelPumpControl = &engineConfiguration->gppwm[1];
2022-05-20 23:25:43 -07:00
2020-11-15 17:56:16 -08:00
// "42 - Injector 4", somehow GP4 did not work? not enough current? not happy with diode?
lowPressureFuelPumpControl->pin = MRE_INJ_4;
2020-10-21 22:48:28 -07:00
gppwm_channel *coolantControl = &engineConfiguration->gppwm[0];
coolantControl->pin = MRE_LS_2;
2020-11-15 12:37:53 -08:00
// "7 - Lowside 1"
2022-01-08 22:29:39 -08:00
//engineConfiguration->hpfpValvePin = MRE_LS_1;
engineConfiguration->disablePrimaryUart = true;
engineConfiguration->hpfpValvePin = Gpio::B10; // AUX J13
2020-10-19 20:25:23 -07:00
#endif /* HW_MICRO_RUSEFI */
2020-08-29 07:06:28 -07:00
}