On 14 January 2013 20:06, MyungJoo Ham <myungjoo....@samsung.com> wrote: > On Tue, Jan 8, 2013 at 2:50 PM, Rajagopal Venkat > <rajagopal.ven...@linaro.org> wrote: >> Set devfreq device min and max frequency limits when device >> is added to devfreq, provided frequency table is supplied. >> This helps governors to suggest target frequency with in >> limits. >> >> Signed-off-by: Rajagopal Venkat <rajagopal.ven...@linaro.org> > > Could you please elaborate the benefit of the patch? >
When freq table is supplied, it's unreasonable to suggest the target frequency which is - target_freq < min_freq and target_freq > max_freq. It avoids unnecessary checks at devfreq drivers. > The devfreq device drivers are required to choose proper frequencies > anyway regardless which values the governors may give (hopefully by > choosing the closest value that can support the required performance). > Yes. but then each driver needs to have conditional checks for choosing closet value even though freq table is provided. > Besides, the min/max values are to be set by userspace. Users may > enter 0 in order to express that they do not want to limit the > behaviors of governors. > > > Cheers, > MyungJoo. > >> --- >> drivers/devfreq/devfreq.c | 24 ++++++++++++++++++++++++ >> 1 file changed, 24 insertions(+) >> >> diff --git a/drivers/devfreq/devfreq.c b/drivers/devfreq/devfreq.c >> index a8f0173..5782c9b 100644 >> --- a/drivers/devfreq/devfreq.c >> +++ b/drivers/devfreq/devfreq.c >> @@ -69,6 +69,29 @@ static struct devfreq *find_device_devfreq(struct device >> *dev) >> } >> >> /** >> + * devfreq_set_freq_limits() - Set min and max frequency from freq_table >> + * @devfreq: the devfreq instance >> + */ >> +static void devfreq_set_freq_limits(struct devfreq *devfreq) >> +{ >> + int idx; >> + unsigned long min = ~0, max = 0; >> + >> + if (!devfreq->profile->freq_table) >> + return; >> + >> + for (idx = 0; idx < devfreq->profile->max_state; idx++) { >> + if (min > devfreq->profile->freq_table[idx]) >> + min = devfreq->profile->freq_table[idx]; >> + if (max < devfreq->profile->freq_table[idx]) >> + max = devfreq->profile->freq_table[idx]; >> + } >> + >> + devfreq->min_freq = min; >> + devfreq->max_freq = max; >> +} >> + >> +/** >> * devfreq_get_freq_level() - Lookup freq_table for the frequency >> * @devfreq: the devfreq instance >> * @freq: the target frequency >> @@ -476,6 +499,7 @@ struct devfreq *devfreq_add_device(struct device *dev, >> devfreq->profile->max_state, >> GFP_KERNEL); >> devfreq->last_stat_updated = jiffies; >> + devfreq_set_freq_limits(devfreq); >> >> dev_set_name(&devfreq->dev, dev_name(dev)); >> err = device_register(&devfreq->dev); >> -- >> 1.7.10.4 >> >> -- >> To unsubscribe from this list: send the line "unsubscribe linux-pm" in >> the body of a message to majord...@vger.kernel.org >> More majordomo info at http://vger.kernel.org/majordomo-info.html > > > > -- > MyungJoo Ham, Ph.D. > Mobile Software Platform Lab, DMC Business, Samsung Electronics -- Regards, Rajagopal -- 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/