Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp3972922pxb; Tue, 19 Apr 2022 13:56:29 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwaw3Atv2kpmsjlVYxRes5xLS3x7iKSsYmMxlc1oQBcLHTLY3qoJRMq9+nBfHybAV78Qttf X-Received: by 2002:a63:907:0:b0:374:b3c2:2df2 with SMTP id 7-20020a630907000000b00374b3c22df2mr15988367pgj.614.1650401788842; Tue, 19 Apr 2022 13:56:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1650401788; cv=none; d=google.com; s=arc-20160816; b=lnwgLzXqhaxxoFkg3teupfaLOcQLewPfj7vBd1x1LybnPQVB9Gtuim7aZd+NbtB91G 4mJYNvFWrfhVzk7dkoWFGqKApeHGj1wtCCofa6V15Wt+xEJsM/zIuUuu/ioWyp5Nrz/r iY3YnEw62ZCmpMpm5tMCrMJjAyNxKwG7RwYVTdTGGQYP32EO8d8V/fFjOr9Pm2RXB57i y1AD+wIeR2KckcWlKqH0OjnZjb2YJ7mELBRFC2JM2o70bjXjOKF9KNulBirlqsgdJzuv pDk6W0t/Fu3jlcnKpGJ5VfRPWVurSNlNuznHkPjOZZoz97dDf4YWa1uERqkrh6FnZrzV +v3A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=ey/QxKrmIg4OHNN548GIlGe6ZJvuEI0Sxc4t94+i5eQ=; b=TBEsFCOYvAz0WXwqP89Eks5sKNit5EXNv71+GXazhiKr/em3/mw1SO2X+006jPak5c dtfOB85TDWO4xU1KIVShUkGIlCQeorGKfUIKtjVlgueUuwAeahN0QBq1g4k7yDNG16vV d/rgSgXxL7aQhWcr1vpqgZaSbhh8tQ2JEhOiklm+CQAAyy2NhPpyM9JNslLGiUMG9ZzX ye13tgivChYyhvM8xEMKMD9as/nwj9J4GwQGDBB3+5Lj8QdOwa80XxmzCFOsIujMeT1T ZcvRrbHU6/gr5wSJc2VY+NPpWEk9An627oAjY0ODyz/R8dXurb1uI4FPUAVJSL9NksW2 QS0Q== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=windriver.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id q5-20020a170903204500b00153b2d16424si266303pla.44.2022.04.19.13.56.12; Tue, 19 Apr 2022 13:56:28 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=windriver.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1351744AbiDSLn2 (ORCPT + 99 others); Tue, 19 Apr 2022 07:43:28 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46330 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1352318AbiDSLnK (ORCPT ); Tue, 19 Apr 2022 07:43:10 -0400 Received: from mail1.wrs.com (unknown-3-146.windriver.com [147.11.3.146]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 0AE2F167C3; Tue, 19 Apr 2022 04:40:20 -0700 (PDT) Received: from ala-exchng01.corp.ad.wrs.com (ala-exchng01.corp.ad.wrs.com [147.11.82.252]) by mail1.wrs.com (8.15.2/8.15.2) with ESMTPS id 23JBTO9X002576 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Tue, 19 Apr 2022 04:29:24 -0700 Received: from otp-dpanait-l2.corp.ad.wrs.com (128.224.125.182) by ala-exchng01.corp.ad.wrs.com (147.11.82.252) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256) id 15.1.2242.12; Tue, 19 Apr 2022 04:29:21 -0700 From: Dragos-Marian Panait To: CC: , , , , , , , , , Subject: [PATCH 5.4 1/1] can: usb_8dev: usb_8dev_start_xmit(): fix double dev_kfree_skb() in error path Date: Tue, 19 Apr 2022 14:28:21 +0300 Message-ID: <20220419112821.3112299-2-dragos.panait@windriver.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220419112821.3112299-1-dragos.panait@windriver.com> References: <20220419112821.3112299-1-dragos.panait@windriver.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7BIT Content-Type: text/plain; charset=US-ASCII X-Originating-IP: [128.224.125.182] X-ClientProxiedBy: ala-exchng01.corp.ad.wrs.com (147.11.82.252) To ala-exchng01.corp.ad.wrs.com (147.11.82.252) X-Spam-Status: No, score=-1.2 required=5.0 tests=BAYES_00,KHOP_HELO_FCRDNS, SPF_HELO_NONE,SPF_SOFTFAIL,T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Hangyu Hua commit 3d3925ff6433f98992685a9679613a2cc97f3ce2 upstream. There is no need to call dev_kfree_skb() when usb_submit_urb() fails because can_put_echo_skb() deletes original skb and can_free_echo_skb() deletes the cloned skb. Fixes: 0024d8ad1639 ("can: usb_8dev: Add support for USB2CAN interface from 8 devices") Link: https://lore.kernel.org/all/20220311080614.45229-1-hbh25y@gmail.com Cc: stable@vger.kernel.org Signed-off-by: Hangyu Hua Signed-off-by: Marc Kleine-Budde [DP: adjusted params of can_free_echo_skb() for 5.4 stable] Signed-off-by: Dragos-Marian Panait --- drivers/net/can/usb/usb_8dev.c | 30 ++++++++++++++---------------- 1 file changed, 14 insertions(+), 16 deletions(-) diff --git a/drivers/net/can/usb/usb_8dev.c b/drivers/net/can/usb/usb_8dev.c index c43e98bb6e2d..b514b2eaa318 100644 --- a/drivers/net/can/usb/usb_8dev.c +++ b/drivers/net/can/usb/usb_8dev.c @@ -670,9 +670,20 @@ static netdev_tx_t usb_8dev_start_xmit(struct sk_buff *skb, atomic_inc(&priv->active_tx_urbs); err = usb_submit_urb(urb, GFP_ATOMIC); - if (unlikely(err)) - goto failed; - else if (atomic_read(&priv->active_tx_urbs) >= MAX_TX_URBS) + if (unlikely(err)) { + can_free_echo_skb(netdev, context->echo_index); + + usb_unanchor_urb(urb); + usb_free_coherent(priv->udev, size, buf, urb->transfer_dma); + + atomic_dec(&priv->active_tx_urbs); + + if (err == -ENODEV) + netif_device_detach(netdev); + else + netdev_warn(netdev, "failed tx_urb %d\n", err); + stats->tx_dropped++; + } else if (atomic_read(&priv->active_tx_urbs) >= MAX_TX_URBS) /* Slow down tx path */ netif_stop_queue(netdev); @@ -691,19 +702,6 @@ static netdev_tx_t usb_8dev_start_xmit(struct sk_buff *skb, return NETDEV_TX_BUSY; -failed: - can_free_echo_skb(netdev, context->echo_index); - - usb_unanchor_urb(urb); - usb_free_coherent(priv->udev, size, buf, urb->transfer_dma); - - atomic_dec(&priv->active_tx_urbs); - - if (err == -ENODEV) - netif_device_detach(netdev); - else - netdev_warn(netdev, "failed tx_urb %d\n", err); - nomembuf: usb_free_urb(urb); -- 2.17.1