Fix Shelly Pro 4PM calibration regs

This commit is contained in:
Theo Arends 2023-02-08 14:14:49 +01:00
parent 40be97e6d9
commit 7a2b5177ac
1 changed files with 27 additions and 11 deletions

View File

@ -42,11 +42,12 @@
* Shelly 2.5 EM Plus2PM Pro1PM Pro2PM Pro4PM * Shelly 2.5 EM Plus2PM Pro1PM Pro2PM Pro4PM
* Processor ESP8266 ESP8266 ESP32 ESP32 ESP32 ESP32 * Processor ESP8266 ESP8266 ESP32 ESP32 ESP32 ESP32
* Interface I2C I2C I2C SPI SPI SPI Interface type used * Interface I2C I2C I2C SPI SPI SPI Interface type used
* Number of inputs 2 2 2 1 2 4 Count of ADE9753 inputs used
* Number of ADE9753 chips 1 1 1 1 2 2 Count of ADE9753 chips * Number of ADE9753 chips 1 1 1 1 2 2 Count of ADE9753 chips
* ADE9753 IRQ 1 2 3 4 5 6 Index defines model number * ADE9753 IRQ 1 2 3 4 5 6 Index defines model number
* Current measurement device shunt CT shunt shunt shunt shunt CT = Current Transformer * Current measurement device shunt CT shunt shunt shunt shunt CT = Current Transformer
* Common voltage Yes Yes Yes No No No Show common voltage in GUI/JSON * Common voltage Yes Yes Yes No No Yes Show common voltage in GUI/JSON
* Common frequency Yes Yes Yes No No No Show common frequency in GUI/JSON * Common frequency Yes Yes Yes No No Yes Show common frequency in GUI/JSON
* Swapped channel A/B Yes No No No No No Defined by hardware design - Fixed by Tasmota * Swapped channel A/B Yes No No No No No Defined by hardware design - Fixed by Tasmota
* Support Export Active No Yes No No No No Only EM supports correct negative value detection * Support Export Active No Yes No No No No Only EM supports correct negative value detection
* Show negative (reactive) power No Yes No No No No Only EM supports correct negative value detection * Show negative (reactive) power No Yes No No No No Only EM supports correct negative value detection
@ -374,7 +375,6 @@ void Ade7953DumpRegs(void) {
#endif // ADE7953_DUMP_REGS #endif // ADE7953_DUMP_REGS
void Ade7953SetCalibration(uint32_t regset, uint32_t calibset) { void Ade7953SetCalibration(uint32_t regset, uint32_t calibset) {
Ade7953.cs_index = calibset;
for (uint32_t i = 0; i < ADE7953_CALIBREGS; i++) { for (uint32_t i = 0; i < ADE7953_CALIBREGS; i++) {
int32_t value = Ade7953.calib_data[calibset][i]; int32_t value = Ade7953.calib_data[calibset][i];
if (ADE7943_CAL_PHCAL == i) { if (ADE7943_CAL_PHCAL == i) {
@ -393,6 +393,8 @@ void Ade7953Init(void) {
#ifdef USE_ESP32_SPI #ifdef USE_ESP32_SPI
chips = (Ade7953.pin_cs[1] >= 0) ? 2 : 1; chips = (Ade7953.pin_cs[1] >= 0) ? 2 : 1;
#endif // USE_ESP32_SPI #endif // USE_ESP32_SPI
// Init ADE7953 with calibration settings
for (uint32_t chip = 0; chip < chips; chip++) { for (uint32_t chip = 0; chip < chips; chip++) {
Ade7953.cs_index = chip; Ade7953.cs_index = chip;
@ -406,18 +408,32 @@ void Ade7953Init(void) {
#ifdef USE_ESP32_SPI #ifdef USE_ESP32_SPI
// int32_t value = Ade7953Read(0x702); // Silicon version // int32_t value = Ade7953Read(0x702); // Silicon version
// AddLog(LOG_LEVEL_DEBUG, PSTR("ADE: Chip%d version %d"), chip +1, value); // AddLog(LOG_LEVEL_DEBUG, PSTR("ADE: Chip%d version %d"), chip +1, value);
if (1 == chip) {
switch (Ade7953.model) {
case ADE7953_SHELLY_PRO_2PM:
Ade7953SetCalibration(0, 1); // Second ADE7953 A registers set with calibration set 1
break;
case ADE7953_SHELLY_PRO_4PM:
Ade7953SetCalibration(0, 2); // Second ADE7953 A registers set with calibration set 2
Ade7953SetCalibration(1, 3); // Second ADE7953 B registers set with calibration set 3
}
} else {
#endif // USE_ESP32_SPI #endif // USE_ESP32_SPI
} Ade7953SetCalibration(0, 0); // First ADE7953 A registers set with calibration set 0
switch (Ade7953.model) {
Ade7953SetCalibration(0, 0); // First ADE7953 A registers set with calibration set 0 case ADE7953_SHELLY_25:
case ADE7953_SHELLY_EM:
case ADE7953_SHELLY_PLUS_2PM:
// case ADE7953_SHELLY_PRO_1PM: // Uses defaults for B registers
case ADE7953_SHELLY_PRO_4PM:
Ade7953SetCalibration(1, 1); // First ADE7953 B registers set with calibration set 1
}
#ifdef USE_ESP32_SPI #ifdef USE_ESP32_SPI
if (Ade7953.pin_cs[1] >= 0) { // Second ADE7953 using SPI }
Ade7953SetCalibration(0, 1); // Second ADE7953 A registers set with calibration set 1
}
else if (Ade7953.pin_cs[0] == -1) // No first ADE7953 using SPI so set register set B
#endif // USE_ESP32_SPI #endif // USE_ESP32_SPI
Ade7953SetCalibration(1, 1); // First ADE7953 B register set with calibration set 1 }
// Report set calibration settings
int32_t regs[ADE7953_CALIBREGS]; int32_t regs[ADE7953_CALIBREGS];
for (uint32_t chip = 0; chip < chips; chip++) { for (uint32_t chip = 0; chip < chips; chip++) {
Ade7953.cs_index = chip; Ade7953.cs_index = chip;