fix W5500 reconnect

This commit is contained in:
technyon
2022-04-30 19:59:07 +02:00
parent d38ed9b983
commit 490bff20c5
8 changed files with 84 additions and 13 deletions

View File

@@ -121,6 +121,8 @@ void Network::initialize()
bool Network::reconnect() bool Network::reconnect()
{ {
_mqttConnected = false;
while (!_device->mqttClient()->connected() && millis() > _nextReconnect) while (!_device->mqttClient()->connected() && millis() > _nextReconnect)
{ {
Serial.println(F("Attempting MQTT connection")); Serial.println(F("Attempting MQTT connection"));
@@ -137,11 +139,11 @@ bool Network::reconnect()
success = _device->mqttClient()->connect(_preferences->getString(preference_hostname).c_str(), _mqttUser, _mqttPass); success = _device->mqttClient()->connect(_preferences->getString(preference_hostname).c_str(), _mqttUser, _mqttPass);
} }
if (success)
if (success) { {
Serial.println(F("MQTT connected")); Serial.println(F("MQTT connected"));
_mqttConnected = true; _mqttConnected = true;
delay(200); delay(100);
subscribe(mqtt_topic_lock_action); subscribe(mqtt_topic_lock_action);
for(auto topic : _configTopics) for(auto topic : _configTopics)
@@ -162,10 +164,23 @@ bool Network::reconnect()
void Network::update() void Network::update()
{ {
long ts = millis();
if((ts - _lastMaintain) > 1000)
{
_device->update();
if(!_device->isConnected()) if(!_device->isConnected())
{ {
Serial.println(F("Network not connected")); Serial.println(F("Network not connected. Trying reconnect."));
vTaskDelay( 1000 / portTICK_PERIOD_MS); bool success = _device->reconnect();
Serial.println(success ? F("Reconnect successful") : F("Reconnect failed"));
}
}
if(!_device->isConnected())
{
return;
} }
if(!_device->mqttClient()->connected()) if(!_device->mqttClient()->connected())

View File

@@ -74,6 +74,8 @@ private:
bool _firstTunerStatePublish = true; bool _firstTunerStatePublish = true;
long _lastMaintain = 0;
void (*_lockActionReceivedCallback)(const char* value) = nullptr; void (*_lockActionReceivedCallback)(const char* value) = nullptr;
void (*_configUpdateReceivedCallback)(const char* path, const char* value) = nullptr; void (*_configUpdateReceivedCallback)(const char* path, const char* value) = nullptr;
}; };

View File

@@ -1,3 +1,3 @@
#pragma once #pragma once
#define nuki_hub_version "1.11" #define nuki_hub_version "1.12"

View File

@@ -12,8 +12,11 @@ public:
virtual PubSubClient* mqttClient() = 0; virtual PubSubClient* mqttClient() = 0;
virtual void initialize() = 0; virtual void initialize() = 0;
virtual bool reconnect() = 0;
virtual void reconfigure() = 0; virtual void reconfigure() = 0;
virtual void update() = 0;
virtual bool isConnected() = 0; virtual bool isConnected() = 0;
protected: protected:

View File

@@ -35,6 +35,16 @@ void W5500Device::initialize()
_ethClient = new EthernetClient(); _ethClient = new EthernetClient();
_mqttClient = new PubSubClient(*_ethClient); _mqttClient = new PubSubClient(*_ethClient);
reconnect();
_fromTask = true;
}
bool W5500Device::reconnect()
{
_hasDHCPAddress = false;
// start the Ethernet connection: // start the Ethernet connection:
Serial.println(F("Initialize Ethernet with DHCP:")); Serial.println(F("Initialize Ethernet with DHCP:"));
@@ -54,8 +64,6 @@ void W5500Device::initialize()
if (Ethernet.hardwareStatus() == EthernetNoHardware) if (Ethernet.hardwareStatus() == EthernetNoHardware)
{ {
Serial.println(F("Ethernet module not found")); Serial.println(F("Ethernet module not found"));
delay(10000);
ESP.restart();
} }
if (Ethernet.linkStatus() == LinkOFF) if (Ethernet.linkStatus() == LinkOFF)
{ {
@@ -72,17 +80,21 @@ void W5500Device::initialize()
Ethernet.begin(_mac, ip); Ethernet.begin(_mac, ip);
Ethernet.setSubnetMask(subnet); Ethernet.setSubnetMask(subnet);
delay(2000); nwDelay(1000);
} }
else else
{ {
_hasDHCPAddress = true;
dhcpRetryCnt = 1000; dhcpRetryCnt = 1000;
Serial.print(F(" DHCP assigned IP ")); Serial.print(F(" DHCP assigned IP "));
Serial.println(Ethernet.localIP()); Serial.println(Ethernet.localIP());
} }
} }
return _hasDHCPAddress;
} }
void W5500Device::reconfigure() void W5500Device::reconfigure()
{ {
Serial.println(F("Reconfigure W5500 not implemented.")); Serial.println(F("Reconfigure W5500 not implemented."));
@@ -93,11 +105,11 @@ void W5500Device::resetDevice()
Serial.println(F("Resetting network hardware.")); Serial.println(F("Resetting network hardware."));
pinMode(ETHERNET_RESET_PIN, OUTPUT); pinMode(ETHERNET_RESET_PIN, OUTPUT);
digitalWrite(ETHERNET_RESET_PIN, HIGH); digitalWrite(ETHERNET_RESET_PIN, HIGH);
delay(250); nwDelay(250);
digitalWrite(ETHERNET_RESET_PIN, LOW); digitalWrite(ETHERNET_RESET_PIN, LOW);
delay(50); nwDelay(50);
digitalWrite(ETHERNET_RESET_PIN, HIGH); digitalWrite(ETHERNET_RESET_PIN, HIGH);
delay(1500); nwDelay(1500);
} }
PubSubClient *W5500Device::mqttClient() PubSubClient *W5500Device::mqttClient()
@@ -107,7 +119,7 @@ PubSubClient *W5500Device::mqttClient()
bool W5500Device::isConnected() bool W5500Device::isConnected()
{ {
return _ethClient->connected(); return Ethernet.linkStatus() == EthernetLinkStatus::LinkON && _maintainResult == 0 && _hasDHCPAddress;
} }
void W5500Device::initializeMacAddress(byte *mac) void W5500Device::initializeMacAddress(byte *mac)
@@ -136,3 +148,20 @@ void W5500Device::initializeMacAddress(byte *mac)
_preferences->putBool(preference_has_mac_saved, true); _preferences->putBool(preference_has_mac_saved, true);
} }
} }
void W5500Device::nwDelay(unsigned long ms)
{
if(_fromTask)
{
vTaskDelay( ms / portTICK_PERIOD_MS);
}
else
{
delay(ms);
}
}
void W5500Device::update()
{
_maintainResult = Ethernet.maintain();
}

View File

@@ -11,8 +11,11 @@ public:
~W5500Device(); ~W5500Device();
virtual void initialize(); virtual void initialize();
virtual bool reconnect();
virtual void reconfigure(); virtual void reconfigure();
virtual void update();
virtual bool isConnected(); virtual bool isConnected();
virtual PubSubClient *mqttClient(); virtual PubSubClient *mqttClient();
@@ -20,10 +23,16 @@ public:
private: private:
void resetDevice(); void resetDevice();
void initializeMacAddress(byte* mac); void initializeMacAddress(byte* mac);
void nwDelay(unsigned long ms);
bool _fromTask = false;
EthernetClient* _ethClient = nullptr; EthernetClient* _ethClient = nullptr;
PubSubClient* _mqttClient = nullptr; PubSubClient* _mqttClient = nullptr;
Preferences* _preferences = nullptr; Preferences* _preferences = nullptr;
int _maintainResult = 0;
bool _hasDHCPAddress = false;
byte _mac[6]; byte _mac[6];
}; };

View File

@@ -60,3 +60,13 @@ bool WifiDevice::isConnected()
{ {
return WiFi.isConnected(); return WiFi.isConnected();
} }
bool WifiDevice::reconnect()
{
return isConnected();
}
void WifiDevice::update()
{
}

View File

@@ -11,6 +11,9 @@ public:
virtual void initialize(); virtual void initialize();
virtual void reconfigure(); virtual void reconfigure();
virtual bool reconnect();
virtual void update();
virtual bool isConnected(); virtual bool isConnected();