Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp3027084ybt; Mon, 29 Jun 2020 13:16:21 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxtMOdZEhhnWgWeOc/jzt6Bs/Cu/PRaTCQqQdXHwoe3W29PjdfRF3oxmgyY7lzMVyBamyou X-Received: by 2002:a05:6402:b9b:: with SMTP id cf27mr17082434edb.84.1593461780849; Mon, 29 Jun 2020 13:16:20 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593461780; cv=none; d=google.com; s=arc-20160816; b=NGaDpIQLccqMvu5GV0CwwwB9/lEV6ble+N9kc1Dlzm8BKvFJoGJCOpHEGsURRshrtg Dy2FjXqRIA1N3NowFyEk6PTNYl+IEGQLi4bzA+4T0rzShHPFKroCg4933WzblBy7Xl19 kCfSrVUf3q4bpeK9bflz7n2ZX5YHB0l2zWTTbIkkftpmz8lRMyCOLhQl6IfK7OAVJ3Mk Q6AbT4rC6ptpoCI/go0TfVNgq1tBxOxfe0mrXkvgkzCaXJ0p7ibwtHyKQXRbLP4bukFg f5Dch72Q91Z8FgsFXM2Q6CTKxw8eY1/B73CogrnCCmXr8TVGOyutvS8YIu8UOUwT37mG Cw1A== 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 :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=k1DkuX2vS+S2Xq6IJWxSOTjwu3z9Psgxg+382I8RId0=; b=r9xBlUqucRZMg5Ix9J2HAsi/k3Ymq02Rq77f3SAOzCJZBSW65Qz2GCL71k8gNtGWyA d/QBlEiCpGCDf+VfzGK/SgaXYVkNraogzNIBtqnh+2/k+mX/yC8QEY831EAHoDY3hZ9Y A7DfNRG1am/K3raQxMJIjmDGTqfIO3BXpov3xmGHJr82zRXD66FlEiZggECOJX3WEBet 6TXSwUXvkbgH+k/B2rwZDw+WSfNBTzPgPRuSQvT/ShpTIHSrU2dryKxXRGU+LI1Jyj9V jo4dyYg8s7V/tQuKTDvg0lu0GZMP0TMk5bePa0Vg0tC+wZgkB2lB0lNv9vgmzj8JOgFY eejg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=dxJLuuhh; 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=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u6si371825ejf.218.2020.06.29.13.15.57; Mon, 29 Jun 2020 13:16:20 -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=@kernel.org header.s=default header.b=dxJLuuhh; 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=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1732305AbgF2UOI (ORCPT + 99 others); Mon, 29 Jun 2020 16:14:08 -0400 Received: from mail.kernel.org ([198.145.29.99]:40556 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732850AbgF2TaT (ORCPT ); Mon, 29 Jun 2020 15:30:19 -0400 Received: from sasha-vm.mshome.net (c-73-47-72-35.hsd1.nh.comcast.net [73.47.72.35]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 23EEA252ED; Mon, 29 Jun 2020 15:38:39 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1593445119; bh=HuBcpEOyArzgHliXVv1A8XgnBsosqlw1lP16sXOKJco=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=dxJLuuhhi2hUoTtACxLZOJnBOBgc566vQkJkyalCMDYcgcruQuyPjxXzNcqPk4zlH jz2v4V04RvlAlmywvO8cjATnynWRWe2cNrYdYzHsX8LuI6WeBm8JqBD4HU49KZFgOr Zw6Mtjtyl/VmYMobXwR58s5yCpkHyQkJP2jNyq5A= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Longfang Liu , Alan Stern , Greg Kroah-Hartman Subject: [PATCH 4.14 26/78] USB: ehci: reopen solution for Synopsys HC bug Date: Mon, 29 Jun 2020 11:37:14 -0400 Message-Id: <20200629153806.2494953-27-sashal@kernel.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200629153806.2494953-1-sashal@kernel.org> References: <20200629153806.2494953-1-sashal@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 X-KernelTest-Patch: http://kernel.org/pub/linux/kernel/v4.x/stable-review/patch-4.14.186-rc1.gz X-KernelTest-Tree: git://git.kernel.org/pub/scm/linux/kernel/git/stable/linux-stable-rc.git X-KernelTest-Branch: linux-4.14.y X-KernelTest-Patches: git://git.kernel.org/pub/scm/linux/kernel/git/stable/stable-queue.git X-KernelTest-Version: 4.14.186-rc1 X-KernelTest-Deadline: 2020-07-01T15:38+00:00 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Longfang Liu commit 1ddcb71a3edf0e1682b6e056158e4c4b00325f66 upstream. A Synopsys USB2.0 core used in Huawei Kunpeng920 SoC has a bug which might cause the host controller not issuing ping. Bug description: After indicating an Interrupt on Async Advance, the software uses the doorbell mechanism to delete the Next Link queue head of the last executed queue head. At this time, the host controller still references the removed queue head(the queue head is NULL). NULL reference causes the host controller to lose the USB device. Solution: After deleting the Next Link queue head, when has_synopsys_hc_bug set to 1,the software can write one of the valid queue head addresses to the ASYNCLISTADDR register to allow the host controller to get the valid queue head. in order to solve that problem, this patch set the flag for Huawei Kunpeng920 There are detailed instructions and solutions in this patch: commit 2f7ac6c19997 ("USB: ehci: add workaround for Synopsys HC bug") Signed-off-by: Longfang Liu Cc: stable Acked-by: Alan Stern Link: https://lore.kernel.org/r/1591588019-44284-1-git-send-email-liulongfang@huawei.com Signed-off-by: Greg Kroah-Hartman --- drivers/usb/host/ehci-pci.c | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/drivers/usb/host/ehci-pci.c b/drivers/usb/host/ehci-pci.c index 93326974ff4b3..265c9af1d2b5b 100644 --- a/drivers/usb/host/ehci-pci.c +++ b/drivers/usb/host/ehci-pci.c @@ -229,6 +229,13 @@ static int ehci_pci_setup(struct usb_hcd *hcd) ehci_info(ehci, "applying MosChip frame-index workaround\n"); ehci->frame_index_bug = 1; break; + case PCI_VENDOR_ID_HUAWEI: + /* Synopsys HC bug */ + if (pdev->device == 0xa239) { + ehci_info(ehci, "applying Synopsys HC workaround\n"); + ehci->has_synopsys_hc_bug = 1; + } + break; } /* optional debug port, normally in the first BAR */ -- 2.25.1