Received: by 2002:ac0:aed5:0:0:0:0:0 with SMTP id t21csp5902424imb; Fri, 8 Mar 2019 05:07:35 -0800 (PST) X-Google-Smtp-Source: APXvYqyEJpuEyedOlUWAJE/7/NsNuErHNFPUe0cRTnDL+iFoWTV/clqt/7K69NRGpMRjnN9eLlS0 X-Received: by 2002:a62:3681:: with SMTP id d123mr18480778pfa.242.1552050454916; Fri, 08 Mar 2019 05:07:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1552050454; cv=none; d=google.com; s=arc-20160816; b=O6fPDcfxVuXC7ejNrmIuSt5GrNjGcnQlmQQSzaRpqdXdC6NoEznD72XRclmGCXoWjY cEF/ZjPZ7Udos16sGlo2446/bmnQZ1EdsT1piAbJI5sfeEqS/6rvBWf5ucX9dpzLeWsZ ke01dRiRqcimD/cNxjc0MCr/qOEsc/D5bY1vJBVnBwwb/y7dZP7HdFKpgu+Go+ZfrdYq B/EnhC29Ez+7/2OM3ZdVUVrB6y5BI2IJBO4HAC8hJeu7rRGEfyT3flJKoXVmWyfn4s/j USmPwAzhN2F6/FL284zYvtxtNd7QHLIlMUVf+DD0D4+HQ5o8MhqWfaA2rsUypbF+rM/I 4Xaw== 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=pkcNfNBUt+oXV5f/i3idmI3DYoep9oDe9PA/443LdQE=; b=RJ/gWpSxnxf1xCFhFR/qdUwPbigrqA6dELEE9jfO4gAbjR3POAPBABST5ez6FytitO uBxitzbJ7JB3a8RR3OyCUdZNvZbdJkmdmjBIshWROwrNLcqma879AY6n53/CEvjSjDun 7mYmzOJTpr8QV8WK1rQ5MHpdeL9JN1JOQncvIlI2POVp0jae6P+7yztdFlB5q0r7iUKQ F+HAP4pqDq3lk5RjH9gT5lmXOxhrxTf9Wx8W5h1F2HPLsUp7M6uqUPYjsNEPPuVfgPw4 HuWsCEvqD5E1laZUcSwvhJlmStAHR6jc7PDpZgdSz+1s8Dht61DdsB5H7/Fp8MD8VXfJ x4gA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=xJ1NOsHj; 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 j70si6323124pge.271.2019.03.08.05.07.18; Fri, 08 Mar 2019 05:07:34 -0800 (PST) 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=xJ1NOsHj; 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 S1727765AbfCHM4y (ORCPT + 99 others); Fri, 8 Mar 2019 07:56:54 -0500 Received: from mail.kernel.org ([198.145.29.99]:33124 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727657AbfCHM4w (ORCPT ); Fri, 8 Mar 2019 07:56:52 -0500 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 E9FCC20449; Fri, 8 Mar 2019 12:56:50 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1552049811; bh=LfpCe6Wmlq2iUtRMSgfXQtNncMXIOn45/568VDgfkAo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=xJ1NOsHj94i70cPCXd3P0KIWpqQbWKF6ZWQ6k3Hg/cAdVdir7Cct3k57HVCfiBsq5 bH/+v9tbGuxVOV/zEmY3lr8cvcVfpa7CnlG06tDvmWBnY5sldqiX5R67lnqw5KWXMy HKLZk9cvMeD2xKoFds5bBJmRUshCY3wCkB6FeAZI= 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.20 34/76] lan743x: Fix TX Stall Issue Date: Fri, 8 Mar 2019 13:49:46 +0100 Message-Id: <20190308124916.027484092@linuxfoundation.org> X-Mailer: git-send-email 2.21.0 In-Reply-To: <20190308124914.789210760@linuxfoundation.org> References: <20190308124914.789210760@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.20-stable review patch. If anyone has any objections, please let me know. ------------------ From: Bryan Whitehead [ Upstream commit 90490ef7269906423a1c1b917fc24be8b1602658 ] It has been observed that tx queue stalls while downloading from certain web sites (example www.speedtest.net) The cause has been tracked down to a corner case where dma descriptors where not setup properly. And there for a tx completion interrupt was not signaled. This fix corrects the problem by properly marking the end of a multi descriptor transmission. 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 | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) --- a/drivers/net/ethernet/microchip/lan743x_main.c +++ b/drivers/net/ethernet/microchip/lan743x_main.c @@ -1400,7 +1400,8 @@ static int lan743x_tx_frame_start(struct } static void lan743x_tx_frame_add_lso(struct lan743x_tx *tx, - unsigned int frame_length) + unsigned int frame_length, + int nr_frags) { /* called only from within lan743x_tx_xmit_frame. * assuming tx->ring_lock has already been acquired. @@ -1410,6 +1411,10 @@ static void lan743x_tx_frame_add_lso(str /* wrap up previous descriptor */ tx->frame_data0 |= TX_DESC_DATA0_EXT_; + if (nr_frags <= 0) { + tx->frame_data0 |= TX_DESC_DATA0_LS_; + tx->frame_data0 |= TX_DESC_DATA0_IOC_; + } tx_descriptor = &tx->ring_cpu_ptr[tx->frame_tail]; tx_descriptor->data0 = tx->frame_data0; @@ -1514,8 +1519,11 @@ static void lan743x_tx_frame_end(struct u32 tx_tail_flags = 0; /* wrap up previous descriptor */ - tx->frame_data0 |= TX_DESC_DATA0_LS_; - tx->frame_data0 |= TX_DESC_DATA0_IOC_; + if ((tx->frame_data0 & TX_DESC_DATA0_DTYPE_MASK_) == + TX_DESC_DATA0_DTYPE_DATA_) { + tx->frame_data0 |= TX_DESC_DATA0_LS_; + tx->frame_data0 |= TX_DESC_DATA0_IOC_; + } tx_descriptor = &tx->ring_cpu_ptr[tx->frame_tail]; buffer_info = &tx->buffer_info[tx->frame_tail]; @@ -1600,7 +1608,7 @@ static netdev_tx_t lan743x_tx_xmit_frame } if (gso) - lan743x_tx_frame_add_lso(tx, frame_length); + lan743x_tx_frame_add_lso(tx, frame_length, nr_frags); if (nr_frags <= 0) goto finish;