Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp905319pxx; Tue, 27 Oct 2020 03:36:28 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxh2wfG7rfbBfEEhtuamvfGCJAjLoncgP7M8q/pa1Y8xYalK5zx3iY+AmBv1zJxPw+ekhlW X-Received: by 2002:a05:6402:142c:: with SMTP id c12mr1559226edx.41.1603794988134; Tue, 27 Oct 2020 03:36:28 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603794988; cv=none; d=google.com; s=arc-20160816; b=H3RA8cOxGFDSnUW5txC7QQ0HFfdJiYmkm71ybskjkVYYesiYxR/ySFUdckNIknbnU3 G7FgLrv7XFe0JQ2g7sFq7RNbhCfmoLP5ctDeq+ql4x+uOw320C/MOigOdw33SNGnUw+g lBtFf5PbtYo1W0QH/1xgYUAQ8SwywrMB5VYOvH6o3lC+TLRi3y9Ud+yyAujOhiJCO2bK lZkipAPVtRm32mxbMXPzy/I+xzCqFg1akBS7K4c9oEcuXMs5AIxb3/Q4qqUGJtXitBeq 8IdaR2sSgUaOpaz66CTEtM/5pMvTum9UZDC7MM0RmRSeDV7xw0xoV+XI2SEBRirri/bg r2ug== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=GCywvzPkTdeH7u+49o8h8q/rFZA1k5Q7Q7tL0INIr0w=; b=p3RMwhwadc7u3v/peUme9Captt6CFLJCRWe0kD/BokIW/0wzqn3G0qL6mxdFXY5GBk 1eaKmCj/I9lqX6yCd2Ui7Id/bbjdQlqqpf4AI04EtuBOoaChYqsOwwQ2T60kdv8a7zKA BKNox37omnI+apNJc7Tg/50I5hI/R0gJ7sPXHo8iZ0weitXUxY6cigst9zHH42X3dsOc jtj6h82qZJ30kEwajSCe5A13DBtXTFZtd0tvwcoteDBDVVirIemzQPZhdVH7HmqQaEGw 0rFvy2TCfXX62sLFQM5Q/57N8TgDP+GFIgx2B5lu1oHjcLUvKReoskDgNMHNGylUxmnN cJpw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=NKDnrXuH; 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 j15si632066ejy.366.2020.10.27.03.36.05; Tue, 27 Oct 2020 03:36:28 -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=NKDnrXuH; 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 S2436995AbgJZX6Q (ORCPT + 99 others); Mon, 26 Oct 2020 19:58:16 -0400 Received: from mail.kernel.org ([198.145.29.99]:35366 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2411035AbgJZX4H (ORCPT ); Mon, 26 Oct 2020 19:56:07 -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 D8DA7221FC; Mon, 26 Oct 2020 23:56:05 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1603756566; bh=UsP5Op/3imQ3f2V8/G0OczM1OdRKveFc8e0d0Jr0dZY=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=NKDnrXuH91vc5woM9Gxl2u+cr89qz+JDF9g+RsmbiNqp6///c3p0bwibujGBX1SRj r7dppPKsJdGTdwO2oPl8s0VXGL5YOU09Ia+dUwNMSkP1ptVm6ZIVK+lhH/xJSJSz3A AGMXujZYt7mCdBJI+7YZMoNPEcUa1H76iQqrFYp8= From: Sasha Levin To: linux-kernel@vger.kernel.org, stable@vger.kernel.org Cc: Peter Chen , Jun Li , Mathias Nyman , Greg Kroah-Hartman , Sasha Levin , linux-usb@vger.kernel.org Subject: [PATCH AUTOSEL 5.4 41/80] usb: xhci: omit duplicate actions when suspending a runtime suspended host. Date: Mon, 26 Oct 2020 19:54:37 -0400 Message-Id: <20201026235516.1025100-41-sashal@kernel.org> X-Mailer: git-send-email 2.25.1 In-Reply-To: <20201026235516.1025100-1-sashal@kernel.org> References: <20201026235516.1025100-1-sashal@kernel.org> MIME-Version: 1.0 X-stable: review X-Patchwork-Hint: Ignore Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Peter Chen [ Upstream commit 18a367e8947d72dd91b6fc401e88a2952c6363f7 ] If the xhci-plat.c is the platform driver, after the runtime pm is enabled, the xhci_suspend is called if nothing is connected on the port. When the system goes to suspend, it will call xhci_suspend again if USB wakeup is enabled. Since the runtime suspend wakeup setting is not always the same as system suspend wakeup setting, eg, at runtime suspend we always need wakeup if the controller is in low power mode; but at system suspend, we may not need wakeup. So, we move the judgement after changing wakeup setting. [commit message rewording -Mathias] Reviewed-by: Jun Li Signed-off-by: Peter Chen Signed-off-by: Mathias Nyman Link: https://lore.kernel.org/r/20200918131752.16488-8-mathias.nyman@linux.intel.com Signed-off-by: Greg Kroah-Hartman Signed-off-by: Sasha Levin --- drivers/usb/host/xhci.c | 7 +++++-- 1 file changed, 5 insertions(+), 2 deletions(-) diff --git a/drivers/usb/host/xhci.c b/drivers/usb/host/xhci.c index bad154f446f8d..51116030852e9 100644 --- a/drivers/usb/host/xhci.c +++ b/drivers/usb/host/xhci.c @@ -982,12 +982,15 @@ int xhci_suspend(struct xhci_hcd *xhci, bool do_wakeup) xhci->shared_hcd->state != HC_STATE_SUSPENDED) return -EINVAL; - xhci_dbc_suspend(xhci); - /* Clear root port wake on bits if wakeup not allowed. */ if (!do_wakeup) xhci_disable_port_wake_on_bits(xhci); + if (!HCD_HW_ACCESSIBLE(hcd)) + return 0; + + xhci_dbc_suspend(xhci); + /* Don't poll the roothubs on bus suspend. */ xhci_dbg(xhci, "%s: stopping port polling.\n", __func__); clear_bit(HCD_FLAG_POLL_RH, &hcd->flags); -- 2.25.1