sh_eth: add sh_eth_cpu_data::edtrr_trns value
authorSergei Shtylyov <sergei.shtylyov@cogentembedded.com>
Sat, 24 Mar 2018 20:08:42 +0000 (23:08 +0300)
committerDavid S. Miller <davem@davemloft.net>
Mon, 26 Mar 2018 16:34:19 +0000 (12:34 -0400)
sh_eth_get_edtrr_trns() returns the value to be written to EDTRR in order
to start TX DMA -- this value is different between the GEther-like and
the other controllers. We can replace this function (and thus get rid of
the calls to sh_eth_is_{gether|rz_fast_ether}() by it) with a new field
'edtrr_trns' in the 'struct sh_eth_cpu_data'.

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
drivers/net/ethernet/renesas/sh_eth.h

index e7d980f9df7df5e00b590a743496ec51fb1f5461..d4a11ff2449675bca78bef7e5fc162b011518306 100644 (file)
@@ -584,6 +584,7 @@ static struct sh_eth_cpu_data r7s72100_data = {
 
        .register_type  = SH_ETH_REG_FAST_RZ,
 
+       .edtrr_trns     = EDTRR_TRNS_GETHER,
        .ecsr_value     = ECSR_ICD,
        .ecsipr_value   = ECSIPR_ICDIP,
        .eesipr_value   = EESIPR_TWB1IP | EESIPR_TWBIP | EESIPR_TC1IP |
@@ -631,6 +632,7 @@ static struct sh_eth_cpu_data r8a7740_data = {
 
        .register_type  = SH_ETH_REG_GIGABIT,
 
+       .edtrr_trns     = EDTRR_TRNS_GETHER,
        .ecsr_value     = ECSR_ICD | ECSR_MPD,
        .ecsipr_value   = ECSIPR_LCHNGIP | ECSIPR_ICDIP | ECSIPR_MPDIP,
        .eesipr_value   = EESIPR_RFCOFIP | EESIPR_ECIIP |
@@ -687,6 +689,7 @@ static struct sh_eth_cpu_data rcar_gen1_data = {
 
        .register_type  = SH_ETH_REG_FAST_RCAR,
 
+       .edtrr_trns     = EDTRR_TRNS_ETHER,
        .ecsr_value     = ECSR_PSRTO | ECSR_LCHNG | ECSR_ICD,
        .ecsipr_value   = ECSIPR_PSRTOIP | ECSIPR_LCHNGIP | ECSIPR_ICDIP,
        .eesipr_value   = EESIPR_RFCOFIP | EESIPR_ADEIP | EESIPR_ECIIP |
@@ -716,6 +719,7 @@ static struct sh_eth_cpu_data rcar_gen2_data = {
 
        .register_type  = SH_ETH_REG_FAST_RCAR,
 
+       .edtrr_trns     = EDTRR_TRNS_ETHER,
        .ecsr_value     = ECSR_PSRTO | ECSR_LCHNG | ECSR_ICD | ECSR_MPD,
        .ecsipr_value   = ECSIPR_PSRTOIP | ECSIPR_LCHNGIP | ECSIPR_ICDIP |
                          ECSIPR_MPDIP,
@@ -765,6 +769,7 @@ static struct sh_eth_cpu_data sh7724_data = {
 
        .register_type  = SH_ETH_REG_FAST_SH4,
 
+       .edtrr_trns     = EDTRR_TRNS_ETHER,
        .ecsr_value     = ECSR_PSRTO | ECSR_LCHNG | ECSR_ICD,
        .ecsipr_value   = ECSIPR_PSRTOIP | ECSIPR_LCHNGIP | ECSIPR_ICDIP,
        .eesipr_value   = EESIPR_RFCOFIP | EESIPR_ADEIP | EESIPR_ECIIP |
@@ -809,6 +814,7 @@ static struct sh_eth_cpu_data sh7757_data = {
 
        .register_type  = SH_ETH_REG_FAST_SH4,
 
+       .edtrr_trns     = EDTRR_TRNS_ETHER,
        .eesipr_value   = EESIPR_RFCOFIP | EESIPR_ECIIP |
                          EESIPR_FTCIP | EESIPR_TDEIP | EESIPR_TFUFIP |
                          EESIPR_FRIP | EESIPR_RDEIP | EESIPR_RFOFIP |
@@ -884,6 +890,7 @@ static struct sh_eth_cpu_data sh7757_data_giga = {
 
        .register_type  = SH_ETH_REG_GIGABIT,
 
+       .edtrr_trns     = EDTRR_TRNS_GETHER,
        .ecsr_value     = ECSR_ICD | ECSR_MPD,
        .ecsipr_value   = ECSIPR_LCHNGIP | ECSIPR_ICDIP | ECSIPR_MPDIP,
        .eesipr_value   = EESIPR_RFCOFIP | EESIPR_ECIIP |
@@ -925,6 +932,7 @@ static struct sh_eth_cpu_data sh7734_data = {
 
        .register_type  = SH_ETH_REG_GIGABIT,
 
+       .edtrr_trns     = EDTRR_TRNS_GETHER,
        .ecsr_value     = ECSR_ICD | ECSR_MPD,
        .ecsipr_value   = ECSIPR_LCHNGIP | ECSIPR_ICDIP | ECSIPR_MPDIP,
        .eesipr_value   = EESIPR_RFCOFIP | EESIPR_ECIIP |
@@ -963,6 +971,7 @@ static struct sh_eth_cpu_data sh7763_data = {
 
        .register_type  = SH_ETH_REG_GIGABIT,
 
+       .edtrr_trns     = EDTRR_TRNS_GETHER,
        .ecsr_value     = ECSR_ICD | ECSR_MPD,
        .ecsipr_value   = ECSIPR_LCHNGIP | ECSIPR_ICDIP | ECSIPR_MPDIP,
        .eesipr_value   = EESIPR_RFCOFIP | EESIPR_ECIIP |
@@ -995,6 +1004,7 @@ static struct sh_eth_cpu_data sh7619_data = {
 
        .register_type  = SH_ETH_REG_FAST_SH3_SH2,
 
+       .edtrr_trns     = EDTRR_TRNS_ETHER,
        .eesipr_value   = EESIPR_RFCOFIP | EESIPR_ECIIP |
                          EESIPR_FTCIP | EESIPR_TDEIP | EESIPR_TFUFIP |
                          EESIPR_FRIP | EESIPR_RDEIP | EESIPR_RFOFIP |
@@ -1015,6 +1025,7 @@ static struct sh_eth_cpu_data sh771x_data = {
 
        .register_type  = SH_ETH_REG_FAST_SH3_SH2,
 
+       .edtrr_trns     = EDTRR_TRNS_ETHER,
        .eesipr_value   = EESIPR_RFCOFIP | EESIPR_ECIIP |
                          EESIPR_FTCIP | EESIPR_TDEIP | EESIPR_TFUFIP |
                          EESIPR_FRIP | EESIPR_RDEIP | EESIPR_RFOFIP |
@@ -1094,14 +1105,6 @@ static void read_mac_address(struct net_device *ndev, unsigned char *mac)
        }
 }
 
-static u32 sh_eth_get_edtrr_trns(struct sh_eth_private *mdp)
-{
-       if (sh_eth_is_gether(mdp) || sh_eth_is_rz_fast_ether(mdp))
-               return EDTRR_TRNS_GETHER;
-       else
-               return EDTRR_TRNS_ETHER;
-}
-
 struct bb_info {
        void (*set_gate)(void *addr);
        struct mdiobb_ctrl ctrl;
@@ -1741,9 +1744,9 @@ static void sh_eth_error(struct net_device *ndev, u32 intr_status)
                sh_eth_tx_free(ndev, true);
 
                /* SH7712 BUG */
-               if (edtrr ^ sh_eth_get_edtrr_trns(mdp)) {
+               if (edtrr ^ mdp->cd->edtrr_trns) {
                        /* tx dma start */
-                       sh_eth_write(ndev, sh_eth_get_edtrr_trns(mdp), EDTRR);
+                       sh_eth_write(ndev, mdp->cd->edtrr_trns, EDTRR);
                }
                /* wakeup */
                netif_wake_queue(ndev);
@@ -2502,8 +2505,8 @@ static int sh_eth_start_xmit(struct sk_buff *skb, struct net_device *ndev)
 
        mdp->cur_tx++;
 
-       if (!(sh_eth_read(ndev, EDTRR) & sh_eth_get_edtrr_trns(mdp)))
-               sh_eth_write(ndev, sh_eth_get_edtrr_trns(mdp), EDTRR);
+       if (!(sh_eth_read(ndev, EDTRR) & mdp->cd->edtrr_trns))
+               sh_eth_write(ndev, mdp->cd->edtrr_trns, EDTRR);
 
        return NETDEV_TX_OK;
 }
index ff3520b0d86fdceced4da2a1f8c64faf0da3fc31..aa3c45153c9ab2b0e68b4d7cbd3cd4e813aa93ca 100644 (file)
@@ -479,6 +479,7 @@ struct sh_eth_cpu_data {
 
        /* mandatory initialize value */
        int register_type;
+       u32 edtrr_trns;
        u32 eesipr_value;
 
        /* optional initialize value */