[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20170206192445.35829-1-abrodkin@synopsys.com>
Date: Mon, 6 Feb 2017 22:24:45 +0300
From: Alexey Brodkin <Alexey.Brodkin@...opsys.com>
To: netdev@...r.kernel.org
Cc: linux-snps-arc@...ts.infradead.org, linux-kernel@...r.kernel.org,
Alexey Brodkin <Alexey.Brodkin@...opsys.com>,
Murali Karicheri <m-karicheri2@...com>,
Sekhar Nori <nsekhar@...com>,
"David S . Miller" <davem@...emloft.net>,
Grygorii Strashko <grygorii.strashko@...com>,
Florian Fainelli <f.fainelli@...il.com>,
Mugunthan V N <mugunthanvnm@...com>,
Andrew Lunn <andrew@...n.ch>
Subject: [PATCH] net: phy: dp83867: Fall-back to default values of clock delay and FIFO depth
Given there're default values mentioned in the PHY datasheet
fall-back gracefully to them instead of silently return an error
through the whole call-chain.
This allows to use minimalistic description in DT if no special
features are required.
Signed-off-by: Alexey Brodkin <abrodkin@...opsys.com>
Cc: Murali Karicheri <m-karicheri2@...com>
Cc: Sekhar Nori <nsekhar@...com>
Cc: David S. Miller <davem@...emloft.net>
Cc: Grygorii Strashko <grygorii.strashko@...com>
Cc: Florian Fainelli <f.fainelli@...il.com>
Cc: Mugunthan V N <mugunthanvnm@...com>
Cc: Andrew Lunn <andrew@...n.ch>
---
drivers/net/phy/dp83867.c | 11 +++++++----
1 file changed, 7 insertions(+), 4 deletions(-)
diff --git a/drivers/net/phy/dp83867.c b/drivers/net/phy/dp83867.c
index ca1b462..5d8c5ec 100644
--- a/drivers/net/phy/dp83867.c
+++ b/drivers/net/phy/dp83867.c
@@ -135,17 +135,20 @@ static int dp83867_of_init(struct phy_device *phydev)
if (ret &&
(phydev->interface == PHY_INTERFACE_MODE_RGMII_ID ||
phydev->interface == PHY_INTERFACE_MODE_RGMII_RXID))
- return ret;
+ dp83867->rx_id_delay = DP83867_RGMIIDCTL_2_00_NS;
ret = of_property_read_u32(of_node, "ti,tx-internal-delay",
&dp83867->tx_id_delay);
if (ret &&
(phydev->interface == PHY_INTERFACE_MODE_RGMII_ID ||
phydev->interface == PHY_INTERFACE_MODE_RGMII_TXID))
- return ret;
+ dp83867->tx_id_delay = DP83867_RGMIIDCTL_2_00_NS;
- return of_property_read_u32(of_node, "ti,fifo-depth",
- &dp83867->fifo_depth);
+ ret = of_property_read_u32(of_node, "ti,fifo-depth", &dp83867->fifo_depth);
+ if (ret)
+ dp83867->fifo_depth = DP83867_PHYCR_FIFO_DEPTH_4_B_NIB;
+
+ return 0;
}
#else
static int dp83867_of_init(struct phy_device *phydev)
--
2.10.2
Powered by blists - more mailing lists