提交 b2713f67 编写于 作者: S Shengzhen Li 提交者: Kalle Valo

mwifiex: avoid queue_work while work is ongoing

Current code does not check whether main_work_queue or
rx_work_queue is running when preparing to do queue_work,
this code fix add check before calling queue_work, reducing
unnecessary queue_work switch.

This change instead sets more_task flag to ensure we run main_process
superloop once again.
Signed-off-by: NShengzhen Li <szli@marvell.com>
Signed-off-by: NZhaoyang Liu <liuzy@marvell.com>
Reviewed-by: NCathy Luo <cluo@marvell.com>
Reviewed-by: NAmitkumar Karwar <akarwar@marvell.com>
Reviewed-by: NAvinash Patil <patila@marvell.com>
Signed-off-by: NKalle Valo <kvalo@codeaurora.org>
上级 ea44f4d0
...@@ -131,6 +131,34 @@ static int mwifiex_unregister(struct mwifiex_adapter *adapter) ...@@ -131,6 +131,34 @@ static int mwifiex_unregister(struct mwifiex_adapter *adapter)
return 0; return 0;
} }
void mwifiex_queue_main_work(struct mwifiex_adapter *adapter)
{
unsigned long flags;
spin_lock_irqsave(&adapter->main_proc_lock, flags);
if (adapter->mwifiex_processing) {
adapter->more_task_flag = true;
spin_unlock_irqrestore(&adapter->main_proc_lock, flags);
} else {
spin_unlock_irqrestore(&adapter->main_proc_lock, flags);
queue_work(adapter->workqueue, &adapter->main_work);
}
}
EXPORT_SYMBOL_GPL(mwifiex_queue_main_work);
static void mwifiex_queue_rx_work(struct mwifiex_adapter *adapter)
{
unsigned long flags;
spin_lock_irqsave(&adapter->rx_proc_lock, flags);
if (adapter->rx_processing) {
spin_unlock_irqrestore(&adapter->rx_proc_lock, flags);
} else {
spin_unlock_irqrestore(&adapter->rx_proc_lock, flags);
queue_work(adapter->rx_workqueue, &adapter->rx_work);
}
}
static int mwifiex_process_rx(struct mwifiex_adapter *adapter) static int mwifiex_process_rx(struct mwifiex_adapter *adapter)
{ {
unsigned long flags; unsigned long flags;
...@@ -154,7 +182,7 @@ static int mwifiex_process_rx(struct mwifiex_adapter *adapter) ...@@ -154,7 +182,7 @@ static int mwifiex_process_rx(struct mwifiex_adapter *adapter)
if (adapter->if_ops.submit_rem_rx_urbs) if (adapter->if_ops.submit_rem_rx_urbs)
adapter->if_ops.submit_rem_rx_urbs(adapter); adapter->if_ops.submit_rem_rx_urbs(adapter);
adapter->delay_main_work = false; adapter->delay_main_work = false;
queue_work(adapter->workqueue, &adapter->main_work); mwifiex_queue_main_work(adapter);
} }
mwifiex_handle_rx_packet(adapter, skb); mwifiex_handle_rx_packet(adapter, skb);
} }
...@@ -214,9 +242,7 @@ int mwifiex_main_process(struct mwifiex_adapter *adapter) ...@@ -214,9 +242,7 @@ int mwifiex_main_process(struct mwifiex_adapter *adapter)
if (atomic_read(&adapter->rx_pending) >= HIGH_RX_PENDING && if (atomic_read(&adapter->rx_pending) >= HIGH_RX_PENDING &&
adapter->iface_type != MWIFIEX_USB) { adapter->iface_type != MWIFIEX_USB) {
adapter->delay_main_work = true; adapter->delay_main_work = true;
if (!adapter->rx_processing) mwifiex_queue_rx_work(adapter);
queue_work(adapter->rx_workqueue,
&adapter->rx_work);
break; break;
} }
...@@ -229,7 +255,7 @@ int mwifiex_main_process(struct mwifiex_adapter *adapter) ...@@ -229,7 +255,7 @@ int mwifiex_main_process(struct mwifiex_adapter *adapter)
} }
if (adapter->rx_work_enabled && adapter->data_received) if (adapter->rx_work_enabled && adapter->data_received)
queue_work(adapter->rx_workqueue, &adapter->rx_work); mwifiex_queue_rx_work(adapter);
/* Need to wake up the card ? */ /* Need to wake up the card ? */
if ((adapter->ps_state == PS_STATE_SLEEP) && if ((adapter->ps_state == PS_STATE_SLEEP) &&
...@@ -606,7 +632,7 @@ int mwifiex_queue_tx_pkt(struct mwifiex_private *priv, struct sk_buff *skb) ...@@ -606,7 +632,7 @@ int mwifiex_queue_tx_pkt(struct mwifiex_private *priv, struct sk_buff *skb)
atomic_inc(&priv->adapter->tx_pending); atomic_inc(&priv->adapter->tx_pending);
mwifiex_wmm_add_buf_txqueue(priv, skb); mwifiex_wmm_add_buf_txqueue(priv, skb);
queue_work(priv->adapter->workqueue, &priv->adapter->main_work); mwifiex_queue_main_work(priv->adapter);
return 0; return 0;
} }
......
...@@ -1424,6 +1424,7 @@ u8 mwifiex_adjust_data_rate(struct mwifiex_private *priv, ...@@ -1424,6 +1424,7 @@ u8 mwifiex_adjust_data_rate(struct mwifiex_private *priv,
void mwifiex_dump_drv_info(struct mwifiex_adapter *adapter); void mwifiex_dump_drv_info(struct mwifiex_adapter *adapter);
void *mwifiex_alloc_dma_align_buf(int rx_len, gfp_t flags); void *mwifiex_alloc_dma_align_buf(int rx_len, gfp_t flags);
void mwifiex_queue_main_work(struct mwifiex_adapter *adapter);
#ifdef CONFIG_DEBUG_FS #ifdef CONFIG_DEBUG_FS
void mwifiex_debugfs_init(void); void mwifiex_debugfs_init(void);
......
...@@ -2101,7 +2101,7 @@ static irqreturn_t mwifiex_pcie_interrupt(int irq, void *context) ...@@ -2101,7 +2101,7 @@ static irqreturn_t mwifiex_pcie_interrupt(int irq, void *context)
goto exit; goto exit;
mwifiex_interrupt_status(adapter); mwifiex_interrupt_status(adapter);
queue_work(adapter->workqueue, &adapter->main_work); mwifiex_queue_main_work(adapter);
exit: exit:
return IRQ_HANDLED; return IRQ_HANDLED;
......
...@@ -193,7 +193,7 @@ static void mwifiex_usb_rx_complete(struct urb *urb) ...@@ -193,7 +193,7 @@ static void mwifiex_usb_rx_complete(struct urb *urb)
dev_dbg(adapter->dev, "info: recv_length=%d, status=%d\n", dev_dbg(adapter->dev, "info: recv_length=%d, status=%d\n",
recv_length, status); recv_length, status);
if (status == -EINPROGRESS) { if (status == -EINPROGRESS) {
queue_work(adapter->workqueue, &adapter->main_work); mwifiex_queue_main_work(adapter);
/* urb for data_ep is re-submitted now; /* urb for data_ep is re-submitted now;
* urb for cmd_ep will be re-submitted in callback * urb for cmd_ep will be re-submitted in callback
...@@ -262,7 +262,7 @@ static void mwifiex_usb_tx_complete(struct urb *urb) ...@@ -262,7 +262,7 @@ static void mwifiex_usb_tx_complete(struct urb *urb)
urb->status ? -1 : 0); urb->status ? -1 : 0);
} }
queue_work(adapter->workqueue, &adapter->main_work); mwifiex_queue_main_work(adapter);
return; return;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册