From: Xunlei Pang <[email protected]> Since we're using cpuidle_driver::safe_state_index directly as the target state index, it's better to add the sanity check at the point of registering the driver.
Signed-off-by: Xunlei Pang <[email protected]> --- drivers/cpuidle/driver.c | 13 +++++++++++++ 1 file changed, 13 insertions(+) diff --git a/drivers/cpuidle/driver.c b/drivers/cpuidle/driver.c index 5db1478..def299e 100644 --- a/drivers/cpuidle/driver.c +++ b/drivers/cpuidle/driver.c @@ -223,10 +223,23 @@ static void poll_idle_init(struct cpuidle_driver *drv) {} static int __cpuidle_register_driver(struct cpuidle_driver *drv) { int ret; +#ifdef CONFIG_ARCH_NEEDS_CPU_IDLE_COUPLED + int i; +#endif if (!drv || !drv->state_count) return -EINVAL; +#ifdef CONFIG_ARCH_NEEDS_CPU_IDLE_COUPLED + for (i = drv->state_count - 1; i >= 0; i--) { + if (cpuidle_state_is_coupled(drv, i) && + (drv->safe_state_index == i || + drv->safe_state_index < 0 || + drv->safe_state_index >= drv->state_count)) + return -EINVAL; + } +#endif + if (cpuidle_disabled()) return -ENODEV; -- 1.9.1 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [email protected] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/

