mac802154: util: fix release queue handling
The semantic of atomic_dec_and_test() is to return true if zero is
reached and we need call ieee802154_wake_queue() when zero is reached.
Fixes: 20a19d1df3
("net: mac802154: Bring the ability to hold the transmit queue")
Signed-off-by: Alexander Aring <aahringo@redhat.com>
Reviewed-by: Miquel Raynal <miquel.raynal@bootlin.com>
Link: https://lore.kernel.org/r/20220613043735.1039895-2-aahringo@redhat.com
Signed-off-by: Stefan Schmidt <stefan@datenfreihafen.org>
This commit is contained in:
parent
4f79018413
commit
2ec2f6bed4
|
@ -79,7 +79,7 @@ void ieee802154_release_queue(struct ieee802154_local *local)
|
|||
unsigned long flags;
|
||||
|
||||
spin_lock_irqsave(&local->phy->queue_lock, flags);
|
||||
if (!atomic_dec_and_test(&local->phy->hold_txs))
|
||||
if (atomic_dec_and_test(&local->phy->hold_txs))
|
||||
ieee802154_wake_queue(&local->hw);
|
||||
spin_unlock_irqrestore(&local->phy->queue_lock, flags);
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue