OVMS3/OVMS.V3/components/vehicle_renaultzoe_ph2/src/LBC_pids.cpp

641 lines
20 KiB
C++
Raw Normal View History

2022-04-15 14:17:12 +00:00
/*
; Project: Open Vehicle Monitor System
; Date: 15th Apr 2022
;
; (C) 2022 Carsten Schmiemann
;
; Permission is hereby granted, free of charge, to any person obtaining a copy
; of this software and associated documentation files (the "Software"), to deal
; in the Software without restriction, including without limitation the rights
; to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
; copies of the Software, and to permit persons to whom the Software is
; furnished to do so, subject to the following conditions:
;
; The above copyright notice and this permission notice shall be included in
; all copies or substantial portions of the Software.
;
; THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
; IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
; FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
; AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
; LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
; OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
; THE SOFTWARE.
*/
#include "vehicle_renaultzoe_ph2.h"
2022-04-14 22:35:23 +00:00
void OvmsVehicleRenaultZoePh2::IncomingLBC(uint16_t type, uint16_t pid, const char* data, uint16_t len) {
switch (pid) {
case 0x9005: { //Battery voltage
StandardMetrics.ms_v_bat_voltage->SetValue((float) (CAN_UINT(0) * 0.1), Volts);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "9005 LBC ms_v_bat_voltage: %f", CAN_UINT(0) * 0.1);
2022-04-17 07:43:20 +00:00
StandardMetrics.ms_v_bat_power->SetValue(((CAN_UINT(0) * 0.1) * StandardMetrics.ms_v_bat_current->AsFloat()) * 0.001);
2022-04-14 22:35:23 +00:00
break;
}
case 0x925D: { //Battery current
2022-04-18 17:21:09 +00:00
StandardMetrics.ms_v_bat_current->SetValue((float) ((CAN_UINT(0) * 0.03125 - 1020) * -1.0f), Amps);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "925D LBC ms_v_bat_current: %f", (CAN_UINT(0) * 0.03125 - 1020));
2022-04-18 20:42:43 +00:00
StandardMetrics.ms_v_bat_power->SetValue((((CAN_UINT(0) * 0.03125 - 1020) * -1.0f) * StandardMetrics.ms_v_bat_voltage->AsFloat()) * 0.001);
2022-04-14 22:35:23 +00:00
break;
}
case 0x9012: { //Battery average temperature
2022-04-16 19:32:07 +00:00
StandardMetrics.ms_v_bat_temp->SetValue((float) (CAN_UINT(0) * 0.0625 - 40), Celcius);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "9012 LBC ms_v_bat_temp: %f", (CAN_UINT(0) * 0.0625 - 40));
2022-04-14 22:35:23 +00:00
break;
}
case 0x9002: { //Battery SOC
2022-04-20 22:15:39 +00:00
mt_bat_lbc_soc->SetValue((float) (CAN_UINT(0)) * 0.01, Percentage);
//ESP_LOGD(TAG, "9002 LBC mt_bat_lbc_soc: %f", CAN_UINT(0) * 0.01);
2022-04-14 22:35:23 +00:00
break;
}
case 0x9003: { //Battery SOH
StandardMetrics.ms_v_bat_soh->SetValue((float) (CAN_UINT(0) * 0.01), Percentage);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "9003 LBC ms_v_bat_soh: %f", CAN_UINT(0) * 0.01);
2022-04-14 22:35:23 +00:00
break;
}
case 0x9243: { //Battery energy charged kWh
StandardMetrics.ms_v_charge_kwh_grid_total->SetValue((float) (CAN_UINT32(0) * 0.001), kWh);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "9243 LBC ms_v_charge_kwh_grid_total: %f", CAN_UINT32(0) * 0.001);
2022-04-14 22:35:23 +00:00
break;
}
case 0x9245: { //Battery energy discharged kWh
StandardMetrics.ms_v_bat_energy_used_total->SetValue((float) (CAN_UINT32(0) * 0.001), kWh);
//ESP_LOGD(TAG, "9244 LBC ms_v_bat_energy_used_total: %f", CAN_UINT32(0) * 0.001);
2022-04-14 22:35:23 +00:00
break;
}
case 0x9247: { //Battery energy regenerated kWh
StandardMetrics.ms_v_bat_energy_recd_total->SetValue((float) (CAN_UINT32(0) * 0.001), kWh);
//ESP_LOGD(TAG, "9246 LBC ms_v_bat_energy_recd_total: %f", CAN_UINT32(0) * 0.001);
2022-04-14 22:35:23 +00:00
break;
}
2022-04-21 21:15:13 +00:00
case 0x9210: { //Number of charge cycles
2022-04-21 21:00:52 +00:00
mt_bat_cycles->SetValue(CAN_UINT(0));
2022-04-23 14:07:17 +00:00
//ESP_LOGD(TAG, "9210 LBC mt_bat_cycles: %d", CAN_UINT(0));
2022-04-14 22:35:23 +00:00
break;
}
case 0x9018: { //Max charge power
mt_bat_max_charge_power->SetValue((float) (CAN_UINT(0) * 0.01), kW);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "9018 LBC mt_bat_max_charge_power: %f", CAN_UINT(0) * 0.01);
2022-04-14 22:35:23 +00:00
break;
}
case 0x91C8: { //Available charge in kWh
2022-04-20 19:36:52 +00:00
mt_bat_available_energy->SetValue(float(CAN_UINT24(0) * 0.001), kWh);
//ESP_LOGD(TAG, "91C8 LBC mt_bat_available_energy: %f", CAN_UINT24(0) * 0.001);
2022-04-14 22:35:23 +00:00
break;
}
case 0x9131: {
2022-04-16 22:02:03 +00:00
BmsSetCellTemperature(0, CAN_UINT(0) * 0.0625 - 40);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f C", pid, CAN_UINT(0) * 0.0625 - 40);
break;
}
case 0x9132: {
2022-04-16 22:02:03 +00:00
BmsSetCellTemperature(1, CAN_UINT(0) * 0.0625 - 40);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f C", pid, CAN_UINT(0) * 0.0625 - 40);
break;
}
case 0x9133: {
2022-04-16 22:02:03 +00:00
BmsSetCellTemperature(2, CAN_UINT(0) * 0.0625 - 40);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f C", pid, CAN_UINT(0) * 0.0625 - 40);
break;
}
case 0x9134: {
2022-04-16 22:02:03 +00:00
BmsSetCellTemperature(3, CAN_UINT(0) * 0.0625 - 40);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f C", pid, CAN_UINT(0) * 0.0625 - 40);
break;
}
case 0x9135: {
2022-04-16 22:02:03 +00:00
BmsSetCellTemperature(4, CAN_UINT(0) * 0.0625 - 40);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f C", pid, CAN_UINT(0) * 0.0625 - 40);
break;
}
case 0x9136: {
2022-04-16 22:02:03 +00:00
BmsSetCellTemperature(5, CAN_UINT(0) * 0.0625 - 40);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f C", pid, CAN_UINT(0) * 0.0625 - 40);
break;
}
case 0x9137: {
2022-04-16 22:02:03 +00:00
BmsSetCellTemperature(6, CAN_UINT(0) * 0.0625 - 40);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f C", pid, CAN_UINT(0) * 0.0625 - 40);
break;
}
case 0x9138: {
2022-04-16 22:02:03 +00:00
BmsSetCellTemperature(7, CAN_UINT(0) * 0.0625 - 40);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f C", pid, CAN_UINT(0) * 0.0625 - 40);
break;
}
case 0x9139: {
2022-04-16 22:02:03 +00:00
BmsSetCellTemperature(8, CAN_UINT(0) * 0.0625 - 40);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f C", pid, CAN_UINT(0) * 0.0625 - 40);
break;
}
case 0x913A: {
2022-04-16 22:02:03 +00:00
BmsSetCellTemperature(9, CAN_UINT(0) * 0.0625 - 40);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f C", pid, CAN_UINT(0) * 0.0625 - 40);
break;
}
case 0x913B: {
2022-04-16 22:02:03 +00:00
BmsSetCellTemperature(10, CAN_UINT(0) * 0.0625 - 40);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f C", pid, CAN_UINT(0) * 0.0625 - 40);
break;
}
case 0x913C: {
2022-04-16 22:02:03 +00:00
BmsSetCellTemperature(11, CAN_UINT(0) * 0.0625 - 40);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f C", pid, CAN_UINT(0) * 0.0625 - 40);
2022-04-14 22:35:23 +00:00
break;
}
case 0x9021: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(0, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9022: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(1, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9023: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(2, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9024: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(3, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9025: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(4, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9026: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(5, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9027: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(6, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9028: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(7, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9029: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(8, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x902A: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(9, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x902B: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(10, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x902C: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(11, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x902D: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(12, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x902E: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(13, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x902F: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(14, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9030: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(15, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9031: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(16, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9032: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(17, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9033: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(18, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9034: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(19, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9035: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(20, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9036: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(21, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9037: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(22, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9038: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(23, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9039: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(24, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x903A: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(25, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x903B: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(26, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x903C: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(27, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x903D: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(28, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x903E: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(29, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x903F: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(30, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9041: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(31, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9042: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(32, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9043: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(33, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9044: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(34, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9045: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(35, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9046: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(36, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9047: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(37, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9048: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(38, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9049: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(39, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x904A: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(40, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x904B: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(41, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x904C: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(42, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x904D: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(43, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x904E: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(44, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x904F: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(45, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9050: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(46, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9051: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(47, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9052: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(48, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9053: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(49, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9054: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(50, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9055: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(51, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9056: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(52, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9057: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(53, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9058: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(54, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9059: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(55, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x905A: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(56, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x905B: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(57, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x905C: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(58, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x905D: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(59, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x905E: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(60, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x905F: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(61, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9061: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(62, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
2022-04-14 22:35:23 +00:00
break;
}
case 0x9062: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(63, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9063: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(64, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9064: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(65, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9065: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(66, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9066: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(67, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9067: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(68, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9068: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(69, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
2022-04-14 22:35:23 +00:00
break;
}
case 0x9069: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(70, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x906A: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(71, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x906B: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(72, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x906C: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(73, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x906D: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(74, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x906E: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(75, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x906F: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(76, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9070: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(77, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9071: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(78, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9072: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(79, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9073: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(80, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9074: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(81, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9075: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(82, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9076: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(83, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9077: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(84, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9078: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(85, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9079: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(86, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x907A: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(87, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x907B: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(88, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x907C: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(89, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x907D: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(90, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x907E: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(91, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x907F: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(92, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9081: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(93, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9082: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(94, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
case 0x9083: {
2022-04-16 22:18:26 +00:00
BmsSetCellVoltage(95, CAN_UINT(0) * 0.001);
2022-04-17 06:21:37 +00:00
//ESP_LOGD(TAG, "%x: %f V", pid, CAN_UINT(0) * 0.001);
break;
}
2022-04-14 22:35:23 +00:00
default: {
char *buf = NULL;
size_t rlen = len, offset = 0;
do {
rlen = FormatHexDump(&buf, data + offset, rlen, 16);
offset += 16;
ESP_LOGW(TAG, "OBD2: unhandled reply from LBC [%02x %02x]: %s", type, pid, buf ? buf : "-");
2022-04-14 22:35:23 +00:00
} while (rlen);
if (buf)
free(buf);
break;
}
}
}