OVMS3/OVMS.V3/components/vehicle_bmwi3/ecu_definitions/ecu_eps_code.cpp

167 lines
7.1 KiB
C++

//
// Warning: don't edit - generated by generate_ecu_code.pl processing ../dev/eps_i1.json: EPS 30: Power steering
// This generated code makes it easier to process CANBUS messages from the EPS ecu in a BMW i3
//
case I3_PID_EPS_STEUERN_EPS_PULLDRIFT_OFFSET_RESET: { // 0xA2BB
// ========== Add your processing here ==========
hexdump(rxbuf, type, pid);
break;
}
case I3_PID_EPS_EPS_LENKWINKELSENSOR_KALIBRIERUNG_RESET: { // 0xAB69
// ========== Add your processing here ==========
hexdump(rxbuf, type, pid);
break;
}
case I3_PID_EPS_EPS_INITIALISIERUNG_SERVICE: { // 0xAB6C
if (datalen < 4) {
ESP_LOGW(TAG, "Received %d bytes for %s, expected %d", datalen, "I3_PID_EPS_EPS_INITIALISIERUNG_SERVICE", 4);
break;
}
unsigned char STAT_ROUTINE_STATUS = (RXBUF_UCHAR(0));
// Execution status / Ausführungsstatus
ESP_LOGD(TAG, "From ECU %s, pid %s: got %s=%x%s\n", "EPS", "EPS_INITIALISIERUNG_SERVICE", "STAT_ROUTINE_STATUS", STAT_ROUTINE_STATUS, "\"0-n\"");
short STAT_LENKRADWINKEL_WERT = (RXBUF_SINT(1));
// Steering wheel angle / Lenkradwinkel
ESP_LOGD(TAG, "From ECU %s, pid %s: got %s=%d%s\n", "EPS", "EPS_INITIALISIERUNG_SERVICE", "STAT_LENKRADWINKEL_WERT", STAT_LENKRADWINKEL_WERT, "\"°\"");
char STAT_SENSOR_ZUSTAND_NR = (RXBUF_SCHAR(3));
// Condition sensor pinion angle sensor / Zustand Sensor Ritzelwinkelsensor
ESP_LOGD(TAG, "From ECU %s, pid %s: got %s=%x%s\n", "EPS", "EPS_INITIALISIERUNG_SERVICE", "STAT_SENSOR_ZUSTAND_NR", STAT_SENSOR_ZUSTAND_NR, "\"0-n\"");
// ========== Add your processing here ==========
hexdump(rxbuf, type, pid);
break;
}
case I3_PID_EPS_STEUERN_EPS_MULTITURNWERT_RESET: { // 0xAB7D
// ========== Add your processing here ==========
hexdump(rxbuf, type, pid);
break;
}
case I3_PID_EPS_EPS_RITZELWINKELSENSOR: { // 0xDB57
if (datalen < 7) {
ESP_LOGW(TAG, "Received %d bytes for %s, expected %d", datalen, "I3_PID_EPS_EPS_RITZELWINKELSENSOR", 7);
break;
}
float STAT_RITZELWINKEL_WERT = (RXBUF_SINT32(0)/100.0f);
// Pinion angle / Ritzelwinkel
ESP_LOGD(TAG, "From ECU %s, pid %s: got %s=%.4f%s\n", "EPS", "EPS_RITZELWINKELSENSOR", "STAT_RITZELWINKEL_WERT", STAT_RITZELWINKEL_WERT, "\"°\"");
short STAT_RITZELWINKELGESCHWINDIGKEIT_WERT = (RXBUF_SINT(4));
// Pinion angle angular speed / Ritzelwinkel Winkelgeschwindigkeit
ESP_LOGD(TAG, "From ECU %s, pid %s: got %s=%d%s\n", "EPS", "EPS_RITZELWINKELSENSOR", "STAT_RITZELWINKELGESCHWINDIGKEIT_WERT", STAT_RITZELWINKELGESCHWINDIGKEIT_WERT, "\"°/s\"");
char STAT_SENSOR_ZUSTAND_NR_0XDB57 = (RXBUF_SCHAR(6));
// Condition sensor pinion angle sensor / Zustand Sensor Ritzelwinkelsensor
ESP_LOGD(TAG, "From ECU %s, pid %s: got %s=%x%s\n", "EPS", "EPS_RITZELWINKELSENSOR", "STAT_SENSOR_ZUSTAND_NR_0XDB57", STAT_SENSOR_ZUSTAND_NR_0XDB57, "\"0-n\"");
// ========== Add your processing here ==========
hexdump(rxbuf, type, pid);
break;
}
case I3_PID_EPS_EPS_MOMENTENSENSOR: { // 0xDB99
if (datalen < 3) {
ESP_LOGW(TAG, "Received %d bytes for %s, expected %d", datalen, "I3_PID_EPS_EPS_MOMENTENSENSOR", 3);
break;
}
float STAT_MOMENT_WERT = (RXBUF_SINT(0)/128.0f);
// Current moment / Aktuelles Moment
ESP_LOGD(TAG, "From ECU %s, pid %s: got %s=%.4f%s\n", "EPS", "EPS_MOMENTENSENSOR", "STAT_MOMENT_WERT", STAT_MOMENT_WERT, "\"Nm\"");
char STAT_SENSOR_ZUSTAND_NR_0XDB99 = (RXBUF_SCHAR(2));
// State of the steering torque sensor / Zustand Sensor Lenkmoment
ESP_LOGD(TAG, "From ECU %s, pid %s: got %s=%x%s\n", "EPS", "EPS_MOMENTENSENSOR", "STAT_SENSOR_ZUSTAND_NR_0XDB99", STAT_SENSOR_ZUSTAND_NR_0XDB99, "\"0-n\"");
// ========== Add your processing here ==========
hexdump(rxbuf, type, pid);
break;
}
case I3_PID_EPS_EPS_ZAHNSTANGENMITTE: { // 0xDC77
if (datalen < 1) {
ESP_LOGW(TAG, "Received %d bytes for %s, expected %d", datalen, "I3_PID_EPS_EPS_ZAHNSTANGENMITTE", 1);
break;
}
unsigned char STAT_ZAHNSTANGENMITTE_ZUSTAND_NR = (RXBUF_UCHAR(0));
// State of rack center learned / Zustand Zahnstangenmitte gelernt
ESP_LOGD(TAG, "From ECU %s, pid %s: got %s=%x%s\n", "EPS", "EPS_ZAHNSTANGENMITTE", "STAT_ZAHNSTANGENMITTE_ZUSTAND_NR", STAT_ZAHNSTANGENMITTE_ZUSTAND_NR, "\"0-n\"");
// ========== Add your processing here ==========
hexdump(rxbuf, type, pid);
break;
}
case I3_PID_EPS_GELERNTER_ZAHNSTANGENWEG: { // 0xDFDD
if (datalen < 0) {
ESP_LOGW(TAG, "Received %d bytes for %s, expected %d", datalen, "I3_PID_EPS_GELERNTER_ZAHNSTANGENWEG", 0);
break;
}
// ========== Add your processing here ==========
hexdump(rxbuf, type, pid);
break;
}
case I3_PID_EPS_READHWMODIFICATIONINDEX: { // 0xF152
if (datalen < 2) {
ESP_LOGW(TAG, "Received %d bytes for %s, expected %d", datalen, "I3_PID_EPS_READHWMODIFICATIONINDEX", 2);
break;
}
unsigned char STAT_HW_MODIFICATION_INDEX_WERT = (RXBUF_UCHAR(0));
// Index of hardware modification: FF: Not supported index / Index of hardware modification: FF: Not supported
// index
ESP_LOGD(TAG, "From ECU %s, pid %s: got %s=%x%s\n", "EPS", "READHWMODIFICATIONINDEX", "STAT_HW_MODIFICATION_INDEX_WERT", STAT_HW_MODIFICATION_INDEX_WERT, "\"HEX\"");
unsigned char BF_22_F152_SUPPLIERINFO = (RXBUF_UCHAR(1));
// Supplier info tab / Tab Supplierinfo
// BF_22_F152_SUPPLIERINFO is a BITFIELD of size unsigned char. We don't yet generate definitions for each bit, we treat as the host data type
// STAT_HWMODEL: Mask: 0xC0 - hardware model
// STAT_SUPPLIERINFOFIELD: Mask: 0x3F - supplierInfo
ESP_LOGD(TAG, "From ECU %s, pid %s: got %s=%lx%s\n", "EPS", "READHWMODIFICATIONINDEX", "BF_22_F152_SUPPLIERINFO", (unsigned long)BF_22_F152_SUPPLIERINFO, "\"Bit\"");
// ========== Add your processing here ==========
hexdump(rxbuf, type, pid);
break;
}
case I3_PID_EPS_FLASH_UPDATE_MULTITURNZAEHLER: { // 0x1234
if (datalen < 2) {
ESP_LOGW(TAG, "Received %d bytes for %s, expected %d", datalen, "I3_PID_EPS_FLASH_UPDATE_MULTITURNZAEHLER", 2);
break;
}
unsigned char STAT_SERVICE = (RXBUF_UCHAR(0));
// Status of the service / Status des Service
ESP_LOGD(TAG, "From ECU %s, pid %s: got %s=%x%s\n", "EPS", "FLASH_UPDATE_MULTITURNZAEHLER", "STAT_SERVICE", STAT_SERVICE, "\"0-n\"");
unsigned char STAT_PIC = (RXBUF_UCHAR(1));
// Status of the processor to be flashed / Status des zu flashenden Prozessors
ESP_LOGD(TAG, "From ECU %s, pid %s: got %s=%x%s\n", "EPS", "FLASH_UPDATE_MULTITURNZAEHLER", "STAT_PIC", STAT_PIC, "\"0-n\"");
// ========== Add your processing here ==========
hexdump(rxbuf, type, pid);
break;
}