From e3cbc20903575750fe99bb7dcf39cf6d106b08bb Mon Sep 17 00:00:00 2001
From: Gabor Juhos <juhosg@openwrt.org>
Date: Wed, 7 Mar 2012 16:32:43 +0000
Subject: [PATCH] generic: ar8216: use ar8216_read_port_link to get the CPU
 port link parameters

SVN-Revision: 30846
---
 .../generic/files/drivers/net/phy/ar8216.c    | 23 ++++++++++++++++---
 1 file changed, 20 insertions(+), 3 deletions(-)

diff --git a/target/linux/generic/files/drivers/net/phy/ar8216.c b/target/linux/generic/files/drivers/net/phy/ar8216.c
index 38ccaa36a7..2e3a8426b0 100644
--- a/target/linux/generic/files/drivers/net/phy/ar8216.c
+++ b/target/linux/generic/files/drivers/net/phy/ar8216.c
@@ -929,14 +929,31 @@ static int
 ar8216_read_status(struct phy_device *phydev)
 {
 	struct ar8216_priv *priv = phydev->priv;
+	struct switch_port_link link;
 	int ret;
 	if (phydev->addr != 0) {
 		return genphy_read_status(phydev);
 	}
 
-	phydev->speed = priv->chip == AR8316 ? SPEED_1000 : SPEED_100;
-	phydev->duplex = DUPLEX_FULL;
-	phydev->link = 1;
+	ar8216_read_port_link(priv, phydev->addr, &link);
+	phydev->link = !!link.link;
+	if (!phydev->link)
+		return 0;
+
+	switch (link.speed) {
+	case SWITCH_PORT_SPEED_10:
+	    	phydev->speed = SPEED_10;
+		break;
+	case SWITCH_PORT_SPEED_100:
+	    	phydev->speed = SPEED_100;
+		break;
+	case SWITCH_PORT_SPEED_1000:
+	    	phydev->speed = SPEED_1000;
+		break;
+	default:
+		phydev->speed = 0;
+	}
+	phydev->duplex = link.duplex ? DUPLEX_FULL : DUPLEX_HALF;
 
 	/* flush the address translation unit */
 	mutex_lock(&priv->reg_mutex);
-- 
2.30.2