|
@@ -27,6 +27,8 @@
|
|
|
void lbs_mac_event_disconnected(struct lbs_private *priv,
|
|
|
bool locally_generated)
|
|
|
{
|
|
|
+ unsigned long flags;
|
|
|
+
|
|
|
if (priv->connect_status != LBS_CONNECTED)
|
|
|
return;
|
|
|
|
|
@@ -46,9 +48,11 @@ void lbs_mac_event_disconnected(struct lbs_private *priv,
|
|
|
netif_carrier_off(priv->dev);
|
|
|
|
|
|
/* Free Tx and Rx packets */
|
|
|
+ spin_lock_irqsave(&priv->driver_lock, flags);
|
|
|
kfree_skb(priv->currenttxskb);
|
|
|
priv->currenttxskb = NULL;
|
|
|
priv->tx_pending_len = 0;
|
|
|
+ spin_unlock_irqrestore(&priv->driver_lock, flags);
|
|
|
|
|
|
priv->connect_status = LBS_DISCONNECTED;
|
|
|
|