sh_eth: call sh_eth_tsu_write() from sh_eth_chip_reset_giga()
authorSergei Shtylyov <sergei.shtylyov@cogentembedded.com>
Sat, 7 May 2016 21:08:05 +0000 (00:08 +0300)
committerDavid S. Miller <davem@davemloft.net>
Mon, 9 May 2016 04:15:23 +0000 (00:15 -0400)
sh_eth_chip_reset_giga() doesn't really need to use direct iowrite32() when
writing  to the ARSTR register,  it can use sh_eth_tsu_write() as all other
chip_reset() methods.

Signed-off-by: Sergei Shtylyov <sergei.shtylyov@cogentembedded.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/renesas/sh_eth.c

index 07e29638299f7db29f51e34c2a8c5aaef297876c..23678e7cce6b889dd20d53d3b5b50e1d7630de8f 100644 (file)
@@ -725,8 +725,9 @@ static struct sh_eth_cpu_data sh7757_data = {
 #define GIGA_MAHR(port)                (SH_GIGA_ETH_BASE + 0x800 * (port) + 0x05c0)
 static void sh_eth_chip_reset_giga(struct net_device *ndev)
 {
-       int i;
+       struct sh_eth_private *mdp = netdev_priv(ndev);
        u32 mahr[2], malr[2];
+       int i;
 
        /* save MAHR and MALR */
        for (i = 0; i < 2; i++) {
@@ -735,7 +736,7 @@ static void sh_eth_chip_reset_giga(struct net_device *ndev)
        }
 
        /* reset device */
-       iowrite32(ARSTR_ARST, (void *)(SH_GIGA_ETH_BASE + 0x1800));
+       sh_eth_tsu_write(mdp, ARSTR_ARST, ARSTR);
        mdelay(1);
 
        /* restore MAHR and MALR */