Commit 32b249b0 authored by Malcolm Priestley's avatar Malcolm Priestley Committed by Greg Kroah-Hartman

staging: vt6655: device_intr check for vif on while loop

vif should never be or go null while in loop.

Fixes race condition where interrupts are late and when
interface is not present.
Signed-off-by: default avatarMalcolm Priestley <tvboxspy@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent aeda3b2d
...@@ -1090,7 +1090,7 @@ static irqreturn_t device_intr(int irq, void *dev_instance) ...@@ -1090,7 +1090,7 @@ static irqreturn_t device_intr(int irq, void *dev_instance)
* update ISR counter * update ISR counter
*/ */
STAvUpdate802_11Counter(&pDevice->s802_11Counter, &pDevice->scStatistic, dwMIBCounter); STAvUpdate802_11Counter(&pDevice->s802_11Counter, &pDevice->scStatistic, dwMIBCounter);
while (pDevice->dwIsr != 0) { while (pDevice->dwIsr && pDevice->vif) {
STAvUpdateIsrStatCounter(&pDevice->scStatistic, pDevice->dwIsr); STAvUpdateIsrStatCounter(&pDevice->scStatistic, pDevice->dwIsr);
MACvWriteISR(pDevice->PortOffset, pDevice->dwIsr); MACvWriteISR(pDevice->PortOffset, pDevice->dwIsr);
...@@ -1102,8 +1102,7 @@ static irqreturn_t device_intr(int irq, void *dev_instance) ...@@ -1102,8 +1102,7 @@ static irqreturn_t device_intr(int irq, void *dev_instance)
} }
if (pDevice->dwIsr & ISR_TBTT) { if (pDevice->dwIsr & ISR_TBTT) {
if (pDevice->vif && if (pDevice->op_mode != NL80211_IFTYPE_ADHOC)
pDevice->op_mode != NL80211_IFTYPE_ADHOC)
vnt_check_bb_vga(pDevice); vnt_check_bb_vga(pDevice);
pDevice->bBeaconSent = false; pDevice->bBeaconSent = false;
...@@ -1143,19 +1142,15 @@ static irqreturn_t device_intr(int irq, void *dev_instance) ...@@ -1143,19 +1142,15 @@ static irqreturn_t device_intr(int irq, void *dev_instance)
max_count += device_tx_srv(pDevice, TYPE_AC0DMA); max_count += device_tx_srv(pDevice, TYPE_AC0DMA);
if (pDevice->dwIsr & ISR_SOFTTIMER1) { if (pDevice->dwIsr & ISR_SOFTTIMER1) {
if (pDevice->vif) {
if (pDevice->vif->bss_conf.enable_beacon) if (pDevice->vif->bss_conf.enable_beacon)
vnt_beacon_make(pDevice, pDevice->vif); vnt_beacon_make(pDevice, pDevice->vif);
} }
}
/* If both buffers available wake the queue */ /* If both buffers available wake the queue */
if (pDevice->vif) {
if (AVAIL_TD(pDevice, TYPE_TXDMA0) && if (AVAIL_TD(pDevice, TYPE_TXDMA0) &&
AVAIL_TD(pDevice, TYPE_AC0DMA) && AVAIL_TD(pDevice, TYPE_AC0DMA) &&
ieee80211_queue_stopped(pDevice->hw, 0)) ieee80211_queue_stopped(pDevice->hw, 0))
ieee80211_wake_queues(pDevice->hw); ieee80211_wake_queues(pDevice->hw);
}
MACvReadISR(pDevice->PortOffset, &pDevice->dwIsr); MACvReadISR(pDevice->PortOffset, &pDevice->dwIsr);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment