On Wed, Aug 8, 2012 at 10:58 PM, Kevin Hilman <khilman@xxxxxx> wrote: > > "Shilimkar, Santosh" <santosh.shilimkar@xxxxxx> writes: > > > On Wed, Aug 8, 2012 at 4:24 PM, Rajendra Nayak <rnayak@xxxxxx> wrote: > >> > >> On OMAP4, if the first CPU fails to get a valid frequency table (this > >> could happen if the platform does not register any OPP table), the > >> subsequent CPU instances end up dealing with a NULL freq_table and > >> crash. Add a check for a NULL freq_table to help error the rest > >> of the CPU instances out. > >> > >> Signed-off-by: Rajendra Nayak <rnayak@xxxxxx> > >> Cc: <linux-pm@xxxxxxxxxxxxxxx> > >> --- > >> drivers/cpufreq/omap-cpufreq.c | 2 +- > >> 1 file changed, 1 insertion(+), 1 deletion(-) > >> > >> diff --git a/drivers/cpufreq/omap-cpufreq.c > >> b/drivers/cpufreq/omap-cpufreq.c > >> index 17fa04d..0ee824c 100644 > >> --- a/drivers/cpufreq/omap-cpufreq.c > >> +++ b/drivers/cpufreq/omap-cpufreq.c > >> @@ -221,7 +221,7 @@ static int __cpuinit omap_cpu_init(struct > >> cpufreq_policy *policy) > >> if (atomic_inc_return(&freq_table_users) == 1) > >> result = opp_init_cpufreq_table(mpu_dev, &freq_table); > >> > >> - if (result) { > >> + if (result || !freq_table) { > >> dev_err(mpu_dev, "%s: cpu%d: failed creating freq > >> table[%d]\n", > >> __func__, policy->cpu, result); > >> goto fail_ck; > > > > The freq_table use count seems to be buggy in that case. > > Something like below should fix the issue. > > Feel free to update your patch with below if you agree. > > > > diff --git a/drivers/cpufreq/omap-cpufreq.c > > b/drivers/cpufreq/omap-cpufreq.c > > index 17fa04d..fd97c3d 100644 > > --- a/drivers/cpufreq/omap-cpufreq.c > > +++ b/drivers/cpufreq/omap-cpufreq.c > > @@ -218,7 +218,7 @@ static int __cpuinit omap_cpu_init(struct > > cpufreq_policy *po > > > > policy->cur = policy->min = policy->max = > > omap_getspeed(policy->cpu); > > > > - if (atomic_inc_return(&freq_table_users) == 1) > > + if (freq_table) > > I think you meant 'if (!freq_table)' ? > Right. regards Santosh -- 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