On Tuesday, August 04, 2015 01:48:57 PM Xunlei Pang wrote: > From: Xunlei Pang <pang.xun...@linaro.org> > > 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 <pang.xun...@linaro.org> > --- > 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
Please move this code to a separate function depending on CONFIG_ARCH_NEEDS_CPU_IDLE_COUPLED, define a "return 0" stub of it for CONFIG_ARCH_NEEDS_CPU_IDLE_COUPLED unset and call it from here. Generally, please try to avoid using #ifdef and similar in function bodies if possible. > + > if (cpuidle_disabled()) > return -ENODEV; > > Thanks, Rafael -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/