diff options
author | Jimmy Assarsson <jimmyassarsson@gmail.com> | 2017-11-21 02:22:26 -0500 |
---|---|---|
committer | Marc Kleine-Budde <mkl@pengutronix.de> | 2017-12-01 05:20:52 -0500 |
commit | 435019b48033138581a6171093b181fc6b4d3d30 (patch) | |
tree | 3d6b57731ed91293bc89eed60d87d02f92345141 | |
parent | 6fef90c6b3f6a2b52018e66c0886944ea0c03fcc (diff) |
can: kvaser_usb: free buf in error paths
The allocated buffer was not freed if usb_submit_urb() failed.
Signed-off-by: Jimmy Assarsson <jimmyassarsson@gmail.com>
Cc: linux-stable <stable@vger.kernel.org>
Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
-rw-r--r-- | drivers/net/can/usb/kvaser_usb.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/net/can/usb/kvaser_usb.c b/drivers/net/can/usb/kvaser_usb.c index 9b18d96ef526..075644591498 100644 --- a/drivers/net/can/usb/kvaser_usb.c +++ b/drivers/net/can/usb/kvaser_usb.c | |||
@@ -813,6 +813,7 @@ static int kvaser_usb_simple_msg_async(struct kvaser_usb_net_priv *priv, | |||
813 | if (err) { | 813 | if (err) { |
814 | netdev_err(netdev, "Error transmitting URB\n"); | 814 | netdev_err(netdev, "Error transmitting URB\n"); |
815 | usb_unanchor_urb(urb); | 815 | usb_unanchor_urb(urb); |
816 | kfree(buf); | ||
816 | usb_free_urb(urb); | 817 | usb_free_urb(urb); |
817 | return err; | 818 | return err; |
818 | } | 819 | } |
@@ -1768,6 +1769,7 @@ static netdev_tx_t kvaser_usb_start_xmit(struct sk_buff *skb, | |||
1768 | spin_unlock_irqrestore(&priv->tx_contexts_lock, flags); | 1769 | spin_unlock_irqrestore(&priv->tx_contexts_lock, flags); |
1769 | 1770 | ||
1770 | usb_unanchor_urb(urb); | 1771 | usb_unanchor_urb(urb); |
1772 | kfree(buf); | ||
1771 | 1773 | ||
1772 | stats->tx_dropped++; | 1774 | stats->tx_dropped++; |
1773 | 1775 | ||