Remove old and modified libs, switch to ESPAsyncWebserver, add support for ESP32-H2 and multiple Ethernet modules (#455)
* Asyncwebserver * Squashed commit of the following: commit 575ef02f593918ec6654c87407a4d11fc17071b8 Author: technyon <j.o.schuemann@gmx.de> Date: Mon Aug 12 17:56:11 2024 +0200 merge master commit 35e5adf4ecd80f9829e8801181f35dd2c1d94759 Merge: a2cc7be221adca01Author: technyon <j.o.schuemann@gmx.de> Date: Mon Aug 12 17:41:04 2024 +0200 Merge branch 'master' of github.com:technyon/nuki_hub into DM9051 commit a2cc7be2954cbd8767ab8186296c0b14134d1d0b Author: technyon <j.o.schuemann@gmx.de> Date: Mon Aug 12 10:51:50 2024 +0200 update nuki ble commit 20c809f3dca28b29b219d1ff3a183f1981316de5 Author: technyon <j.o.schuemann@gmx.de> Date: Mon Aug 12 10:44:46 2024 +0200 backup commit dd41c218efb5270f5efeb734e64dff695920db16 Merge: 153000b5e84b944aAuthor: technyon <j.o.schuemann@gmx.de> Date: Mon Aug 12 10:40:03 2024 +0200 Merge branch 'master' of github.com:technyon/nuki_hub into DM9051 commit 153000b5b1af7df1fbeb5263df94eb26f689cc0a Author: technyon <j.o.schuemann@gmx.de> Date: Mon Aug 12 10:23:07 2024 +0200 fix linker error commit a93bbfbfc4301e46ff3696a763dd13c6c89efefb Author: technyon <j.o.schuemann@gmx.de> Date: Sun Aug 11 11:27:07 2024 +0200 backup commit f611c75ce8c35f829bcad6cf7e86188f4b3ec331 Merge: f1964917063fbab6Author: technyon <j.o.schuemann@gmx.de> Date: Sun Aug 11 11:24:47 2024 +0200 merge master commit f1964917b4dade3920f1ecdb699c58630199e6da Author: technyon <j.o.schuemann@gmx.de> Date: Sat Aug 10 15:17:45 2024 +0200 update platformio.ini commit f448e5e8a7e93be38e09e2ab0b622199a3721af6 Author: technyon <j.o.schuemann@gmx.de> Date: Sat Aug 10 11:28:09 2024 +0200 add SPIClass instance for DM9051 commit 1f190e9aa08033535a2eb442a92e6e20409bbda1 Author: technyon <j.o.schuemann@gmx.de> Date: Sat Aug 10 11:22:26 2024 +0200 add definitions and constructor for DM9051 commit 726b3602ae91594ee1210ad5b6714f75cc5e42a7 Merge: 50a2eb134af90cbcAuthor: technyon <j.o.schuemann@gmx.de> Date: Sat Aug 10 10:19:34 2024 +0200 merge master commit 50a2eb136d75d90921f1c6974f18bc107bddc123 Author: technyon <j.o.schuemann@gmx.de> Date: Fri Aug 9 11:52:09 2024 +0200 add comment commit 9437e485cae169efdf8e5a7bf188a1c7e792d1e5 Author: technyon <j.o.schuemann@gmx.de> Date: Sun Aug 4 08:29:21 2024 +0200 move LAN8720 definitions to seperate file * Remove Core 2 Ethernet library * Custom Ethernet * GPIO and Preferences * H2
This commit is contained in:
148
src/Gpio.cpp
148
src/Gpio.cpp
@@ -6,6 +6,9 @@
|
||||
#include "PreferencesKeys.h"
|
||||
#include "RestartReason.h"
|
||||
#include "Gpio2Go.h"
|
||||
#include "networkDevices/LAN8720Definitions.h"
|
||||
#include "networkDevices/DM9051Definitions.h"
|
||||
#include "networkDevices/W5500Definitions.h"
|
||||
|
||||
Gpio* Gpio::_inst = nullptr;
|
||||
int64_t Gpio::_debounceTs = 0;
|
||||
@@ -97,6 +100,8 @@ void Gpio::init()
|
||||
case PinRole::GeneralInputPullUp:
|
||||
Gpio2Go::configurePin(entry.pin, PinMode::InputPullup, InterruptMode::Change, 300);
|
||||
break;
|
||||
case PinRole::Ethernet:
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
@@ -112,6 +117,7 @@ const std::vector<uint8_t>& Gpio::availablePins() const
|
||||
|
||||
void Gpio::loadPinConfiguration()
|
||||
{
|
||||
Log->println("Load GPIO configuration");
|
||||
size_t storedLength = _preferences->getBytesLength(preference_gpio_configuration);
|
||||
if(storedLength == 0)
|
||||
{
|
||||
@@ -133,32 +139,162 @@ void Gpio::loadPinConfiguration()
|
||||
_pinConfiguration.clear();
|
||||
_pinConfiguration.reserve(numEntries);
|
||||
|
||||
std::vector<int> disabledPins = getDisabledPins();
|
||||
|
||||
for(int i=0; i < numEntries; i++)
|
||||
{
|
||||
PinEntry entry;
|
||||
entry.pin = serialized[i * 2];
|
||||
entry.role = (PinRole) serialized[(i * 2 + 1)];
|
||||
if(entry.role != PinRole::Disabled)
|
||||
Log->print(F("Pin "));
|
||||
Log->println(entry.pin);
|
||||
|
||||
if(std::find(disabledPins.begin(), disabledPins.end(), entry.pin) == disabledPins.end())
|
||||
{
|
||||
_pinConfiguration.push_back(entry);
|
||||
if(entry.role == PinRole::Ethernet) entry.role = PinRole::Disabled;
|
||||
entry.role = (PinRole) serialized[(i * 2 + 1)];
|
||||
Log->println("Not found in Ethernet disabled pins");
|
||||
Log->print(F("Role: "));
|
||||
Log->println(getRoleDescription(entry.role));
|
||||
}
|
||||
else
|
||||
{
|
||||
entry.role = PinRole::Ethernet;
|
||||
Log->println("Found in Ethernet disabled pins");
|
||||
Log->print(F("Role: "));
|
||||
Log->println(getRoleDescription(entry.role));
|
||||
}
|
||||
if(entry.role != PinRole::Disabled) _pinConfiguration.push_back(entry);
|
||||
}
|
||||
}
|
||||
|
||||
const std::vector<int> Gpio::getDisabledPins() const
|
||||
{
|
||||
std::vector<int> disabledPins;
|
||||
|
||||
switch(_preferences->getInt(preference_network_hardware, 0))
|
||||
{
|
||||
case 2:
|
||||
disabledPins.push_back(ETH_PHY_CS_GENERIC_W5500);
|
||||
disabledPins.push_back(ETH_PHY_IRQ_GENERIC_W5500);
|
||||
disabledPins.push_back(ETH_PHY_RST_GENERIC_W5500);
|
||||
disabledPins.push_back(ETH_PHY_SPI_SCK_GENERIC_W5500);
|
||||
disabledPins.push_back(ETH_PHY_SPI_MISO_GENERIC_W5500);
|
||||
disabledPins.push_back(ETH_PHY_SPI_MOSI_GENERIC_W5500);
|
||||
break;
|
||||
case 3:
|
||||
disabledPins.push_back(ETH_PHY_CS_M5_W5500);
|
||||
disabledPins.push_back(ETH_PHY_IRQ_M5_W5500);
|
||||
disabledPins.push_back(ETH_PHY_RST_M5_W5500);
|
||||
disabledPins.push_back(ETH_PHY_SPI_SCK_M5_W5500);
|
||||
disabledPins.push_back(ETH_PHY_SPI_MISO_M5_W5500);
|
||||
disabledPins.push_back(ETH_PHY_SPI_MOSI_M5_W5500);
|
||||
break;
|
||||
case 10:
|
||||
disabledPins.push_back(ETH_PHY_CS_M5_W5500_S3);
|
||||
disabledPins.push_back(ETH_PHY_IRQ_M5_W5500);
|
||||
disabledPins.push_back(ETH_PHY_RST_M5_W5500);
|
||||
disabledPins.push_back(ETH_PHY_SPI_SCK_M5_W5500_S3);
|
||||
disabledPins.push_back(ETH_PHY_SPI_MISO_M5_W5500_S3);
|
||||
disabledPins.push_back(ETH_PHY_SPI_MOSI_M5_W5500_S3);
|
||||
break;
|
||||
case 9:
|
||||
disabledPins.push_back(ETH_PHY_CS_ETH01EVO);
|
||||
disabledPins.push_back(ETH_PHY_IRQ_ETH01EVO);
|
||||
disabledPins.push_back(ETH_PHY_RST_ETH01EVO);
|
||||
disabledPins.push_back(ETH_PHY_SPI_SCK_ETH01EVO);
|
||||
disabledPins.push_back(ETH_PHY_SPI_MISO_ETH01EVO);
|
||||
disabledPins.push_back(ETH_PHY_SPI_MOSI_ETH01EVO);
|
||||
break;
|
||||
case 6:
|
||||
disabledPins.push_back(ETH_PHY_CS_M5_W5500);
|
||||
disabledPins.push_back(ETH_PHY_IRQ_M5_W5500);
|
||||
disabledPins.push_back(ETH_PHY_RST_M5_W5500);
|
||||
disabledPins.push_back(ETH_PHY_SPI_SCK_M5_W5500);
|
||||
disabledPins.push_back(ETH_PHY_SPI_MISO_M5_W5500);
|
||||
disabledPins.push_back(ETH_PHY_SPI_MOSI_M5_W5500);
|
||||
break;
|
||||
case 11:
|
||||
disabledPins.push_back(_preferences->getInt(preference_network_custom_cs, -1));
|
||||
disabledPins.push_back(_preferences->getInt(preference_network_custom_irq, -1));
|
||||
disabledPins.push_back(_preferences->getInt(preference_network_custom_rst, -1));
|
||||
disabledPins.push_back(_preferences->getInt(preference_network_custom_sck, -1));
|
||||
disabledPins.push_back(_preferences->getInt(preference_network_custom_miso, -1));
|
||||
disabledPins.push_back(_preferences->getInt(preference_network_custom_mosi, -1));
|
||||
disabledPins.push_back(_preferences->getInt(preference_network_custom_pwr, -1));
|
||||
disabledPins.push_back(_preferences->getInt(preference_network_custom_mdc, -1));
|
||||
disabledPins.push_back(_preferences->getInt(preference_network_custom_mdio, -1));
|
||||
break;
|
||||
#if defined(CONFIG_IDF_TARGET_ESP32)
|
||||
case 4:
|
||||
disabledPins.push_back(12);
|
||||
disabledPins.push_back(ETH_RESET_PIN_LAN8720);
|
||||
disabledPins.push_back(ETH_PHY_MDC_LAN8720);
|
||||
disabledPins.push_back(ETH_PHY_MDIO_LAN8720);
|
||||
break;
|
||||
case 5:
|
||||
disabledPins.push_back(16);
|
||||
disabledPins.push_back(ETH_RESET_PIN_LAN8720);
|
||||
disabledPins.push_back(ETH_PHY_MDC_LAN8720);
|
||||
disabledPins.push_back(ETH_PHY_MDIO_LAN8720);
|
||||
break;
|
||||
case 8:
|
||||
disabledPins.push_back(5);
|
||||
disabledPins.push_back(ETH_RESET_PIN_LAN8720);
|
||||
disabledPins.push_back(ETH_PHY_MDC_LAN8720);
|
||||
disabledPins.push_back(ETH_PHY_MDIO_LAN8720);
|
||||
break;
|
||||
case 7:
|
||||
disabledPins.push_back(-1);
|
||||
disabledPins.push_back(ETH_RESET_PIN_LAN8720);
|
||||
disabledPins.push_back(ETH_PHY_MDC_LAN8720);
|
||||
disabledPins.push_back(ETH_PHY_MDIO_LAN8720);
|
||||
break;
|
||||
#endif
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
Log->print(F("GPIO Ethernet disabled pins:"));
|
||||
for_each_n(disabledPins.begin(), disabledPins.size(),
|
||||
[](int x) { Log->print(" "); Log->print(x); });
|
||||
Log->println();
|
||||
return disabledPins;
|
||||
}
|
||||
|
||||
void Gpio::savePinConfiguration(const std::vector<PinEntry> &pinConfiguration)
|
||||
{
|
||||
Log->println("Save GPIO configuration");
|
||||
int8_t serialized[std::max(pinConfiguration.size() * 2, _preferences->getBytesLength(preference_gpio_configuration))];
|
||||
memset(serialized, 0, sizeof(serialized));
|
||||
|
||||
std::vector<int> disabledPins = getDisabledPins();
|
||||
|
||||
int len = pinConfiguration.size();
|
||||
for(int i=0; i < len; i++)
|
||||
{
|
||||
const auto& entry = pinConfiguration[i];
|
||||
Log->print(F("Pin "));
|
||||
Log->println(entry.pin);
|
||||
|
||||
if(entry.role != PinRole::Disabled)
|
||||
if(std::find(disabledPins.begin(), disabledPins.end(), entry.pin) != disabledPins.end())
|
||||
{
|
||||
serialized[i * 2] = entry.pin;
|
||||
serialized[i * 2 + 1] = (int8_t) entry.role;
|
||||
serialized[i * 2 + 1] = (int8_t)PinRole::Ethernet;
|
||||
Log->println("Found in Ethernet disabled pins");
|
||||
Log->print(F("Role: "));
|
||||
Log->println(getRoleDescription(PinRole::Ethernet));
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
if(entry.role != PinRole::Disabled && entry.role != PinRole::Ethernet)
|
||||
{
|
||||
serialized[i * 2] = entry.pin;
|
||||
serialized[i * 2 + 1] = (int8_t) entry.role;
|
||||
Log->println("Not found in Ethernet disabled pins");
|
||||
Log->print(F("Role: "));
|
||||
Log->println(getRoleDescription(entry.role));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -228,6 +364,8 @@ String Gpio::getRoleDescription(PinRole role) const
|
||||
return "General input (Pull-down)";
|
||||
case PinRole::GeneralInputPullUp:
|
||||
return "General input (Pull-up)";
|
||||
case PinRole::Ethernet:
|
||||
return "Ethernet";
|
||||
default:
|
||||
return "Unknown";
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user