diff --git a/firmware/console/binary_log/binary_logging.cpp b/firmware/console/binary_log/binary_logging.cpp index ce2394d93e..c865f61adf 100644 --- a/firmware/console/binary_log/binary_logging.cpp +++ b/firmware/console/binary_log/binary_logging.cpp @@ -17,110 +17,8 @@ static scaled_channel packedTime; // todo: we are at the edge of sdLogBuffer size and at the moment we have no code to make sure buffer does not overflow // todo: make this logic smarter -static constexpr LogField fields[] = { - {engine->outputChannels.RPMValue, GAUGE_NAME_RPM, "rpm", 0}, - {packedTime, GAUGE_NAME_TIME, "sec", 0}, - {engine->outputChannels.totalTriggerErrorCounter, GAUGE_NAME_TRG_ERR, "err", 0}, - {engine->outputChannels.vehicleSpeedKph, GAUGE_NAME_VVS, "kph", 0}, - {engine->outputChannels.internalMcuTemperature, GAUGE_NAME_CPU_TEMP, "C", 0}, - {engine->outputChannels.coolant, GAUGE_NAME_CLT, "C", 1}, - {engine->outputChannels.intake, GAUGE_NAME_IAT, "C", 1}, - {engine->outputChannels.auxTemp1, GAUGE_NAME_AUX_TEMP1, "C", 1}, - {engine->outputChannels.auxTemp2, GAUGE_NAME_AUX_TEMP2, "C", 1}, - {engine->outputChannels.TPSValue, GAUGE_NAME_TPS, "%", 2}, - {engine->outputChannels.TPS2Value, GAUGE_NAME_TPS2, "%", 2}, - {engine->outputChannels.throttlePedalPosition, GAUGE_NAME_THROTTLE_PEDAL, "%", 2}, - {engine->outputChannels.MAPValue, GAUGE_NAME_MAP, "kPa", 1}, - {engine->outputChannels.AFRValue, GAUGE_NAME_AFR, "afr", 2}, - {engine->outputChannels.AFRValue2, GAUGE_NAME_AFR2, "afr", 2}, - {engine->outputChannels.lambdaValue, GAUGE_NAME_LAMBDA, "", 3}, - {engine->outputChannels.lambdaValue2, GAUGE_NAME_LAMBDA2, "", 3}, - {engine->outputChannels.warningCounter, GAUGE_NAME_WARNING_COUNTER, "", 0}, - {engine->outputChannels.lastErrorCode, GAUGE_NAME_WARNING_LAST, "", 0}, - {engine->outputChannels.tuneCrc16, GAUGE_NAME_TUNE_CRC16, "", 0}, - {engine->outputChannels.engineMakeCodeNameCrc16, GAUGE_NAME_ENGINE_CRC16, "", 0}, - - {engine->outputChannels.firmwareVersion, GAUGE_NAME_VERSION, "", 0}, - {engine->outputChannels.accelerationX, GAUGE_NAME_ACCEL_X, "", 2}, - {engine->outputChannels.accelerationY, GAUGE_NAME_ACCEL_Y, "", 2}, - {engine->outputChannels.accelerationZ, GAUGE_NAME_ACCEL_Z, "", 2}, - {engine->outputChannels.accelerationRoll, GAUGE_NAME_ACCEL_ROLL, "", 2}, - {engine->outputChannels.accelerationYaw, GAUGE_NAME_ACCEL_YAW, "", 2}, - - {engine->outputChannels.debugIntField1, GAUGE_NAME_DEBUG_I1, "", 0}, - {engine->outputChannels.debugIntField2, GAUGE_NAME_DEBUG_I2, "", 0}, - {engine->outputChannels.debugIntField3, GAUGE_NAME_DEBUG_I3, "", 0}, - {engine->outputChannels.debugIntField4, GAUGE_NAME_DEBUG_I4, "", 0}, - {engine->outputChannels.debugIntField5, GAUGE_NAME_DEBUG_I5, "", 0}, - {engine->outputChannels.debugFloatField1, GAUGE_NAME_DEBUG_F1, "", 3}, - {engine->outputChannels.debugFloatField2, GAUGE_NAME_DEBUG_F2, "", 3}, - {engine->outputChannels.debugFloatField3, GAUGE_NAME_DEBUG_F3, "", 3}, - {engine->outputChannels.debugFloatField4, GAUGE_NAME_DEBUG_F4, "", 3}, - {engine->outputChannels.debugFloatField5, GAUGE_NAME_DEBUG_F5, "", 3}, - {engine->outputChannels.debugFloatField6, GAUGE_NAME_DEBUG_F6, "", 3}, - {engine->outputChannels.debugFloatField7, GAUGE_NAME_DEBUG_F7, "", 3}, - {engine->outputChannels.VBatt, GAUGE_NAME_VBAT, "v", 2}, - {engine->outputChannels.oilPressure, GAUGE_NAME_OIL_PRESSURE, GAUGE_NAME_FUEL_PRESSURE_HIGH_UNITS, 0}, - {engine->outputChannels.lowFuelPressure, GAUGE_NAME_FUEL_PRESSURE_LOW, GAUGE_NAME_FUEL_PRESSURE_LOW_UNITS, 0}, - {engine->outputChannels.highFuelPressure, GAUGE_NAME_FUEL_PRESSURE_HIGH, GAUGE_NAME_FUEL_PRESSURE_HIGH_UNITS, 0}, - {engine->outputChannels.vvtPositionB1I, GAUGE_NAME_VVT_B1I, "deg", 1}, - {engine->outputChannels.vvtPositionB1E, GAUGE_NAME_VVT_B1E, "deg", 1}, - {engine->outputChannels.vvtPositionB2I, GAUGE_NAME_VVT_B2I, "deg", 1}, - {engine->outputChannels.vvtPositionB2E, GAUGE_NAME_VVT_B2E, "deg", 1}, - {engine->outputChannels.vvtTargets[0], GAUGE_NAME_VVT_TARGET_B1I, "deg", 0}, - {engine->outputChannels.vvtTargets[1], GAUGE_NAME_VVT_TARGET_B1E, "deg", 0}, - {engine->outputChannels.vvtTargets[2], GAUGE_NAME_VVT_TARGET_B2I, "deg", 0}, - {engine->outputChannels.vvtTargets[3], GAUGE_NAME_VVT_TARGET_B2E, "deg", 0}, - {engine->outputChannels.wastegatePositionSensor, GAUGE_NAME_WG_POSITION, "%", 2}, - {engine->outputChannels.idlePositionSensor, GAUGE_NAME_IDLE_POSITION, "%", 2}, - {engine->outputChannels.chargeAirMass, GAUGE_NAME_AIR_MASS, "g", 3}, - {engine->outputChannels.currentTargetAfr, GAUGE_NAME_TARGET_AFR, "afr", 2}, - {engine->outputChannels.targetLambda, GAUGE_NAME_TARGET_LAMBDA, "", 3}, - {engine->outputChannels.baseFuel, GAUGE_NAME_FUEL_BASE, "ms", 3}, - {engine->outputChannels.fuelRunning, GAUGE_NAME_FUEL_RUNNING, "ms", 3}, - {engine->outputChannels.actualLastInjection, GAUGE_NAME_FUEL_LAST_INJECTION, "ms", 3}, - {engine->outputChannels.injectorDutyCycle, GAUGE_NAME_FUEL_INJ_DUTY, "%", 0}, - {engine->outputChannels.veValue, GAUGE_NAME_FUEL_VE, "%", 1}, - {engine->outputChannels.tCharge, GAUGE_NAME_TCHARGE, "C", 1}, - {engine->outputChannels.injectorLagMs, GAUGE_NAME_INJECTOR_LAG, "ms", 3}, - {engine->outputChannels.fuelPidCorrection[0], GAUGE_NAME_FUEL_TRIM, "%", 2}, - {engine->outputChannels.fuelPidCorrection[1], GAUGE_NAME_FUEL_TRIM_2, "%", 2}, - {engine->outputChannels.wallFuelCorrection, GAUGE_NAME_FUEL_WALL_CORRECTION, "mg", 3}, - {engine->outputChannels.wallFuelAmount, GAUGE_NAME_FUEL_WALL_CORRECTION, "mg", 3}, - {engine->outputChannels.tpsAccelFuel, GAUGE_NAME_FUEL_TPS_EXTRA, "ms", 3}, - {engine->outputChannels.ignitionAdvance, GAUGE_NAME_TIMING_ADVANCE, "deg", 1}, - {engine->outputChannels.sparkDwellValue, GAUGE_COIL_DWELL_TIME, "ms", 1}, - {engine->outputChannels.coilDutyCycle, GAUGE_NAME_DWELL_DUTY, "%", 0}, - {engine->outputChannels.idleAirValvePosition, GAUGE_NAME_IAC, "%", 1}, - {engine->outputChannels.etbTarget, GAUGE_NAME_ETB_TARGET, "%", 2}, - {engine->outputChannels.etb1DutyCycle, GAUGE_NAME_ETB_DUTY, "%", 1}, - {engine->outputChannels.etb1Error, GAUGE_NAME_ETB_ERROR, "%", 3}, - {engine->outputChannels.fuelTankLevel, GAUGE_NAME_FUEL_LEVEL, "%", 0}, - {engine->outputChannels.fuelingLoad, GAUGE_NAME_FUEL_LOAD, "%", 1}, - {engine->outputChannels.ignitionLoad, GAUGE_NAME_IGNITION_LOAD, "%", 1}, - {engine->outputChannels.mafMeasured, GAUGE_NAME_AIR_FLOW_MEASURED, "kg/h", 1}, - {engine->outputChannels.mafEstimate, GAUGE_NAME_AIR_FLOW_ESTIMATE, "kg/h", 1}, - {engine->outputChannels.tcuDesiredGear, GAUGE_NAME_DESIRED_GEAR, "gear", 0}, - {engine->outputChannels.tcuCurrentGear, GAUGE_NAME_CURRENT_GEAR, "gear", 0}, - {engine->outputChannels.flexPercent, GAUGE_NAME_FLEX, "%", 1}, - {engine->outputChannels.fuelFlowRate, GAUGE_NAME_FUEL_FLOW, "g/s", 3}, - {engine->outputChannels.totalFuelConsumption, GAUGE_NAME_FUEL_CONSUMPTION, "g", 1}, - {engine->outputChannels.knockLevel, GAUGE_NAME_KNOCK_LEVEL, "dBv", 0}, - {engine->outputChannels.knock[0], GAUGE_NAME_KNOCK_1, "dBv", 0}, - {engine->outputChannels.knock[1], GAUGE_NAME_KNOCK_2, "dBv", 0}, - {engine->outputChannels.knock[2], GAUGE_NAME_KNOCK_3, "dBv", 0}, - {engine->outputChannels.knock[3], GAUGE_NAME_KNOCK_4, "dBv", 0}, - {engine->outputChannels.knock[4], GAUGE_NAME_KNOCK_5, "dBv", 0}, - {engine->outputChannels.knock[5], GAUGE_NAME_KNOCK_6, "dBv", 0}, - {engine->outputChannels.knock[6], GAUGE_NAME_KNOCK_7, "dBv", 0}, - {engine->outputChannels.knock[7], GAUGE_NAME_KNOCK_8, "dBv", 0}, - {engine->outputChannels.knock[8], GAUGE_NAME_KNOCK_9, "dBv", 0}, - {engine->outputChannels.knock[9], GAUGE_NAME_KNOCK_10, "dBv", 0}, - {engine->outputChannels.knock[10], GAUGE_NAME_KNOCK_11, "dBv", 0}, - {engine->outputChannels.knock[11], GAUGE_NAME_KNOCK_12, "dBv", 0}, - {engine->outputChannels.sparkCutReason, "Spark Cut Code", "", 0}, - {engine->outputChannels.fuelCutReason, "Fuel Cut Code", "", 0}, -}; +// minor hack to facilitate code generation while still enjoying constexpr access to generated array +#include "log_fields_generated.cpp" static constexpr uint16_t computeFieldsRecordLength() { uint16_t recLength = 0; diff --git a/firmware/console/binary_log/log_fields_generated.cpp b/firmware/console/binary_log/log_fields_generated.cpp index e69de29bb2..8920a540ab 100644 --- a/firmware/console/binary_log/log_fields_generated.cpp +++ b/firmware/console/binary_log/log_fields_generated.cpp @@ -0,0 +1,105 @@ + +static constexpr LogField fields[] = { + {engine->outputChannels.RPMValue, GAUGE_NAME_RPM, "rpm", 0}, + {packedTime, GAUGE_NAME_TIME, "sec", 0}, + {engine->outputChannels.totalTriggerErrorCounter, GAUGE_NAME_TRG_ERR, "err", 0}, + {engine->outputChannels.vehicleSpeedKph, GAUGE_NAME_VVS, "kph", 0}, + {engine->outputChannels.internalMcuTemperature, GAUGE_NAME_CPU_TEMP, "C", 0}, + {engine->outputChannels.coolant, GAUGE_NAME_CLT, "C", 1}, + {engine->outputChannels.intake, GAUGE_NAME_IAT, "C", 1}, + {engine->outputChannels.auxTemp1, GAUGE_NAME_AUX_TEMP1, "C", 1}, + {engine->outputChannels.auxTemp2, GAUGE_NAME_AUX_TEMP2, "C", 1}, + {engine->outputChannels.TPSValue, GAUGE_NAME_TPS, "%", 2}, + {engine->outputChannels.TPS2Value, GAUGE_NAME_TPS2, "%", 2}, + {engine->outputChannels.throttlePedalPosition, GAUGE_NAME_THROTTLE_PEDAL, "%", 2}, + {engine->outputChannels.MAPValue, GAUGE_NAME_MAP, "kPa", 1}, + {engine->outputChannels.AFRValue, GAUGE_NAME_AFR, "afr", 2}, + {engine->outputChannels.AFRValue2, GAUGE_NAME_AFR2, "afr", 2}, + {engine->outputChannels.lambdaValue, GAUGE_NAME_LAMBDA, "", 3}, + {engine->outputChannels.lambdaValue2, GAUGE_NAME_LAMBDA2, "", 3}, + {engine->outputChannels.warningCounter, GAUGE_NAME_WARNING_COUNTER, "", 0}, + {engine->outputChannels.lastErrorCode, GAUGE_NAME_WARNING_LAST, "", 0}, + {engine->outputChannels.tuneCrc16, GAUGE_NAME_TUNE_CRC16, "", 0}, + {engine->outputChannels.engineMakeCodeNameCrc16, GAUGE_NAME_ENGINE_CRC16, "", 0}, + + {engine->outputChannels.firmwareVersion, GAUGE_NAME_VERSION, "", 0}, + {engine->outputChannels.accelerationX, GAUGE_NAME_ACCEL_X, "", 2}, + {engine->outputChannels.accelerationY, GAUGE_NAME_ACCEL_Y, "", 2}, + {engine->outputChannels.accelerationZ, GAUGE_NAME_ACCEL_Z, "", 2}, + {engine->outputChannels.accelerationRoll, GAUGE_NAME_ACCEL_ROLL, "", 2}, + {engine->outputChannels.accelerationYaw, GAUGE_NAME_ACCEL_YAW, "", 2}, + + {engine->outputChannels.debugIntField1, GAUGE_NAME_DEBUG_I1, "", 0}, + {engine->outputChannels.debugIntField2, GAUGE_NAME_DEBUG_I2, "", 0}, + {engine->outputChannels.debugIntField3, GAUGE_NAME_DEBUG_I3, "", 0}, + {engine->outputChannels.debugIntField4, GAUGE_NAME_DEBUG_I4, "", 0}, + {engine->outputChannels.debugIntField5, GAUGE_NAME_DEBUG_I5, "", 0}, + {engine->outputChannels.debugFloatField1, GAUGE_NAME_DEBUG_F1, "", 3}, + {engine->outputChannels.debugFloatField2, GAUGE_NAME_DEBUG_F2, "", 3}, + {engine->outputChannels.debugFloatField3, GAUGE_NAME_DEBUG_F3, "", 3}, + {engine->outputChannels.debugFloatField4, GAUGE_NAME_DEBUG_F4, "", 3}, + {engine->outputChannels.debugFloatField5, GAUGE_NAME_DEBUG_F5, "", 3}, + {engine->outputChannels.debugFloatField6, GAUGE_NAME_DEBUG_F6, "", 3}, + {engine->outputChannels.debugFloatField7, GAUGE_NAME_DEBUG_F7, "", 3}, + {engine->outputChannels.VBatt, GAUGE_NAME_VBAT, "v", 2}, + {engine->outputChannels.oilPressure, GAUGE_NAME_OIL_PRESSURE, GAUGE_NAME_FUEL_PRESSURE_HIGH_UNITS, 0}, + {engine->outputChannels.lowFuelPressure, GAUGE_NAME_FUEL_PRESSURE_LOW, GAUGE_NAME_FUEL_PRESSURE_LOW_UNITS, 0}, + {engine->outputChannels.highFuelPressure, GAUGE_NAME_FUEL_PRESSURE_HIGH, GAUGE_NAME_FUEL_PRESSURE_HIGH_UNITS, 0}, + {engine->outputChannels.vvtPositionB1I, GAUGE_NAME_VVT_B1I, "deg", 1}, + {engine->outputChannels.vvtPositionB1E, GAUGE_NAME_VVT_B1E, "deg", 1}, + {engine->outputChannels.vvtPositionB2I, GAUGE_NAME_VVT_B2I, "deg", 1}, + {engine->outputChannels.vvtPositionB2E, GAUGE_NAME_VVT_B2E, "deg", 1}, + {engine->outputChannels.vvtTargets[0], GAUGE_NAME_VVT_TARGET_B1I, "deg", 0}, + {engine->outputChannels.vvtTargets[1], GAUGE_NAME_VVT_TARGET_B1E, "deg", 0}, + {engine->outputChannels.vvtTargets[2], GAUGE_NAME_VVT_TARGET_B2I, "deg", 0}, + {engine->outputChannels.vvtTargets[3], GAUGE_NAME_VVT_TARGET_B2E, "deg", 0}, + {engine->outputChannels.wastegatePositionSensor, GAUGE_NAME_WG_POSITION, "%", 2}, + {engine->outputChannels.idlePositionSensor, GAUGE_NAME_IDLE_POSITION, "%", 2}, + {engine->outputChannels.chargeAirMass, GAUGE_NAME_AIR_MASS, "g", 3}, + {engine->outputChannels.currentTargetAfr, GAUGE_NAME_TARGET_AFR, "afr", 2}, + {engine->outputChannels.targetLambda, GAUGE_NAME_TARGET_LAMBDA, "", 3}, + {engine->outputChannels.baseFuel, GAUGE_NAME_FUEL_BASE, "ms", 3}, + {engine->outputChannels.fuelRunning, GAUGE_NAME_FUEL_RUNNING, "ms", 3}, + {engine->outputChannels.actualLastInjection, GAUGE_NAME_FUEL_LAST_INJECTION, "ms", 3}, + {engine->outputChannels.injectorDutyCycle, GAUGE_NAME_FUEL_INJ_DUTY, "%", 0}, + {engine->outputChannels.veValue, GAUGE_NAME_FUEL_VE, "%", 1}, + {engine->outputChannels.tCharge, GAUGE_NAME_TCHARGE, "C", 1}, + {engine->outputChannels.injectorLagMs, GAUGE_NAME_INJECTOR_LAG, "ms", 3}, + {engine->outputChannels.fuelPidCorrection[0], GAUGE_NAME_FUEL_TRIM, "%", 2}, + {engine->outputChannels.fuelPidCorrection[1], GAUGE_NAME_FUEL_TRIM_2, "%", 2}, + {engine->outputChannels.wallFuelCorrection, GAUGE_NAME_FUEL_WALL_CORRECTION, "mg", 3}, + {engine->outputChannels.wallFuelAmount, GAUGE_NAME_FUEL_WALL_CORRECTION, "mg", 3}, + {engine->outputChannels.tpsAccelFuel, GAUGE_NAME_FUEL_TPS_EXTRA, "ms", 3}, + {engine->outputChannels.ignitionAdvance, GAUGE_NAME_TIMING_ADVANCE, "deg", 1}, + {engine->outputChannels.sparkDwellValue, GAUGE_COIL_DWELL_TIME, "ms", 1}, + {engine->outputChannels.coilDutyCycle, GAUGE_NAME_DWELL_DUTY, "%", 0}, + {engine->outputChannels.idleAirValvePosition, GAUGE_NAME_IAC, "%", 1}, + {engine->outputChannels.etbTarget, GAUGE_NAME_ETB_TARGET, "%", 2}, + {engine->outputChannels.etb1DutyCycle, GAUGE_NAME_ETB_DUTY, "%", 1}, + {engine->outputChannels.etb1Error, GAUGE_NAME_ETB_ERROR, "%", 3}, + {engine->outputChannels.fuelTankLevel, GAUGE_NAME_FUEL_LEVEL, "%", 0}, + {engine->outputChannels.fuelingLoad, GAUGE_NAME_FUEL_LOAD, "%", 1}, + {engine->outputChannels.ignitionLoad, GAUGE_NAME_IGNITION_LOAD, "%", 1}, + {engine->outputChannels.mafMeasured, GAUGE_NAME_AIR_FLOW_MEASURED, "kg/h", 1}, + {engine->outputChannels.mafEstimate, GAUGE_NAME_AIR_FLOW_ESTIMATE, "kg/h", 1}, + {engine->outputChannels.tcuDesiredGear, GAUGE_NAME_DESIRED_GEAR, "gear", 0}, + {engine->outputChannels.tcuCurrentGear, GAUGE_NAME_CURRENT_GEAR, "gear", 0}, + {engine->outputChannels.flexPercent, GAUGE_NAME_FLEX, "%", 1}, + {engine->outputChannels.fuelFlowRate, GAUGE_NAME_FUEL_FLOW, "g/s", 3}, + {engine->outputChannels.totalFuelConsumption, GAUGE_NAME_FUEL_CONSUMPTION, "g", 1}, + {engine->outputChannels.knockLevel, GAUGE_NAME_KNOCK_LEVEL, "dBv", 0}, + {engine->outputChannels.knock[0], GAUGE_NAME_KNOCK_1, "dBv", 0}, + {engine->outputChannels.knock[1], GAUGE_NAME_KNOCK_2, "dBv", 0}, + {engine->outputChannels.knock[2], GAUGE_NAME_KNOCK_3, "dBv", 0}, + {engine->outputChannels.knock[3], GAUGE_NAME_KNOCK_4, "dBv", 0}, + {engine->outputChannels.knock[4], GAUGE_NAME_KNOCK_5, "dBv", 0}, + {engine->outputChannels.knock[5], GAUGE_NAME_KNOCK_6, "dBv", 0}, + {engine->outputChannels.knock[6], GAUGE_NAME_KNOCK_7, "dBv", 0}, + {engine->outputChannels.knock[7], GAUGE_NAME_KNOCK_8, "dBv", 0}, + {engine->outputChannels.knock[8], GAUGE_NAME_KNOCK_9, "dBv", 0}, + {engine->outputChannels.knock[9], GAUGE_NAME_KNOCK_10, "dBv", 0}, + {engine->outputChannels.knock[10], GAUGE_NAME_KNOCK_11, "dBv", 0}, + {engine->outputChannels.knock[11], GAUGE_NAME_KNOCK_12, "dBv", 0}, + {engine->outputChannels.sparkCutReason, "Spark Cut Code", "", 0}, + {engine->outputChannels.fuelCutReason, "Fuel Cut Code", "", 0}, +}; diff --git a/firmware/console/console.mk b/firmware/console/console.mk index 58474e1957..ce8212eb07 100644 --- a/firmware/console/console.mk +++ b/firmware/console/console.mk @@ -5,7 +5,6 @@ CONSOLE_SRC_CPP = $(PROJECT_DIR)/console/status_loop.cpp \ $(PROJECT_DIR)/console/connector_uart_dma.cpp \ $(PROJECT_DIR)/console/binary/tooth_logger.cpp \ $(PROJECT_DIR)/console/binary_log/log_field.cpp \ - $(PROJECT_DIR)/console/binary_log/log_fields_generated.cpp \ $(PROJECT_DIR)/console/binary_log/binary_logging.cpp \ $(PROJECT_DIR)/console/binary_log/usb_console.cpp \ $(PROJECT_DIR)/console/binary_log/ethernet_console.cpp \