diff options
author | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2019-12-10 12:48:35 +0100 |
---|---|---|
committer | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2019-12-10 23:41:20 +0100 |
commit | b0142d66f4edb8578b7772d6d7ad731836b82ddb (patch) | |
tree | d5e9cfeb7782e390392c0956ed9b12e9744fdd8c /drivers/cpuidle/cpuidle.c | |
parent | cpuidle: use first valid target residency as poll time (diff) | |
download | linux-b0142d66f4edb8578b7772d6d7ad731836b82ddb.tar.xz linux-b0142d66f4edb8578b7772d6d7ad731836b82ddb.zip |
cpuidle: Fix cpuidle_driver_state_disabled()
It turns out that cpuidle_driver_state_disabled() can be called
before registering the cpufreq driver on some platforms, which
was not expected when it was introduced and which leads to a NULL
pointer dereference when trying to walk the CPUs associated with
the given cpuidle driver.
Fix the problem by making cpuidle_driver_state_disabled() check if
the driver's mask of CPUs associated with it is present and to set
CPUIDLE_FLAG_UNUSABLE for the given idle state in the driver's states
list if that is not the case to cause __cpuidle_register_device() to
set CPUIDLE_STATE_DISABLED_BY_DRIVER for that state for all cpuidle
devices registered by it later.
Fixes: cbda56d5fefc ("cpuidle: Introduce cpuidle_driver_state_disabled() for driver quirks")
Reported-by: Daniel Lezcano <daniel.lezcano@linaro.org>
Tested-by: Daniel Lezcano <daniel.lezcano@linaro.org>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Diffstat (limited to '')
0 files changed, 0 insertions, 0 deletions