Merge branch 'development' into fix_so37

This commit is contained in:
Theo Arends 2019-10-31 12:15:35 +01:00 committed by GitHub
commit c541457763
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 116 additions and 34 deletions

View File

@ -6,6 +6,7 @@
* Add frequency to ADE7953 energy monitor as used in Shelly 2.5 by ljakob (#6778) * Add frequency to ADE7953 energy monitor as used in Shelly 2.5 by ljakob (#6778)
* Add command SetOption74 0/1 to enable DS18x20 internal pull-up and remove define DS18B20_INTERNAL_PULLUP (#6795) * Add command SetOption74 0/1 to enable DS18x20 internal pull-up and remove define DS18B20_INTERNAL_PULLUP (#6795)
* Fix better control of RGB/White when SetOption37 >128, added Dimmer1 and Dimmer2 commands (#6714) * Fix better control of RGB/White when SetOption37 >128, added Dimmer1 and Dimmer2 commands (#6714)
* Add hide Alexa objects with friendlyname starting with '$' (#6722, #6762)
* *
* 6.7.1.1 20191026 * 6.7.1.1 20191026
* Change ArduinoSlave to TasmotaSlave (Experimental) * Change ArduinoSlave to TasmotaSlave (Experimental)

View File

@ -98,6 +98,44 @@ typedef union { // Restricted by MISRA-C Rule 18.4 bu
}; };
} SysBitfield3; } SysBitfield3;
typedef union { // Restricted by MISRA-C Rule 18.4 but so useful...
uint32_t data; // Allow bit manipulation using SetOption
struct { // SetOption82 .. SetOption113
uint32_t spare00 : 1;
uint32_t spare01 : 1;
uint32_t spare02 : 1;
uint32_t spare03 : 1;
uint32_t spare04 : 1;
uint32_t spare05 : 1;
uint32_t spare06 : 1;
uint32_t spare07 : 1;
uint32_t spare08 : 1;
uint32_t spare09 : 1;
uint32_t spare10 : 1;
uint32_t spare11 : 1;
uint32_t spare12 : 1;
uint32_t spare13 : 1;
uint32_t spare14 : 1;
uint32_t spare15 : 1;
uint32_t spare16 : 1;
uint32_t spare17 : 1;
uint32_t spare18 : 1;
uint32_t spare19 : 1;
uint32_t spare20 : 1;
uint32_t spare21 : 1;
uint32_t spare22 : 1;
uint32_t spare23 : 1;
uint32_t spare24 : 1;
uint32_t spare25 : 1;
uint32_t spare26 : 1;
uint32_t spare27 : 1;
uint32_t spare28 : 1;
uint32_t spare29 : 1;
uint32_t spare30 : 1;
uint32_t spare31 : 1;
};
} SysBitfield4;
typedef union { typedef union {
uint32_t data; // Allow bit manipulation uint32_t data; // Allow bit manipulation
struct { struct {
@ -227,7 +265,13 @@ struct SYSCFG {
uint8_t weblog_level; // 1AC uint8_t weblog_level; // 1AC
uint8_t mqtt_fingerprint[2][20]; // 1AD uint8_t mqtt_fingerprint[2][20]; // 1AD
uint8_t adc_param_type; // 1D5 uint8_t adc_param_type; // 1D5
uint8_t register8[16]; // 1D6 - 16 x 8-bit registers indexed by enum SettingsRegister8
uint8_t free_1d6[10]; // 1D6
SysBitfield4 flag4; // 1E0
uint8_t free_1e4[2]; // 1E4
uint8_t shutter_accuracy; // 1E6 uint8_t shutter_accuracy; // 1E6
uint8_t mqttlog_level; // 1E7 uint8_t mqttlog_level; // 1E7
uint8_t sps30_inuse_hours; // 1E8 uint8_t sps30_inuse_hours; // 1E8
@ -389,6 +433,7 @@ struct SYSCFG {
uint32_t deepsleep; // E94 uint32_t deepsleep; // E94
uint16_t energy_power_delta; // E98 uint16_t energy_power_delta; // E98
uint8_t shutter_motordelay[MAX_SHUTTERS]; // E9A uint8_t shutter_motordelay[MAX_SHUTTERS]; // E9A
uint8_t free_e9e[346]; // E9E uint8_t free_e9e[346]; // E9E
uint32_t cfg_timestamp; // FF8 uint32_t cfg_timestamp; // FF8

View File

@ -1064,7 +1064,7 @@ void SettingsDelta(void)
} }
} }
if (Settings.version < 0x0606000C) { if (Settings.version < 0x0606000C) {
memset(&Settings.register8, 0x00, sizeof(Settings.register8)); memset((char*)&Settings +0x1D6, 0x00, 16);
} }
if (Settings.version < 0x0606000F) { if (Settings.version < 0x0606000F) {
Settings.shutter_accuracy = 0; Settings.shutter_accuracy = 0;

View File

@ -372,10 +372,11 @@ void CmndStatus(void)
if ((0 == payload) || (3 == payload)) { if ((0 == payload) || (3 == payload)) {
Response_P(PSTR("{\"" D_CMND_STATUS D_STATUS3_LOGGING "\":{\"" D_CMND_SERIALLOG "\":%d,\"" D_CMND_WEBLOG "\":%d,\"" D_CMND_MQTTLOG "\":%d,\"" D_CMND_SYSLOG "\":%d,\"" Response_P(PSTR("{\"" D_CMND_STATUS D_STATUS3_LOGGING "\":{\"" D_CMND_SERIALLOG "\":%d,\"" D_CMND_WEBLOG "\":%d,\"" D_CMND_MQTTLOG "\":%d,\"" D_CMND_SYSLOG "\":%d,\""
D_CMND_LOGHOST "\":\"%s\",\"" D_CMND_LOGPORT "\":%d,\"" D_CMND_SSID "\":[\"%s\",\"%s\"],\"" D_CMND_TELEPERIOD "\":%d,\"" D_CMND_LOGHOST "\":\"%s\",\"" D_CMND_LOGPORT "\":%d,\"" D_CMND_SSID "\":[\"%s\",\"%s\"],\"" D_CMND_TELEPERIOD "\":%d,\""
D_JSON_RESOLUTION "\":\"%08X\",\"" D_CMND_SETOPTION "\":[\"%08X\",\"%s\",\"%08X\"]}}"), D_JSON_RESOLUTION "\":\"%08X\",\"" D_CMND_SETOPTION "\":[\"%08X\",\"%s\",\"%08X\",\"%08X\"]}}"),
Settings.seriallog_level, Settings.weblog_level, Settings.mqttlog_level, Settings.syslog_level, Settings.seriallog_level, Settings.weblog_level, Settings.mqttlog_level, Settings.syslog_level,
Settings.syslog_host, Settings.syslog_port, Settings.sta_ssid[0], Settings.sta_ssid[1], Settings.tele_period, Settings.syslog_host, Settings.syslog_port, Settings.sta_ssid[0], Settings.sta_ssid[1], Settings.tele_period,
Settings.flag2.data, Settings.flag.data, ToHex_P((unsigned char*)Settings.param, PARAM8_SIZE, stemp2, sizeof(stemp2)), Settings.flag3.data); Settings.flag2.data, Settings.flag.data, ToHex_P((unsigned char*)Settings.param, PARAM8_SIZE, stemp2, sizeof(stemp2)),
Settings.flag3.data, Settings.flag4.data);
MqttPublishPrefixTopic_P(option, PSTR(D_CMND_STATUS "3")); MqttPublishPrefixTopic_P(option, PSTR(D_CMND_STATUS "3"));
} }
@ -627,7 +628,7 @@ void CmndSavedata(void)
void CmndSetoption(void) void CmndSetoption(void)
{ {
if (XdrvMailbox.index < 82) { if (XdrvMailbox.index < 114) {
uint32_t ptype; uint32_t ptype;
uint32_t pindex; uint32_t pindex;
if (XdrvMailbox.index <= 31) { // SetOption0 .. 31 = Settings.flag if (XdrvMailbox.index <= 31) { // SetOption0 .. 31 = Settings.flag
@ -638,10 +639,15 @@ void CmndSetoption(void)
ptype = 2; ptype = 2;
pindex = XdrvMailbox.index -32; // 0 .. 17 (= PARAM8_SIZE -1) pindex = XdrvMailbox.index -32; // 0 .. 17 (= PARAM8_SIZE -1)
} }
else { // SetOption50 .. 81 = Settings.flag3
else if (XdrvMailbox.index <= 81) { // SetOption50 .. 81 = Settings.flag3
ptype = 1; ptype = 1;
pindex = XdrvMailbox.index -50; // 0 .. 31 pindex = XdrvMailbox.index -50; // 0 .. 31
} }
else { // SetOption82 .. 113 = Settings.flag4
ptype = 3;
pindex = XdrvMailbox.index -82; // 0 .. 31
}
if (XdrvMailbox.payload >= 0) { if (XdrvMailbox.payload >= 0) {
if (0 == ptype) { // SetOption0 .. 31 if (0 == ptype) { // SetOption0 .. 31
if (XdrvMailbox.payload <= 1) { if (XdrvMailbox.payload <= 1) {
@ -690,6 +696,11 @@ void CmndSetoption(void)
} }
} }
} }
else if (3 == ptype) { // SetOption82 .. 113
if (XdrvMailbox.payload <= 1) {
bitWrite(Settings.flag4.data, pindex, XdrvMailbox.payload);
}
}
else { // SetOption32 .. 49 else { // SetOption32 .. 49
uint32_t param_low = 0; uint32_t param_low = 0;
uint32_t param_high = 255; uint32_t param_high = 255;
@ -719,9 +730,18 @@ void CmndSetoption(void)
} }
} }
if (ptype < 99) { if (ptype < 99) {
char stemp1[TOPSZ]; if (2 == ptype) {
if (2 == ptype) { snprintf_P(stemp1, sizeof(stemp1), PSTR("%d"), Settings.param[pindex]); } ResponseCmndIdxNumber(Settings.param[pindex]);
ResponseCmndIdxChar((2 == ptype) ? stemp1 : (1 == ptype) ? GetStateText(bitRead(Settings.flag3.data, pindex)) : GetStateText(bitRead(Settings.flag.data, pindex))); } else {
uint32_t flag = Settings.flag.data;
if (1 == ptype) {
flag = Settings.flag3.data;
}
else if (3 == ptype) {
flag = Settings.flag4.data;
}
ResponseCmndIdxChar(GetStateText(bitRead(flag, pindex)));
}
} }
} }
} }

View File

@ -250,11 +250,6 @@ enum SettingsParamIndex { P_HOLD_TIME, P_MAX_POWER_RETRY, P_BACKLOG_DELAY, P_MDN
P_ex_ENERGY_TARIFF1, P_ex_ENERGY_TARIFF2, // SetOption47 .. SetOption48 P_ex_ENERGY_TARIFF1, P_ex_ENERGY_TARIFF2, // SetOption47 .. SetOption48
P_MAX_PARAM8 }; // Max is PARAM8_SIZE (18) - SetOption32 until SetOption49 P_MAX_PARAM8 }; // Max is PARAM8_SIZE (18) - SetOption32 until SetOption49
enum SettingsRegister8 { R8_SPARE00, R8_SPARE01, R8_SPARE02, R8_SPARE03,
R8_SPARE04, R8_SPARE05, R8_SPARE06, R8_SPARE07,
R8_SPARE08, R8_SPARE09, R8_SPARE10, R8_SPARE11,
R8_SPARE12, R8_SPARE13, R8_SPARE14, R8_SPARE15 }; // Max size is 16 (Settings.register8[])
enum DomoticzSensors {DZ_TEMP, DZ_TEMP_HUM, DZ_TEMP_HUM_BARO, DZ_POWER_ENERGY, DZ_ILLUMINANCE, DZ_COUNT, DZ_VOLTAGE, DZ_CURRENT, enum DomoticzSensors {DZ_TEMP, DZ_TEMP_HUM, DZ_TEMP_HUM_BARO, DZ_POWER_ENERGY, DZ_ILLUMINANCE, DZ_COUNT, DZ_VOLTAGE, DZ_CURRENT,
DZ_AIRQUALITY, DZ_P1_SMART_METER, DZ_SHUTTER, DZ_MAX_SENSORS}; DZ_AIRQUALITY, DZ_P1_SMART_METER, DZ_SHUTTER, DZ_MAX_SENSORS};

View File

@ -361,6 +361,13 @@ void HueLightStatus1(uint8_t device, String *response)
response->replace("{light_status}", light_status); response->replace("{light_status}", light_status);
} }
// Check whether this device should be reported to Alexa or considered hidden.
// Any device whose friendly name start with "$" is considered hidden
bool HueActive(uint8_t device) {
if (device > MAX_FRIENDLYNAMES) { device = MAX_FRIENDLYNAMES; }
return '$' != Settings.friendlyname[device-1][0];
}
void HueLightStatus2(uint8_t device, String *response) void HueLightStatus2(uint8_t device, String *response)
{ {
*response += FPSTR(HUE_LIGHTS_STATUS_JSON2); *response += FPSTR(HUE_LIGHTS_STATUS_JSON2);
@ -442,20 +449,22 @@ uint32_t findEchoGeneration(void) {
return gen; return gen;
} }
void HueGlobalConfig(String *path) void HueGlobalConfig(String *path) {
{
String response; String response;
uint8_t maxhue = (devices_present > MAX_HUE_DEVICES) ? MAX_HUE_DEVICES : devices_present; uint8_t maxhue = (devices_present > MAX_HUE_DEVICES) ? MAX_HUE_DEVICES : devices_present;
path->remove(0,1); // cut leading / to get <id> path->remove(0,1); // cut leading / to get <id>
response = F("{\"lights\":{\""); response = F("{\"lights\":{");
bool appending = false; // do we need to add a comma to append
for (uint32_t i = 1; i <= maxhue; i++) { for (uint32_t i = 1; i <= maxhue; i++) {
response += EncodeLightId(i); if (HueActive(i)) {
response += F("\":{\"state\":"); if (appending) { response += ","; }
HueLightStatus1(i, &response); response += "\"";
HueLightStatus2(i, &response); response += EncodeLightId(i);
if (i < maxhue) { response += F("\":{\"state\":");
response += ",\""; HueLightStatus1(i, &response);
HueLightStatus2(i, &response);
appending = true;
} }
} }
response += F("},\"groups\":{},\"schedules\":{},\"config\":"); response += F("},\"groups\":{},\"schedules\":{},\"config\":");
@ -493,14 +502,17 @@ void HueLights(String *path)
path->remove(0,path->indexOf("/lights")); // Remove until /lights path->remove(0,path->indexOf("/lights")); // Remove until /lights
if (path->endsWith("/lights")) { // Got /lights if (path->endsWith("/lights")) { // Got /lights
response = "{\""; response = "{";
bool appending = false;
for (uint32_t i = 1; i <= maxhue; i++) { for (uint32_t i = 1; i <= maxhue; i++) {
response += EncodeLightId(i); if (HueActive(i)) {
response += F("\":{\"state\":"); if (appending) { response += ","; }
HueLightStatus1(i, &response); response += "\"";
HueLightStatus2(i, &response); response += EncodeLightId(i);
if (i < maxhue) { response += F("\":{\"state\":");
response += ",\""; HueLightStatus1(i, &response);
HueLightStatus2(i, &response);
appending = true;
} }
} }
#ifdef USE_SCRIPT_HUE #ifdef USE_SCRIPT_HUE

View File

@ -86,7 +86,7 @@ a_setoption = [[
],[ ],[
"Key hold time (ms)", "Key hold time (ms)",
"Sonoff POW Max_Power_Retry", "Sonoff POW Max_Power_Retry",
"(not used) Tuya MCU device id", "Backlog delay (ms)",
"(not used) mDNS delayed start (Sec)", "(not used) mDNS delayed start (Sec)",
"Boot loop retry offset (0 = disable)", "Boot loop retry offset (0 = disable)",
"RGBWW remap", "RGBWW remap",
@ -99,8 +99,8 @@ a_setoption = [[
"(not used) Tuya MCU voltage Id", "(not used) Tuya MCU voltage Id",
"(not used) Tuya MCU current Id", "(not used) Tuya MCU current Id",
"(not used) Tuya MCU power Id", "(not used) Tuya MCU power Id",
"Energy Tariff1 start hour", "(not used) Energy Tariff1 start hour",
"Energy Tariff2 start hour", "(not used) Energy Tariff2 start hour",
"", "",
],[ ],[
"Timers enabled", "Timers enabled",
@ -131,6 +131,15 @@ a_setoption = [[
"","", "","",
"Enable shutter support", "Enable shutter support",
"Invert PCF8574 ports" "Invert PCF8574 ports"
],[
"","","","",
"","","","",
"","","","",
"","","","",
"","","","",
"","","","",
"","","","",
"","","",""
]] ]]
a_features = [[ a_features = [[
@ -246,7 +255,7 @@ def StartDecode():
options.append(str("{0:2d} ({1:3d}) {2}".format(i, split_register[opt_idx], option))) options.append(str("{0:2d} ({1:3d}) {2}".format(i, split_register[opt_idx], option)))
i += 1 i += 1
if r in (0, 2): #registers 1 and 3 hold binary values if r in (0, 2, 3): #registers 1 and 3 hold binary values
for opt_idx, option in enumerate(opt_group): for opt_idx, option in enumerate(opt_group):
i_register = int(register,16) i_register = int(register,16)
state = (i_register >> opt_idx) & 1 state = (i_register >> opt_idx) & 1