Exposed OUT Pin as Relays

This commit is contained in:
stefanbode 2020-08-03 18:02:27 +02:00 committed by GitHub
parent 1d990ad091
commit b966a5a933
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 52 additions and 21 deletions

View File

@ -45,6 +45,8 @@ uint8_t MCP230xx_GPIO = 0x09;
uint8_t mcp230xx_type = 0; uint8_t mcp230xx_type = 0;
uint8_t mcp230xx_pincount = 0; uint8_t mcp230xx_pincount = 0;
uint8_t mcp230xx_oldoutpincount = 0;
uint8_t mcp230xx_outpinmapping[16];
uint8_t mcp230xx_int_en = 0; uint8_t mcp230xx_int_en = 0;
uint8_t mcp230xx_int_prio_counter = 0; uint8_t mcp230xx_int_prio_counter = 0;
uint8_t mcp230xx_int_counter_en = 0; uint8_t mcp230xx_int_counter_en = 0;
@ -192,9 +194,16 @@ void MCP230xx_ApplySettings(void)
I2cWrite8(USE_MCP230xx_ADDR, MCP230xx_GPIO+mcp230xx_port, reg_portpins); I2cWrite8(USE_MCP230xx_ADDR, MCP230xx_GPIO+mcp230xx_port, reg_portpins);
#endif // USE_MCP230xx_OUTPUT #endif // USE_MCP230xx_OUTPUT
} }
devices_present -= mcp230xx_oldoutpincount;
mcp230xx_oldoutpincount = 0;
for (uint32_t idx=0;idx<mcp230xx_pincount;idx++) { for (uint32_t idx=0;idx<mcp230xx_pincount;idx++) {
if (Settings.mcp230xx_config[idx].pinmode >= 5) {
mcp230xx_outpinmapping[mcp230xx_oldoutpincount] = idx;
mcp230xx_oldoutpincount++;
}
int_millis[idx]=millis(); int_millis[idx]=millis();
} }
devices_present += mcp230xx_oldoutpincount;
mcp230xx_int_en = int_en; mcp230xx_int_en = int_en;
MCP230xx_CheckForIntCounter(); // update register on whether or not we should be counting interrupts MCP230xx_CheckForIntCounter(); // update register on whether or not we should be counting interrupts
MCP230xx_CheckForIntRetainer(); // update register on whether or not we should be retaining interrupt events for teleperiod MCP230xx_CheckForIntRetainer(); // update register on whether or not we should be retaining interrupt events for teleperiod
@ -356,7 +365,6 @@ void MCP230xx_Show(bool json)
ResponseAppend_P(PSTR("\"END\":1}")); ResponseAppend_P(PSTR("\"END\":1}"));
} }
#endif // USE_MCP230xx_OUTPUT #endif // USE_MCP230xx_OUTPUT
ResponseJsonEnd(); ResponseJsonEnd();
} }
} }
@ -794,6 +802,26 @@ void MCP230xx_Interrupt_Retain_Report(void) {
MqttPublishTeleSensor(); MqttPublishTeleSensor();
} }
void MCP230xx_SwitchRelay() {
//AddLog_P2(LOG_LEVEL_DEBUG, PSTR("MCP: devices_present %d"), devices_present);
for (uint32_t i = devices_present - mcp230xx_oldoutpincount; i < devices_present; i++) {
uint8_t pin = mcp230xx_outpinmapping[i - (devices_present - mcp230xx_oldoutpincount)];
uint8_t pincmd = Settings.mcp230xx_config[pin].pinmode - 5;
uint8_t relay_state = bitRead(XdrvMailbox.index, i);
AddLog_P2(LOG_LEVEL_DEBUG, PSTR("MCP: relay %d pin_no %d state %d"), i,pin, relay_state);
switch (relay_state) {
case 1:
MCP230xx_SetOutPin(pin,abs(pincmd-1));
break;
case 0:
MCP230xx_SetOutPin(pin,pincmd);
break;
}
}
}
/*********************************************************************************************\ /*********************************************************************************************\
Interface Interface
\*********************************************************************************************/ \*********************************************************************************************/
@ -804,7 +832,7 @@ bool Xsns29(uint8_t function)
bool result = false; bool result = false;
if (FUNC_INIT == function) { if (FUNC_PRE_INIT == function) {
MCP230xx_Detect(); MCP230xx_Detect();
} }
else if (mcp230xx_type) { else if (mcp230xx_type) {
@ -836,6 +864,9 @@ bool Xsns29(uint8_t function)
*/ */
} }
break; break;
case FUNC_SET_POWER:
MCP230xx_SwitchRelay();
break;
case FUNC_JSON_APPEND: case FUNC_JSON_APPEND:
MCP230xx_Show(1); MCP230xx_Show(1);
break; break;