On Mon, May 26, 2014 at 11:28 AM, Viresh Kumar <viresh.kumar@xxxxxxxxxx> wrote: > On 23 May 2014 19:07, Thomas Abraham <thomas.ab@xxxxxxxxxxx> wrote: >> From: Thomas Abraham <thomas.ab@xxxxxxxxxxx> >> >> Commit 6f19efc0 ("cpufreq: Add boost frequency support in core") adds >> support for CPU boost mode. This patch adds support for finding available >> boost frequencies from device tree and marking them as usable in boost mode. >> >> Cc: Nishanth Menon <nm@xxxxxx> >> Cc: Lukasz Majewski <l.majewski@xxxxxxxxxxx> >> Signed-off-by: Thomas Abraham <thomas.ab@xxxxxxxxxxx> >> --- >> drivers/cpufreq/cpufreq_opp.c | 44 +++++++++++++++++++++++++++++++++++++++++ >> 1 file changed, 44 insertions(+) >> >> diff --git a/drivers/cpufreq/cpufreq_opp.c b/drivers/cpufreq/cpufreq_opp.c >> index c0c6f4a..2b3905b 100644 >> --- a/drivers/cpufreq/cpufreq_opp.c >> +++ b/drivers/cpufreq/cpufreq_opp.c >> @@ -19,6 +19,7 @@ >> #include <linux/pm_opp.h> >> #include <linux/rcupdate.h> >> #include <linux/slab.h> >> +#include <linux/of.h> >> >> /** >> * dev_pm_opp_init_cpufreq_table() - create a cpufreq table for a device >> @@ -51,6 +52,10 @@ int dev_pm_opp_init_cpufreq_table(struct device *dev, >> struct cpufreq_frequency_table *freq_table = NULL; >> int i, max_opps, ret = 0; >> unsigned long rate; >> +#ifdef CONFIG_CPU_FREQ_BOOST_SW >> + int j, len; >> + u32 *boost_freqs = NULL; >> +#endif >> >> rcu_read_lock(); >> >> @@ -82,6 +87,45 @@ int dev_pm_opp_init_cpufreq_table(struct device *dev, >> >> *table = &freq_table[0]; >> >> +#ifdef CONFIG_CPU_FREQ_BOOST_SW >> + if (of_find_property(dev->of_node, "boost-frequencies", &len)) { > > Maybe: > if(!of_find_property(...)) > goto out; > > To get rid of extra indentation levels below.. > >> + struct cpufreq_frequency_table *ft; > > Declare at the top with boost_freqs, etc.. > >> + if (len == 0 || (len & (sizeof(u32) - 1)) != 0) { > > s/len == 0/!len > > And use IS_ALIGNED() instead of the right hand side of || > >> + dev_err(dev, "%s: invalid boost frequency\n", __func__); >> + ret = -EINVAL; >> + goto out; >> + } >> + >> + boost_freqs = kzalloc(len, GFP_KERNEL); > > Can we do a devm_kzalloc instead? And why not kmalloc BTW ? This is a temporary storage that is freed at the end of this function. So devm_kzalloc is not used. Yes, kmalloc can be used. > >> + if (!boost_freqs) { >> + dev_warn(dev, "%s: no memory for boost freq table\n", > > dev_err ? > >> + __func__); >> + ret = -ENOMEM; >> + goto out; >> + } >> + of_property_read_u32_array(dev->of_node, "boost-frequencies", >> + boost_freqs, len / sizeof(u32)); > > > Create int count = len / sizeof(u32) instead.. You have used this > multiple times. > >> + for (j = 0; j < len / sizeof(u32); j++) { >> + ft = *table; >> + for (i = 0; ft->frequency != CPUFREQ_TABLE_END; i++) { > > See if new macros can be used here instead. cpufreq_for_each_valid_entry(). > >> + if (boost_freqs[j] == ft->frequency) { >> + ft->flags |= CPUFREQ_BOOST_FREQ; >> + break; >> + } >> + ft++; >> + } >> + >> + if (ft->frequency == CPUFREQ_TABLE_END) >> + pr_err("%s: invalid boost frequency %d\n", >> + __func__, boost_freqs[j]); > > Maybe a pr_debug on the else part as well ? With boost freqs .. > >> + } >> + } >> + >> + kfree(boost_freqs); >> +#endif >> + >> out: >> rcu_read_unlock(); >> if (ret) >> -- >> 1.7.9.5 >> > -- > To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in > the body of a message to majordomo@xxxxxxxxxxxxxxx > More majordomo info at http://vger.kernel.org/majordomo-info.html -- To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html