Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp3088924ybt; Mon, 29 Jun 2020 15:04:24 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx7stKBDcz1knxvuTulATBn1HepqD51A4SWF8im3ztH3DHmt6x81/mr+gc8m3RkdsrdoSHl X-Received: by 2002:a50:fd12:: with SMTP id i18mr20287911eds.371.1593468264546; Mon, 29 Jun 2020 15:04:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593468264; cv=none; d=google.com; s=arc-20160816; b=pddlPe1kSltLbFLE2XzI5zcIAGIXeVdeRUFYkHxTEy2eiAZ1hU5yQbbSf4wNXL5nPC 7LWGL7SXjeYgTnk5EMZHarDKA1ANN1QNgfwNJ51+tPll0H+KycwHtUTS5UOYB1i8SaB2 AagaroTaPXm1NccTCNXKhIkOM16PtLAzxG5ArVQKJ1lHMvjFoVrd1WAk24oyRI7cou5d u3E49cALOEeyBDK1FzinevvAIsTjSFF44gRUBXpvi53nmE0vTXfkp67CwLjsOUDh4a1b /mbnHTkc2KeI+BMSXMzY0QAX4CNTUk7GNDIIvK3OI5eFbPcHYbSxrBUapfzNRlktbV6K rBkA== 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=hPCHE5ZLK/Ykfwxg+2Q0vfhy3J7u5bc5iLq/HKFsth4=; b=VNzYd7NEeO+vjXfwsn3YT3JAik8ymgCZNuSiN/TazmGJDXHDctHkZS5YdD2zV3dxfw hha+oA+hP9WdASp7VfSWvW7i+t/FepUhHHy5jj3strEAZmQsFB967RrDzfnDeSx8a7jJ RSTFSs52CNRD0uyz8JG8g9UnhvyyiHDxsARsGfipEs8KXxPYIl3LxSfkVKGQCMcgVWBD RLiTAd975cH8ShIU7vLvi+SroBhPqWFOWoMoCnEJeFzPEQzEqemAIlrv6ZMC0A4ncozW lQH76wSuTBqyG6THD08zrhauiFd7kPjWcN5TFkK7sWBxFPV7tbJ0i36elDDYaGWX3Yfk RmMA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=cQBqF9oz; 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 dv20si530305ejb.582.2020.06.29.15.04.01; Mon, 29 Jun 2020 15:04:24 -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=cQBqF9oz; 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 S2404829AbgF2WAq (ORCPT + 99 others); Mon, 29 Jun 2020 18:00:46 -0400 Received: from mail.kernel.org ([198.145.29.99]:56796 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726334AbgF2SfY (ORCPT ); Mon, 29 Jun 2020 14:35:24 -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 6C35624640; Mon, 29 Jun 2020 15:19:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1593443965; bh=gdqGbviJQ8DPHxHnkuoAUnXO84jNZ/sdL4M8a2yZTZg=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=cQBqF9oztiGjtZxlBcMptoZXgvkoIiJQc5iTDnIYyXVoxo7yM6oF0Ut/+OJjlOMxT sAiMf4rWBD1pSoX3tdTOhOrNd3zqc9iIBLVXdgF0Ek80i7Pjhu2vzwHZIZ6qU/S6y7 GuA5RPfryC52Dg7t1DpU+eDMmr+FqaXs88zMyCh0= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Kai-Heng Feng , Mathias Nyman , Greg Kroah-Hartman Subject: [PATCH 5.7 068/265] xhci: Poll for U0 after disabling USB2 LPM Date: Mon, 29 Jun 2020 11:15:01 -0400 Message-Id: <20200629151818.2493727-69-sashal@kernel.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20200629151818.2493727-1-sashal@kernel.org> References: <20200629151818.2493727-1-sashal@kernel.org> MIME-Version: 1.0 X-KernelTest-Patch: http://kernel.org/pub/linux/kernel/v5.x/stable-review/patch-5.7.7-rc1.gz X-KernelTest-Tree: git://git.kernel.org/pub/scm/linux/kernel/git/stable/linux-stable-rc.git X-KernelTest-Branch: linux-5.7.y X-KernelTest-Patches: git://git.kernel.org/pub/scm/linux/kernel/git/stable/stable-queue.git X-KernelTest-Version: 5.7.7-rc1 X-KernelTest-Deadline: 2020-07-01T15:14+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: Kai-Heng Feng commit b3d71abd135e6919ca0b6cab463738472653ddfb upstream. USB2 devices with LPM enabled may interrupt the system suspend: [ 932.510475] usb 1-7: usb suspend, wakeup 0 [ 932.510549] hub 1-0:1.0: hub_suspend [ 932.510581] usb usb1: bus suspend, wakeup 0 [ 932.510590] xhci_hcd 0000:00:14.0: port 9 not suspended [ 932.510593] xhci_hcd 0000:00:14.0: port 8 not suspended .. [ 932.520323] xhci_hcd 0000:00:14.0: Port change event, 1-7, id 7, portsc: 0x400e03 .. [ 932.591405] PM: pci_pm_suspend(): hcd_pci_suspend+0x0/0x30 returns -16 [ 932.591414] PM: dpm_run_callback(): pci_pm_suspend+0x0/0x160 returns -16 [ 932.591418] PM: Device 0000:00:14.0 failed to suspend async: error -16 During system suspend, USB core will let HC suspends the device if it doesn't have remote wakeup enabled and doesn't have any children. However, from the log above we can see that the usb 1-7 doesn't get bus suspended due to not in U0. After a while the port finished U2 -> U0 transition, interrupts the suspend process. The observation is that after disabling LPM, port doesn't transit to U0 immediately and can linger in U2. xHCI spec 4.23.5.2 states that the maximum exit latency for USB2 LPM should be BESL + 10us. The BESL for the affected device is advertised as 400us, which is still not enough based on my testing result. So let's use the maximum permitted latency, 10000, to poll for U0 status to solve the issue. Cc: stable@vger.kernel.org Signed-off-by: Kai-Heng Feng Signed-off-by: Mathias Nyman Link: https://lore.kernel.org/r/20200624135949.22611-6-mathias.nyman@linux.intel.com Signed-off-by: Greg Kroah-Hartman --- drivers/usb/host/xhci.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/drivers/usb/host/xhci.c b/drivers/usb/host/xhci.c index bee5deccc83d8..10d76205a79ca 100644 --- a/drivers/usb/host/xhci.c +++ b/drivers/usb/host/xhci.c @@ -4471,6 +4471,9 @@ static int xhci_set_usb2_hardware_lpm(struct usb_hcd *hcd, mutex_lock(hcd->bandwidth_mutex); xhci_change_max_exit_latency(xhci, udev, 0); mutex_unlock(hcd->bandwidth_mutex); + readl_poll_timeout(ports[port_num]->addr, pm_val, + (pm_val & PORT_PLS_MASK) == XDEV_U0, + 100, 10000); return 0; } } -- 2.25.1