]> git.baikalelectronics.ru Git - kernel.git/commit
platform/x86: amd-pmc: Set QOS during suspend on CZN w/ timer wakeup
authorMario Limonciello <mario.limonciello@amd.com>
Wed, 23 Feb 2022 17:52:37 +0000 (11:52 -0600)
committerHans de Goede <hdegoede@redhat.com>
Wed, 2 Mar 2022 10:42:11 +0000 (11:42 +0100)
commit19e71e3639de273005f3eeb95d4f3e80268aeccf
tree4287ba7f5c6936e998c80fcf792b5b1ea19ec8ca
parent98284c2f5c22f699c43378dde0ffa64b3495a904
platform/x86: amd-pmc: Set QOS during suspend on CZN w/ timer wakeup

commit 5ce9f7468cc3 ("platform/x86: amd-pmc: Add special handling for
timer based S0i3 wakeup") adds support for using another platform timer
in lieu of the RTC which doesn't work properly on some systems. This path
was validated and worked well before submission. During the 5.16-rc1 merge
window other patches were merged that caused this to stop working properly.

When this feature was used with 5.16-rc1 or later some OEM laptops with the
matching firmware requirements from that commit would shutdown instead of
program a timer based wakeup.

This was bisected to commit f146da28dd2f ("PM: suspend: Do not pause
cpuidle in the suspend-to-idle path").  This wasn't supposed to cause any
negative impacts and also tested well on both Intel and ARM platforms.
However this changed the semantics of when CPUs are allowed to be in the
deepest state. For the AMD systems in question it appears this causes a
firmware crash for timer based wakeup.

It's hypothesized to be caused by the `amd-pmc` driver sending `OS_HINT`
and all the CPUs going into a deep state while the timer is still being
programmed. It's likely a firmware bug, but to avoid it don't allow setting
CPUs into the deepest state while using CZN timer wakeup path.

If later it's discovered that this also occurs from "regular" suspends
without a timer as well or on other silicon, this may be later expanded to
run in the suspend path for more scenarios.

Cc: stable@vger.kernel.org # 5.16+
Suggested-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Link: https://lore.kernel.org/linux-acpi/BL1PR12MB51570F5BD05980A0DCA1F3F4E23A9@BL1PR12MB5157.namprd12.prod.outlook.com/T/#mee35f39c41a04b624700ab2621c795367f19c90e
Fixes: f146da28dd2f ("PM: suspend: Do not pause cpuidle in the suspend-to-idle path")
Fixes: 4df1e0743e4e ("PM: sleep: Pause cpuidle later and resume it earlier during system transitions")
Fixes: 5ce9f7468cc3 ("platform/x86: amd-pmc: Add special handling for timer based S0i3 wakeup")
Reviewed-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Signed-off-by: Mario Limonciello <mario.limonciello@amd.com>
Link: https://lore.kernel.org/r/20220223175237.6209-1-mario.limonciello@amd.com
Reviewed-by: Hans de Goede <hdegoede@redhat.com>
Signed-off-by: Hans de Goede <hdegoede@redhat.com>
drivers/platform/x86/amd-pmc.c