|
@@ -4849,16 +4849,18 @@ static const struct {
|
|
|
|
|
|
static void bnx2x_stats_handle(struct bnx2x *bp, enum bnx2x_stats_event event)
|
|
|
{
|
|
|
- enum bnx2x_stats_state state = bp->stats_state;
|
|
|
+ enum bnx2x_stats_state state;
|
|
|
|
|
|
if (unlikely(bp->panic))
|
|
|
return;
|
|
|
|
|
|
- bnx2x_stats_stm[state][event].action(bp);
|
|
|
+ /* Protect a state change flow */
|
|
|
+ spin_lock_bh(&bp->stats_lock);
|
|
|
+ state = bp->stats_state;
|
|
|
bp->stats_state = bnx2x_stats_stm[state][event].next_state;
|
|
|
+ spin_unlock_bh(&bp->stats_lock);
|
|
|
|
|
|
- /* Make sure the state has been "changed" */
|
|
|
- smp_wmb();
|
|
|
+ bnx2x_stats_stm[state][event].action(bp);
|
|
|
|
|
|
if ((event != STATS_EVENT_UPDATE) || netif_msg_timer(bp))
|
|
|
DP(BNX2X_MSG_STATS, "state %d -> event %d -> state %d\n",
|
|
@@ -9908,6 +9910,7 @@ static int __devinit bnx2x_init_bp(struct bnx2x *bp)
|
|
|
|
|
|
mutex_init(&bp->port.phy_mutex);
|
|
|
mutex_init(&bp->fw_mb_mutex);
|
|
|
+ spin_lock_init(&bp->stats_lock);
|
|
|
#ifdef BCM_CNIC
|
|
|
mutex_init(&bp->cnic_mutex);
|
|
|
#endif
|