From patchwork Tue Nov 6 21:28:25 2012 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Nishanth Menon X-Patchwork-Id: 1706861 Return-Path: X-Original-To: patchwork-linux-pm@patchwork.kernel.org Delivered-To: patchwork-process-083081@patchwork2.kernel.org Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by patchwork2.kernel.org (Postfix) with ESMTP id 795BDDFE75 for ; Tue, 6 Nov 2012 21:28:36 +0000 (UTC) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751468Ab2KFV2f (ORCPT ); Tue, 6 Nov 2012 16:28:35 -0500 Received: from arroyo.ext.ti.com ([192.94.94.40]:36521 "EHLO arroyo.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751412Ab2KFV2f (ORCPT ); Tue, 6 Nov 2012 16:28:35 -0500 Received: from dlelxv30.itg.ti.com ([172.17.2.17]) by arroyo.ext.ti.com (8.13.7/8.13.7) with ESMTP id qA6LSQ9E008734; Tue, 6 Nov 2012 15:28:26 -0600 Received: from DFLE72.ent.ti.com (dfle72.ent.ti.com [128.247.5.109]) by dlelxv30.itg.ti.com (8.13.8/8.13.8) with ESMTP id qA6LSQII017289; Tue, 6 Nov 2012 15:28:26 -0600 Received: from dlelxv22.itg.ti.com (172.17.1.197) by dfle72.ent.ti.com (128.247.5.109) with Microsoft SMTP Server id 14.1.323.3; Tue, 6 Nov 2012 15:28:26 -0600 Received: from localhost (kahuna.am.dhcp.ti.com [128.247.75.12]) by dlelxv22.itg.ti.com (8.13.8/8.13.8) with ESMTP id qA6LSQCK016939; Tue, 6 Nov 2012 15:28:26 -0600 Date: Tue, 6 Nov 2012 15:28:25 -0600 From: Nishanth Menon To: MyungJoo Ham CC: , LKML , Kevin Hilman , linux-pm , Rajagopal Venkat , =?utf-8?B?67CV6rK966+8?= , "Rafael J. Wysocki" Subject: Re: [linux-next PATCH 6/7] PM / devfreq: allow sysfs governor node to switch governor Message-ID: <20121106212825.GA21925@kahuna> References: <31153640.425391352192535931.JavaMail.weblogic@epml11> MIME-Version: 1.0 Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-pm-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-pm@vger.kernel.org On 18:18-20121106, MyungJoo Ham wrote: > 2012. 11. 6. ?? 6:02? "MyungJoo Ham" ?? ??: > > > > > --- a/drivers/devfreq/devfreq.c > > > +++ b/drivers/devfreq/devfreq.c > > > @@ -629,6 +629,44 @@ static ssize_t show_governor(struct device *dev, > > > return sprintf(buf, "%s\n", to_devfreq(dev)->governor->name); > > > } > > > > > > +static ssize_t store_governor(struct device *dev, struct > device_attribute *attr, > > > + const char *buf, size_t count) > > > +{ > > > + struct devfreq *df = to_devfreq(dev); > > > + int ret = 0; > > > + struct devfreq_governor *governor; > > > + > > > + mutex_lock(&devfreq_list_lock); > > > > Please remove the trailing \n from buf here. > > When user enters "userspace", buf gets "userspace\n". > > > > With some printks in find_devfreq_governor (printing the buf and governor > names): > > > > # echo userspace > /sys/class/devfreq/exynos4210-busfreq.0/governor > > [ 65.975000] [userspace > > [ 65.975000] ].[userspace] > > [ 65.980000] [userspace > > [ 65.980000] ].[powersave] > > [ 65.985000] [userspace > > [ 65.985000] ].[performance] > > [ 65.990000] [userspace > > [ 65.990000] ].[simple_ondemand] > > [ 65.995000] err no = -19 > > # > > > > Anyway this seems quite wierd. I will look more into this one in my target > system. Thanks for catching this. :( I missed the \n (been using echo -n toooo often now grr..) What do you think of the following change to the patch? diff --git a/drivers/devfreq/devfreq.c b/drivers/devfreq/devfreq.c index 586b6fd..9a4e898 100644 --- a/drivers/devfreq/devfreq.c +++ b/drivers/devfreq/devfreq.c @@ -614,11 +614,16 @@ static ssize_t store_governor(struct device *dev, struct device_attribute *attr, const char *buf, size_t count) { struct devfreq *df = to_devfreq(dev); - int ret = 0; + int ret; + char str_governor[DEVFREQ_NAME_LEN + 1]; struct devfreq_governor *governor; + ret = sscanf(buf, "%" __stringify(DEVFREQ_NAME_LEN) "s", str_governor); + if (ret != 1) + return -EINVAL; + mutex_lock(&devfreq_list_lock); - governor = find_devfreq_governor(buf); + governor = find_devfreq_governor(str_governor); if (IS_ERR(governor)) { ret = PTR_ERR(governor); goto out;