net: wireless: bcmdhd: Fix event thread termination in case of empty queue
authorDmitry Shmidt <dimitrysh@google.com>
Wed, 5 Oct 2011 17:48:59 +0000 (10:48 -0700)
committerDmitry Shmidt <dimitrysh@google.com>
Thu, 6 Oct 2011 17:39:55 +0000 (10:39 -0700)
Signed-off-by: Dmitry Shmidt <dimitrysh@google.com>
drivers/net/wireless/bcmdhd/wl_cfg80211.c

index 1eaf512b6f2e3c032d9c7ffb06a67d1ea2589114..a576ca38db79923f7284910e2e25ee45c749bd42 100644 (file)
@@ -5735,22 +5735,18 @@ static s32 wl_event_handler(void *data)
                SMP_RD_BARRIER_DEPENDS();
                if (tsk->terminated)
                        break;
-               e = wl_deq_event(wl);
-               if (unlikely(!e)) {
-                       WL_ERR(("equeue empty..\n"));
-                       DHD_OS_WAKE_UNLOCK(wl->pub);
-                       return 0;
-               }
-               WL_DBG(("event type (%d), if idx: %d\n", e->etype, e->emsg.ifidx));
-               netdev = dhd_idx2net((struct dhd_pub *)(wl->pub), e->emsg.ifidx);
-               if (!netdev)
-                       netdev = wl_to_prmry_ndev(wl);
-               if (e->etype < WLC_E_LAST && wl->evt_handler[e->etype]) {
-                       wl->evt_handler[e->etype] (wl, netdev, &e->emsg, e->edata);
-               } else {
-                       WL_DBG(("Unknown Event (%d): ignoring\n", e->etype));
+               while ((e = wl_deq_event(wl))) {
+                       WL_DBG(("event type (%d), if idx: %d\n", e->etype, e->emsg.ifidx));
+                       netdev = dhd_idx2net((struct dhd_pub *)(wl->pub), e->emsg.ifidx);
+                       if (!netdev)
+                               netdev = wl_to_prmry_ndev(wl);
+                       if (e->etype < WLC_E_LAST && wl->evt_handler[e->etype]) {
+                               wl->evt_handler[e->etype] (wl, netdev, &e->emsg, e->edata);
+                       } else {
+                               WL_DBG(("Unknown Event (%d): ignoring\n", e->etype));
+                       }
+                       wl_put_event(e);
                }
-               wl_put_event(e);
                DHD_OS_WAKE_UNLOCK(wl->pub);
        }
        WL_DBG(("%s was terminated\n", __func__));