mirror of https://gitee.com/openkylin/linux.git
Final power management fixes for v4.14
- Prevent the schedutil cpufreq governor from using the utilization of a wrong CPU in some cases which started to happen after one of the recent changes in it (Chris Redpath). - Blacklist Dell XPS13 9360 from using the Low Power S0 Idle _DSM interface as that causes serious issue (related to NVMe) to appear on one of these machines, even though the other Dells XPS13 9360 in somewhat different HW configurations behave correctly (Rafael Wysocki). -----BEGIN PGP SIGNATURE----- Version: GnuPG v2 iQIcBAABCAAGBQJaBFMsAAoJEILEb/54YlRxb8sP/jhqgCEiaUvSpFYBLklx1fqK QDbbYw3Os2JlAcMFElGjZEoV0+WBbadTHQxIxB353mpcAe1moI/SoDAJEgA9HWib tjJIt1lak3nLF967y0pOgAi9uvFCG6Rw+ZyVSrYBnT+eG6fw3h6MdHaOEFeCHJY4 qUgj+Bm0OtisW9mRFk5zdGam+6MxaE1z9mhjRAebrAjOI+46Oj/LQl7q32S2vWTp GJm6lSYOmSruo5vdU7T3dOSkBrkymf4E//1XkegFvcweEX/aITuCAil0Rl4X2PV0 NSeeCp66skftvlZ/vf3QOem1XLgPdVZ9dr7WRzOZt3CDctXuDaA3uKfRJf3oIMsi rnrsmWnfsT4sNaqV6zHYTkMtQfSsxFfjOde/HC7vAtC0oM/EECsonBtIlMUBmYlR 7fi+wtrE6ErsMgkThOvplG+cAnvWCK8yhmFBAKbcwg9UHwooF0HxXPqVwHE6M8pw eFALkJyagx1PTGKXNHOUTHfZcYGlhhJxH6SEhs/pJIxL8rVgey8mJfA9y8eGmEXP fKPnEb6yI7/9ZpzFFu3DLiHMifgc6o9F0mRqw3apeQFGtg46frYw51meP5Faq0EZ BAb0AXBF4qNB+XvORG0ABJkPqqDaZVPVfdo1SIA06IBr2mpVT1RAetMU0qSuWy+x STI04myU/9hHmCSdqzpg =F9fg -----END PGP SIGNATURE----- Merge tag 'pm-final-4.14' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm Pull final power management fixes from Rafael Wysocki: "These fix a regression in the schedutil cpufreq governor introduced by a recent change and blacklist Dell XPS13 9360 from using the Low Power S0 Idle _DSM interface which triggers serious problems on one of these machines. Specifics: - Prevent the schedutil cpufreq governor from using the utilization of a wrong CPU in some cases which started to happen after one of the recent changes in it (Chris Redpath). - Blacklist Dell XPS13 9360 from using the Low Power S0 Idle _DSM interface as that causes serious issue (related to NVMe) to appear on one of these machines, even though the other Dells XPS13 9360 in somewhat different HW configurations behave correctly (Rafael Wysocki)" * tag 'pm-final-4.14' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: ACPI / PM: Blacklist Low Power S0 Idle _DSM for Dell XPS13 9360 cpufreq: schedutil: Examine the correct CPU when we update util
This commit is contained in:
commit
3fefc31843
|
@ -160,6 +160,14 @@ static int __init init_nvs_nosave(const struct dmi_system_id *d)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static bool acpi_sleep_no_lps0;
|
||||||
|
|
||||||
|
static int __init init_no_lps0(const struct dmi_system_id *d)
|
||||||
|
{
|
||||||
|
acpi_sleep_no_lps0 = true;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static const struct dmi_system_id acpisleep_dmi_table[] __initconst = {
|
static const struct dmi_system_id acpisleep_dmi_table[] __initconst = {
|
||||||
{
|
{
|
||||||
.callback = init_old_suspend_ordering,
|
.callback = init_old_suspend_ordering,
|
||||||
|
@ -343,6 +351,19 @@ static const struct dmi_system_id acpisleep_dmi_table[] __initconst = {
|
||||||
DMI_MATCH(DMI_PRODUCT_NAME, "80E3"),
|
DMI_MATCH(DMI_PRODUCT_NAME, "80E3"),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
/*
|
||||||
|
* https://bugzilla.kernel.org/show_bug.cgi?id=196907
|
||||||
|
* Some Dell XPS13 9360 cannot do suspend-to-idle using the Low Power
|
||||||
|
* S0 Idle firmware interface.
|
||||||
|
*/
|
||||||
|
{
|
||||||
|
.callback = init_no_lps0,
|
||||||
|
.ident = "Dell XPS13 9360",
|
||||||
|
.matches = {
|
||||||
|
DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc."),
|
||||||
|
DMI_MATCH(DMI_PRODUCT_NAME, "XPS 13 9360"),
|
||||||
|
},
|
||||||
|
},
|
||||||
{},
|
{},
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -485,6 +506,7 @@ static void acpi_pm_end(void)
|
||||||
}
|
}
|
||||||
#else /* !CONFIG_ACPI_SLEEP */
|
#else /* !CONFIG_ACPI_SLEEP */
|
||||||
#define acpi_target_sleep_state ACPI_STATE_S0
|
#define acpi_target_sleep_state ACPI_STATE_S0
|
||||||
|
#define acpi_sleep_no_lps0 (false)
|
||||||
static inline void acpi_sleep_dmi_check(void) {}
|
static inline void acpi_sleep_dmi_check(void) {}
|
||||||
#endif /* CONFIG_ACPI_SLEEP */
|
#endif /* CONFIG_ACPI_SLEEP */
|
||||||
|
|
||||||
|
@ -863,6 +885,12 @@ static int lps0_device_attach(struct acpi_device *adev,
|
||||||
if (lps0_device_handle)
|
if (lps0_device_handle)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
if (acpi_sleep_no_lps0) {
|
||||||
|
acpi_handle_info(adev->handle,
|
||||||
|
"Low Power S0 Idle interface disabled\n");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
if (!(acpi_gbl_FADT.flags & ACPI_FADT_LOW_POWER_S0))
|
if (!(acpi_gbl_FADT.flags & ACPI_FADT_LOW_POWER_S0))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
|
|
|
@ -649,6 +649,7 @@ static int sugov_start(struct cpufreq_policy *policy)
|
||||||
struct sugov_cpu *sg_cpu = &per_cpu(sugov_cpu, cpu);
|
struct sugov_cpu *sg_cpu = &per_cpu(sugov_cpu, cpu);
|
||||||
|
|
||||||
memset(sg_cpu, 0, sizeof(*sg_cpu));
|
memset(sg_cpu, 0, sizeof(*sg_cpu));
|
||||||
|
sg_cpu->cpu = cpu;
|
||||||
sg_cpu->sg_policy = sg_policy;
|
sg_cpu->sg_policy = sg_policy;
|
||||||
sg_cpu->flags = SCHED_CPUFREQ_RT;
|
sg_cpu->flags = SCHED_CPUFREQ_RT;
|
||||||
sg_cpu->iowait_boost_max = policy->cpuinfo.max_freq;
|
sg_cpu->iowait_boost_max = policy->cpuinfo.max_freq;
|
||||||
|
@ -714,11 +715,6 @@ struct cpufreq_governor *cpufreq_default_governor(void)
|
||||||
|
|
||||||
static int __init sugov_register(void)
|
static int __init sugov_register(void)
|
||||||
{
|
{
|
||||||
int cpu;
|
|
||||||
|
|
||||||
for_each_possible_cpu(cpu)
|
|
||||||
per_cpu(sugov_cpu, cpu).cpu = cpu;
|
|
||||||
|
|
||||||
return cpufreq_register_governor(&schedutil_gov);
|
return cpufreq_register_governor(&schedutil_gov);
|
||||||
}
|
}
|
||||||
fs_initcall(sugov_register);
|
fs_initcall(sugov_register);
|
||||||
|
|
Loading…
Reference in New Issue