Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp6190589iob; Tue, 10 May 2022 12:24:48 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwxKgPXF84ocDTec5kJOT7IwG/1SEr42t4fa7LJNkfC74CtbxhMVrRH3hpeGlXMlW0wqZj2 X-Received: by 2002:a05:6830:1dce:b0:606:126e:5ee1 with SMTP id a14-20020a0568301dce00b00606126e5ee1mr8549110otj.259.1652210688350; Tue, 10 May 2022 12:24:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1652210688; cv=none; d=google.com; s=arc-20160816; b=NYlvTdHJGgmPcwHNjnO+76FF2qDgBkFwY0+2zwAdrZpMyGyV/4K8/dYR7sDzadwFiO EmYfXXt7NCkdM751EZueOd9tGea42nK6UhKJlmofeevm1p2ol8BbE8m6g7/MiWatA6jA E1PI9eoYdeY7jGzVExBNIvTdJ0c1w31bdPrYAn3EWo+amvj8O+mK+aTOig53EPV8Q+1e oIHmU7RVDNhgzPDMILFSjs0BvT9XBoEsCHPkXP1EgA3NqBdsUtP0V5dNAPGHWBacmq7g wqDTeKRher5Ef/pLwVc6zSIauu6OryQmmmPjzTflugtmkjmE4gY3BvWc3QSxaIJsORsI dNJg== 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=OnWwC8TdX84K9gl10u623lfKRdVi0zxebnGGcuk2/Zk=; b=QtxzVy5VWPk1waW5E2jmr9skUKy+FGliewWIZOdv9Km5dBTnU4ga8cz5/RSohJcPrW qgSrr3sf6SM5wG8G4KaJc1aRzdxl++L3OtfBls0754qFXET0HAbos9n+r2FgsmDhFij5 hnY6MaQOJX3bRFazzjWoomwNlHG04IsruxjLRLWyRbQroYu48exLi9PGw2CDlThxHpCX i+chzdLYzl4/2M4JT8/KE6Cz/ddjP0vbnSiv+4o/OkdzOgdAE/SFOsCcCpb7yPRwDZ2j qpJaSCYFivrPrIOp7oQajOjW2NsEXXC6gdI7J3RfALk5lWFC9LHcNC6K7Df/lo1hzR+S pAQw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=Ypb4zSih; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id 59-20020a9d0141000000b00606aa4bfc39si46460otu.31.2022.05.10.12.24.32; Tue, 10 May 2022 12:24:48 -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; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=Ypb4zSih; 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=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S244445AbiEJOIz (ORCPT + 99 others); Tue, 10 May 2022 10:08:55 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51296 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S244819AbiEJNrB (ORCPT ); Tue, 10 May 2022 09:47:01 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 721BC237D5; Tue, 10 May 2022 06:32:08 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 0A6AB61768; Tue, 10 May 2022 13:32:08 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 159FEC385C9; Tue, 10 May 2022 13:32:06 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1652189527; bh=MBaLoHneMCmPtHljIqvgGk48FZvuHrUTqGR15C6G604=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=Ypb4zSihbQ09qYTgNiavm5sVhPxvYvqBz/u9lbRpxZDO6nMhd8bv3NdCJixK5Xx37 vZ4DyMOhI8L+d4sCXnU+r8jD34KoXsAMQgOaJfinbLSnEX1joOmbkeL2yJ8v2GWubs ysca7L1olyY8OFR0z6V8iWHylRUn6LC1Ii88BEH8= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Andy Gospodarek , Michael Chan , Jakub Kicinski Subject: [PATCH 5.15 077/135] bnxt_en: Fix unnecessary dropping of RX packets Date: Tue, 10 May 2022 15:07:39 +0200 Message-Id: <20220510130742.620644065@linuxfoundation.org> X-Mailer: git-send-email 2.36.1 In-Reply-To: <20220510130740.392653815@linuxfoundation.org> References: <20220510130740.392653815@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.7 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED autolearn=ham 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: Michael Chan commit 195af57914d15229186658ed26dab24b9ada4122 upstream. In bnxt_poll_p5(), we first check cpr->has_more_work. If it is true, we are in NAPI polling mode and we will call __bnxt_poll_cqs() to continue polling. It is possible to exhanust the budget again when __bnxt_poll_cqs() returns. We then enter the main while loop to check for new entries in the NQ. If we had previously exhausted the NAPI budget, we may call __bnxt_poll_work() to process an RX entry with zero budget. This will cause packets to be dropped unnecessarily, thinking that we are in the netpoll path. Fix it by breaking out of the while loop if we need to process an RX NQ entry with no budget left. We will then exit NAPI and stay in polling mode. Fixes: 389a877a3b20 ("bnxt_en: Process the NQ under NAPI continuous polling.") Reviewed-by: Andy Gospodarek Signed-off-by: Michael Chan Signed-off-by: Jakub Kicinski Signed-off-by: Greg Kroah-Hartman --- drivers/net/ethernet/broadcom/bnxt/bnxt.c | 4 ++++ 1 file changed, 4 insertions(+) --- a/drivers/net/ethernet/broadcom/bnxt/bnxt.c +++ b/drivers/net/ethernet/broadcom/bnxt/bnxt.c @@ -2699,6 +2699,10 @@ static int bnxt_poll_p5(struct napi_stru u32 idx = le32_to_cpu(nqcmp->cq_handle_low); struct bnxt_cp_ring_info *cpr2; + /* No more budget for RX work */ + if (budget && work_done >= budget && idx == BNXT_RX_HDL) + break; + cpr2 = cpr->cp_ring_arr[idx]; work_done += __bnxt_poll_work(bp, cpr2, budget - work_done);