Received: by 2002:ac0:bc90:0:0:0:0:0 with SMTP id a16csp263926img; Mon, 18 Mar 2019 02:34:47 -0700 (PDT) X-Google-Smtp-Source: APXvYqxaaj8wNhRE5ydALcOVOY/lAYeG1FZKZQ77kCGC7rP4SPICNEzc7oX6jTfi/5aYLW53NTrY X-Received: by 2002:a62:69c3:: with SMTP id e186mr17800883pfc.169.1552901687493; Mon, 18 Mar 2019 02:34:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552901687; cv=none; d=google.com; s=arc-20160816; b=HEPrnzRHW0DqR0xb1YvtIInIHhCEusgWK10r7P0UP0G4F5FA18eIUly/jEMnNX8dnW tcGWsRejzECueYXrC2Te7PIm6HE/NDN46V7j0qIq8ydmI6qbhX/DXciXSmfDKiWtdtg+ vsvPAr9zoQempwcRrWyqVDmAEN9kdQhYzXLc/no/ArIdR1zKdTOnB+clMpHPn0CAwHq6 0ZYHjTD34tu6vDd5+JueHvaomcoU7RZIK9p0l62CGpYbWx1zpJd6ywrqCIGGTRftIOqI luwGRH+MkzBSvBKS9R7OqbCrX52bwnBcY+QurGtbWoR1s59vWAjPb1tUJqXYs3KkCph6 ouFg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=Eyw4J5tWLQZmVOLK0ADk5BglRVN8pbJMpob9XcUEJec=; b=0L0GfMYWn4/U5p21MSW9YoiGn4xXDgiEn+wW/ErTjtPgu+Cdop2/hECdpttYPLrhVu /+FFuY5T7VweJKOhumTPZYSH3yCqcGJS4LtBiJxMgMSvZamE3Gg9Ye5mE3sEjbVYyDcg utuYkADJbnq72YF+KYuHHEh71ZCWH9aV+raeuwaUdPsFcJnUI1r5JEyayOZjWRvdz/uo AQ1dNRsw6TalDekrSkVhOgyOiKzONzZ8CK6GDN7wtQcaFxxk9KRVy60tt3kjxHXMbFce +FPL/UwImktKyBDom5Go/78oaC2uHhRx0BdnqEuTChPxkq2/Jq4aDoVZF9Ad2cXf2oRC VM+w== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=s0kUHILR; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 89si9184111pla.124.2019.03.18.02.34.32; Mon, 18 Mar 2019 02:34:47 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=s0kUHILR; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728827AbfCRJdK (ORCPT + 99 others); Mon, 18 Mar 2019 05:33:10 -0400 Received: from mail.kernel.org ([198.145.29.99]:41276 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727907AbfCRJdI (ORCPT ); Mon, 18 Mar 2019 05:33:08 -0400 Received: from localhost (5356596B.cm-6-7b.dynamic.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id C3CBA2075C; Mon, 18 Mar 2019 09:33:06 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1552901587; bh=h/n/E1j4Vm6JxjLBeHhDqsWf2DoPXbCgCLfxkbqWvjc=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=s0kUHILRZ8zOVus+sGgToBt1GQ92KP5m5hPaYHijizLr5MDsqjMB9c77ScXcYbMJj TYpHVSLQt5QPs9j1HoqpEoLFgWFAufBlbYex1ZP3r1Q2C/nqXMPzBYw8IjS2IBCH4V TkmNBYO6Wa5sBwGgiUE3JeeOIU2xHRHOc8GO7UoQ= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Bryan Whitehead , "David S. Miller" Subject: [PATCH 4.19 06/52] lan743x: Fix TX Stall Issue Date: Mon, 18 Mar 2019 10:25:03 +0100 Message-Id: <20190318084014.310908126@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190318084013.532280682@linuxfoundation.org> References: <20190318084013.532280682@linuxfoundation.org> User-Agent: quilt/0.65 X-stable: review X-Patchwork-Hint: ignore MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 4.19-stable review patch. If anyone has any objections, please let me know. ------------------ From: Bryan Whitehead [ Upstream commit deb6bfabdbb634e91f36a4e9cb00a7137d72d886 ] It has been observed that tx queue may stall while downloading from certain web sites (example www.speedtest.net) The cause has been tracked down to a corner case where the tx interrupt vector was disabled automatically, but was not re enabled later. The lan743x has two mechanisms to enable/disable individual interrupts. Interrupts can be enabled/disabled by individual source, and they can also be enabled/disabled by individual vector which has been mapped to the source. Both must be enabled for interrupts to work properly. The TX code path, primarily uses the interrupt enable/disable of the TX source bit, while leaving the vector enabled all the time. However, while investigating this issue it was noticed that the driver requested the use of the vector auto clear feature. The test above revealed a case where the vector enable was cleared unintentionally. This patch fixes the issue by deleting the lines that request the vector auto clear feature to be used. Fixes: 23f0703c125b ("lan743x: Add main source files for new lan743x driver") Signed-off-by: Bryan Whitehead Signed-off-by: David S. Miller Signed-off-by: Greg Kroah-Hartman --- drivers/net/ethernet/microchip/lan743x_main.c | 9 +-------- 1 file changed, 1 insertion(+), 8 deletions(-) --- a/drivers/net/ethernet/microchip/lan743x_main.c +++ b/drivers/net/ethernet/microchip/lan743x_main.c @@ -585,8 +585,7 @@ static int lan743x_intr_open(struct lan7 if (adapter->csr.flags & LAN743X_CSR_FLAG_SUPPORTS_INTR_AUTO_SET_CLR) { - flags = LAN743X_VECTOR_FLAG_VECTOR_ENABLE_AUTO_CLEAR | - LAN743X_VECTOR_FLAG_VECTOR_ENABLE_AUTO_SET | + flags = LAN743X_VECTOR_FLAG_VECTOR_ENABLE_AUTO_SET | LAN743X_VECTOR_FLAG_SOURCE_ENABLE_AUTO_SET | LAN743X_VECTOR_FLAG_SOURCE_ENABLE_AUTO_CLEAR | LAN743X_VECTOR_FLAG_SOURCE_STATUS_AUTO_CLEAR; @@ -599,12 +598,6 @@ static int lan743x_intr_open(struct lan7 /* map TX interrupt to vector */ int_vec_map1 |= INT_VEC_MAP1_TX_VEC_(index, vector); lan743x_csr_write(adapter, INT_VEC_MAP1, int_vec_map1); - if (flags & - LAN743X_VECTOR_FLAG_VECTOR_ENABLE_AUTO_CLEAR) { - int_vec_en_auto_clr |= INT_VEC_EN_(vector); - lan743x_csr_write(adapter, INT_VEC_EN_AUTO_CLR, - int_vec_en_auto_clr); - } /* Remove TX interrupt from shared mask */ intr->vector_list[0].int_mask &= ~int_bit;