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

84 lines
3.2 KiB
C++
Raw Normal View History

2022-04-08 23:03:19 +00:00
/*
; Project: Open Vehicle Monitor System
2022-04-15 14:17:12 +00:00
; Date: 15th Apr 2022
2022-04-08 23:03:19 +00:00
;
2022-04-15 14:17:12 +00:00
; (C) 2022 Carsten Schmiemann
2022-04-08 23:03:19 +00:00
;
; 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.
*/
2022-04-10 18:30:54 +00:00
#include "vehicle_renaultzoe_ph2.h"
2022-04-08 23:03:19 +00:00
2022-04-15 14:17:12 +00:00
void OvmsVehicleRenaultZoePh2::IncomingBCM(uint16_t type, uint16_t pid, const char* data, uint16_t len) {
switch (pid) {
2022-04-16 23:08:27 +00:00
case 0x4204: {
2022-04-16 23:16:40 +00:00
StandardMetrics.ms_v_tpms_pressure->SetElemValue(MS_V_TPMS_IDX_FL, (float)CAN_UINT(0));
2022-04-16 23:08:27 +00:00
ESP_LOGD(TAG, "4204 BCM tpms pressure FL: %f", float(CAN_UINT(0)));
break;
}
2022-04-17 08:07:38 +00:00
case 0x4205: {
StandardMetrics.ms_v_tpms_pressure->SetElemValue(MS_V_TPMS_IDX_FR, (float)CAN_UINT(0));
ESP_LOGD(TAG, "4204 BCM tpms pressure FR: %f", float(CAN_UINT(0)));
break;
}
case 0x4206: {
StandardMetrics.ms_v_tpms_pressure->SetElemValue(MS_V_TPMS_IDX_RL, (float)CAN_UINT(0));
ESP_LOGD(TAG, "4204 BCM tpms pressure RL: %f", float(CAN_UINT(0)));
break;
}
case 0x4207: {
StandardMetrics.ms_v_tpms_pressure->SetElemValue(MS_V_TPMS_IDX_RR, (float)CAN_UINT(0));
ESP_LOGD(TAG, "4204 BCM tpms pressure RR: %f", float(CAN_UINT(0)));
break;
}
case 0x420C: {
StandardMetrics.ms_v_tpms_temp->SetElemValue(MS_V_TPMS_IDX_FL, (float)CAN_UINT(0));
ESP_LOGD(TAG, "4204 BCM tpms temp FL: %f", float(CAN_UINT(0)));
break;
}
case 0x420D: {
StandardMetrics.ms_v_tpms_temp->SetElemValue(MS_V_TPMS_IDX_FR, (float)CAN_UINT(0));
ESP_LOGD(TAG, "4204 BCM tpms temp FR: %f", float(CAN_UINT(0)));
break;
}
case 0x420E: {
StandardMetrics.ms_v_tpms_temp->SetElemValue(MS_V_TPMS_IDX_RL, (float)CAN_UINT(0));
ESP_LOGD(TAG, "4204 BCM tpms temp RL: %f", float(CAN_UINT(0)));
break;
}
case 0x420F: {
StandardMetrics.ms_v_tpms_temp->SetElemValue(MS_V_TPMS_IDX_RR, (float)CAN_UINT(0));
ESP_LOGD(TAG, "4204 BCM tpms temp RR: %f", float(CAN_UINT(0)));
break;
}
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 BCM [%02x %02x]: %s", type, pid, buf ? buf : "-");
} while (rlen);
if (buf)
free(buf);
break;
}
}
2022-04-15 14:17:12 +00:00
}