Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp431701pxj; Tue, 18 May 2021 06:40:09 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyrm385yNcu9OBqnNwReWzLZWg6t96nYd+6RqguxPk0oCjkxeSN11YkkKZjXdJXN/qWyrFV X-Received: by 2002:a5e:930d:: with SMTP id k13mr4173472iom.61.1621345209377; Tue, 18 May 2021 06:40:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1621345209; cv=none; d=google.com; s=arc-20160816; b=vovJvIZTI8uURxH8nzO5wn2mMFep4cL+/eNnAW5hhFBVyI1APUrGX5Q5raNT1mw7H4 2Sz0S08kry/zWJvSCEGAmdoruJmmuXCHULqwyTnuxPsBgioOhAGbhrG13RDTZzYIQltc j21B2vK6tpZay+A9F5l8ypuUYrtGBSTc6BjPrGmX78HZQ/wxIJbdC2f/UprK2JVqzKNH dYr+SjGDLjm1Ni1knrYnXQ4V3nhJKbpJXhK4rrjWIC0JLzf4Fr3DjWEg4S9+b43PZII9 vOMQ+JSIkb6FyN8m1+tJDf6ha+tSgloO5Stt3TrzwW8g//2w//wxziz94a/lk5s2fOcz LUlA== 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 :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=HlPnwPhEF1iq+sfHKhAZ/alMs0PiiMckPkHSfs7TpcQ=; b=gnoPVs4gPVoT4UUsFbcVzSpFh2sIi5HOt1Vh1xMdHWgA1/2TJr8GDdwwpDEmo2hoB3 MhopZRg+ET0NRNWK8qd3KFHP3Vdem4/EzBT7Jhr5gXHXvu+5oDnxi/3P7cTK1T5MagZZ y8/oHcwPivUbubD6LNUVIrWbOOluFUzvgl9EskTQbIgvRhlwlE+Swdb+6Irw9aHqbX+q fsrahfv+HJRrgtfntVk9JJpfj/7l4q3vd0csSbKIJVguPOCdatW+Ke9tPW39sYCDVY+h mb3hhXanf+zHLEMrrJdgatalHDv7r4omN26Qb+LkL/7wWiqZ0tOgKmwKy+ivytgR7rZp aEPQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=VsPevmkl; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id n20si132542jat.115.2021.05.18.06.39.56; Tue, 18 May 2021 06:40:09 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=VsPevmkl; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S244170AbhEQPjA (ORCPT + 99 others); Mon, 17 May 2021 11:39:00 -0400 Received: from mail.kernel.org ([198.145.29.99]:42054 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S238673AbhEQPXB (ORCPT ); Mon, 17 May 2021 11:23:01 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id 1B5DA61CA3; Mon, 17 May 2021 14:35:15 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1621262116; bh=iHKtszs9IIlWoFV7+AuVDwDxIjB0taP5A/9EBFJd1V4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=VsPevmkleIfsgmA56NkZjQPVhQe2yoRIRJvbKU/q/gDAzihAEO6dLMdFqH2yLSRtH bLVQvJTpJo43qpAstziB3OAjBM8/Yg6zB9yOui0haFkp3+mtCuThfwnOWVewTaDI93 bviaDUNG8akH0Z8SrOqncjJYkZrbyAvrgsx3Fv14= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Lv Yunlong , Govindarajulu Varadarajan , "David S. Miller" , Sasha Levin Subject: [PATCH 5.11 192/329] ethernet:enic: Fix a use after free bug in enic_hard_start_xmit Date: Mon, 17 May 2021 16:01:43 +0200 Message-Id: <20210517140308.624680293@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210517140302.043055203@linuxfoundation.org> References: <20210517140302.043055203@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Lv Yunlong [ Upstream commit 643001b47adc844ae33510c4bb93c236667008a3 ] In enic_hard_start_xmit, it calls enic_queue_wq_skb(). Inside enic_queue_wq_skb, if some error happens, the skb will be freed by dev_kfree_skb(skb). But the freed skb is still used in skb_tx_timestamp(skb). My patch makes enic_queue_wq_skb() return error and goto spin_unlock() incase of error. The solution is provided by Govind. See https://lkml.org/lkml/2021/4/30/961. Fixes: fb7516d42478e ("enic: add sw timestamp support") Signed-off-by: Lv Yunlong Acked-by: Govindarajulu Varadarajan Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- drivers/net/ethernet/cisco/enic/enic_main.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/drivers/net/ethernet/cisco/enic/enic_main.c b/drivers/net/ethernet/cisco/enic/enic_main.c index fb269d587b74..548d8095c0a7 100644 --- a/drivers/net/ethernet/cisco/enic/enic_main.c +++ b/drivers/net/ethernet/cisco/enic/enic_main.c @@ -768,7 +768,7 @@ static inline int enic_queue_wq_skb_encap(struct enic *enic, struct vnic_wq *wq, return err; } -static inline void enic_queue_wq_skb(struct enic *enic, +static inline int enic_queue_wq_skb(struct enic *enic, struct vnic_wq *wq, struct sk_buff *skb) { unsigned int mss = skb_shinfo(skb)->gso_size; @@ -814,6 +814,7 @@ static inline void enic_queue_wq_skb(struct enic *enic, wq->to_use = buf->next; dev_kfree_skb(skb); } + return err; } /* netif_tx_lock held, process context with BHs disabled, or BH */ @@ -857,7 +858,8 @@ static netdev_tx_t enic_hard_start_xmit(struct sk_buff *skb, return NETDEV_TX_BUSY; } - enic_queue_wq_skb(enic, wq, skb); + if (enic_queue_wq_skb(enic, wq, skb)) + goto error; if (vnic_wq_desc_avail(wq) < MAX_SKB_FRAGS + ENIC_DESC_MAX_SPLITS) netif_tx_stop_queue(txq); @@ -865,6 +867,7 @@ static netdev_tx_t enic_hard_start_xmit(struct sk_buff *skb, if (!netdev_xmit_more() || netif_xmit_stopped(txq)) vnic_wq_doorbell(wq); +error: spin_unlock(&enic->wq_lock[txq_map]); return NETDEV_TX_OK; -- 2.30.2