2020-03-31 13:49:19 -07:00
|
|
|
/**
|
|
|
|
* @file can_verbose.cpp
|
|
|
|
*
|
|
|
|
* TODO: change 'verbose' into 'broadcast'?
|
|
|
|
*
|
|
|
|
* @author Matthew Kennedy, (c) 2020
|
|
|
|
*/
|
2020-03-19 14:58:46 -07:00
|
|
|
|
2021-07-25 22:05:17 -07:00
|
|
|
#include "pch.h"
|
2020-03-19 14:58:46 -07:00
|
|
|
#if EFI_CAN_SUPPORT
|
|
|
|
|
|
|
|
#include "scaled_channel.h"
|
|
|
|
#include "can_msg_tx.h"
|
2020-03-29 18:15:06 -07:00
|
|
|
#include "can.h"
|
2020-03-19 14:58:46 -07:00
|
|
|
#include "fuel_math.h"
|
|
|
|
#include "spark_logic.h"
|
|
|
|
#include "vehicle_speed.h"
|
|
|
|
|
|
|
|
struct Status {
|
|
|
|
uint16_t warningCounter;
|
|
|
|
uint16_t lastErrorCode;
|
|
|
|
|
|
|
|
uint8_t revLimit : 1;
|
|
|
|
uint8_t mainRelay : 1;
|
|
|
|
uint8_t fuelPump : 1;
|
|
|
|
uint8_t checkEngine : 1;
|
|
|
|
uint8_t o2Heater : 1;
|
|
|
|
|
|
|
|
uint8_t pad6 : 1;
|
|
|
|
uint8_t pad7 : 1;
|
|
|
|
uint8_t pad8 : 1;
|
|
|
|
|
|
|
|
uint8_t pad[3];
|
|
|
|
};
|
|
|
|
|
|
|
|
static void populateFrame(Status& msg) {
|
|
|
|
msg.warningCounter = engine->engineState.warnings.warningCounter;
|
|
|
|
msg.lastErrorCode = engine->engineState.warnings.lastErrorCode;
|
|
|
|
|
|
|
|
msg.revLimit = GET_RPM() > CONFIG(rpmHardLimit);
|
|
|
|
msg.mainRelay = enginePins.mainRelay.getLogicValue();
|
|
|
|
msg.fuelPump = enginePins.fuelPumpRelay.getLogicValue();
|
|
|
|
msg.checkEngine = enginePins.checkEnginePin.getLogicValue();
|
|
|
|
msg.o2Heater = enginePins.o2heater.getLogicValue();
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Speeds {
|
|
|
|
uint16_t rpm;
|
|
|
|
scaled_angle timing;
|
|
|
|
scaled_channel<uint8_t, 2> injDuty;
|
|
|
|
scaled_channel<uint8_t, 2> coilDuty;
|
|
|
|
scaled_channel<uint8_t> vssKph;
|
|
|
|
uint8_t pad[1];
|
|
|
|
};
|
|
|
|
|
|
|
|
static void populateFrame(Speeds& msg) {
|
|
|
|
auto rpm = GET_RPM();
|
|
|
|
msg.rpm = rpm;
|
|
|
|
|
|
|
|
auto timing = engine->engineState.timingAdvance;
|
|
|
|
msg.timing = timing > 360 ? timing - 720 : timing;
|
|
|
|
|
|
|
|
msg.injDuty = getInjectorDutyCycle(rpm);
|
|
|
|
msg.coilDuty = getCoilDutyCycle(rpm);
|
|
|
|
|
|
|
|
msg.vssKph = getVehicleSpeed();
|
|
|
|
}
|
|
|
|
|
|
|
|
struct PedalAndTps {
|
|
|
|
scaled_percent pedal;
|
|
|
|
scaled_percent tps1;
|
|
|
|
scaled_percent tps2;
|
|
|
|
uint8_t pad[2];
|
|
|
|
};
|
|
|
|
|
|
|
|
static void populateFrame(PedalAndTps& msg)
|
|
|
|
{
|
2020-04-01 17:21:03 -07:00
|
|
|
msg.pedal = Sensor::get(SensorType::AcceleratorPedal).value_or(-1);
|
2020-03-19 14:58:46 -07:00
|
|
|
msg.tps1 = Sensor::get(SensorType::Tps1).value_or(-1);
|
|
|
|
msg.tps2 = Sensor::get(SensorType::Tps2).value_or(-1);
|
|
|
|
}
|
|
|
|
|
|
|
|
struct Sensors1 {
|
|
|
|
scaled_pressure map;
|
|
|
|
scaled_channel<uint8_t> clt;
|
|
|
|
scaled_channel<uint8_t> iat;
|
|
|
|
scaled_channel<uint8_t> aux1;
|
|
|
|
scaled_channel<uint8_t> aux2;
|
|
|
|
scaled_channel<uint8_t> mcuTemp;
|
|
|
|
scaled_channel<uint8_t, 2> fuelLevel;
|
|
|
|
};
|
|
|
|
|
|
|
|
static void populateFrame(Sensors1& msg) {
|
2020-12-30 05:43:49 -08:00
|
|
|
msg.map = Sensor::get(SensorType::Map).value_or(0);
|
2020-03-19 14:58:46 -07:00
|
|
|
|
2020-04-18 12:53:04 -07:00
|
|
|
msg.clt = Sensor::get(SensorType::Clt).value_or(0) + PACK_ADD_TEMPERATURE;
|
|
|
|
msg.iat = Sensor::get(SensorType::Iat).value_or(0) + PACK_ADD_TEMPERATURE;
|
2020-03-19 14:58:46 -07:00
|
|
|
|
2021-03-31 19:54:59 -07:00
|
|
|
msg.aux1 = Sensor::get(SensorType::AuxTemp1).value_or(0) + PACK_ADD_TEMPERATURE;
|
|
|
|
msg.aux2 = Sensor::get(SensorType::AuxTemp2).value_or(0) + PACK_ADD_TEMPERATURE;
|
2020-03-19 14:58:46 -07:00
|
|
|
|
|
|
|
msg.mcuTemp = getMCUInternalTemperature();
|
2021-03-19 05:39:08 -07:00
|
|
|
msg.fuelLevel = Sensor::get(SensorType::FuelLevel).value_or(0);
|
2020-03-19 14:58:46 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
struct Sensors2 {
|
|
|
|
scaled_afr afr;
|
|
|
|
scaled_pressure oilPressure;
|
|
|
|
scaled_angle vvtPos;
|
|
|
|
scaled_voltage vbatt;
|
|
|
|
};
|
|
|
|
|
|
|
|
static void populateFrame(Sensors2& msg) {
|
2021-05-19 23:39:20 -07:00
|
|
|
msg.afr = Sensor::get(SensorType::Lambda1).value_or(0) * STOICH_RATIO;
|
2020-03-19 14:58:46 -07:00
|
|
|
msg.oilPressure = Sensor::get(SensorType::OilPressure).value_or(-1);
|
2021-03-25 04:39:23 -07:00
|
|
|
msg.vvtPos = engine->triggerCentral.getVVTPosition(0, 0);
|
2021-03-07 17:18:32 -08:00
|
|
|
msg.vbatt = Sensor::get(SensorType::BatteryVoltage).value_or(0);
|
2020-03-19 14:58:46 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
struct Fueling {
|
|
|
|
scaled_channel<uint16_t, 1000> cylAirmass;
|
|
|
|
scaled_channel<uint16_t, 100> estAirflow;
|
|
|
|
scaled_ms fuel_pulse;
|
|
|
|
scaled_percent stft;
|
|
|
|
};
|
|
|
|
|
|
|
|
static void populateFrame(Fueling& msg) {
|
|
|
|
msg.cylAirmass = engine->engineState.sd.airMassInOneCylinder;
|
|
|
|
msg.estAirflow = engine->engineState.airFlow;
|
2021-05-08 14:41:50 -07:00
|
|
|
msg.fuel_pulse = engine->actualLastInjection[0];
|
2020-03-19 14:58:46 -07:00
|
|
|
|
|
|
|
// todo
|
|
|
|
msg.stft = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void sendCanVerbose() {
|
|
|
|
auto base = CONFIG(verboseCanBaseAddress);
|
|
|
|
|
|
|
|
transmitStruct<Status> (base + 0);
|
|
|
|
transmitStruct<Speeds> (base + 1);
|
2020-03-29 18:15:06 -07:00
|
|
|
transmitStruct<PedalAndTps> (base + CAN_PEDAL_TPS_OFFSET);
|
|
|
|
transmitStruct<Sensors1> (base + CAN_SENSOR_1_OFFSET);
|
2020-03-19 14:58:46 -07:00
|
|
|
transmitStruct<Sensors2> (base + 4);
|
|
|
|
transmitStruct<Fueling> (base + 5);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // EFI_CAN_SUPPORT
|