diff options
author | Eilon Greenstein <eilong@broadcom.com> | 2009-08-12 04:23:56 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2009-08-13 02:02:55 -0400 |
commit | 8924665a7d77bb79ee895b98864e3201507f6ef2 (patch) | |
tree | d26483fc10f8d86504494ac8d65f224de23a959a /drivers/net/bnx2x_main.c | |
parent | 57937203aa077520a7e1665bfb7071b3cbb3f5a9 (diff) |
bnx2x: Missing smp_wmb for statistics state machine
Signed-off-by: Vladislav Zolotarov <vladz@broadcom.com>
Signed-off-by: Eilon Greenstein <eilong@broadcom.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/bnx2x_main.c')
-rw-r--r-- | drivers/net/bnx2x_main.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/net/bnx2x_main.c b/drivers/net/bnx2x_main.c index edd7b137b76c..1e8e7e1efbd6 100644 --- a/drivers/net/bnx2x_main.c +++ b/drivers/net/bnx2x_main.c | |||
@@ -4412,6 +4412,9 @@ static void bnx2x_stats_handle(struct bnx2x *bp, enum bnx2x_stats_event event) | |||
4412 | bnx2x_stats_stm[state][event].action(bp); | 4412 | bnx2x_stats_stm[state][event].action(bp); |
4413 | bp->stats_state = bnx2x_stats_stm[state][event].next_state; | 4413 | bp->stats_state = bnx2x_stats_stm[state][event].next_state; |
4414 | 4414 | ||
4415 | /* Make sure the state has been "changed" */ | ||
4416 | smp_wmb(); | ||
4417 | |||
4415 | if ((event != STATS_EVENT_UPDATE) || (bp->msglevel & NETIF_MSG_TIMER)) | 4418 | if ((event != STATS_EVENT_UPDATE) || (bp->msglevel & NETIF_MSG_TIMER)) |
4416 | DP(BNX2X_MSG_STATS, "state %d -> event %d -> state %d\n", | 4419 | DP(BNX2X_MSG_STATS, "state %d -> event %d -> state %d\n", |
4417 | state, event, bp->stats_state); | 4420 | state, event, bp->stats_state); |