aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/mv643xx_eth.c
diff options
context:
space:
mode:
Diffstat (limited to 'drivers/net/mv643xx_eth.c')
-rw-r--r--drivers/net/mv643xx_eth.c61
1 files changed, 24 insertions, 37 deletions
diff --git a/drivers/net/mv643xx_eth.c b/drivers/net/mv643xx_eth.c
index 8a9ee8e46a1a..d5c9ceb2f685 100644
--- a/drivers/net/mv643xx_eth.c
+++ b/drivers/net/mv643xx_eth.c
@@ -106,7 +106,14 @@ static char mv643xx_driver_version[] = "1.0";
106#define TXQ_COMMAND(p) (0x0448 + ((p) << 10)) 106#define TXQ_COMMAND(p) (0x0448 + ((p) << 10))
107#define TX_BW_MTU(p) (0x0458 + ((p) << 10)) 107#define TX_BW_MTU(p) (0x0458 + ((p) << 10))
108#define INT_CAUSE(p) (0x0460 + ((p) << 10)) 108#define INT_CAUSE(p) (0x0460 + ((p) << 10))
109#define INT_RX 0x00000804
110#define INT_EXT 0x00000002
109#define INT_CAUSE_EXT(p) (0x0464 + ((p) << 10)) 111#define INT_CAUSE_EXT(p) (0x0464 + ((p) << 10))
112#define INT_EXT_LINK 0x00100000
113#define INT_EXT_PHY 0x00010000
114#define INT_EXT_TX_ERROR_0 0x00000100
115#define INT_EXT_TX_0 0x00000001
116#define INT_EXT_TX 0x00000101
110#define INT_MASK(p) (0x0468 + ((p) << 10)) 117#define INT_MASK(p) (0x0468 + ((p) << 10))
111#define INT_MASK_EXT(p) (0x046c + ((p) << 10)) 118#define INT_MASK_EXT(p) (0x046c + ((p) << 10))
112#define TX_FIFO_URGENT_THRESHOLD(p) (0x0474 + ((p) << 10)) 119#define TX_FIFO_URGENT_THRESHOLD(p) (0x0474 + ((p) << 10))
@@ -162,26 +169,6 @@ static char mv643xx_driver_version[] = "1.0";
162#define PORT_DEFAULT_TRANSMIT_QUEUE_SIZE 800 169#define PORT_DEFAULT_TRANSMIT_QUEUE_SIZE 800
163#define PORT_DEFAULT_RECEIVE_QUEUE_SIZE 400 170#define PORT_DEFAULT_RECEIVE_QUEUE_SIZE 400
164 171
165#define ETH_RX_QUEUES_ENABLED (1 << 0) /* use only Q0 for receive */
166#define ETH_TX_QUEUES_ENABLED (1 << 0) /* use only Q0 for transmit */
167
168#define ETH_INT_CAUSE_RX_DONE (ETH_RX_QUEUES_ENABLED << 2)
169#define ETH_INT_CAUSE_RX_ERROR (ETH_RX_QUEUES_ENABLED << 9)
170#define ETH_INT_CAUSE_RX (ETH_INT_CAUSE_RX_DONE | ETH_INT_CAUSE_RX_ERROR)
171#define ETH_INT_CAUSE_EXT 0x00000002
172#define ETH_INT_UNMASK_ALL (ETH_INT_CAUSE_RX | ETH_INT_CAUSE_EXT)
173
174#define ETH_INT_CAUSE_TX_DONE (ETH_TX_QUEUES_ENABLED << 0)
175#define ETH_INT_CAUSE_TX_ERROR (ETH_TX_QUEUES_ENABLED << 8)
176#define ETH_INT_CAUSE_TX (ETH_INT_CAUSE_TX_DONE | ETH_INT_CAUSE_TX_ERROR)
177#define ETH_INT_CAUSE_PHY 0x00010000
178#define ETH_INT_CAUSE_STATE 0x00100000
179#define ETH_INT_UNMASK_ALL_EXT (ETH_INT_CAUSE_TX | ETH_INT_CAUSE_PHY | \
180 ETH_INT_CAUSE_STATE)
181
182#define ETH_INT_MASK_ALL 0x00000000
183#define ETH_INT_MASK_ALL_EXT 0x00000000
184
185#define PHY_WAIT_ITERATIONS 1000 /* 1000 iterations * 10uS = 10mS max */ 172#define PHY_WAIT_ITERATIONS 1000 /* 1000 iterations * 10uS = 10mS max */
186#define PHY_WAIT_MICRO_SECONDS 10 173#define PHY_WAIT_MICRO_SECONDS 10
187 174
@@ -841,7 +828,7 @@ static int mv643xx_poll(struct napi_struct *napi, int budget)
841 netif_rx_complete(dev, napi); 828 netif_rx_complete(dev, napi);
842 wrl(mp, INT_CAUSE(port_num), 0); 829 wrl(mp, INT_CAUSE(port_num), 0);
843 wrl(mp, INT_CAUSE_EXT(port_num), 0); 830 wrl(mp, INT_CAUSE_EXT(port_num), 0);
844 wrl(mp, INT_MASK(port_num), ETH_INT_UNMASK_ALL); 831 wrl(mp, INT_MASK(port_num), INT_RX | INT_EXT);
845 } 832 }
846 833
847 return work_done; 834 return work_done;
@@ -997,7 +984,7 @@ static void eth_tx_submit_descs_for_skb(struct mv643xx_private *mp,
997 984
998 /* ensure all descriptors are written before poking hardware */ 985 /* ensure all descriptors are written before poking hardware */
999 wmb(); 986 wmb();
1000 mv643xx_eth_port_enable_tx(mp, ETH_TX_QUEUES_ENABLED); 987 mv643xx_eth_port_enable_tx(mp, 1);
1001 988
1002 mp->tx_desc_count += nr_frags + 1; 989 mp->tx_desc_count += nr_frags + 1;
1003} 990}
@@ -1980,21 +1967,21 @@ static irqreturn_t mv643xx_eth_int_handler(int irq, void *dev_id)
1980 unsigned int port_num = mp->port_num; 1967 unsigned int port_num = mp->port_num;
1981 1968
1982 /* Read interrupt cause registers */ 1969 /* Read interrupt cause registers */
1983 eth_int_cause = rdl(mp, INT_CAUSE(port_num)) & ETH_INT_UNMASK_ALL; 1970 eth_int_cause = rdl(mp, INT_CAUSE(port_num)) & (INT_RX | INT_EXT);
1984 if (eth_int_cause & ETH_INT_CAUSE_EXT) { 1971 if (eth_int_cause & INT_EXT) {
1985 eth_int_cause_ext = rdl(mp, INT_CAUSE_EXT(port_num)) 1972 eth_int_cause_ext = rdl(mp, INT_CAUSE_EXT(port_num))
1986 & ETH_INT_UNMASK_ALL_EXT; 1973 & (INT_EXT_LINK | INT_EXT_PHY | INT_EXT_TX);
1987 wrl(mp, INT_CAUSE_EXT(port_num), ~eth_int_cause_ext); 1974 wrl(mp, INT_CAUSE_EXT(port_num), ~eth_int_cause_ext);
1988 } 1975 }
1989 1976
1990 /* PHY status changed */ 1977 /* PHY status changed */
1991 if (eth_int_cause_ext & (ETH_INT_CAUSE_PHY | ETH_INT_CAUSE_STATE)) { 1978 if (eth_int_cause_ext & (INT_EXT_LINK | INT_EXT_PHY)) {
1992 struct ethtool_cmd cmd; 1979 struct ethtool_cmd cmd;
1993 1980
1994 if (mii_link_ok(&mp->mii)) { 1981 if (mii_link_ok(&mp->mii)) {
1995 mii_ethtool_gset(&mp->mii, &cmd); 1982 mii_ethtool_gset(&mp->mii, &cmd);
1996 mv643xx_eth_update_pscr(dev, &cmd); 1983 mv643xx_eth_update_pscr(dev, &cmd);
1997 mv643xx_eth_port_enable_tx(mp, ETH_TX_QUEUES_ENABLED); 1984 mv643xx_eth_port_enable_tx(mp, 1);
1998 if (!netif_carrier_ok(dev)) { 1985 if (!netif_carrier_ok(dev)) {
1999 netif_carrier_on(dev); 1986 netif_carrier_on(dev);
2000 if (mp->tx_ring_size - mp->tx_desc_count >= 1987 if (mp->tx_ring_size - mp->tx_desc_count >=
@@ -2008,9 +1995,9 @@ static irqreturn_t mv643xx_eth_int_handler(int irq, void *dev_id)
2008 } 1995 }
2009 1996
2010#ifdef MV643XX_NAPI 1997#ifdef MV643XX_NAPI
2011 if (eth_int_cause & ETH_INT_CAUSE_RX) { 1998 if (eth_int_cause & INT_RX) {
2012 /* schedule the NAPI poll routine to maintain port */ 1999 /* schedule the NAPI poll routine to maintain port */
2013 wrl(mp, INT_MASK(port_num), ETH_INT_MASK_ALL); 2000 wrl(mp, INT_MASK(port_num), 0x00000000);
2014 2001
2015 /* wait for previous write to complete */ 2002 /* wait for previous write to complete */
2016 rdl(mp, INT_MASK(port_num)); 2003 rdl(mp, INT_MASK(port_num));
@@ -2018,10 +2005,10 @@ static irqreturn_t mv643xx_eth_int_handler(int irq, void *dev_id)
2018 netif_rx_schedule(dev, &mp->napi); 2005 netif_rx_schedule(dev, &mp->napi);
2019 } 2006 }
2020#else 2007#else
2021 if (eth_int_cause & ETH_INT_CAUSE_RX) 2008 if (eth_int_cause & INT_RX)
2022 mv643xx_eth_receive_queue(dev, INT_MAX); 2009 mv643xx_eth_receive_queue(dev, INT_MAX);
2023#endif 2010#endif
2024 if (eth_int_cause_ext & ETH_INT_CAUSE_TX) 2011 if (eth_int_cause_ext & INT_EXT_TX)
2025 mv643xx_eth_free_completed_tx_descs(dev); 2012 mv643xx_eth_free_completed_tx_descs(dev);
2026 2013
2027 /* 2014 /*
@@ -2145,7 +2132,7 @@ static void eth_port_start(struct net_device *dev)
2145 wrl(mp, SDMA_CONFIG(port_num), PORT_SDMA_CONFIG_DEFAULT_VALUE); 2132 wrl(mp, SDMA_CONFIG(port_num), PORT_SDMA_CONFIG_DEFAULT_VALUE);
2146 2133
2147 /* Enable port Rx. */ 2134 /* Enable port Rx. */
2148 mv643xx_eth_port_enable_rx(mp, ETH_RX_QUEUES_ENABLED); 2135 mv643xx_eth_port_enable_rx(mp, 1);
2149 2136
2150 /* Disable port bandwidth limits by clearing MTU register */ 2137 /* Disable port bandwidth limits by clearing MTU register */
2151 wrl(mp, TX_BW_MTU(port_num), 0); 2138 wrl(mp, TX_BW_MTU(port_num), 0);
@@ -2392,10 +2379,10 @@ static int mv643xx_eth_open(struct net_device *dev)
2392 eth_port_set_tx_coal(mp, MV643XX_TX_COAL); 2379 eth_port_set_tx_coal(mp, MV643XX_TX_COAL);
2393 2380
2394 /* Unmask phy and link status changes interrupts */ 2381 /* Unmask phy and link status changes interrupts */
2395 wrl(mp, INT_MASK_EXT(port_num), ETH_INT_UNMASK_ALL_EXT); 2382 wrl(mp, INT_MASK_EXT(port_num), INT_EXT_LINK | INT_EXT_PHY | INT_EXT_TX);
2396 2383
2397 /* Unmask RX buffer and TX end interrupt */ 2384 /* Unmask RX buffer and TX end interrupt */
2398 wrl(mp, INT_MASK(port_num), ETH_INT_UNMASK_ALL); 2385 wrl(mp, INT_MASK(port_num), INT_RX | INT_EXT);
2399 2386
2400 return 0; 2387 return 0;
2401 2388
@@ -2462,7 +2449,7 @@ static int mv643xx_eth_stop(struct net_device *dev)
2462 unsigned int port_num = mp->port_num; 2449 unsigned int port_num = mp->port_num;
2463 2450
2464 /* Mask all interrupts on ethernet port */ 2451 /* Mask all interrupts on ethernet port */
2465 wrl(mp, INT_MASK(port_num), ETH_INT_MASK_ALL); 2452 wrl(mp, INT_MASK(port_num), 0x00000000);
2466 /* wait for previous write to complete */ 2453 /* wait for previous write to complete */
2467 rdl(mp, INT_MASK(port_num)); 2454 rdl(mp, INT_MASK(port_num));
2468 2455
@@ -2567,13 +2554,13 @@ static void mv643xx_netpoll(struct net_device *netdev)
2567 struct mv643xx_private *mp = netdev_priv(netdev); 2554 struct mv643xx_private *mp = netdev_priv(netdev);
2568 int port_num = mp->port_num; 2555 int port_num = mp->port_num;
2569 2556
2570 wrl(mp, INT_MASK(port_num), ETH_INT_MASK_ALL); 2557 wrl(mp, INT_MASK(port_num), 0x00000000);
2571 /* wait for previous write to complete */ 2558 /* wait for previous write to complete */
2572 rdl(mp, INT_MASK(port_num)); 2559 rdl(mp, INT_MASK(port_num));
2573 2560
2574 mv643xx_eth_int_handler(netdev->irq, netdev); 2561 mv643xx_eth_int_handler(netdev->irq, netdev);
2575 2562
2576 wrl(mp, INT_MASK(port_num), ETH_INT_UNMASK_ALL); 2563 wrl(mp, INT_MASK(port_num), INT_RX | INT_CAUSE_EXT);
2577} 2564}
2578#endif 2565#endif
2579 2566