Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions drivers/ethernet/phy/Kconfig
Original file line number Diff line number Diff line change
Expand Up @@ -42,6 +42,7 @@ config PHY_ADIN2111
default y
depends on DT_HAS_ADI_ADIN2111_PHY_ENABLED || DT_HAS_ADI_ADIN1100_PHY_ENABLED
select MDIO
select GPIO if $(dt_compat_any_has_prop,$(DT_COMPAT_ADI_ADIN1100_PHY),reset-gpios)
help
Enable ADIN2111 PHY driver.

Expand Down
47 changes: 47 additions & 0 deletions drivers/ethernet/phy/phy_adin2111.c
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
#include <stdbool.h>
#include <zephyr/kernel.h>
#include <zephyr/device.h>
#include <zephyr/drivers/gpio.h>
#include <zephyr/drivers/mdio.h>
#include <zephyr/logging/log.h>
#include <zephyr/net/mdio.h>
Expand All @@ -36,6 +37,8 @@ LOG_MODULE_REGISTER(phy_adin, CONFIG_PHY_LOG_LEVEL);

/* Software reset, CLK_25 disabled time*/
#define ADIN1100_PHY_SFT_RESET_MS 25U
#define ADIN1100_PHY_HRD_RESET_MS 70U
#define ADIN1100_PHY_HRD_RESET_PULSE_WIDTH_US 16U

/* PHYs autonegotiation complete timeout */
#define ADIN2111_AN_COMPLETE_AWAIT_TIMEOUT_MS 3000U
Expand Down Expand Up @@ -90,6 +93,9 @@ LOG_MODULE_REGISTER(phy_adin, CONFIG_PHY_LOG_LEVEL);

struct phy_adin2111_config {
const struct device *mdio;
#if DT_ANY_COMPAT_HAS_PROP_STATUS_OKAY(adi_adin1100_phy, reset_gpios)
const struct gpio_dt_spec reset_gpio;
#endif /* DT_ANY_COMPAT_HAS_PROP_STATUS_OKAY(adi_adin1100_phy, reset_gpios) */
uint8_t phy_addr;
bool led0_en;
bool led1_en;
Expand Down Expand Up @@ -352,6 +358,30 @@ static int phy_adin2111_reset(const struct device *dev)
{
int ret;

#if DT_ANY_COMPAT_HAS_PROP_STATUS_OKAY(adi_adin1100_phy, reset_gpios)
const struct phy_adin2111_config *config = dev->config;

if (config->reset_gpio.port) {
/* Assert reset (min. reset pulse width 10us) */
ret = gpio_pin_set_dt(&config->reset_gpio, 1);
if (ret < 0) {
return ret;
}
k_busy_wait(ADIN1100_PHY_HRD_RESET_PULSE_WIDTH_US);

/* Deassert reset */
ret = gpio_pin_set_dt(&config->reset_gpio, 0);
if (ret < 0) {
return ret;
}

k_msleep(ADIN1100_PHY_HRD_RESET_MS);

return 0;
}
#endif /* DT_ANY_COMPAT_HAS_PROP_STATUS_OKAY(adi_adin1100_phy, reset_gpios) */

/* Perform software reset */
ret = phy_adin2111_c22_write(dev, MII_BMCR, MII_BMCR_RESET);
if (ret < 0) {
return ret;
Expand Down Expand Up @@ -439,6 +469,15 @@ static int phy_adin2111_init(const struct device *dev)
data->state.is_up = false;
data->state.speed = LINK_FULL_10BASE;

#if DT_ANY_COMPAT_HAS_PROP_STATUS_OKAY(adi_adin1100_phy, reset_gpios)
if (cfg->reset_gpio.port) {
ret = gpio_pin_configure_dt(&cfg->reset_gpio, GPIO_OUTPUT_INACTIVE);
if (ret < 0) {
return ret;
}
}
#endif /* DT_ANY_COMPAT_HAS_PROP_STATUS_OKAY(adi_adin1100_phy, reset_gpios) */

/*
* For adin1100 and further mii stuff,
* reset may not be performed from the mac layer, doing a clean reset here.
Expand Down Expand Up @@ -617,9 +656,17 @@ static DEVICE_API(ethphy, phy_adin2111_api) = {
.write = phy_adin2111_reg_write,
};

#if DT_ANY_COMPAT_HAS_PROP_STATUS_OKAY(adi_adin1100_phy, reset_gpios)
#define RESET_GPIO(n) \
.reset_gpio = GPIO_DT_SPEC_INST_GET_OR(n, reset_gpios, {0}),
#else
#define RESET_GPIO(n)
#endif /* reset gpio */

#define ADIN2111_PHY_INITIALIZE(n, model) \
static const struct phy_adin2111_config phy_adin##model##_config_##n = { \
.mdio = DEVICE_DT_GET(DT_INST_BUS(n)), \
RESET_GPIO(n) \
.phy_addr = DT_INST_REG_ADDR(n), \
.led0_en = DT_INST_PROP(n, led0_en), \
.led1_en = DT_INST_PROP(n, led1_en), \
Expand Down
5 changes: 5 additions & 0 deletions dts/bindings/ethernet/phy/adi,adin1100-phy.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -7,3 +7,8 @@ description: ADIN1100 PHY
compatible: "adi,adin1100-phy"

include: adi,adin2111-phy.yaml

properties:
reset-gpios:
type: phandle-array
description: GPIO connected to PHY reset signal pin. Reset is active low.