Hi Thara, * Thara Gopinath <thara@xxxxxx> [101027 09:08]: > By default the system boots up at nominal voltage for every > voltage domain in the system. This patch puts vdd_mpu, vdd_iva > and vdd_core to the correct boot up voltage as per the opp tables > specified. This patch implements this by matching the rate of > the main clock of the voltage domain with the opp table and > picking up the correct voltage. > > Signed-off-by: Thara Gopinath <thara@xxxxxx> > --- > arch/arm/mach-omap2/pm.c | 4 ++++ > 1 files changed, 4 insertions(+), 0 deletions(-) > > diff --git a/arch/arm/mach-omap2/pm.c b/arch/arm/mach-omap2/pm.c > index 353e155..0651667 100644 > --- a/arch/arm/mach-omap2/pm.c > +++ b/arch/arm/mach-omap2/pm.c > @@ -211,6 +211,10 @@ static int __init omap2_common_pm_init(void) > if (cpu_is_omap34xx()) { > omap2_set_init_voltage("mpu", "dpll1_ck", mpu_dev); > omap2_set_init_voltage("core", "l3_ick", l3_dev); > + } else if (cpu_is_omap44xx()) { > + omap2_set_init_voltage("mpu", "dpll_mpu_ck", mpu_dev); > + omap2_set_init_voltage("core", "l3_div_ck", l3_dev); > + omap2_set_init_voltage("iva", "dpll_iva_m5x2_ck", iva_dev); > } > > omap_pm_if_init(); In general, we want to avoid adding these "if cpu_is_ompa34xx else if" things all over the place. That makes the code hard to maintain and requires patching all over the place to add support for new omaps. Instead, please do something like this: static int __init omap_common_whatever_init(struct whatever_data *d) { ... return 0; } static int __init omap3_whatever_init(void) { struct whatever_data *d; if (!cpu_is_omap34xx()) return -ENODEV; /* Initialize omap3 specific things */ ... return omap_common_whatever_init(d); } device_initcall(omap3_whatever_init); static int __init omap4_whatever_init(void) { struct whatever_data *d; if (!cpu_is_omap44xx()) return -ENODEV; /* Initialize omap4 specific things */ ... return omap_common_whatever_init(d); } device_initcall(omap4_whatever_init); ... This way the common code stays readable and does not need to be patched when support for new omaps is added. Also the code for unselected omaps gets optimized out and an extra level of code indentation is left out. Regards, Tony -- To unsubscribe from this list: send the line "unsubscribe linux-omap" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html