Received: by 2002:a05:6a10:6d10:0:0:0:0 with SMTP id gq16csp4295011pxb; Tue, 19 Apr 2022 23:16:11 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxWKsiID4Upxny45C0+GKaVpe6bnCHiJ0TbhGXk28mQy9QF7lOmcuPYlmX1sehbXANFYI9q X-Received: by 2002:a17:906:5006:b0:6ce:3762:c72e with SMTP id s6-20020a170906500600b006ce3762c72emr16795076ejj.30.1650435371709; Tue, 19 Apr 2022 23:16:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1650435371; cv=none; d=google.com; s=arc-20160816; b=bGIMDel2M3Ldg3u9Vk7Y49dj9y5FM3z8zBGVe5uU9i9QfNSb/uLewBn2DwuA1Gfrcp ngMlv4ZWl/DH3fCTs7twiBV6FEDZQAK3GjJVHqmvesS7SxsZ6OvxzWWJ55BcS0vUdix5 S/r/piQA2SIlwLKLkOcNHzxpGPfR6+apnsrQ8UP6y8jb3cRWnuGE5BQ0ZM5VezwSb4X8 zdoBs3mGmuzyY7GXMsB50IpmvN579NSL54H/pJqbb4ssGhZDmSP6SwAmwRbNqbrsg8h7 LNLFmLQrAJ6KExH0dMz/ysoF0gKKs1KWZgasfEphbJ3jvULGJyakCaOji+BVdc6ia9Jp h8Pg== 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=Uai4estFyDpG/FteLsGLnC5P+6PN62ekSaC902emWsU=; b=UWz7jTjhQ1biK9vU1An9+9ZN6izoiCLUoJeye0S4eU1leqCfYJtdDTPxs94AP3TOt6 xfnV90k1kS8hjvOxLqqr8zQIGUO5RLkNf1dDrN3PzYFToBSAhmAmSacu24exYHDXBpAo QxNqf6SxgsFL9iG3VU6mNTK/8/o4l5Nv9o+QVPt+XK1KvaiybfhhF1PbqmdhzTn/qRYl 7L0h1H+Ybb5tqhNO2F4SgVEPV67RLpq/nHjX9bYWWAkbW7Cm9519w0Z3RRrCu3r6/lMW DCRuXUwJUUOUYPNjDfE/jAHU3KSOqj94JQDnAMs9mJEenAvazhy0gnY2JBaTkrk2o5WS 8tqA== 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 h14-20020aa7c5ce000000b00423f55d46c9si659423eds.285.2022.04.19.23.15.47; Tue, 19 Apr 2022 23:16:11 -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 S1351919AbiDSLnd (ORCPT + 99 others); Tue, 19 Apr 2022 07:43:33 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44180 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1352319AbiDSLnK (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 1A1211BE96; Tue, 19 Apr 2022 04:40:21 -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 23JBbinf005017 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Tue, 19 Apr 2022 04:37:44 -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:37:42 -0700 From: Dragos-Marian Panait To: CC: , , , , , , , , , Subject: [PATCH 4.19 1/1] can: usb_8dev: usb_8dev_start_xmit(): fix double dev_kfree_skb() in error path Date: Tue, 19 Apr 2022 14:36:42 +0300 Message-ID: <20220419113642.3115359-2-dragos.panait@windriver.com> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20220419113642.3115359-1-dragos.panait@windriver.com> References: <20220419113642.3115359-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 4.19 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 df99354ec12a..232f45f722f0 100644 --- a/drivers/net/can/usb/usb_8dev.c +++ b/drivers/net/can/usb/usb_8dev.c @@ -681,9 +681,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); @@ -702,19 +713,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