From f0a180aae8bcff04631b752d487e733489ce5ce2 Mon Sep 17 00:00:00 2001 From: Sebastian Muszynski Date: Sun, 31 Oct 2021 20:34:59 +0100 Subject: [PATCH 1/5] Send a protocol v4 frame for testing --- components/jk_bms/jk_bms.cpp | 2 +- components/jk_modbus/jk_modbus.cpp | 33 ++++- components/jk_modbus/jk_modbus.h | 4 + esp32-example.yaml | 185 ++--------------------------- 4 files changed, 48 insertions(+), 176 deletions(-) diff --git a/components/jk_bms/jk_bms.cpp b/components/jk_bms/jk_bms.cpp index cc1fea90..d6912770 100644 --- a/components/jk_bms/jk_bms.cpp +++ b/components/jk_bms/jk_bms.cpp @@ -359,7 +359,7 @@ void JkBms::on_status_data_(const std::vector &data) { } void JkBms::update() { - this->read_registers(FUNCTION_READ_ALL, ADDRESS_READ_ALL); + this->query_status_v4(); if (this->enable_fake_traffic_) { // Start: 0x4E, 0x57, 0x01, 0x1B, 0x00, 0x00, 0x00, 0x00, 0x06, 0x00, 0x01 diff --git a/components/jk_modbus/jk_modbus.cpp b/components/jk_modbus/jk_modbus.cpp index 50578018..6efb8abd 100644 --- a/components/jk_modbus/jk_modbus.cpp +++ b/components/jk_modbus/jk_modbus.cpp @@ -32,11 +32,14 @@ uint16_t chksum(const uint8_t data[], const uint16_t len) { return checksum; } -bool JkModbus::parse_jk_modbus_byte_(uint8_t byte) { +bool JkModbus::parse_jk_modbus_byte_(uint8_t byte) { // NOLINT size_t at = this->rx_buffer_.size(); this->rx_buffer_.push_back(byte); const uint8_t *raw = &this->rx_buffer_[0]; + // @FIXME + return false; + // Byte 0: Start sequence (0x4E) if (at == 0) return true; @@ -152,5 +155,33 @@ void JkModbus::read_registers(uint8_t function, uint8_t address) { this->flush(); } +void JkModbus::query_status_v4() { + uint8_t frame[7]; + frame[0] = 0xDD; + frame[1] = 0xA5; + frame[2] = 0x03; + frame[3] = 0x00; + frame[4] = 0xFF; + frame[5] = 0xFD; + frame[6] = 0x77; + + this->write_array(frame, 7); + this->flush(); +} + +void JkModbus::query_cells_v4() { + uint8_t frame[7]; + frame[0] = 0xDD; + frame[1] = 0xA5; + frame[2] = 0x04; + frame[3] = 0x00; + frame[4] = 0xFF; + frame[5] = 0xFC; + frame[6] = 0x77; + + this->write_array(frame, 7); + this->flush(); +} + } // namespace jk_modbus } // namespace esphome diff --git a/components/jk_modbus/jk_modbus.h b/components/jk_modbus/jk_modbus.h index 96ee5f6d..ff7915c2 100644 --- a/components/jk_modbus/jk_modbus.h +++ b/components/jk_modbus/jk_modbus.h @@ -22,6 +22,8 @@ class JkModbus : public uart::UARTDevice, public Component { void send(uint8_t function, uint8_t address, uint8_t value); void read_registers(uint8_t function, uint8_t address); + void query_cells_v4(); + void query_status_v4(); protected: bool parse_jk_modbus_byte_(uint8_t byte); @@ -39,6 +41,8 @@ class JkModbusDevice { void send(int8_t function, uint8_t address, uint8_t value) { this->parent_->send(function, address, value); } void read_registers(uint8_t function, uint8_t address) { this->parent_->read_registers(function, address); } + void query_cells_v4() { this->parent_->query_cells_v4(); } + void query_status_v4() { this->parent_->query_status_v4(); } protected: friend JkModbus; diff --git a/esp32-example.yaml b/esp32-example.yaml index 1d7641bb..2d7a7981 100644 --- a/esp32-example.yaml +++ b/esp32-example.yaml @@ -1,6 +1,6 @@ substitutions: name: jk-bms - external_components_source: github://syssi/esphome-jk-bms@main + external_components_source: github://syssi/esphome-ant-bms@add-protocol-v4-support tx_pin: GPIO16 rx_pin: GPIO17 @@ -17,21 +17,24 @@ wifi: ssid: !secret wifi_ssid password: !secret wifi_password +api: ota: logger: - -mqtt: - broker: !secret mqtt_host - username: !secret mqtt_username - password: !secret mqtt_password - id: mqtt_client + level: DEBUG + logs: + api.service: WARN + ota: WARN + wifi: WARN + sensor: DEBUG uart: id: uart0 - baud_rate: 115200 + baud_rate: 9600 rx_buffer_size: 384 tx_pin: ${tx_pin} rx_pin: ${rx_pin} + debug: + direction: BOTH jk_modbus: id: modbus0 @@ -68,169 +71,3 @@ sensor: name: "${name} delta cell voltage" cell_voltage_1: name: "${name} cell voltage 1" - cell_voltage_2: - name: "${name} cell voltage 2" - cell_voltage_3: - name: "${name} cell voltage 3" - cell_voltage_4: - name: "${name} cell voltage 4" - cell_voltage_5: - name: "${name} cell voltage 5" - cell_voltage_6: - name: "${name} cell voltage 6" - cell_voltage_7: - name: "${name} cell voltage 7" - cell_voltage_8: - name: "${name} cell voltage 8" - cell_voltage_9: - name: "${name} cell voltage 9" - cell_voltage_10: - name: "${name} cell voltage 10" - cell_voltage_11: - name: "${name} cell voltage 11" - cell_voltage_12: - name: "${name} cell voltage 12" - cell_voltage_13: - name: "${name} cell voltage 13" - cell_voltage_14: - name: "${name} cell voltage 14" - cell_voltage_15: - name: "${name} cell voltage 15" - cell_voltage_16: - name: "${name} cell voltage 16" - cell_voltage_17: - name: "${name} cell voltage 17" - cell_voltage_18: - name: "${name} cell voltage 18" - cell_voltage_19: - name: "${name} cell voltage 19" - cell_voltage_20: - name: "${name} cell voltage 20" - cell_voltage_21: - name: "${name} cell voltage 21" - cell_voltage_22: - name: "${name} cell voltage 22" - cell_voltage_23: - name: "${name} cell voltage 23" - cell_voltage_24: - name: "${name} cell voltage 24" - power_tube_temperature: - name: "${name} power tube temperature" - temperature_sensor_1: - name: "${name} temperature sensor 1" - temperature_sensor_2: - name: "${name} temperature sensor 2" - total_voltage: - name: "${name} total voltage" - current: - name: "${name} current" - # https://github.com/syssi/esphome-jk-bms/issues/40 - # filters: - # - multiply: -1 - capacity_remaining: - name: "${name} capacity remaining" - capacity_remaining_derived: - name: "${name} capacity remaining derived" - temperature_sensors: - name: "${name} temperature sensors" - charging_cycles: - name: "${name} charging cycles" - total_charging_cycle_capacity: - name: "${name} total charging cycle capacity" - battery_strings: - name: "${name} battery strings" - errors_bitmask: - name: "${name} errors bitmask" - operation_mode_bitmask: - name: "${name} operation mode bitmask" - total_voltage_overvoltage_protection: - name: "${name} total voltage overvoltage protection" - total_voltage_undervoltage_protection: - name: "${name} total voltage undervoltage protection" - cell_voltage_overvoltage_protection: - name: "${name} cell voltage overvoltage protection" - cell_voltage_overvoltage_recovery: - name: "${name} cell voltage overvoltage recovery" - cell_voltage_overvoltage_delay: - name: "${name} cell voltage overvoltage delay" - cell_voltage_undervoltage_protection: - name: "${name} cell voltage undervoltage protection" - cell_voltage_undervoltage_recovery: - name: "${name} cell voltage undervoltage recovery" - cell_voltage_undervoltage_delay: - name: "${name} cell voltage undervoltage delay" - cell_pressure_difference_protection: - name: "${name} cell pressure difference protection" - discharging_overcurrent_protection: - name: "${name} discharging overcurrent protection" - discharging_overcurrent_delay: - name: "${name} discharging overcurrent delay" - charging_overcurrent_protection: - name: "${name} charging overcurrent protection" - charging_overcurrent_delay: - name: "${name} charging overcurrent delay" - balance_starting_voltage: - name: "${name} balance starting voltage" - balance_opening_pressure_difference: - name: "${name} balance opening pressure difference" - power_tube_temperature_protection: - name: "${name} power tube temperature protection" - power_tube_temperature_recovery: - name: "${name} power tube temperature recovery" - temperature_sensor_temperature_protection: - name: "${name} temperature sensor temperature protection" - temperature_sensor_temperature_recovery: - name: "${name} temperature sensor temperature recovery" - temperature_sensor_temperature_difference_protection: - name: "${name} temperature sensor temperature difference protection" - charging_high_temperature_protection: - name: "${name} charging high temperature protection" - discharging_high_temperature_protection: - name: "${name} discharging high temperature protection" - charging_low_temperature_protection: - name: "${name} charging low temperature protection" - charging_low_temperature_recovery: - name: "${name} charging low temperature recovery" - discharging_low_temperature_protection: - name: "${name} discharging low temperature protection" - discharging_low_temperature_recovery: - name: "${name} discharging low temperature recovery" - total_battery_capacity_setting: - name: "${name} total battery capacity setting" - current_calibration: - name: "${name} current calibration" - device_address: - name: "${name} device address" - sleep_wait_time: - name: "${name} sleep wait time" - alarm_low_volume: - name: "${name} alarm low volume" - manufacturing_date: - name: "${name} manufacturing date" - total_runtime: - name: "${name} total runtime" -# start_current_calibration: -# name: "${name} start current calibration" - actual_battery_capacity: - name: "${name} actual battery capacity" -# protocol_version: -# name: "${name} protocol version" - -text_sensor: - - platform: jk_bms - errors: - name: "${name} errors" - operation_mode: - name: "${name} operation mode" - battery_type: - name: "${name} battery type" - password: - name: "${name} password" - device_type: - name: "${name} device type" - software_version: - name: "${name} software version" - manufacturer: - name: "${name} manufacturer" - total_runtime_formatted: - name: "${name} total runtime formatted" From 278b5e40ead3cbc1dd2822c296a5010adf19dd18 Mon Sep 17 00:00:00 2001 From: Sebastian Muszynski Date: Sun, 27 Feb 2022 20:46:49 +0100 Subject: [PATCH 2/5] Add ESP8266 example --- esp8266-example.yaml | 184 +++---------------------------------------- 1 file changed, 10 insertions(+), 174 deletions(-) diff --git a/esp8266-example.yaml b/esp8266-example.yaml index e68434fc..91938578 100644 --- a/esp8266-example.yaml +++ b/esp8266-example.yaml @@ -17,23 +17,25 @@ wifi: ssid: !secret wifi_ssid password: !secret wifi_password +api: ota: logger: baud_rate: 0 - level: INFO - -mqtt: - broker: !secret mqtt_host - username: !secret mqtt_username - password: !secret mqtt_password - id: mqtt_client + level: DEBUG + logs: + api.service: WARN + ota: WARN + wifi: WARN + sensor: DEBUG uart: id: uart0 - baud_rate: 115200 + baud_rate: 9600 rx_buffer_size: 384 tx_pin: ${tx_pin} rx_pin: ${rx_pin} + debug: + direction: BOTH jk_modbus: id: modbus0 @@ -70,169 +72,3 @@ sensor: name: "${name} delta cell voltage" cell_voltage_1: name: "${name} cell voltage 1" - cell_voltage_2: - name: "${name} cell voltage 2" - cell_voltage_3: - name: "${name} cell voltage 3" - cell_voltage_4: - name: "${name} cell voltage 4" - cell_voltage_5: - name: "${name} cell voltage 5" - cell_voltage_6: - name: "${name} cell voltage 6" - cell_voltage_7: - name: "${name} cell voltage 7" - cell_voltage_8: - name: "${name} cell voltage 8" - cell_voltage_9: - name: "${name} cell voltage 9" - cell_voltage_10: - name: "${name} cell voltage 10" - cell_voltage_11: - name: "${name} cell voltage 11" - cell_voltage_12: - name: "${name} cell voltage 12" - cell_voltage_13: - name: "${name} cell voltage 13" - cell_voltage_14: - name: "${name} cell voltage 14" - cell_voltage_15: - name: "${name} cell voltage 15" - cell_voltage_16: - name: "${name} cell voltage 16" - cell_voltage_17: - name: "${name} cell voltage 17" - cell_voltage_18: - name: "${name} cell voltage 18" - cell_voltage_19: - name: "${name} cell voltage 19" - cell_voltage_20: - name: "${name} cell voltage 20" - cell_voltage_21: - name: "${name} cell voltage 21" - cell_voltage_22: - name: "${name} cell voltage 22" - cell_voltage_23: - name: "${name} cell voltage 23" - cell_voltage_24: - name: "${name} cell voltage 24" - power_tube_temperature: - name: "${name} power tube temperature" - temperature_sensor_1: - name: "${name} temperature sensor 1" - temperature_sensor_2: - name: "${name} temperature sensor 2" - total_voltage: - name: "${name} total voltage" - current: - name: "${name} current" - # https://github.com/syssi/esphome-jk-bms/issues/40 - # filters: - # - multiply: -1 - capacity_remaining: - name: "${name} capacity remaining" - capacity_remaining_derived: - name: "${name} capacity remaining derived" - temperature_sensors: - name: "${name} temperature sensors" - charging_cycles: - name: "${name} charging cycles" - total_charging_cycle_capacity: - name: "${name} total charging cycle capacity" - battery_strings: - name: "${name} battery strings" - errors_bitmask: - name: "${name} errors bitmask" - operation_mode_bitmask: - name: "${name} operation mode bitmask" - total_voltage_overvoltage_protection: - name: "${name} total voltage overvoltage protection" - total_voltage_undervoltage_protection: - name: "${name} total voltage undervoltage protection" - cell_voltage_overvoltage_protection: - name: "${name} cell voltage overvoltage protection" - cell_voltage_overvoltage_recovery: - name: "${name} cell voltage overvoltage recovery" - cell_voltage_overvoltage_delay: - name: "${name} cell voltage overvoltage delay" - cell_voltage_undervoltage_protection: - name: "${name} cell voltage undervoltage protection" - cell_voltage_undervoltage_recovery: - name: "${name} cell voltage undervoltage recovery" - cell_voltage_undervoltage_delay: - name: "${name} cell voltage undervoltage delay" - cell_pressure_difference_protection: - name: "${name} cell pressure difference protection" - discharging_overcurrent_protection: - name: "${name} discharging overcurrent protection" - discharging_overcurrent_delay: - name: "${name} discharging overcurrent delay" - charging_overcurrent_protection: - name: "${name} charging overcurrent protection" - charging_overcurrent_delay: - name: "${name} charging overcurrent delay" - balance_starting_voltage: - name: "${name} balance starting voltage" - balance_opening_pressure_difference: - name: "${name} balance opening pressure difference" - power_tube_temperature_protection: - name: "${name} power tube temperature protection" - power_tube_temperature_recovery: - name: "${name} power tube temperature recovery" - temperature_sensor_temperature_protection: - name: "${name} temperature sensor temperature protection" - temperature_sensor_temperature_recovery: - name: "${name} temperature sensor temperature recovery" - temperature_sensor_temperature_difference_protection: - name: "${name} temperature sensor temperature difference protection" - charging_high_temperature_protection: - name: "${name} charging high temperature protection" - discharging_high_temperature_protection: - name: "${name} discharging high temperature protection" - charging_low_temperature_protection: - name: "${name} charging low temperature protection" - charging_low_temperature_recovery: - name: "${name} charging low temperature recovery" - discharging_low_temperature_protection: - name: "${name} discharging low temperature protection" - discharging_low_temperature_recovery: - name: "${name} discharging low temperature recovery" - total_battery_capacity_setting: - name: "${name} total battery capacity setting" - current_calibration: - name: "${name} current calibration" - device_address: - name: "${name} device address" - sleep_wait_time: - name: "${name} sleep wait time" - alarm_low_volume: - name: "${name} alarm low volume" - manufacturing_date: - name: "${name} manufacturing date" - total_runtime: - name: "${name} total runtime" -# start_current_calibration: -# name: "${name} start current calibration" - actual_battery_capacity: - name: "${name} actual battery capacity" -# protocol_version: -# name: "${name} protocol version" - -text_sensor: - - platform: jk_bms - errors: - name: "${name} errors" - operation_mode: - name: "${name} operation mode" - battery_type: - name: "${name} battery type" - password: - name: "${name} password" - device_type: - name: "${name} device type" - software_version: - name: "${name} software version" - manufacturer: - name: "${name} manufacturer" - total_runtime_formatted: - name: "${name} total runtime formatted" From 641fff06ed2ea96f355bccf11d125c21d3fab0d3 Mon Sep 17 00:00:00 2001 From: Sebastian Muszynski Date: Sun, 27 Feb 2022 20:48:18 +0100 Subject: [PATCH 3/5] Fix configs --- esp32-example.yaml | 2 +- esp8266-example.yaml | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/esp32-example.yaml b/esp32-example.yaml index 2d7a7981..dba3abe8 100644 --- a/esp32-example.yaml +++ b/esp32-example.yaml @@ -1,6 +1,6 @@ substitutions: name: jk-bms - external_components_source: github://syssi/esphome-ant-bms@add-protocol-v4-support + external_components_source: github://syssi/esphome-jk-bms@add-protocol-v4-support tx_pin: GPIO16 rx_pin: GPIO17 diff --git a/esp8266-example.yaml b/esp8266-example.yaml index 91938578..4c719e89 100644 --- a/esp8266-example.yaml +++ b/esp8266-example.yaml @@ -1,6 +1,6 @@ substitutions: name: jk-bms - external_components_source: github://syssi/esphome-jk-bms@main + external_components_source: github://syssi/esphome-jk-bms@add-protocol-v4-support tx_pin: GPIO1 rx_pin: GPIO3 From 3a7df2b91650976c39ab3894ebc997b92fdb3477 Mon Sep 17 00:00:00 2001 From: Sebastian Muszynski Date: Wed, 2 Mar 2022 20:23:41 +0100 Subject: [PATCH 4/5] Don't touch the frame buffer --- components/jk_modbus/jk_modbus.cpp | 3 --- 1 file changed, 3 deletions(-) diff --git a/components/jk_modbus/jk_modbus.cpp b/components/jk_modbus/jk_modbus.cpp index 6efb8abd..86ab1115 100644 --- a/components/jk_modbus/jk_modbus.cpp +++ b/components/jk_modbus/jk_modbus.cpp @@ -37,9 +37,6 @@ bool JkModbus::parse_jk_modbus_byte_(uint8_t byte) { // NOLINT this->rx_buffer_.push_back(byte); const uint8_t *raw = &this->rx_buffer_[0]; - // @FIXME - return false; - // Byte 0: Start sequence (0x4E) if (at == 0) return true; From 2d6fd82e044f9c3f4c7a46cbc1f97b0bd3f70649 Mon Sep 17 00:00:00 2001 From: Sebastian Muszynski Date: Wed, 2 Mar 2022 20:25:03 +0100 Subject: [PATCH 5/5] Drop NOLINE statement --- components/jk_modbus/jk_modbus.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/components/jk_modbus/jk_modbus.cpp b/components/jk_modbus/jk_modbus.cpp index 86ab1115..cdf0e4f0 100644 --- a/components/jk_modbus/jk_modbus.cpp +++ b/components/jk_modbus/jk_modbus.cpp @@ -32,7 +32,7 @@ uint16_t chksum(const uint8_t data[], const uint16_t len) { return checksum; } -bool JkModbus::parse_jk_modbus_byte_(uint8_t byte) { // NOLINT +bool JkModbus::parse_jk_modbus_byte_(uint8_t byte) { size_t at = this->rx_buffer_.size(); this->rx_buffer_.push_back(byte); const uint8_t *raw = &this->rx_buffer_[0];