mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2024-09-29 22:02:02 +00:00
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
1 changed files with 1 additions and 1 deletions
|
@ -79,7 +79,7 @@ void ieee802154_release_queue(struct ieee802154_local *local)
|
||||||
unsigned long flags;
|
unsigned long flags;
|
||||||
|
|
||||||
spin_lock_irqsave(&local->phy->queue_lock, 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);
|
ieee802154_wake_queue(&local->hw);
|
||||||
spin_unlock_irqrestore(&local->phy->queue_lock, flags);
|
spin_unlock_irqrestore(&local->phy->queue_lock, flags);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue