Merge pull request #3404 from andrethomas/development

MCP23008/MCP23017 - Add extended sensor29 reset commands
This commit is contained in:
Theo Arends 2018-08-04 09:28:05 +02:00 committed by GitHub
commit 06653fc71f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 20 additions and 13 deletions

View File

@ -196,25 +196,32 @@ void MCP230xx_Show(boolean json)
} }
} }
void MCP230xx_Reset(uint8_t pinmode) {
uint8_t pullup = 0;
if ((pinmode > 1) && (pinmode < 5)) pullup=1;
for (uint8_t pinx=0;pinx<16;pinx++) {
Settings.mcp230xx_config[pinx].pinmode=pinmode;
Settings.mcp230xx_config[pinx].pullup=pullup;
Settings.mcp230xx_config[pinx].b4=0;
Settings.mcp230xx_config[pinx].b5=0;
Settings.mcp230xx_config[pinx].b6=0;
Settings.mcp230xx_config[pinx].b7=0;
}
MCP230xx_ApplySettings();
snprintf_P(mqtt_data, sizeof(mqtt_data), MCP230XX_SENSOR_RESPONSE,99,pinmode,pullup,99);
}
bool MCP230xx_Command(void) { bool MCP230xx_Command(void) {
boolean serviced = true; boolean serviced = true;
uint8_t _a, _b = 0; uint8_t _a, _b = 0;
uint8_t pin, pinmode, pullup = 0; uint8_t pin, pinmode, pullup = 0;
String data = XdrvMailbox.data; String data = XdrvMailbox.data;
data.toUpperCase(); data.toUpperCase();
if (data == "RESET") { // we need to reset all pins to input if (data == "RESET") { MCP230xx_Reset(1); return serviced; }
for (uint8_t pinx=0;pinx<16;pinx++) { if (data == "RESET1") { MCP230xx_Reset(1); return serviced; }
Settings.mcp230xx_config[pinx].pinmode=1; if (data == "RESET2") { MCP230xx_Reset(2); return serviced; }
Settings.mcp230xx_config[pinx].pullup=0; if (data == "RESET3") { MCP230xx_Reset(3); return serviced; }
Settings.mcp230xx_config[pinx].b4=0; if (data == "RESET4") { MCP230xx_Reset(4); return serviced; }
Settings.mcp230xx_config[pinx].b5=0;
Settings.mcp230xx_config[pinx].b6=0;
Settings.mcp230xx_config[pinx].b7=0;
}
MCP230xx_ApplySettings();
snprintf_P(mqtt_data, sizeof(mqtt_data), MCP230XX_SENSOR_RESPONSE,99,99,99,99);
return serviced;
}
_a = data.indexOf(","); _a = data.indexOf(",");
pin = data.substring(0, _a).toInt(); pin = data.substring(0, _a).toInt();
if (pin < mcp230xx_pincount) { if (pin < mcp230xx_pincount) {