mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-28 11:18:45 +07:00
iwlwifi: pcie: lock txq a bit later in reclaim code
In reclaim code, we don't need to take the queue lock for waking the queue. The code section is executed only when the tx path is stopped, and since the reclaim path is not executed in parallel to itself, no one can update the queue pointers, and accessing them is safe without a lock. Signed-off-by: Sara Sharon <sara.sharon@intel.com> Signed-off-by: Luca Coelho <luciano.coelho@intel.com> Signed-off-by: Kalle Valo <kvalo@codeaurora.org>
This commit is contained in:
parent
83eabf1e98
commit
3681729429
@ -1160,10 +1160,11 @@ void iwl_trans_pcie_reclaim(struct iwl_trans *trans, int txq_id, int ssn,
|
|||||||
*/
|
*/
|
||||||
iwl_trans_tx(trans, skb, dev_cmd_ptr, txq_id);
|
iwl_trans_tx(trans, skb, dev_cmd_ptr, txq_id);
|
||||||
}
|
}
|
||||||
spin_lock_bh(&txq->lock);
|
|
||||||
|
|
||||||
if (iwl_queue_space(trans, txq) > txq->low_mark)
|
if (iwl_queue_space(trans, txq) > txq->low_mark)
|
||||||
iwl_wake_queue(trans, txq);
|
iwl_wake_queue(trans, txq);
|
||||||
|
|
||||||
|
spin_lock_bh(&txq->lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (txq->read_ptr == txq->write_ptr) {
|
if (txq->read_ptr == txq->write_ptr) {
|
||||||
|
Loading…
Reference in New Issue
Block a user