diff mbox series

net: phy: Fix rgmii-id phy reset timeout issue

Message ID fe35fddb9faa5af577ffdfabaec6879c935a30f8.1648562755.git.michal.simek@xilinx.com
State Accepted
Commit 9b529a972d15af7dabfa2fffa69f0e2ed69b6220
Delegated to: Michal Simek
Headers show
Series net: phy: Fix rgmii-id phy reset timeout issue | expand

Commit Message

Michal Simek March 29, 2022, 2:05 p.m. UTC
From: T Karthik Reddy <t.karthik.reddy@xilinx.com>

While creating a phy device using phy_device_create(), we need to
provide a valid phyaddr instead of 0 causing phy address being
registered as 0 with mdio bus and shows mdio phy list as below

ZynqMP>  mdio list
eth0:
0 - TI DP83867 <--> ethernet@ff0b0000
eth1:
0 - TI DP83867 <--> ethernet@ff0c0000

Also PHY soft reset is being requested on 0 instead of valid
address causing "PHY reset timed out" error.

So add phyaddr argument to phy_connect_phy_id() and to its prototype
to create phy device with valid phyaddress.

Fixes: a744a284e354 ("net: phy: Add support for ethernet-phy-id with gpio reset")
Signed-off-by: T Karthik Reddy <t.karthik.reddy@xilinx.com>
Signed-off-by: Michal Simek <michal.simek@xilinx.com>
---

 drivers/net/phy/ethernet_id.c | 4 ++--
 drivers/net/phy/phy.c         | 2 +-
 include/phy.h                 | 2 +-
 3 files changed, 4 insertions(+), 4 deletions(-)

Comments

Bin Meng March 29, 2022, 4:18 p.m. UTC | #1
On Tue, Mar 29, 2022 at 10:06 PM Michal Simek <michal.simek@xilinx.com> wrote:
>
> From: T Karthik Reddy <t.karthik.reddy@xilinx.com>
>
> While creating a phy device using phy_device_create(), we need to
> provide a valid phyaddr instead of 0 causing phy address being
> registered as 0 with mdio bus and shows mdio phy list as below
>
> ZynqMP>  mdio list
> eth0:
> 0 - TI DP83867 <--> ethernet@ff0b0000
> eth1:
> 0 - TI DP83867 <--> ethernet@ff0c0000
>
> Also PHY soft reset is being requested on 0 instead of valid
> address causing "PHY reset timed out" error.
>
> So add phyaddr argument to phy_connect_phy_id() and to its prototype
> to create phy device with valid phyaddress.
>
> Fixes: a744a284e354 ("net: phy: Add support for ethernet-phy-id with gpio reset")
> Signed-off-by: T Karthik Reddy <t.karthik.reddy@xilinx.com>
> Signed-off-by: Michal Simek <michal.simek@xilinx.com>
> ---
>
>  drivers/net/phy/ethernet_id.c | 4 ++--
>  drivers/net/phy/phy.c         | 2 +-
>  include/phy.h                 | 2 +-
>  3 files changed, 4 insertions(+), 4 deletions(-)
>

Reviewed-by: Bin Meng <bmeng.cn@gmail.com>
Michal Simek April 5, 2022, 1:11 p.m. UTC | #2
Ășt 29. 3. 2022 v 16:06 odesĂ­latel Michal Simek <michal.simek@xilinx.com> napsal:
>
> From: T Karthik Reddy <t.karthik.reddy@xilinx.com>
>
> While creating a phy device using phy_device_create(), we need to
> provide a valid phyaddr instead of 0 causing phy address being
> registered as 0 with mdio bus and shows mdio phy list as below
>
> ZynqMP>  mdio list
> eth0:
> 0 - TI DP83867 <--> ethernet@ff0b0000
> eth1:
> 0 - TI DP83867 <--> ethernet@ff0c0000
>
> Also PHY soft reset is being requested on 0 instead of valid
> address causing "PHY reset timed out" error.
>
> So add phyaddr argument to phy_connect_phy_id() and to its prototype
> to create phy device with valid phyaddress.
>
> Fixes: a744a284e354 ("net: phy: Add support for ethernet-phy-id with gpio reset")
> Signed-off-by: T Karthik Reddy <t.karthik.reddy@xilinx.com>
> Signed-off-by: Michal Simek <michal.simek@xilinx.com>
> ---
>
>  drivers/net/phy/ethernet_id.c | 4 ++--
>  drivers/net/phy/phy.c         | 2 +-
>  include/phy.h                 | 2 +-
>  3 files changed, 4 insertions(+), 4 deletions(-)
>
> diff --git a/drivers/net/phy/ethernet_id.c b/drivers/net/phy/ethernet_id.c
> index 5617ac3ad62f..44abc5bfb301 100644
> --- a/drivers/net/phy/ethernet_id.c
> +++ b/drivers/net/phy/ethernet_id.c
> @@ -12,7 +12,7 @@
>  #include <asm/gpio.h>
>
>  struct phy_device *phy_connect_phy_id(struct mii_dev *bus, struct udevice *dev,
> -                                     phy_interface_t interface)
> +                                     int phyaddr, phy_interface_t interface)
>  {
>         struct phy_device *phydev;
>         struct ofnode_phandle_args phandle_args;
> @@ -61,7 +61,7 @@ struct phy_device *phy_connect_phy_id(struct mii_dev *bus, struct udevice *dev,
>         }
>
>         id =  vendor << 16 | device;
> -       phydev = phy_device_create(bus, 0, id, false, interface);
> +       phydev = phy_device_create(bus, phyaddr, id, false, interface);
>         if (phydev)
>                 phydev->node = node;
>
> diff --git a/drivers/net/phy/phy.c b/drivers/net/phy/phy.c
> index 08a37a344e65..690ed38ba622 100644
> --- a/drivers/net/phy/phy.c
> +++ b/drivers/net/phy/phy.c
> @@ -1049,7 +1049,7 @@ struct phy_device *phy_connect(struct mii_dev *bus, int addr,
>
>  #ifdef CONFIG_PHY_ETHERNET_ID
>         if (!phydev)
> -               phydev = phy_connect_phy_id(bus, dev, interface);
> +               phydev = phy_connect_phy_id(bus, dev, addr, interface);
>  #endif
>
>  #ifdef CONFIG_PHY_XILINX_GMII2RGMII
> diff --git a/include/phy.h b/include/phy.h
> index 9ea4bd42db4d..5e3da4b01b6c 100644
> --- a/include/phy.h
> +++ b/include/phy.h
> @@ -479,7 +479,7 @@ struct phy_device *phy_device_create(struct mii_dev *bus, int addr,
>   *                     or NULL otherwise
>   */
>  struct phy_device *phy_connect_phy_id(struct mii_dev *bus, struct udevice *dev,
> -                                     phy_interface_t interface);
> +                                     int phyaddr, phy_interface_t interface);
>
>  static inline ofnode phy_get_ofnode(struct phy_device *phydev)
>  {
> --
> 2.35.1
>

Applied.
M
diff mbox series

Patch

diff --git a/drivers/net/phy/ethernet_id.c b/drivers/net/phy/ethernet_id.c
index 5617ac3ad62f..44abc5bfb301 100644
--- a/drivers/net/phy/ethernet_id.c
+++ b/drivers/net/phy/ethernet_id.c
@@ -12,7 +12,7 @@ 
 #include <asm/gpio.h>
 
 struct phy_device *phy_connect_phy_id(struct mii_dev *bus, struct udevice *dev,
-				      phy_interface_t interface)
+				      int phyaddr, phy_interface_t interface)
 {
 	struct phy_device *phydev;
 	struct ofnode_phandle_args phandle_args;
@@ -61,7 +61,7 @@  struct phy_device *phy_connect_phy_id(struct mii_dev *bus, struct udevice *dev,
 	}
 
 	id =  vendor << 16 | device;
-	phydev = phy_device_create(bus, 0, id, false, interface);
+	phydev = phy_device_create(bus, phyaddr, id, false, interface);
 	if (phydev)
 		phydev->node = node;
 
diff --git a/drivers/net/phy/phy.c b/drivers/net/phy/phy.c
index 08a37a344e65..690ed38ba622 100644
--- a/drivers/net/phy/phy.c
+++ b/drivers/net/phy/phy.c
@@ -1049,7 +1049,7 @@  struct phy_device *phy_connect(struct mii_dev *bus, int addr,
 
 #ifdef CONFIG_PHY_ETHERNET_ID
 	if (!phydev)
-		phydev = phy_connect_phy_id(bus, dev, interface);
+		phydev = phy_connect_phy_id(bus, dev, addr, interface);
 #endif
 
 #ifdef CONFIG_PHY_XILINX_GMII2RGMII
diff --git a/include/phy.h b/include/phy.h
index 9ea4bd42db4d..5e3da4b01b6c 100644
--- a/include/phy.h
+++ b/include/phy.h
@@ -479,7 +479,7 @@  struct phy_device *phy_device_create(struct mii_dev *bus, int addr,
  *			or NULL otherwise
  */
 struct phy_device *phy_connect_phy_id(struct mii_dev *bus, struct udevice *dev,
-				      phy_interface_t interface);
+				      int phyaddr, phy_interface_t interface);
 
 static inline ofnode phy_get_ofnode(struct phy_device *phydev)
 {