mirror of https://github.com/arendst/Tasmota.git
Add support for Hiking DDS238-2 Modbus energy meter
Add support for Hiking DDS238-2 Modbus energy meter by Matteo Campanella (#6384)
This commit is contained in:
parent
9cd21815c6
commit
657dbff570
|
@ -4,6 +4,7 @@
|
||||||
* Add support for up to 4 INA226 Voltage and Current sensors by Steve Rogers (#6342)
|
* Add support for up to 4 INA226 Voltage and Current sensors by Steve Rogers (#6342)
|
||||||
* Change Improve reliability of TasmotaSerial at 115200 bauds and reduce IRAM usage for Stage/pre-2.6
|
* Change Improve reliability of TasmotaSerial at 115200 bauds and reduce IRAM usage for Stage/pre-2.6
|
||||||
* Add support for A4988 stepper-motor-driver-circuit by Tim Leuschner (#6370)
|
* Add support for A4988 stepper-motor-driver-circuit by Tim Leuschner (#6370)
|
||||||
|
* Add support for Hiking DDS238-2 Modbus energy meter by Matteo Campanella (#6384)
|
||||||
*
|
*
|
||||||
* 6.6.0.10 20190905
|
* 6.6.0.10 20190905
|
||||||
* Redesign Tuya support by Shantur Rathore (#6353)
|
* Redesign Tuya support by Shantur Rathore (#6353)
|
||||||
|
|
|
@ -596,13 +596,14 @@
|
||||||
#define D_SENSOR_IBEACON_RX "iBeacon RX"
|
#define D_SENSOR_IBEACON_RX "iBeacon RX"
|
||||||
#define D_SENSOR_RDM6300_RX "RDM6300 RX"
|
#define D_SENSOR_RDM6300_RX "RDM6300 RX"
|
||||||
#define D_SENSOR_CC1101_CS "CC1101 CS"
|
#define D_SENSOR_CC1101_CS "CC1101 CS"
|
||||||
|
|
||||||
#define D_SENSOR_A4988_DIR "A4988 DIR"
|
#define D_SENSOR_A4988_DIR "A4988 DIR"
|
||||||
#define D_SENSOR_A4988_STP "A4988 STP"
|
#define D_SENSOR_A4988_STP "A4988 STP"
|
||||||
#define D_SENSOR_A4988_ENA "A4988 ENA"
|
#define D_SENSOR_A4988_ENA "A4988 ENA"
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "А"
|
#define D_UNIT_AMPERE "А"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
|
|
|
@ -602,10 +602,13 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "A"
|
#define D_UNIT_AMPERE "A"
|
||||||
#define D_UNIT_CENTIMETER "cm"
|
#define D_UNIT_CENTIMETER "cm"
|
||||||
|
#define D_UNIT_HERTZ "Hz"
|
||||||
#define D_UNIT_HOUR "Hr"
|
#define D_UNIT_HOUR "Hr"
|
||||||
#define D_UNIT_GALLONS "gal"
|
#define D_UNIT_GALLONS "gal"
|
||||||
#define D_UNIT_GALLONS_PER_MIN "g/m"
|
#define D_UNIT_GALLONS_PER_MIN "g/m"
|
||||||
|
@ -635,7 +638,6 @@
|
||||||
#define D_UNIT_WATT "W"
|
#define D_UNIT_WATT "W"
|
||||||
#define D_UNIT_WATTHOUR "Wh"
|
#define D_UNIT_WATTHOUR "Wh"
|
||||||
#define D_UNIT_WATT_METER_QUADRAT "W/m²"
|
#define D_UNIT_WATT_METER_QUADRAT "W/m²"
|
||||||
#define D_UNIT_HERTZ "Hz"
|
|
||||||
|
|
||||||
// Log message prefix
|
// Log message prefix
|
||||||
#define D_LOG_APPLICATION "APP: " // Application
|
#define D_LOG_APPLICATION "APP: " // Application
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "А"
|
#define D_UNIT_AMPERE "А"
|
||||||
|
|
|
@ -602,10 +602,13 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "安"
|
#define D_UNIT_AMPERE "安"
|
||||||
#define D_UNIT_CENTIMETER "厘米"
|
#define D_UNIT_CENTIMETER "厘米"
|
||||||
|
#define D_UNIT_HERTZ "赫兹"
|
||||||
#define D_UNIT_HOUR "时"
|
#define D_UNIT_HOUR "时"
|
||||||
#define D_UNIT_GALLONS "gal"
|
#define D_UNIT_GALLONS "gal"
|
||||||
#define D_UNIT_GALLONS_PER_MIN "g/m"
|
#define D_UNIT_GALLONS_PER_MIN "g/m"
|
||||||
|
@ -634,7 +637,6 @@
|
||||||
#define D_UNIT_VOLT "伏"
|
#define D_UNIT_VOLT "伏"
|
||||||
#define D_UNIT_WATT "瓦"
|
#define D_UNIT_WATT "瓦"
|
||||||
#define D_UNIT_WATTHOUR "瓦时"
|
#define D_UNIT_WATTHOUR "瓦时"
|
||||||
#define D_UNIT_HERTZ "赫兹"
|
|
||||||
#define D_UNIT_WATT_METER_QUADRAT "瓦/平米"
|
#define D_UNIT_WATT_METER_QUADRAT "瓦/平米"
|
||||||
|
|
||||||
// Log message prefix
|
// Log message prefix
|
||||||
|
|
|
@ -602,6 +602,8 @@
|
||||||
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
#define D_SENSOR_A4988_MS1 "A4988 MS1"
|
||||||
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
#define D_SENSOR_A4988_MS2 "A4988 MS2"
|
||||||
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
#define D_SENSOR_A4988_MS3 "A4988 MS3"
|
||||||
|
#define D_SENSOR_DDS2382_TX "DDS238-2 Tx"
|
||||||
|
#define D_SENSOR_DDS2382_RX "DDS238-2 Rx"
|
||||||
|
|
||||||
// Units
|
// Units
|
||||||
#define D_UNIT_AMPERE "安"
|
#define D_UNIT_AMPERE "安"
|
||||||
|
|
|
@ -431,10 +431,13 @@
|
||||||
#define USE_PZEM_AC // Add support for PZEM014,016 Energy monitor (+1k1 code)
|
#define USE_PZEM_AC // Add support for PZEM014,016 Energy monitor (+1k1 code)
|
||||||
#define USE_PZEM_DC // Add support for PZEM003,017 Energy monitor (+1k1 code)
|
#define USE_PZEM_DC // Add support for PZEM003,017 Energy monitor (+1k1 code)
|
||||||
#define USE_MCP39F501 // Add support for MCP39F501 Energy monitor as used in Shelly 2 (+3k1 code)
|
#define USE_MCP39F501 // Add support for MCP39F501 Energy monitor as used in Shelly 2 (+3k1 code)
|
||||||
//#define USE_SDM120_2 // Add support for Eastron SDM120-Modbus energy meter (+1k4 code)
|
//#define USE_SDM120_2 // Add support for Eastron SDM120-Modbus energy monitor (+1k1 code)
|
||||||
|
#define SDM120_SPEED 2400 // SDM120-Modbus RS485 serial speed (default: 2400 baud)
|
||||||
|
//#define USE_DDS2382 // Add support for Hiking DDS2382 Modbus energy monitor (+0k6 code)
|
||||||
|
#define DDS2382_SPEED 9600 // Hiking DDS2382 Modbus RS485 serial speed (default: 9600 baud)
|
||||||
|
|
||||||
//#define USE_SDM120 // Add support for Eastron SDM120-Modbus energy meter (+2k4 code)
|
//#define USE_SDM120 // Add support for Eastron SDM120-Modbus energy meter (+2k4 code)
|
||||||
#define SDM120_SPEED 2400 // SDM120-Modbus RS485 serial speed (default: 2400 baud)
|
// #define SDM120_SPEED 2400 // SDM120-Modbus RS485 serial speed (default: 2400 baud)
|
||||||
#define USE_SDM220 // Add extra parameters for SDM220 (+0k1 code)
|
#define USE_SDM220 // Add extra parameters for SDM220 (+0k1 code)
|
||||||
//#define USE_SDM630 // Add support for Eastron SDM630-Modbus energy meter (+2k code)
|
//#define USE_SDM630 // Add support for Eastron SDM630-Modbus energy meter (+2k code)
|
||||||
#define SDM630_SPEED 9600 // SDM630-Modbus RS485 serial speed (default: 9600 baud)
|
#define SDM630_SPEED 9600 // SDM630-Modbus RS485 serial speed (default: 9600 baud)
|
||||||
|
|
|
@ -148,7 +148,7 @@ char* ToHex_P(const unsigned char * in, size_t insz, char * out, size_t outsz, c
|
||||||
#define USE_PMS5003 // Add support for PMS5003 and PMS7003 particle concentration sensor (+1k3 code)
|
#define USE_PMS5003 // Add support for PMS5003 and PMS7003 particle concentration sensor (+1k3 code)
|
||||||
#define USE_NOVA_SDS // Add support for SDS011 and SDS021 particle concentration sensor (+0k7 code)
|
#define USE_NOVA_SDS // Add support for SDS011 and SDS021 particle concentration sensor (+0k7 code)
|
||||||
#define USE_SERIAL_BRIDGE // Add support for software Serial Bridge (+0k8 code)
|
#define USE_SERIAL_BRIDGE // Add support for software Serial Bridge (+0k8 code)
|
||||||
#define USE_SDM120 // Add support for Eastron SDM120-Modbus energy meter (+1k7 code)
|
//#define USE_SDM120 // Add support for Eastron SDM120-Modbus energy meter (+1k7 code)
|
||||||
#define USE_SDM630 // Add support for Eastron SDM630-Modbus energy meter (+2k code)
|
#define USE_SDM630 // Add support for Eastron SDM630-Modbus energy meter (+2k code)
|
||||||
#define USE_MP3_PLAYER // Use of the DFPlayer Mini MP3 Player RB-DFR-562 commands: play, volume and stop
|
#define USE_MP3_PLAYER // Use of the DFPlayer Mini MP3 Player RB-DFR-562 commands: play, volume and stop
|
||||||
#define MP3_VOLUME 10 // Set the startup volume on init, the range can be 0..30(max)
|
#define MP3_VOLUME 10 // Set the startup volume on init, the range can be 0..30(max)
|
||||||
|
@ -161,6 +161,9 @@ char* ToHex_P(const unsigned char * in, size_t insz, char * out, size_t outsz, c
|
||||||
#define USE_PZEM_AC // Add support for PZEM014,016 Energy monitor (+1k1 code)
|
#define USE_PZEM_AC // Add support for PZEM014,016 Energy monitor (+1k1 code)
|
||||||
#define USE_PZEM_DC // Add support for PZEM003,017 Energy monitor (+1k1 code)
|
#define USE_PZEM_DC // Add support for PZEM003,017 Energy monitor (+1k1 code)
|
||||||
#define USE_MCP39F501 // Add support for MCP39F501 Energy monitor as used in Shelly 2 (+3k1 code)
|
#define USE_MCP39F501 // Add support for MCP39F501 Energy monitor as used in Shelly 2 (+3k1 code)
|
||||||
|
#define USE_SDM120_2 // Add support for Eastron SDM120-Modbus energy monitor (+1k1 code)
|
||||||
|
#define USE_DDS2382 // Add support for Hiking DDS2382 Modbus energy monitor (+0k6 code)
|
||||||
|
|
||||||
#define USE_DHT // Add support for DHT11, AM2301 (DHT21, DHT22, AM2302, AM2321) and SI7021 Temperature and Humidity sensor
|
#define USE_DHT // Add support for DHT11, AM2301 (DHT21, DHT22, AM2302, AM2321) and SI7021 Temperature and Humidity sensor
|
||||||
#define USE_MAX31855 // Add support for MAX31855 K-Type thermocouple sensor using softSPI
|
#define USE_MAX31855 // Add support for MAX31855 K-Type thermocouple sensor using softSPI
|
||||||
#define USE_IR_REMOTE // Send IR remote commands using library IRremoteESP8266 and ArduinoJson (+4k code, 0k3 mem, 48 iram)
|
#define USE_IR_REMOTE // Send IR remote commands using library IRremoteESP8266 and ArduinoJson (+4k code, 0k3 mem, 48 iram)
|
||||||
|
@ -244,6 +247,8 @@ char* ToHex_P(const unsigned char * in, size_t insz, char * out, size_t outsz, c
|
||||||
#undef USE_PZEM_DC // Disable PZEM003,017 Energy monitor
|
#undef USE_PZEM_DC // Disable PZEM003,017 Energy monitor
|
||||||
#undef USE_MCP39F501 // Disable support for MCP39F501 Energy monitor as used in Shelly 2 (+3k1 code)
|
#undef USE_MCP39F501 // Disable support for MCP39F501 Energy monitor as used in Shelly 2 (+3k1 code)
|
||||||
#undef USE_SDM120_2 // Disable support for Eastron SDM120-Modbus energy meter
|
#undef USE_SDM120_2 // Disable support for Eastron SDM120-Modbus energy meter
|
||||||
|
#undef USE_DDS2382 // Disable support for Hiking DDS2382 Modbus energy monitor (+0k6 code)
|
||||||
|
|
||||||
#define USE_DHT // Add support for DHT11, AM2301 (DHT21, DHT22, AM2302, AM2321) and SI7021 Temperature and Humidity sensor
|
#define USE_DHT // Add support for DHT11, AM2301 (DHT21, DHT22, AM2302, AM2321) and SI7021 Temperature and Humidity sensor
|
||||||
#undef USE_MAX31855 // Disable MAX31855 K-Type thermocouple sensor using softSPI
|
#undef USE_MAX31855 // Disable MAX31855 K-Type thermocouple sensor using softSPI
|
||||||
#undef USE_IR_REMOTE // Disable IR remote commands using library IRremoteESP8266 and ArduinoJson
|
#undef USE_IR_REMOTE // Disable IR remote commands using library IRremoteESP8266 and ArduinoJson
|
||||||
|
@ -294,6 +299,8 @@ char* ToHex_P(const unsigned char * in, size_t insz, char * out, size_t outsz, c
|
||||||
#undef USE_PZEM_AC // Disable PZEM014,016 Energy monitor
|
#undef USE_PZEM_AC // Disable PZEM014,016 Energy monitor
|
||||||
#undef USE_PZEM_DC // Disable PZEM003,017 Energy monitor
|
#undef USE_PZEM_DC // Disable PZEM003,017 Energy monitor
|
||||||
#undef USE_MCP39F501 // Disable MCP39F501 Energy monitor as used in Shelly 2
|
#undef USE_MCP39F501 // Disable MCP39F501 Energy monitor as used in Shelly 2
|
||||||
|
#undef USE_SDM120_2 // Disable support for Eastron SDM120-Modbus energy meter
|
||||||
|
#undef USE_DDS2382 // Disable support for Hiking DDS2382 Modbus energy monitor (+0k6 code)
|
||||||
#undef USE_EMULATION // Disable Belkin WeMo and Hue Bridge emulation for Alexa (-16k code, -2k mem)
|
#undef USE_EMULATION // Disable Belkin WeMo and Hue Bridge emulation for Alexa (-16k code, -2k mem)
|
||||||
#undef USE_DOMOTICZ // Disable Domoticz
|
#undef USE_DOMOTICZ // Disable Domoticz
|
||||||
#undef USE_HOME_ASSISTANT // Disable Home Assistant
|
#undef USE_HOME_ASSISTANT // Disable Home Assistant
|
||||||
|
@ -375,6 +382,8 @@ char* ToHex_P(const unsigned char * in, size_t insz, char * out, size_t outsz, c
|
||||||
#undef USE_PZEM_DC // Disable PZEM003,017 Energy monitor
|
#undef USE_PZEM_DC // Disable PZEM003,017 Energy monitor
|
||||||
#undef USE_MCP39F501 // Disable support for MCP39F501 Energy monitor as used in Shelly 2 (+3k1 code)
|
#undef USE_MCP39F501 // Disable support for MCP39F501 Energy monitor as used in Shelly 2 (+3k1 code)
|
||||||
#undef USE_SDM120_2 // Disable support for Eastron SDM120-Modbus energy meter
|
#undef USE_SDM120_2 // Disable support for Eastron SDM120-Modbus energy meter
|
||||||
|
#undef USE_DDS2382 // Disable support for Hiking DDS2382 Modbus energy monitor (+0k6 code)
|
||||||
|
|
||||||
//#define USE_DHT // Add support for DHT11, AM2301 (DHT21, DHT22, AM2302, AM2321) and SI7021 Temperature and Humidity sensor
|
//#define USE_DHT // Add support for DHT11, AM2301 (DHT21, DHT22, AM2302, AM2321) and SI7021 Temperature and Humidity sensor
|
||||||
#undef USE_MAX31855 // Disable MAX31855 K-Type thermocouple sensor using softSPI
|
#undef USE_MAX31855 // Disable MAX31855 K-Type thermocouple sensor using softSPI
|
||||||
#undef USE_WS2812 // Disable WS2812 Led string using library NeoPixelBus (+5k code, +1k mem, 232 iram) - Disable by //
|
#undef USE_WS2812 // Disable WS2812 Led string using library NeoPixelBus (+5k code, +1k mem, 232 iram) - Disable by //
|
||||||
|
@ -468,6 +477,9 @@ char* ToHex_P(const unsigned char * in, size_t insz, char * out, size_t outsz, c
|
||||||
#undef USE_PZEM_AC // Disable PZEM014,016 Energy monitor
|
#undef USE_PZEM_AC // Disable PZEM014,016 Energy monitor
|
||||||
#undef USE_PZEM_DC // Disable PZEM003,017 Energy monitor
|
#undef USE_PZEM_DC // Disable PZEM003,017 Energy monitor
|
||||||
//#undef USE_MCP39F501 // Disable MCP39F501 Energy monitor as used in Shelly 2
|
//#undef USE_MCP39F501 // Disable MCP39F501 Energy monitor as used in Shelly 2
|
||||||
|
#undef USE_SDM120_2 // Disable support for Eastron SDM120-Modbus energy meter
|
||||||
|
#undef USE_DDS2382 // Disable support for Hiking DDS2382 Modbus energy monitor (+0k6 code)
|
||||||
|
|
||||||
#undef USE_DHT // Disable support for DHT11, AM2301 (DHT21, DHT22, AM2302, AM2321) and SI7021 Temperature and Humidity sensor
|
#undef USE_DHT // Disable support for DHT11, AM2301 (DHT21, DHT22, AM2302, AM2321) and SI7021 Temperature and Humidity sensor
|
||||||
#undef USE_MAX31855 // Disable MAX31855 K-Type thermocouple sensor using softSPI
|
#undef USE_MAX31855 // Disable MAX31855 K-Type thermocouple sensor using softSPI
|
||||||
#undef USE_SDM120_2 // Disable support for Eastron SDM120-Modbus energy meter
|
#undef USE_SDM120_2 // Disable support for Eastron SDM120-Modbus energy meter
|
||||||
|
@ -551,6 +563,8 @@ char* ToHex_P(const unsigned char * in, size_t insz, char * out, size_t outsz, c
|
||||||
#undef USE_PZEM_DC // Disable PZEM003,017 Energy monitor
|
#undef USE_PZEM_DC // Disable PZEM003,017 Energy monitor
|
||||||
#undef USE_MCP39F501 // Disable MCP39F501 Energy monitor as used in Shelly 2
|
#undef USE_MCP39F501 // Disable MCP39F501 Energy monitor as used in Shelly 2
|
||||||
#undef USE_SDM120_2 // Disable support for Eastron SDM120-Modbus energy meter
|
#undef USE_SDM120_2 // Disable support for Eastron SDM120-Modbus energy meter
|
||||||
|
#undef USE_DDS2382 // Disable support for Hiking DDS2382 Modbus energy monitor (+0k6 code)
|
||||||
|
|
||||||
#undef USE_DHT // Disable support for DHT11, AM2301 (DHT21, DHT22, AM2302, AM2321) and SI7021 Temperature and Humidity sensor
|
#undef USE_DHT // Disable support for DHT11, AM2301 (DHT21, DHT22, AM2302, AM2321) and SI7021 Temperature and Humidity sensor
|
||||||
#undef USE_MAX31855 // Disable MAX31855 K-Type thermocouple sensor using softSPI
|
#undef USE_MAX31855 // Disable MAX31855 K-Type thermocouple sensor using softSPI
|
||||||
#undef USE_IR_REMOTE // Disable IR driver
|
#undef USE_IR_REMOTE // Disable IR driver
|
||||||
|
|
|
@ -200,6 +200,8 @@ enum UserSelectablePins {
|
||||||
GPIO_A4988_MS1, // A4988 microstep pin1
|
GPIO_A4988_MS1, // A4988 microstep pin1
|
||||||
GPIO_A4988_MS2, // A4988 microstep pin2
|
GPIO_A4988_MS2, // A4988 microstep pin2
|
||||||
GPIO_A4988_MS3, // A4988 microstep pin3
|
GPIO_A4988_MS3, // A4988 microstep pin3
|
||||||
|
GPIO_DDS2382_TX, // DDS2382 Serial interface
|
||||||
|
GPIO_DDS2382_RX, // DDS2382 Serial interface
|
||||||
GPIO_SENSOR_END };
|
GPIO_SENSOR_END };
|
||||||
|
|
||||||
// Programmer selectable GPIO functionality
|
// Programmer selectable GPIO functionality
|
||||||
|
@ -274,6 +276,7 @@ const char kSensorNames[] PROGMEM =
|
||||||
D_SENSOR_RDM6300_RX "|"
|
D_SENSOR_RDM6300_RX "|"
|
||||||
D_SENSOR_IBEACON_TX "|" D_SENSOR_IBEACON_RX "|"
|
D_SENSOR_IBEACON_TX "|" D_SENSOR_IBEACON_RX "|"
|
||||||
D_SENSOR_A4988_DIR "|" D_SENSOR_A4988_STP "|" D_SENSOR_A4988_ENA "|" D_SENSOR_A4988_MS1 "|" D_SENSOR_A4988_MS2 "|" D_SENSOR_A4988_MS3 "|"
|
D_SENSOR_A4988_DIR "|" D_SENSOR_A4988_STP "|" D_SENSOR_A4988_ENA "|" D_SENSOR_A4988_MS1 "|" D_SENSOR_A4988_MS2 "|" D_SENSOR_A4988_MS3 "|"
|
||||||
|
D_SENSOR_DDS2382_TX "|" D_SENSOR_DDS2382_RX "|"
|
||||||
;
|
;
|
||||||
|
|
||||||
// User selectable ADC0 functionality
|
// User selectable ADC0 functionality
|
||||||
|
@ -617,6 +620,10 @@ const uint8_t kGpioNiceList[] PROGMEM = {
|
||||||
GPIO_SDM120_TX, // SDM120 Serial interface
|
GPIO_SDM120_TX, // SDM120 Serial interface
|
||||||
GPIO_SDM120_RX, // SDM120 Serial interface
|
GPIO_SDM120_RX, // SDM120 Serial interface
|
||||||
#endif
|
#endif
|
||||||
|
#ifdef USE_DDS2382
|
||||||
|
GPIO_DDS2382_TX, // DDS2382 Serial interface
|
||||||
|
GPIO_DDS2382_RX, // DDS2382 Serial interface
|
||||||
|
#endif
|
||||||
#endif // USE_ENERGY_SENSOR
|
#endif // USE_ENERGY_SENSOR
|
||||||
#ifndef USE_SDM120_2
|
#ifndef USE_SDM120_2
|
||||||
#ifdef USE_SDM120
|
#ifdef USE_SDM120
|
||||||
|
|
|
@ -447,7 +447,9 @@ void GetFeatures(void)
|
||||||
#ifdef USE_A4988_Stepper
|
#ifdef USE_A4988_Stepper
|
||||||
feature5 |= 0x00000020; // xdrv_25_A4988.ino
|
feature5 |= 0x00000020; // xdrv_25_A4988.ino
|
||||||
#endif
|
#endif
|
||||||
// feature5 |= 0x00000040;
|
#ifdef USE_DDS2382
|
||||||
|
feature5 |= 0x00000040; // Xnrg_09_dds2382.ino
|
||||||
|
#endif
|
||||||
// feature5 |= 0x00000080;
|
// feature5 |= 0x00000080;
|
||||||
|
|
||||||
// feature5 |= 0x00000100;
|
// feature5 |= 0x00000100;
|
||||||
|
|
|
@ -36,40 +36,21 @@
|
||||||
#include <TasmotaModbus.h>
|
#include <TasmotaModbus.h>
|
||||||
TasmotaModbus *PzemAcModbus;
|
TasmotaModbus *PzemAcModbus;
|
||||||
|
|
||||||
/*
|
uint8_t PzemAc_send_retry = 0;
|
||||||
uint16_t PzemCalculateCRC(uint8_t *buffer, uint8_t num)
|
|
||||||
{
|
|
||||||
uint16_t crc = 0xFFFF;
|
|
||||||
for (uint32_t i = 0; i < num; i++) {
|
|
||||||
crc ^= buffer[i];
|
|
||||||
for (uint32_t j = 8; j; j--) {
|
|
||||||
if ((crc & 0x0001) != 0) { // If the LSB is set
|
|
||||||
crc >>= 1; // Shift right and XOR 0xA001
|
|
||||||
crc ^= 0xA001;
|
|
||||||
} else { // Else LSB is not set
|
|
||||||
crc >>= 1; // Just shift right
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return crc;
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
void PzemAcEverySecond(void)
|
void PzemAcEverySecond(void)
|
||||||
{
|
{
|
||||||
static uint8_t send_retry = 0;
|
|
||||||
|
|
||||||
bool data_ready = PzemAcModbus->ReceiveReady();
|
bool data_ready = PzemAcModbus->ReceiveReady();
|
||||||
|
|
||||||
if (data_ready) {
|
if (data_ready) {
|
||||||
uint8_t buffer[26];
|
uint8_t buffer[30]; // At least 5 + (2 * 10) = 25
|
||||||
|
|
||||||
uint8_t error = PzemAcModbus->ReceiveBuffer(buffer, 10);
|
uint8_t error = PzemAcModbus->ReceiveBuffer(buffer, 10);
|
||||||
AddLogBuffer(LOG_LEVEL_DEBUG_MORE, buffer, sizeof(buffer));
|
AddLogBuffer(LOG_LEVEL_DEBUG_MORE, buffer, (buffer[2]) ? buffer[2] +5 : sizeof(buffer));
|
||||||
|
|
||||||
if (error) {
|
if (error) {
|
||||||
AddLog_P2(LOG_LEVEL_DEBUG, PSTR(D_LOG_DEBUG "PzemAc response error %d"), error);
|
AddLog_P2(LOG_LEVEL_DEBUG, PSTR(D_LOG_DEBUG "PzemAc response error %d"), error);
|
||||||
} else {
|
} else {
|
||||||
// if ((PzemCalculateCRC(buffer, 23)) == ((buffer[24] << 8) | buffer[23])) {
|
|
||||||
Energy.data_valid = 0;
|
Energy.data_valid = 0;
|
||||||
|
|
||||||
// 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
|
// 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24
|
||||||
|
@ -83,16 +64,15 @@ void PzemAcEverySecond(void)
|
||||||
float energy = (float)((buffer[15] << 24) + (buffer[16] << 16) + (buffer[13] << 8) + buffer[14]); // 4294967295 Wh
|
float energy = (float)((buffer[15] << 24) + (buffer[16] << 16) + (buffer[13] << 8) + buffer[14]); // 4294967295 Wh
|
||||||
|
|
||||||
EnergyUpdateTotal(energy, false);
|
EnergyUpdateTotal(energy, false);
|
||||||
// }
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (0 == send_retry || data_ready) {
|
if (0 == PzemAc_send_retry || data_ready) {
|
||||||
send_retry = 5;
|
PzemAc_send_retry = 5;
|
||||||
PzemAcModbus->Send(PZEM_AC_DEVICE_ADDRESS, 0x04, 0, 10);
|
PzemAcModbus->Send(PZEM_AC_DEVICE_ADDRESS, 0x04, 0, 10);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
send_retry--;
|
PzemAc_send_retry--;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -43,7 +43,7 @@ void PzemDcEverySecond(void)
|
||||||
bool data_ready = PzemDcModbus->ReceiveReady();
|
bool data_ready = PzemDcModbus->ReceiveReady();
|
||||||
|
|
||||||
if (data_ready) {
|
if (data_ready) {
|
||||||
uint8_t buffer[22];
|
uint8_t buffer[26]; // At least 5 + (2 * 8) = 21
|
||||||
|
|
||||||
uint8_t error = PzemDcModbus->ReceiveBuffer(buffer, 8);
|
uint8_t error = PzemDcModbus->ReceiveBuffer(buffer, 8);
|
||||||
AddLogBuffer(LOG_LEVEL_DEBUG_MORE, buffer, sizeof(buffer));
|
AddLogBuffer(LOG_LEVEL_DEBUG_MORE, buffer, sizeof(buffer));
|
||||||
|
|
|
@ -77,7 +77,7 @@ void SDM120Every250ms(void)
|
||||||
bool data_ready = Sdm120Modbus->ReceiveReady();
|
bool data_ready = Sdm120Modbus->ReceiveReady();
|
||||||
|
|
||||||
if (data_ready) {
|
if (data_ready) {
|
||||||
uint8_t buffer[9];
|
uint8_t buffer[14]; // At least 5 + (2 * 2) = 9
|
||||||
|
|
||||||
uint32_t error = Sdm120Modbus->ReceiveBuffer(buffer, 2);
|
uint32_t error = Sdm120Modbus->ReceiveBuffer(buffer, 2);
|
||||||
AddLogBuffer(LOG_LEVEL_DEBUG_MORE, buffer, sizeof(buffer));
|
AddLogBuffer(LOG_LEVEL_DEBUG_MORE, buffer, sizeof(buffer));
|
||||||
|
@ -85,7 +85,6 @@ void SDM120Every250ms(void)
|
||||||
if (error) {
|
if (error) {
|
||||||
AddLog_P2(LOG_LEVEL_DEBUG, PSTR(D_LOG_DEBUG "SDM120 response error %d"), error);
|
AddLog_P2(LOG_LEVEL_DEBUG, PSTR(D_LOG_DEBUG "SDM120 response error %d"), error);
|
||||||
} else {
|
} else {
|
||||||
uint32_t max_table =
|
|
||||||
Energy.data_valid = 0;
|
Energy.data_valid = 0;
|
||||||
|
|
||||||
// 0 1 2 3 4 5 6 7 8
|
// 0 1 2 3 4 5 6 7 8
|
||||||
|
|
|
@ -0,0 +1,123 @@
|
||||||
|
/*
|
||||||
|
xnrg_09_dds2382.ino - Hiking DDS238-2 Modbus energy meter support for Sonoff-Tasmota
|
||||||
|
|
||||||
|
Copyright (C) 2019 Matteo Campanella - based on the work of Gennaro Tortone
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef USE_ENERGY_SENSOR
|
||||||
|
#ifdef USE_DDS2382
|
||||||
|
/*********************************************************************************************\
|
||||||
|
* Hiking DDS238-2 Modbus energy meter
|
||||||
|
*
|
||||||
|
* Based on: https://github.com/reaper7/SDM_Energy_Meter
|
||||||
|
\*********************************************************************************************/
|
||||||
|
|
||||||
|
#define XNRG_09 9
|
||||||
|
|
||||||
|
#ifndef DDS2382_SPEED
|
||||||
|
#define DDS2382_SPEED 9600 // default dds2382 Modbus address
|
||||||
|
#endif
|
||||||
|
#ifndef DDS2382_ADDR
|
||||||
|
#define DDS2382_ADDR 1 // default dds2382 Modbus address
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include <TasmotaModbus.h>
|
||||||
|
TasmotaModbus *Dds2382Modbus;
|
||||||
|
|
||||||
|
uint8_t Dds2382_send_retry = 0;
|
||||||
|
|
||||||
|
void Dds2382EverySecond(void)
|
||||||
|
{
|
||||||
|
bool data_ready = Dds2382Modbus->ReceiveReady();
|
||||||
|
|
||||||
|
if (data_ready) {
|
||||||
|
uint8_t buffer[46]; // At least 5 + (2 * 18) = 41
|
||||||
|
|
||||||
|
uint32_t error = Dds2382Modbus->ReceiveBuffer(buffer, 18);
|
||||||
|
AddLogBuffer(LOG_LEVEL_DEBUG_MORE, buffer, (buffer[2]) ? buffer[2] +5 : sizeof(buffer));
|
||||||
|
|
||||||
|
if (error) {
|
||||||
|
AddLog_P2(LOG_LEVEL_DEBUG, PSTR(D_LOG_DEBUG "DDS2382 response error %d"), error);
|
||||||
|
} else {
|
||||||
|
Energy.data_valid = 0;
|
||||||
|
|
||||||
|
// 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40
|
||||||
|
// SA FC BC EnergyTotal ExportActiv ImportActiv Volta Curre APowe RPowe PFact Frequ Crc--
|
||||||
|
|
||||||
|
Energy.voltage = (float)((buffer[27] << 8) + buffer[28]) / 10.0;
|
||||||
|
Energy.current = (float)((buffer[29] << 8) + buffer[30]) / 100.0;
|
||||||
|
Energy.active_power = (float)((buffer[31] << 8) + buffer[32]);
|
||||||
|
Energy.reactive_power = (float)((buffer[33] << 8) + buffer[34]);
|
||||||
|
Energy.power_factor = (float)((buffer[35] << 8) + buffer[36]) / 1000.0; // 1.00
|
||||||
|
Energy.frequency = (float)((buffer[37] << 8) + buffer[38]) / 100.0; // 50.0 Hz
|
||||||
|
Energy.export_active = (float)((buffer[11] << 24) + (buffer[12] << 16) + (buffer[13] << 8) + buffer[14]) / 100.0; // 429496729.0 W
|
||||||
|
// float energy_total = (float)((buffer[3] << 24) + (buffer[4] << 16) + (buffer[5] << 8) + buffer[6]) / 100.0; // 429496729.0 W
|
||||||
|
float import_active = (float)((buffer[15] << 24) + (buffer[16] << 16) + (buffer[17] << 8) + buffer[18]) / 100.0; // 429496729.0 W
|
||||||
|
|
||||||
|
EnergyUpdateTotal(import_active, false); // 484.708 kWh
|
||||||
|
}
|
||||||
|
} // end data ready
|
||||||
|
|
||||||
|
if (0 == Dds2382_send_retry || data_ready) {
|
||||||
|
Dds2382_send_retry = 5;
|
||||||
|
Dds2382Modbus->Send(DDS2382_ADDR, 0x03, 0, 18);
|
||||||
|
} else {
|
||||||
|
Dds2382_send_retry--;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Dds2382SnsInit(void)
|
||||||
|
{
|
||||||
|
Dds2382Modbus = new TasmotaModbus(pin[GPIO_DDS2382_RX], pin[GPIO_DDS2382_TX]);
|
||||||
|
uint8_t result = Dds2382Modbus->Begin(DDS2382_SPEED);
|
||||||
|
if (result) {
|
||||||
|
if (2 == result) { ClaimSerial(); }
|
||||||
|
} else {
|
||||||
|
energy_flg = ENERGY_NONE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void Dds2382DrvInit(void)
|
||||||
|
{
|
||||||
|
if ((pin[GPIO_DDS2382_RX] < 99) && (pin[GPIO_DDS2382_TX] < 99)) {
|
||||||
|
energy_flg = XNRG_09;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*********************************************************************************************\
|
||||||
|
* Interface
|
||||||
|
\*********************************************************************************************/
|
||||||
|
|
||||||
|
bool Xnrg09(uint8_t function)
|
||||||
|
{
|
||||||
|
bool result = false;
|
||||||
|
|
||||||
|
switch (function) {
|
||||||
|
case FUNC_ENERGY_EVERY_SECOND:
|
||||||
|
if (uptime > 4) { Dds2382EverySecond(); }
|
||||||
|
break;
|
||||||
|
case FUNC_INIT:
|
||||||
|
Dds2382SnsInit();
|
||||||
|
break;
|
||||||
|
case FUNC_PRE_INIT:
|
||||||
|
Dds2382DrvInit();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif // USE_DDS2382
|
||||||
|
#endif // USE_ENERGY_SENSOR
|
|
@ -167,7 +167,7 @@ a_features = [[
|
||||||
"USE_MAX31865","USE_CHIRP","USE_SOLAX_X1","USE_PAJ7620"
|
"USE_MAX31865","USE_CHIRP","USE_SOLAX_X1","USE_PAJ7620"
|
||||||
],[
|
],[
|
||||||
"USE_BUZZER","USE_RDM6300","USE_IBEACON","USE_SML_M",
|
"USE_BUZZER","USE_RDM6300","USE_IBEACON","USE_SML_M",
|
||||||
"USE_INA226","USE_A4988_Stepper","","",
|
"USE_INA226","USE_A4988_Stepper","USE_DDS2382","",
|
||||||
"","","","",
|
"","","","",
|
||||||
"","","","",
|
"","","","",
|
||||||
"","","","",
|
"","","","",
|
||||||
|
|
Loading…
Reference in New Issue