mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-11 07:39:47 +00:00
mac802154: tx: fix error handling while xmit
In case of an error we should call kfree_skb instead of consume_skb which is called by ieee802154_xmit_complete function. Signed-off-by: Alexander Aring <alex.aring@gmail.com> Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
This commit is contained in:
parent
18d60a0d49
commit
cdb66beaa0
@ -51,12 +51,16 @@ static void mac802154_xmit_worker(struct work_struct *work)
|
|||||||
int res;
|
int res;
|
||||||
|
|
||||||
res = local->ops->xmit(&local->hw, skb);
|
res = local->ops->xmit(&local->hw, skb);
|
||||||
if (res)
|
if (res) {
|
||||||
pr_debug("transmission failed\n");
|
pr_debug("transmission failed\n");
|
||||||
|
/* Restart the netif queue on each sub_if_data object. */
|
||||||
|
ieee802154_wake_queue(&local->hw);
|
||||||
|
kfree_skb(skb);
|
||||||
|
} else {
|
||||||
/* Restart the netif queue on each sub_if_data object. */
|
/* Restart the netif queue on each sub_if_data object. */
|
||||||
ieee802154_xmit_complete(&local->hw, skb);
|
ieee802154_xmit_complete(&local->hw, skb);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static netdev_tx_t
|
static netdev_tx_t
|
||||||
mac802154_tx(struct ieee802154_local *local, struct sk_buff *skb)
|
mac802154_tx(struct ieee802154_local *local, struct sk_buff *skb)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user