Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp530482pxf; Wed, 17 Mar 2021 09:53:44 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyQqkGRjr+P36O/hNscl2UEyKb7bL5qJI3ueUM4KtoY/18gVjblCR2ntEoZWolmbIFfVVmz X-Received: by 2002:a17:906:4f10:: with SMTP id t16mr36600621eju.531.1616000024536; Wed, 17 Mar 2021 09:53:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616000024; cv=none; d=google.com; s=arc-20160816; b=U2OtFztDAZZ/nyggB+a/eWDnyamesSB360EaVSVzkkFI56npXFz7MinGUSmdQfx9// 4EG3gh56Zb6E5vvY27WLlDMUGMK1IaGMljTRiHFYfbevAjztYnM1vB8Gwi1Ckk5XryQD 0VkYvqEREvVGS0o5dUboNibvkN/Toi5+IbmGvNRgpZI9Se7H4IVb9aWt2q90CdH3q+vj TZXz64AESgBERA0I/kvlfvCAxg1zKT22jrZgBX+KlIY2d3hzUptNVQNPYa0cF/HIlTqC 8n3fDxeOaCmlRkiQc9GYm34p+SO196J7H6zub9s3/+qj/76FrhF/FtJhxya5qA41n83u aPvQ== 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 :message-id:date:subject:cc:to:from; bh=ickKAOXy1hu8vZUVPX0HJ5VzpSzcZSJQW6l32Nlv/DA=; b=ppsBNn9fQ2u5GqHrEAVYaC+YT0kzQEY4GZBSLfnPF/51XqQJcnu8yOk4Lp7R4Y+R2F UIFZDtTUJE/KpHotlTbz3YKiP9dMGJkfqG5KM0TgYoDSbBb+hyYK8AcY4R0ibD6pYZpB EDR30HBFSNg4tB8ReF39A30gbPXcOeaqcIM5GLDOAspcojOdxjQSO1Br+w8fOj/AJch9 g86mQ4vqW0BHu4o1w+QXVG1oWQcahRS9e31YKitt0Ul3gF3hqowZ/RM/tK3BaIAvK91W ET9ueMaopTZmWClqsnJU6cxcfzebWfFkpk9EGR+scuNUdbV0Tmn9FYI58t6ynHqI+YJv N5pw== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id p12si16626787eja.559.2021.03.17.09.53.18; Wed, 17 Mar 2021 09:53:44 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232403AbhCQQuU (ORCPT + 99 others); Wed, 17 Mar 2021 12:50:20 -0400 Received: from cloudserver094114.home.pl ([79.96.170.134]:47332 "EHLO cloudserver094114.home.pl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232588AbhCQQuA (ORCPT ); Wed, 17 Mar 2021 12:50:00 -0400 Received: from localhost (127.0.0.1) (HELO v370.home.net.pl) by /usr/run/smtp (/usr/run/postfix/private/idea_relay_lmtp) via UNIX with SMTP (IdeaSmtpServer 2.0.3) id b5a2283f45a98cea; Wed, 17 Mar 2021 17:49:56 +0100 Received: from kreacher.localnet (89-64-80-90.dynamic.chello.pl [89.64.80.90]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by v370.home.net.pl (Postfix) with ESMTPSA id A50E0668F2A; Wed, 17 Mar 2021 17:49:55 +0100 (CET) From: "Rafael J. Wysocki" To: Linux ACPI Cc: LKML , Linux PM , David Box Subject: [PATCH] ACPI: scan: Turn off unused power resources during initialization Date: Wed, 17 Mar 2021 17:49:55 +0100 Message-ID: <2527835.vZkJICojNU@kreacher> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" X-VADE-SPAMSTATE: clean X-VADE-SPAMCAUSE: gggruggvucftvghtrhhoucdtuddrgeduledrudefgedgleehucetufdoteggodetrfdotffvucfrrhhofhhilhgvmecujffqoffgrffnpdggtffipffknecuuegrihhlohhuthemucduhedtnecusecvtfgvtghiphhivghnthhsucdlqddutddtmdenucfjughrpefhvffufffkggfgtgesthfuredttddtvdenucfhrhhomhepfdftrghfrggvlhculfdrucghhihsohgtkhhifdcuoehrjhifsehrjhifhihsohgtkhhirdhnvghtqeenucggtffrrghtthgvrhhnpeevudefgfeguedtjedvhfetveegleduveeuvedvjeekleefhfduhfefheekffefveenucfkphepkeelrdeigedrkedtrdeltdenucevlhhushhtvghrufhiiigvpedtnecurfgrrhgrmhepihhnvghtpeekledrieegrdektddrledtpdhhvghlohepkhhrvggrtghhvghrrdhlohgtrghlnhgvthdpmhgrihhlfhhrohhmpedftfgrfhgrvghlucflrdcuhgihshhotghkihdfuceorhhjfiesrhhjfiihshhotghkihdrnhgvtheqpdhrtghpthhtoheplhhinhhugidqrggtphhisehvghgvrhdrkhgvrhhnvghlrdhorhhgpdhrtghpthhtoheplhhinhhugidqkhgvrhhnvghlsehvghgvrhdrkhgvrhhnvghlrdhorhhgpdhrtghpthhtoheplhhinhhugidqphhmsehvghgvrhdrkhgvrhhnvghlrdhorhhgpdhrtghpthhtohepuggrvhhiugdrvgdrsghogieslhhinhhugidrihhnthgvlhdrtghomh X-DCC--Metrics: v370.home.net.pl 1024; Body=4 Fuz1=4 Fuz2=4 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Rafael J. Wysocki It is reported that on certain platforms unused ACPI power resources that have not been explicitly turned off prevent the platform from reaching the lowest power state in suspend-to-idle which leads to excessive power draw. For this reason, turn all of the unused ACPI power resources off at the end of the initial namespace scan for devices in analogy with resume from suspend-to-RAM. Reported-by: David Box Signed-off-by: Rafael J. Wysocki --- drivers/acpi/internal.h | 1 + drivers/acpi/scan.c | 2 ++ drivers/acpi/sleep.h | 1 - 3 files changed, 3 insertions(+), 1 deletion(-) Index: linux-pm/drivers/acpi/internal.h =================================================================== --- linux-pm.orig/drivers/acpi/internal.h +++ linux-pm/drivers/acpi/internal.h @@ -139,6 +139,7 @@ int acpi_device_sleep_wake(struct acpi_d int acpi_power_get_inferred_state(struct acpi_device *device, int *state); int acpi_power_on_resources(struct acpi_device *device, int state); int acpi_power_transition(struct acpi_device *device, int state); +void acpi_turn_off_unused_power_resources(void); /* -------------------------------------------------------------------------- Device Power Management Index: linux-pm/drivers/acpi/scan.c =================================================================== --- linux-pm.orig/drivers/acpi/scan.c +++ linux-pm/drivers/acpi/scan.c @@ -2360,6 +2360,8 @@ int __init acpi_scan_init(void) } } + acpi_turn_off_unused_power_resources(); + acpi_scan_initialized = true; out: Index: linux-pm/drivers/acpi/sleep.h =================================================================== --- linux-pm.orig/drivers/acpi/sleep.h +++ linux-pm/drivers/acpi/sleep.h @@ -8,7 +8,6 @@ extern struct list_head acpi_wakeup_devi extern struct mutex acpi_device_lock; extern void acpi_resume_power_resources(void); -extern void acpi_turn_off_unused_power_resources(void); static inline acpi_status acpi_set_waking_vector(u32 wakeup_address) {