diff options
author | David S. Miller <davem@davemloft.net> | 2016-01-11 17:31:10 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2016-01-11 17:31:10 -0500 |
commit | 366f29311137ec9dc0cdd4ec675cc6fcaac104d6 (patch) | |
tree | 77fe59349bc0de5be7377046e678eaa02f3ba0db | |
parent | 66530bdf85eb1d72a0c399665e09a2c2298501c6 (diff) | |
parent | bffa731f8f44e0444afc56875a10fd07e9a08c6c (diff) |
Merge branch 'renesas-eth-fixes'
Sergei Shtylyov says:
====================
Fix some dubious code in the Renesas Ethernet drivers
Here's a set of 2 patches against DaveM's 'net.git' repo. While initializing
EMAC the code tries to respect the duplex mode both programmed into ECMR and
stored in its own private data -- this just can't be right.
[1/2] ravb: stop reading ECMR in ravb_emac_init()
[2/2] sh_eth: stop reading ECMR in sh_eth_dev_init()
====================
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | drivers/net/ethernet/renesas/ravb_main.c | 7 | ||||
-rw-r--r-- | drivers/net/ethernet/renesas/sh_eth.c | 7 |
2 files changed, 4 insertions, 10 deletions
diff --git a/drivers/net/ethernet/renesas/ravb_main.c b/drivers/net/ethernet/renesas/ravb_main.c index 467d41698fd5..fef4fa120d8a 100644 --- a/drivers/net/ethernet/renesas/ravb_main.c +++ b/drivers/net/ethernet/renesas/ravb_main.c | |||
@@ -338,16 +338,13 @@ error: | |||
338 | static void ravb_emac_init(struct net_device *ndev) | 338 | static void ravb_emac_init(struct net_device *ndev) |
339 | { | 339 | { |
340 | struct ravb_private *priv = netdev_priv(ndev); | 340 | struct ravb_private *priv = netdev_priv(ndev); |
341 | u32 ecmr; | ||
342 | 341 | ||
343 | /* Receive frame limit set register */ | 342 | /* Receive frame limit set register */ |
344 | ravb_write(ndev, ndev->mtu + ETH_HLEN + VLAN_HLEN + ETH_FCS_LEN, RFLR); | 343 | ravb_write(ndev, ndev->mtu + ETH_HLEN + VLAN_HLEN + ETH_FCS_LEN, RFLR); |
345 | 344 | ||
346 | /* PAUSE prohibition */ | 345 | /* PAUSE prohibition */ |
347 | ecmr = ravb_read(ndev, ECMR); | 346 | ravb_write(ndev, ECMR_ZPF | (priv->duplex ? ECMR_DM : 0) | |
348 | ecmr &= ECMR_DM; | 347 | ECMR_TE | ECMR_RE, ECMR); |
349 | ecmr |= ECMR_ZPF | (priv->duplex ? ECMR_DM : 0) | ECMR_TE | ECMR_RE; | ||
350 | ravb_write(ndev, ecmr, ECMR); | ||
351 | 348 | ||
352 | ravb_set_rate(ndev); | 349 | ravb_set_rate(ndev); |
353 | 350 | ||
diff --git a/drivers/net/ethernet/renesas/sh_eth.c b/drivers/net/ethernet/renesas/sh_eth.c index 6a8fc0f341ff..9c1e290ca4ee 100644 --- a/drivers/net/ethernet/renesas/sh_eth.c +++ b/drivers/net/ethernet/renesas/sh_eth.c | |||
@@ -1289,7 +1289,6 @@ static int sh_eth_dev_init(struct net_device *ndev, bool start) | |||
1289 | { | 1289 | { |
1290 | int ret = 0; | 1290 | int ret = 0; |
1291 | struct sh_eth_private *mdp = netdev_priv(ndev); | 1291 | struct sh_eth_private *mdp = netdev_priv(ndev); |
1292 | u32 val; | ||
1293 | 1292 | ||
1294 | /* Soft Reset */ | 1293 | /* Soft Reset */ |
1295 | ret = sh_eth_reset(ndev); | 1294 | ret = sh_eth_reset(ndev); |
@@ -1342,10 +1341,8 @@ static int sh_eth_dev_init(struct net_device *ndev, bool start) | |||
1342 | } | 1341 | } |
1343 | 1342 | ||
1344 | /* PAUSE Prohibition */ | 1343 | /* PAUSE Prohibition */ |
1345 | val = (sh_eth_read(ndev, ECMR) & ECMR_DM) | | 1344 | sh_eth_write(ndev, ECMR_ZPF | (mdp->duplex ? ECMR_DM : 0) | |
1346 | ECMR_ZPF | (mdp->duplex ? ECMR_DM : 0) | ECMR_TE | ECMR_RE; | 1345 | ECMR_TE | ECMR_RE, ECMR); |
1347 | |||
1348 | sh_eth_write(ndev, val, ECMR); | ||
1349 | 1346 | ||
1350 | if (mdp->cd->set_rate) | 1347 | if (mdp->cd->set_rate) |
1351 | mdp->cd->set_rate(ndev); | 1348 | mdp->cd->set_rate(ndev); |