Message ID | 1364553095-25110-4-git-send-email-daniel.lezcano@linaro.org |
---|---|
State | New |
Headers | show |
On Friday 29 March 2013 04:01 PM, Daniel Lezcano wrote: > The driver is initialized several times. This is wrong and if the > return code of the function was checked, it will return -EINVAL. > > Move this initialization out of the loop. > > Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org> > --- Fix for this is already and v2 of the patch is here [1] Regards, Santosh [1] https://patchwork.kernel.org/patch/2329861/
On 03/29/2013 11:38 AM, Santosh Shilimkar wrote: > On Friday 29 March 2013 04:01 PM, Daniel Lezcano wrote: >> The driver is initialized several times. This is wrong and if the >> return code of the function was checked, it will return -EINVAL. >> >> Move this initialization out of the loop. >> >> Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org> >> --- > Fix for this is already and v2 of the patch is here [1] Ah, ok. Thanks for reviewing the patch. Can we find a solution to have a single entry point to sumbit patches for all the cpuidle drivers ? Otherwise, consolidating them is a pain: a patch for the samsung tree, another one for the at91 tree, etc ... and wait for all the trees to sync before continuing to consolidate the code. Wouldn't be worth to move these drivers under the PM umbrella instead of the SoC specific code ? Any idea to simplify the cpuidle consolidation and maintenance ? Thanks -- Daniel
On Friday 29 March 2013 04:15 PM, Daniel Lezcano wrote: > On 03/29/2013 11:38 AM, Santosh Shilimkar wrote: >> On Friday 29 March 2013 04:01 PM, Daniel Lezcano wrote: >>> The driver is initialized several times. This is wrong and if the >>> return code of the function was checked, it will return -EINVAL. >>> >>> Move this initialization out of the loop. >>> >>> Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org> >>> --- >> Fix for this is already and v2 of the patch is here [1] > > Ah, ok. Thanks for reviewing the patch. > > Can we find a solution to have a single entry point to sumbit patches > for all the cpuidle drivers ? > > Otherwise, consolidating them is a pain: a patch for the samsung tree, > another one for the at91 tree, etc ... and wait for all the trees to > sync before continuing to consolidate the code. > > Wouldn't be worth to move these drivers under the PM umbrella instead of > the SoC specific code ? > > Any idea to simplify the cpuidle consolidation and maintenance ? > Fisrtly patches get posted to right mailing list based on where the code resides. So one must keep a watch on LAKML for the patches. Talking specific to OMAP idle code, there is plan to move to drivers/idle/* but for that to happen there are some PRM/CM dependency for which also driver movement is planned. Once that happen, OMAP idle will find its way in drivers/idle/*
On 03/29/2013 11:53 AM, Santosh Shilimkar wrote: > On Friday 29 March 2013 04:15 PM, Daniel Lezcano wrote: >> On 03/29/2013 11:38 AM, Santosh Shilimkar wrote: >>> On Friday 29 March 2013 04:01 PM, Daniel Lezcano wrote: >>>> The driver is initialized several times. This is wrong and if the >>>> return code of the function was checked, it will return -EINVAL. >>>> >>>> Move this initialization out of the loop. >>>> >>>> Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org> >>>> --- >>> Fix for this is already and v2 of the patch is here [1] >> >> Ah, ok. Thanks for reviewing the patch. >> >> Can we find a solution to have a single entry point to sumbit patches >> for all the cpuidle drivers ? >> >> Otherwise, consolidating them is a pain: a patch for the samsung tree, >> another one for the at91 tree, etc ... and wait for all the trees to >> sync before continuing to consolidate the code. >> >> Wouldn't be worth to move these drivers under the PM umbrella instead of >> the SoC specific code ? >> >> Any idea to simplify the cpuidle consolidation and maintenance ? >> > Fisrtly patches get posted to right mailing list based on where the > code resides. So one must keep a watch on LAKML for the patches. Yes, I agree. The main issue is the multiple tree for the different drivers making hard to track, modify and improve the drivers in one shot. It is not the first time, a modification of the cpuidle framework implied to modify all the drivers. When Rob introduced the first code consolidation, that took months to add a simple flag in the drivers because we had to wait for the merge before the changes in drivers/cpuidle/cpuidle.c were visible. > Talking specific to OMAP idle code, there is plan to move > to drivers/idle/* but for that to happen there are some PRM/CM > dependency for which also driver movement is planned. Once > that happen, OMAP idle will find its way in drivers/idle/* That would be *really* great. If we can do that for all the drivers, that will solve the multi-location / multi-tree problem. The u8500 driver will be moved soon to this directory also. I did some modifications around the at91 some months ago to encapsulate the code more, maybe it could be also a good candidate. Nicolas ? For OMAP3 that could be a bit more difficult. Who is maintaining the driver now ? I Cc'ed the different maintainers for the other boards, may be they can react ? Thanks -- Daniel
On Friday 29 March 2013 04:53 PM, Daniel Lezcano wrote: > On 03/29/2013 11:53 AM, Santosh Shilimkar wrote: >> On Friday 29 March 2013 04:15 PM, Daniel Lezcano wrote: [..] > For OMAP3 that could be a bit more difficult. Who is maintaining the > driver now ? > The driver is still maintained by Kevin Hilman and quite a few us keep that driver upto date. OMAP3 idle is movable as well. A while back I have assessed move of OMAP3 and OMAP4 idle drivers, and the only issue was the other PRM/CM dependency. Regards, Santosh
diff --git a/arch/arm/mach-omap2/cpuidle44xx.c b/arch/arm/mach-omap2/cpuidle44xx.c index f4b1b23..3d33b8a 100644 --- a/arch/arm/mach-omap2/cpuidle44xx.c +++ b/arch/arm/mach-omap2/cpuidle44xx.c @@ -210,6 +210,7 @@ int __init omap4_idle_init(void) { struct cpuidle_device *dev; unsigned int cpu_id = 0; + int ret; mpu_pd = pwrdm_lookup("mpu_pwrdm"); cpu_pd[0] = pwrdm_lookup("cpu0_pwrdm"); @@ -222,14 +223,18 @@ int __init omap4_idle_init(void) if (!cpu_clkdm[0] || !cpu_clkdm[1]) return -ENODEV; + ret = cpuidle_register_driver(&omap4_idle_driver); + if (ret) { + printk(KERN_ERR "failed to register the idle driver\n"); + return ret; + } + for_each_cpu(cpu_id, cpu_online_mask) { dev = &per_cpu(omap4_idle_dev, cpu_id); dev->cpu = cpu_id; #ifdef CONFIG_ARCH_NEEDS_CPU_IDLE_COUPLED dev->coupled_cpus = *cpu_online_mask; #endif - cpuidle_register_driver(&omap4_idle_driver); - if (cpuidle_register_device(dev)) { pr_err("%s: CPUidle register failed\n", __func__); return -EIO;
The driver is initialized several times. This is wrong and if the return code of the function was checked, it will return -EINVAL. Move this initialization out of the loop. Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org> --- arch/arm/mach-omap2/cpuidle44xx.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-)