mirror of
https://github.com/sle118/squeezelite-esp32.git
synced 2025-12-08 12:37:01 +03:00
initial refactoring
This commit is contained in:
@@ -5,15 +5,15 @@ static EXT_RAM_ATTR network_ethernet_driver_t LAN8720;
|
||||
static EXT_RAM_ATTR esp_netif_config_t cfg_rmii;
|
||||
static EXT_RAM_ATTR esp_netif_inherent_config_t esp_netif_config;
|
||||
|
||||
static esp_err_t start(spi_device_handle_t spi_handle, eth_config_t* ethernet_config) {
|
||||
static esp_err_t start(spi_device_handle_t spi_handle, sys_Eth * ethernet_config) {
|
||||
#ifdef CONFIG_ETH_PHY_INTERFACE_RMII
|
||||
eth_phy_config_t phy_config = ETH_PHY_DEFAULT_CONFIG();
|
||||
eth_mac_config_t mac_config = ETH_MAC_DEFAULT_CONFIG();
|
||||
|
||||
mac_config.smi_mdc_gpio_num = ethernet_config->mdc;
|
||||
mac_config.smi_mdio_gpio_num = ethernet_config->mdio;
|
||||
mac_config.smi_mdc_gpio_num = ethernet_config->ethType.rmii.has_mdc?ethernet_config->ethType.rmii.mdc.pin:-1;
|
||||
mac_config.smi_mdio_gpio_num = ethernet_config->ethType.rmii.has_mdio?ethernet_config->ethType.rmii.mdio.pin:-1;
|
||||
phy_config.phy_addr = 1;
|
||||
phy_config.reset_gpio_num = ethernet_config->rst;
|
||||
phy_config.reset_gpio_num = ethernet_config->common.has_rst?ethernet_config->common.rst.pin:-1;
|
||||
|
||||
esp_eth_mac_t* mac = esp_eth_mac_new_esp32(&mac_config);
|
||||
esp_eth_phy_t* phy = esp_eth_phy_new_lan8720(&phy_config);
|
||||
@@ -24,7 +24,7 @@ static esp_err_t start(spi_device_handle_t spi_handle, eth_config_t* ethernet_co
|
||||
#endif
|
||||
}
|
||||
|
||||
static void init_config(eth_config_t* ethernet_config) {
|
||||
static void init_config(sys_Eth * ethernet_config) {
|
||||
esp_netif_inherent_config_t loc_esp_netif_config = ESP_NETIF_INHERENT_DEFAULT_ETH();
|
||||
memcpy(&esp_netif_config, &loc_esp_netif_config, sizeof(loc_esp_netif_config));
|
||||
|
||||
@@ -35,8 +35,9 @@ static void init_config(eth_config_t* ethernet_config) {
|
||||
LAN8720.start = start;
|
||||
}
|
||||
|
||||
network_ethernet_driver_t* LAN8720_Detect(char* Driver) {
|
||||
if (!strcasestr(Driver, "LAN8720"))
|
||||
network_ethernet_driver_t* LAN8720_Detect(sys_Eth * ethernet_config) {
|
||||
if (ethernet_config->common.model != sys_EthModelEnum_LAN8720 ||
|
||||
ethernet_config->which_ethType != sys_Eth_rmii_tag)
|
||||
return NULL;
|
||||
#ifdef CONFIG_ETH_PHY_INTERFACE_RMII
|
||||
LAN8720.valid = true;
|
||||
@@ -45,6 +46,7 @@ network_ethernet_driver_t* LAN8720_Detect(char* Driver) {
|
||||
#endif
|
||||
LAN8720.rmii = true;
|
||||
LAN8720.spi = false;
|
||||
LAN8720.model = ethernet_config->common.model;
|
||||
LAN8720.init_config = init_config;
|
||||
return &LAN8720;
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user