Commit 9067eccd authored by Sebastian Andrzej Siewior's avatar Sebastian Andrzej Siewior Committed by Jakub Kicinski

cxgb4: Properly lock TX queue for the selftest.

The selftest for the driver sends a dummy packet and checks if the
packet will be received properly as it should be. The regular TX path
and the selftest can use the same network queue so locking is required
and was missing in the selftest path. This was addressed in the commit
cited below.
Unfortunately locking the TX queue requires BH to be disabled which is
not the case in selftest path which is invoked in process context.
Lockdep should be complaining about this.

Use __netif_tx_lock_bh() for TX queue locking.

Fixes: c650e048 ("cxgb4: Fix race between loopback and normal Tx path")
Reported-by: default avatar"John B. Wyatt IV" <jwyatt@redhat.com>
Closes: https://lore.kernel.org/all/Zic0ot5aGgR-V4Ks@thinkpad2021/Signed-off-by: default avatarSebastian Andrzej Siewior <bigeasy@linutronix.de>
Link: https://lore.kernel.org/r/20240429091147.YWAaal4v@linutronix.deSigned-off-by: default avatarJakub Kicinski <kuba@kernel.org>
parent 9f8eeea1
...@@ -2670,12 +2670,12 @@ int cxgb4_selftest_lb_pkt(struct net_device *netdev) ...@@ -2670,12 +2670,12 @@ int cxgb4_selftest_lb_pkt(struct net_device *netdev)
lb->loopback = 1; lb->loopback = 1;
q = &adap->sge.ethtxq[pi->first_qset]; q = &adap->sge.ethtxq[pi->first_qset];
__netif_tx_lock(q->txq, smp_processor_id()); __netif_tx_lock_bh(q->txq);
reclaim_completed_tx(adap, &q->q, -1, true); reclaim_completed_tx(adap, &q->q, -1, true);
credits = txq_avail(&q->q) - ndesc; credits = txq_avail(&q->q) - ndesc;
if (unlikely(credits < 0)) { if (unlikely(credits < 0)) {
__netif_tx_unlock(q->txq); __netif_tx_unlock_bh(q->txq);
return -ENOMEM; return -ENOMEM;
} }
...@@ -2710,7 +2710,7 @@ int cxgb4_selftest_lb_pkt(struct net_device *netdev) ...@@ -2710,7 +2710,7 @@ int cxgb4_selftest_lb_pkt(struct net_device *netdev)
init_completion(&lb->completion); init_completion(&lb->completion);
txq_advance(&q->q, ndesc); txq_advance(&q->q, ndesc);
cxgb4_ring_tx_db(adap, &q->q, ndesc); cxgb4_ring_tx_db(adap, &q->q, ndesc);
__netif_tx_unlock(q->txq); __netif_tx_unlock_bh(q->txq);
/* wait for the pkt to return */ /* wait for the pkt to return */
ret = wait_for_completion_timeout(&lb->completion, 10 * HZ); ret = wait_for_completion_timeout(&lb->completion, 10 * HZ);
......
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