Received: by 2002:a05:6a10:206:0:0:0:0 with SMTP id 6csp4689004pxj; Wed, 12 May 2021 10:56:42 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw1BY6mi2APMYRqez5ogaGMLy5FBflnf5EhdLd13A1NJ4bcUFUkBTM4Z+ysqNanYkDg7CiV X-Received: by 2002:a05:6402:b55:: with SMTP id bx21mr45452651edb.281.1620842202554; Wed, 12 May 2021 10:56:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1620842202; cv=none; d=google.com; s=arc-20160816; b=OZtgDtIZslHM8/yhgmBozzpbi8b35ZwUsKw9nkwwqhExsVMAnbj4+RfvkSyOZXN8FH QqEyQxcIDWxz4qskiaeqLgNvmInRA6ybRcWL9R46vCscf3ElGtPWJ+5+LqMF/fqjxm0Q xElgAAhHCdBaL9Rt5qDWXhyW2rGzXnRMBADHf9maKLhI9vKngb/EC2YeEGTLIg+8qsgN lwnHw2IPRZt+YVphBj3YOU/G36m9yuXOTnyzzEciC3l9YAye/NV7PB371BQnFf+0wBYS hWgzCXAXYMAzqpRfnhJQKaEu9BHx49ohWYYIMGk9Jvb2J8D6auMgmT921Fe/SOO+f68P a4fQ== 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=rin0951TcjX7GnlZVzzH+fO4Mu+5L1lKaOVJDcDqins=; b=fYxGY9ZXbPN5ZsfnkPtMlpxLoezdgJE3n0QWgTMbLNy38Ep2TPP9VudTAVhBYqh0WZ P7a9IpEVYUqTCAA4LJMPjJmh3re/T8kA7mL8Gxy7tGB9zF8OlDjaHKrJ/iotlwaeoi/r RNO4c9GWs8LOismW7jgbEDqq510eGDlWUnPBhCRsvHO6ZsZv/U3T+AD9g8SrvuQiDspr B49fh1trpB0Jm+a7Fl//0f/KeXKKAY78GCogoyTPjTkUVp8oHs8PdkQ8PNlf3isxKtuw mMZ/YYHK6KrqhbQt1qMF2ea2iqtE0bamdd9FEkI1ggXq4mRXZCD4BWThNFyif8VRjjvp hP8w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b="LcdcFf/9"; 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 v18si430782ejd.644.2021.05.12.10.56.19; Wed, 12 May 2021 10:56:42 -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="LcdcFf/9"; 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 S1348560AbhELR4V (ORCPT + 99 others); Wed, 12 May 2021 13:56:21 -0400 Received: from mail.kernel.org ([198.145.29.99]:43696 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S240744AbhELQZO (ORCPT ); Wed, 12 May 2021 12:25:14 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id E0DED61CA4; Wed, 12 May 2021 15:48:17 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1620834498; bh=N2SQdtwWJmY/H39yZKetYb4boDtZX4OxMFzzquDVoyI=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=LcdcFf/9XA33KxIo2PE0KJE4xbFt90yqcRPgxe86gveY1Dk52VGPaM73b8E4Vfy9P t2BLhDbOMVkg8t+GQBq6zgIBq5jRDoxtGm8BiRDWnRl/OAkPqoK9ycCpRTL0VEoOMq b99ngBSsX6sQp/xR9pYxyrhlxr5th1jcvyNJpLmI= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Pavan Chebbi , Andy Gospodarek , Michael Chan , "David S. Miller" , Sasha Levin Subject: [PATCH 5.11 569/601] bnxt_en: Fix RX consumer index logic in the error path. Date: Wed, 12 May 2021 16:50:46 +0200 Message-Id: <20210512144846.592040433@linuxfoundation.org> X-Mailer: git-send-email 2.31.1 In-Reply-To: <20210512144827.811958675@linuxfoundation.org> References: <20210512144827.811958675@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: Michael Chan [ Upstream commit bbd6f0a948139970f4a615dff189d9a503681a39 ] In bnxt_rx_pkt(), the RX buffers are expected to complete in order. If the RX consumer index indicates an out of order buffer completion, it means we are hitting a hardware bug and the driver will abort all remaining RX packets and reset the RX ring. The RX consumer index that we pass to bnxt_discard_rx() is not correct. We should be passing the current index (tmp_raw_cons) instead of the old index (raw_cons). This bug can cause us to be at the wrong index when trying to abort the next RX packet. It can crash like this: #0 [ffff9bbcdf5c39a8] machine_kexec at ffffffff9b05e007 #1 [ffff9bbcdf5c3a00] __crash_kexec at ffffffff9b111232 #2 [ffff9bbcdf5c3ad0] panic at ffffffff9b07d61e #3 [ffff9bbcdf5c3b50] oops_end at ffffffff9b030978 #4 [ffff9bbcdf5c3b78] no_context at ffffffff9b06aaf0 #5 [ffff9bbcdf5c3bd8] __bad_area_nosemaphore at ffffffff9b06ae2e #6 [ffff9bbcdf5c3c28] bad_area_nosemaphore at ffffffff9b06af24 #7 [ffff9bbcdf5c3c38] __do_page_fault at ffffffff9b06b67e #8 [ffff9bbcdf5c3cb0] do_page_fault at ffffffff9b06bb12 #9 [ffff9bbcdf5c3ce0] page_fault at ffffffff9bc015c5 [exception RIP: bnxt_rx_pkt+237] RIP: ffffffffc0259cdd RSP: ffff9bbcdf5c3d98 RFLAGS: 00010213 RAX: 000000005dd8097f RBX: ffff9ba4cb11b7e0 RCX: ffffa923cf6e9000 RDX: 0000000000000fff RSI: 0000000000000627 RDI: 0000000000001000 RBP: ffff9bbcdf5c3e60 R8: 0000000000420003 R9: 000000000000020d R10: ffffa923cf6ec138 R11: ffff9bbcdf5c3e83 R12: ffff9ba4d6f928c0 R13: ffff9ba4cac28080 R14: ffff9ba4cb11b7f0 R15: ffff9ba4d5a30000 ORIG_RAX: ffffffffffffffff CS: 0010 SS: 0018 Fixes: a1b0e4e684e9 ("bnxt_en: Improve RX consumer index validity check.") Reviewed-by: Pavan Chebbi Reviewed-by: Andy Gospodarek Signed-off-by: Michael Chan Signed-off-by: David S. Miller Signed-off-by: Sasha Levin --- drivers/net/ethernet/broadcom/bnxt/bnxt.c | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/drivers/net/ethernet/broadcom/bnxt/bnxt.c b/drivers/net/ethernet/broadcom/bnxt/bnxt.c index 11839f086f29..f3c659bc6bb6 100644 --- a/drivers/net/ethernet/broadcom/bnxt/bnxt.c +++ b/drivers/net/ethernet/broadcom/bnxt/bnxt.c @@ -1731,14 +1731,16 @@ static int bnxt_rx_pkt(struct bnxt *bp, struct bnxt_cp_ring_info *cpr, cons = rxcmp->rx_cmp_opaque; if (unlikely(cons != rxr->rx_next_cons)) { - int rc1 = bnxt_discard_rx(bp, cpr, raw_cons, rxcmp); + int rc1 = bnxt_discard_rx(bp, cpr, &tmp_raw_cons, rxcmp); /* 0xffff is forced error, don't print it */ if (rxr->rx_next_cons != 0xffff) netdev_warn(bp->dev, "RX cons %x != expected cons %x\n", cons, rxr->rx_next_cons); bnxt_sched_reset(bp, rxr); - return rc1; + if (rc1) + return rc1; + goto next_rx_no_prod_no_len; } rx_buf = &rxr->rx_buf_ring[cons]; data = rx_buf->data; -- 2.30.2