提交 d41776fa 编写于 作者: G Grazvydas Ignotas 提交者: John W. Linville

wl1251: fix event handling mechanism

In case both A and B events occured simultaneously, current code
would only process A and clear both interrupts. Make it process both
events instead.

Based on wl1271 patches by Juuso Oikarinen:
1fd2794f
13f2dc52Signed-off-by: NGrazvydas Ignotas <notasas@gmail.com>
Acked-by: NKalle Valo <kvalo@adurom.com>
Signed-off-by: NJohn W. Linville <linville@tuxdriver.com>
上级 8d5ad085
...@@ -293,14 +293,14 @@ static void wl1251_irq_work(struct work_struct *work) ...@@ -293,14 +293,14 @@ static void wl1251_irq_work(struct work_struct *work)
wl1251_tx_complete(wl); wl1251_tx_complete(wl);
} }
if (intr & (WL1251_ACX_INTR_EVENT_A | if (intr & WL1251_ACX_INTR_EVENT_A) {
WL1251_ACX_INTR_EVENT_B)) { wl1251_debug(DEBUG_IRQ, "WL1251_ACX_INTR_EVENT_A");
wl1251_debug(DEBUG_IRQ, "WL1251_ACX_INTR_EVENT (0x%x)", wl1251_event_handle(wl, 0);
intr); }
if (intr & WL1251_ACX_INTR_EVENT_A)
wl1251_event_handle(wl, 0); if (intr & WL1251_ACX_INTR_EVENT_B) {
else wl1251_debug(DEBUG_IRQ, "WL1251_ACX_INTR_EVENT_B");
wl1251_event_handle(wl, 1); wl1251_event_handle(wl, 1);
} }
if (intr & WL1251_ACX_INTR_INIT_COMPLETE) if (intr & WL1251_ACX_INTR_INIT_COMPLETE)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册