mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-12-15 15:04:27 +08:00
Power management and ACPI fixes for v4.2-rc3
- Fix a recently introduced issue in the cpufreq policy object reinitialization that leads to CPU offline/online breakage (Viresh Kumar). - Make it possible to access frequency tables of offline CPUs which is needed by thermal management code among other things (Viresh Kumar). - Fix an ACPI resource management regression introduced during the 4.0 cycle that may cause incorrect resource validation results to appear in 32-bit x86 kernels due to silent truncation of 64-bit values to 32-bit (Jiang Liu). - Fix up an RCU-related lockdep complaint about suspicious RCU usage in idle caused by using a suspend tracepoint in the core suspend-to-idle code (Rafael J Wysocki). / -----BEGIN PGP SIGNATURE----- Version: GnuPG v2.0.22 (GNU/Linux) iQIcBAABCAAGBQJVqC6GAAoJEILEb/54YlRxgREP/RXsHHL58VVMmSFEMkNX7lX2 q2YibvVdNrZ9bk9+uNEk/NRc25mHrTHv8HyyIwn88EiUfbdvvKgyZez7KGzaFPYT 0vAJLfKwqBHKpPMc0CaYHSIqAaL3RofqTCrw6pQHUj7S0q07fTV+rZ/A7eUnMbzG fQYf0zDIYAVrmd/GqB2fUxvMXbjWNmntDrHDahXG+C+96ih/wb1Hwz9Afb6l13Le Q6t/FXrVAi4g61dpnKIKFl3efE4u0s1CnfUCoz8VYT+g+ZSb/IYdaKlQ8kNGFGuA xxNpJgwdCWb7rD0WBuonX9lCaeM/Irg9SpfEw/DViSrKUm4GMOVm4EJ2S50oneVh lY6vy4Z95YqPxRccrsPchqg6KKUTnlv3PyNMdVM4UQCyoeKmIXLYIS0MT2juHh4R w1+GWE94AFcNC6kny0M6jWhG1pUfWEbajxNz3diIB4wJPG+qyBYcdzTrg1vyLD32 4EeT5hUeQFPRILA9IiLk/L8uabJnqnvBarlJ/fl3qN0Pust3q/WbqgarqwN7tDcw ML3TlDLc9kU2e6q7VnvKqav0jCil7HHns5RIk3noOo1LZI7gM0o11sUXT4N84rla Aao+1v0Al6zMqSinCzp4uzwgaPThQpLWEGxuRvkNCceNXlJ1p5abx2DBZsSLI1Uk gAEcsa1eAg1TT3MQ2+RZ =BDs+ -----END PGP SIGNATURE----- Merge tag 'pm+acpi-4.2-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm Pull power management and ACPI fixes from Rafael Wysocki: "These fix two bugs in the cpufreq core (including one recent regression), fix a 4.0 PCI regression related to the ACPI resources management and quieten an RCU-related lockdep complaint about a tracepoint in the suspend-to-idle code. Specifics: - Fix a recently introduced issue in the cpufreq policy object reinitialization that leads to CPU offline/online breakage (Viresh Kumar) - Make it possible to access frequency tables of offline CPUs which is needed by thermal management code among other things (Viresh Kumar) - Fix an ACPI resource management regression introduced during the 4.0 cycle that may cause incorrect resource validation results to appear in 32-bit x86 kernels due to silent truncation of 64-bit values to 32-bit (Jiang Liu) - Fix up an RCU-related lockdep complaint about suspicious RCU usage in idle caused by using a suspend tracepoint in the core suspend- to-idle code (Rafael J Wysocki)" * tag 'pm+acpi-4.2-rc3' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm: ACPI / PCI: Fix regressions caused by resource_size_t overflow with 32-bit kernel cpufreq: Allow freq_table to be obtained for offline CPUs cpufreq: Initialize the governor again while restoring policy suspend-to-idle: Prevent RCU from complaining about tick_freeze()
This commit is contained in:
commit
21bdb584af
@ -193,6 +193,7 @@ static bool acpi_decode_space(struct resource_win *win,
|
|||||||
u8 iodec = attr->granularity == 0xfff ? ACPI_DECODE_10 : ACPI_DECODE_16;
|
u8 iodec = attr->granularity == 0xfff ? ACPI_DECODE_10 : ACPI_DECODE_16;
|
||||||
bool wp = addr->info.mem.write_protect;
|
bool wp = addr->info.mem.write_protect;
|
||||||
u64 len = attr->address_length;
|
u64 len = attr->address_length;
|
||||||
|
u64 start, end, offset = 0;
|
||||||
struct resource *res = &win->res;
|
struct resource *res = &win->res;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -204,9 +205,6 @@ static bool acpi_decode_space(struct resource_win *win,
|
|||||||
pr_debug("ACPI: Invalid address space min_addr_fix %d, max_addr_fix %d, len %llx\n",
|
pr_debug("ACPI: Invalid address space min_addr_fix %d, max_addr_fix %d, len %llx\n",
|
||||||
addr->min_address_fixed, addr->max_address_fixed, len);
|
addr->min_address_fixed, addr->max_address_fixed, len);
|
||||||
|
|
||||||
res->start = attr->minimum;
|
|
||||||
res->end = attr->maximum;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* For bridges that translate addresses across the bridge,
|
* For bridges that translate addresses across the bridge,
|
||||||
* translation_offset is the offset that must be added to the
|
* translation_offset is the offset that must be added to the
|
||||||
@ -214,12 +212,22 @@ static bool acpi_decode_space(struct resource_win *win,
|
|||||||
* primary side. Non-bridge devices must list 0 for all Address
|
* primary side. Non-bridge devices must list 0 for all Address
|
||||||
* Translation offset bits.
|
* Translation offset bits.
|
||||||
*/
|
*/
|
||||||
if (addr->producer_consumer == ACPI_PRODUCER) {
|
if (addr->producer_consumer == ACPI_PRODUCER)
|
||||||
res->start += attr->translation_offset;
|
offset = attr->translation_offset;
|
||||||
res->end += attr->translation_offset;
|
else if (attr->translation_offset)
|
||||||
} else if (attr->translation_offset) {
|
|
||||||
pr_debug("ACPI: translation_offset(%lld) is invalid for non-bridge device.\n",
|
pr_debug("ACPI: translation_offset(%lld) is invalid for non-bridge device.\n",
|
||||||
attr->translation_offset);
|
attr->translation_offset);
|
||||||
|
start = attr->minimum + offset;
|
||||||
|
end = attr->maximum + offset;
|
||||||
|
|
||||||
|
win->offset = offset;
|
||||||
|
res->start = start;
|
||||||
|
res->end = end;
|
||||||
|
if (sizeof(resource_size_t) < sizeof(u64) &&
|
||||||
|
(offset != win->offset || start != res->start || end != res->end)) {
|
||||||
|
pr_warn("acpi resource window ([%#llx-%#llx] ignored, not CPU addressable)\n",
|
||||||
|
attr->minimum, attr->maximum);
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (addr->resource_type) {
|
switch (addr->resource_type) {
|
||||||
@ -236,8 +244,6 @@ static bool acpi_decode_space(struct resource_win *win,
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
win->offset = attr->translation_offset;
|
|
||||||
|
|
||||||
if (addr->producer_consumer == ACPI_PRODUCER)
|
if (addr->producer_consumer == ACPI_PRODUCER)
|
||||||
res->flags |= IORESOURCE_WINDOW;
|
res->flags |= IORESOURCE_WINDOW;
|
||||||
|
|
||||||
|
@ -169,6 +169,15 @@ struct kobject *get_governor_parent_kobj(struct cpufreq_policy *policy)
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(get_governor_parent_kobj);
|
EXPORT_SYMBOL_GPL(get_governor_parent_kobj);
|
||||||
|
|
||||||
|
struct cpufreq_frequency_table *cpufreq_frequency_get_table(unsigned int cpu)
|
||||||
|
{
|
||||||
|
struct cpufreq_policy *policy = per_cpu(cpufreq_cpu_data, cpu);
|
||||||
|
|
||||||
|
return policy && !policy_is_inactive(policy) ?
|
||||||
|
policy->freq_table : NULL;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(cpufreq_frequency_get_table);
|
||||||
|
|
||||||
static inline u64 get_cpu_idle_time_jiffy(unsigned int cpu, u64 *wall)
|
static inline u64 get_cpu_idle_time_jiffy(unsigned int cpu, u64 *wall)
|
||||||
{
|
{
|
||||||
u64 idle_time;
|
u64 idle_time;
|
||||||
@ -1132,6 +1141,7 @@ static struct cpufreq_policy *cpufreq_policy_restore(unsigned int cpu)
|
|||||||
|
|
||||||
down_write(&policy->rwsem);
|
down_write(&policy->rwsem);
|
||||||
policy->cpu = cpu;
|
policy->cpu = cpu;
|
||||||
|
policy->governor = NULL;
|
||||||
up_write(&policy->rwsem);
|
up_write(&policy->rwsem);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -297,15 +297,6 @@ int cpufreq_table_validate_and_show(struct cpufreq_policy *policy,
|
|||||||
}
|
}
|
||||||
EXPORT_SYMBOL_GPL(cpufreq_table_validate_and_show);
|
EXPORT_SYMBOL_GPL(cpufreq_table_validate_and_show);
|
||||||
|
|
||||||
struct cpufreq_policy *cpufreq_cpu_get_raw(unsigned int cpu);
|
|
||||||
|
|
||||||
struct cpufreq_frequency_table *cpufreq_frequency_get_table(unsigned int cpu)
|
|
||||||
{
|
|
||||||
struct cpufreq_policy *policy = cpufreq_cpu_get_raw(cpu);
|
|
||||||
return policy ? policy->freq_table : NULL;
|
|
||||||
}
|
|
||||||
EXPORT_SYMBOL_GPL(cpufreq_frequency_get_table);
|
|
||||||
|
|
||||||
MODULE_AUTHOR("Dominik Brodowski <linux@brodo.de>");
|
MODULE_AUTHOR("Dominik Brodowski <linux@brodo.de>");
|
||||||
MODULE_DESCRIPTION("CPUfreq frequency table helpers");
|
MODULE_DESCRIPTION("CPUfreq frequency table helpers");
|
||||||
MODULE_LICENSE("GPL");
|
MODULE_LICENSE("GPL");
|
||||||
|
@ -112,7 +112,12 @@ int cpuidle_find_deepest_state(struct cpuidle_driver *drv,
|
|||||||
static void enter_freeze_proper(struct cpuidle_driver *drv,
|
static void enter_freeze_proper(struct cpuidle_driver *drv,
|
||||||
struct cpuidle_device *dev, int index)
|
struct cpuidle_device *dev, int index)
|
||||||
{
|
{
|
||||||
tick_freeze();
|
/*
|
||||||
|
* trace_suspend_resume() called by tick_freeze() for the last CPU
|
||||||
|
* executing it contains RCU usage regarded as invalid in the idle
|
||||||
|
* context, so tell RCU about that.
|
||||||
|
*/
|
||||||
|
RCU_NONIDLE(tick_freeze());
|
||||||
/*
|
/*
|
||||||
* The state used here cannot be a "coupled" one, because the "coupled"
|
* The state used here cannot be a "coupled" one, because the "coupled"
|
||||||
* cpuidle mechanism enables interrupts and doing that with timekeeping
|
* cpuidle mechanism enables interrupts and doing that with timekeeping
|
||||||
@ -122,7 +127,7 @@ static void enter_freeze_proper(struct cpuidle_driver *drv,
|
|||||||
WARN_ON(!irqs_disabled());
|
WARN_ON(!irqs_disabled());
|
||||||
/*
|
/*
|
||||||
* timekeeping_resume() that will be called by tick_unfreeze() for the
|
* timekeeping_resume() that will be called by tick_unfreeze() for the
|
||||||
* last CPU executing it calls functions containing RCU read-side
|
* first CPU executing it calls functions containing RCU read-side
|
||||||
* critical sections, so tell RCU about that.
|
* critical sections, so tell RCU about that.
|
||||||
*/
|
*/
|
||||||
RCU_NONIDLE(tick_unfreeze());
|
RCU_NONIDLE(tick_unfreeze());
|
||||||
|
Loading…
Reference in New Issue
Block a user