diff options
author | Lan Tianyu <tianyu.lan@intel.com> | 2014-07-31 10:28:50 -0400 |
---|---|---|
committer | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2014-08-06 16:22:03 -0400 |
commit | ea9c167d93e6e2f4697f5061756f26356793cd95 (patch) | |
tree | 40edef11d556e794c9dda5e31bb37f491d26cd89 /drivers/acpi | |
parent | 515afdcba0880528fa8ae6fa63a14de6b9018770 (diff) |
ACPI / processor: Make acpi_cpu_soft_notify() process CPU FROZEN events
CPU hotplug happens during S2RAM and CPU notify event will be CPU_XXX_FROZEN.
acpi_cpu_soft_notify() ignores to check these events. This also may make
acpi_cpu_soft_notify() fall into sleep during CPU_DYING/STARTING_FROZEN
events which don't allow callbacks to sleep. This patch is to fix it.
Signed-off-by: Lan Tianyu <tianyu.lan@intel.com>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Diffstat (limited to 'drivers/acpi')
-rw-r--r-- | drivers/acpi/processor_driver.c | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/acpi/processor_driver.c b/drivers/acpi/processor_driver.c index 4fcbd670415c..d9f71581b79b 100644 --- a/drivers/acpi/processor_driver.c +++ b/drivers/acpi/processor_driver.c | |||
@@ -120,6 +120,7 @@ static int acpi_cpu_soft_notify(struct notifier_block *nfb, | |||
120 | unsigned int cpu = (unsigned long)hcpu; | 120 | unsigned int cpu = (unsigned long)hcpu; |
121 | struct acpi_processor *pr = per_cpu(processors, cpu); | 121 | struct acpi_processor *pr = per_cpu(processors, cpu); |
122 | struct acpi_device *device; | 122 | struct acpi_device *device; |
123 | action &= ~CPU_TASKS_FROZEN; | ||
123 | 124 | ||
124 | /* | 125 | /* |
125 | * CPU_STARTING and CPU_DYING must not sleep. Return here since | 126 | * CPU_STARTING and CPU_DYING must not sleep. Return here since |