tg3: Fix RSS ring refill race condition
authorMichael Chan <mchan@broadcom.com>
Wed, 21 Mar 2012 15:38:33 +0000 (15:38 +0000)
committerDavid S. Miller <davem@davemloft.net>
Thu, 22 Mar 2012 01:57:36 +0000 (21:57 -0400)
commit7ae5289017e5ed5514b2603d157fb54c058a3c82
tree3ab4c34f95aced979df8ad5e7be721996f5911b1
parent5676cc7bfe1e388e87843f71daa229610385b41e
tg3: Fix RSS ring refill race condition

The RSS feature in tg3 hardware has only one rx producer ring for all
RSS rings.  NAPI vector 1 is special and handles the refilling of the
rx producer ring on behalf of all RSS rings.  There is a race condition
between these RSS NAPIs and the NAPI[1].  If NAPI[1] finishes checking
for refill and then another RSS ring empties the rx producer ring
before NAPI[1] exits NAPI, the chip will be completely out of SKBs in
the rx producer ring.

We fix this by adding a flag tp->rx_refill and rely on napi_schedule()/
napi_complete() to help synchronize it to close the race condition.

Update driver version to 3.123.

Signed-off-by: Michael Chan <mchan@broadcom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/broadcom/tg3.c
drivers/net/ethernet/broadcom/tg3.h