From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754071AbdC2VbX (ORCPT ); Wed, 29 Mar 2017 17:31:23 -0400 Received: from shards.monkeyblade.net ([184.105.139.130]:51526 "EHLO shards.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932681AbdC2VaQ (ORCPT ); Wed, 29 Mar 2017 17:30:16 -0400 Date: Wed, 29 Mar 2017 14:30:14 -0700 (PDT) Message-Id: <20170329.143014.2001816338079751776.davem@davemloft.net> To: Vladislav.Zakharov@synopsys.com Cc: netdev@vger.kernel.org, edumazet@google.com, eladkan@mellanox.com, noamca@mellanox.com, linux-kernel@vger.kernel.org, linux-snps-arc@lists.infradead.org Subject: Re: [PATCH] ezchip: nps_enet: check if napi has been completed From: David Miller In-Reply-To: <1490784106-14489-1-git-send-email-vzakhar@synopsys.com> References: <1490784106-14489-1-git-send-email-vzakhar@synopsys.com> X-Mailer: Mew version 6.7 on Emacs 24.5 / Mule 6.0 (HANACHIRUSATO) Mime-Version: 1.0 Content-Type: Text/Plain; charset=us-ascii Content-Transfer-Encoding: 7bit X-Greylist: Sender succeeded SMTP AUTH, not delayed by milter-greylist-4.5.12 (shards.monkeyblade.net [149.20.54.216]); Wed, 29 Mar 2017 13:49:00 -0700 (PDT) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Vlad Zakharov Date: Wed, 29 Mar 2017 13:41:46 +0300 > After a new NAPI_STATE_MISSED state was added to NAPI we can get into > this state and in such case we have to reschedule NAPI as some work is > still pending and we have to process it. napi_complete_done() function > returns false if we have to reschedule something (e.g. in case we were > in MISSED state) as current polling have not been completed yet. > > nps_enet driver hasn't been verifying the return value of > napi_complete_done() and has been forcibly enabling interrupts. That is > not correct as we should not enable interrupts before we have processed > all scheduled work. As a result we were getting trapped in interrupt > hanlder chain as we had never been able to disabale ethernet > interrupts again. > > So this patch makes nps_enet_poll() func verify return value of > napi_complete_done() and enable interrupts only in case all scheduled > work has been completed. > > Signed-off-by: Vlad Zakharov Applied. Eric, if this is really required now, we have 148 broken drivers still.