wcn36xx: don't disable RX IRQ from handler
There's no need to disable the IRQ from inside its handler. Instead just grab the spinlock of the channel that is being processed. Signed-off-by: Daniel Mack <daniel@zonque.org> Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
This commit is contained in:
parent
57e06e0e2a
commit
ba437e7237
|
@ -476,9 +476,8 @@ static irqreturn_t wcn36xx_irq_rx_ready(int irq, void *dev)
|
||||||
{
|
{
|
||||||
struct wcn36xx *wcn = (struct wcn36xx *)dev;
|
struct wcn36xx *wcn = (struct wcn36xx *)dev;
|
||||||
|
|
||||||
disable_irq_nosync(wcn->rx_irq);
|
|
||||||
wcn36xx_dxe_rx_frame(wcn);
|
wcn36xx_dxe_rx_frame(wcn);
|
||||||
enable_irq(wcn->rx_irq);
|
|
||||||
return IRQ_HANDLED;
|
return IRQ_HANDLED;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -514,8 +513,8 @@ out_err:
|
||||||
static int wcn36xx_rx_handle_packets(struct wcn36xx *wcn,
|
static int wcn36xx_rx_handle_packets(struct wcn36xx *wcn,
|
||||||
struct wcn36xx_dxe_ch *ch)
|
struct wcn36xx_dxe_ch *ch)
|
||||||
{
|
{
|
||||||
struct wcn36xx_dxe_ctl *ctl = ch->head_blk_ctl;
|
struct wcn36xx_dxe_desc *dxe;
|
||||||
struct wcn36xx_dxe_desc *dxe = ctl->desc;
|
struct wcn36xx_dxe_ctl *ctl;
|
||||||
dma_addr_t dma_addr;
|
dma_addr_t dma_addr;
|
||||||
struct sk_buff *skb;
|
struct sk_buff *skb;
|
||||||
int ret = 0, int_mask;
|
int ret = 0, int_mask;
|
||||||
|
@ -529,6 +528,11 @@ static int wcn36xx_rx_handle_packets(struct wcn36xx *wcn,
|
||||||
int_mask = WCN36XX_DXE_INT_CH3_MASK;
|
int_mask = WCN36XX_DXE_INT_CH3_MASK;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
spin_lock(&ch->lock);
|
||||||
|
|
||||||
|
ctl = ch->head_blk_ctl;
|
||||||
|
dxe = ctl->desc;
|
||||||
|
|
||||||
while (!(READ_ONCE(dxe->ctrl) & WCN36xx_DXE_CTRL_VLD)) {
|
while (!(READ_ONCE(dxe->ctrl) & WCN36xx_DXE_CTRL_VLD)) {
|
||||||
skb = ctl->skb;
|
skb = ctl->skb;
|
||||||
dma_addr = dxe->dst_addr_l;
|
dma_addr = dxe->dst_addr_l;
|
||||||
|
@ -549,6 +553,9 @@ static int wcn36xx_rx_handle_packets(struct wcn36xx *wcn,
|
||||||
wcn36xx_dxe_write_register(wcn, WCN36XX_DXE_ENCH_ADDR, int_mask);
|
wcn36xx_dxe_write_register(wcn, WCN36XX_DXE_ENCH_ADDR, int_mask);
|
||||||
|
|
||||||
ch->head_blk_ctl = ctl;
|
ch->head_blk_ctl = ctl;
|
||||||
|
|
||||||
|
spin_unlock(&ch->lock);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue