diff options
author | Sriram <srk@ti.com> | 2010-07-28 22:33:59 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-07-31 02:55:37 -0400 |
commit | 3725b1fe0b9c7e5ba3c4f6e585cd93a7174c1e07 (patch) | |
tree | d294d986150fbd08adf5ee219b714d6123c525e6 /drivers/net | |
parent | 84da2658a619c2d96fae6741580879cc6d7a4cd1 (diff) |
TI DaVinci EMAC: Fix asymmetric handling of packets in NAPI Poll function.
The current implementation of NAPI poll function in the driver does not service
Rx packets, error condition even if a single Tx packet gets serviced in
the napi poll call. This behavior severely affects performance for specific use
cases. This patch modifies the poll function implementation to service tx/rx
packets in an identical manner.
Signed-off-by: Sriramakrishnan <srk@ti.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net')
-rw-r--r-- | drivers/net/davinci_emac.c | 21 |
1 files changed, 8 insertions, 13 deletions
diff --git a/drivers/net/davinci_emac.c b/drivers/net/davinci_emac.c index 28633761be21..2ebf1a1dd1e1 100644 --- a/drivers/net/davinci_emac.c +++ b/drivers/net/davinci_emac.c | |||
@@ -2266,7 +2266,7 @@ static int emac_poll(struct napi_struct *napi, int budget) | |||
2266 | struct net_device *ndev = priv->ndev; | 2266 | struct net_device *ndev = priv->ndev; |
2267 | struct device *emac_dev = &ndev->dev; | 2267 | struct device *emac_dev = &ndev->dev; |
2268 | u32 status = 0; | 2268 | u32 status = 0; |
2269 | u32 num_pkts = 0; | 2269 | u32 num_tx_pkts = 0, num_rx_pkts = 0; |
2270 | 2270 | ||
2271 | /* Check interrupt vectors and call packet processing */ | 2271 | /* Check interrupt vectors and call packet processing */ |
2272 | status = emac_read(EMAC_MACINVECTOR); | 2272 | status = emac_read(EMAC_MACINVECTOR); |
@@ -2277,27 +2277,19 @@ static int emac_poll(struct napi_struct *napi, int budget) | |||
2277 | mask = EMAC_DM646X_MAC_IN_VECTOR_TX_INT_VEC; | 2277 | mask = EMAC_DM646X_MAC_IN_VECTOR_TX_INT_VEC; |
2278 | 2278 | ||
2279 | if (status & mask) { | 2279 | if (status & mask) { |
2280 | num_pkts = emac_tx_bdproc(priv, EMAC_DEF_TX_CH, | 2280 | num_tx_pkts = emac_tx_bdproc(priv, EMAC_DEF_TX_CH, |
2281 | EMAC_DEF_TX_MAX_SERVICE); | 2281 | EMAC_DEF_TX_MAX_SERVICE); |
2282 | } /* TX processing */ | 2282 | } /* TX processing */ |
2283 | 2283 | ||
2284 | if (num_pkts) | ||
2285 | return budget; | ||
2286 | |||
2287 | mask = EMAC_DM644X_MAC_IN_VECTOR_RX_INT_VEC; | 2284 | mask = EMAC_DM644X_MAC_IN_VECTOR_RX_INT_VEC; |
2288 | 2285 | ||
2289 | if (priv->version == EMAC_VERSION_2) | 2286 | if (priv->version == EMAC_VERSION_2) |
2290 | mask = EMAC_DM646X_MAC_IN_VECTOR_RX_INT_VEC; | 2287 | mask = EMAC_DM646X_MAC_IN_VECTOR_RX_INT_VEC; |
2291 | 2288 | ||
2292 | if (status & mask) { | 2289 | if (status & mask) { |
2293 | num_pkts = emac_rx_bdproc(priv, EMAC_DEF_RX_CH, budget); | 2290 | num_rx_pkts = emac_rx_bdproc(priv, EMAC_DEF_RX_CH, budget); |
2294 | } /* RX processing */ | 2291 | } /* RX processing */ |
2295 | 2292 | ||
2296 | if (num_pkts < budget) { | ||
2297 | napi_complete(napi); | ||
2298 | emac_int_enable(priv); | ||
2299 | } | ||
2300 | |||
2301 | mask = EMAC_DM644X_MAC_IN_VECTOR_HOST_INT; | 2293 | mask = EMAC_DM644X_MAC_IN_VECTOR_HOST_INT; |
2302 | if (priv->version == EMAC_VERSION_2) | 2294 | if (priv->version == EMAC_VERSION_2) |
2303 | mask = EMAC_DM646X_MAC_IN_VECTOR_HOST_INT; | 2295 | mask = EMAC_DM646X_MAC_IN_VECTOR_HOST_INT; |
@@ -2328,9 +2320,12 @@ static int emac_poll(struct napi_struct *napi, int budget) | |||
2328 | dev_err(emac_dev, "RX Host error %s on ch=%d\n", | 2320 | dev_err(emac_dev, "RX Host error %s on ch=%d\n", |
2329 | &emac_rxhost_errcodes[cause][0], ch); | 2321 | &emac_rxhost_errcodes[cause][0], ch); |
2330 | } | 2322 | } |
2331 | } /* Host error processing */ | 2323 | } else if (num_rx_pkts < budget) { |
2324 | napi_complete(napi); | ||
2325 | emac_int_enable(priv); | ||
2326 | } | ||
2332 | 2327 | ||
2333 | return num_pkts; | 2328 | return num_rx_pkts; |
2334 | } | 2329 | } |
2335 | 2330 | ||
2336 | #ifdef CONFIG_NET_POLL_CONTROLLER | 2331 | #ifdef CONFIG_NET_POLL_CONTROLLER |