Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp4890822imm; Wed, 30 May 2018 14:13:59 -0700 (PDT) X-Google-Smtp-Source: ADUXVKJGYA53mnClc2kVAVwaRrgvsB+8A98tdzQIBYQ3dllKKu1BPNFn1HclpURnHQyCQPx7YBoV X-Received: by 2002:a65:4249:: with SMTP id d9-v6mr3445712pgq.362.1527714839227; Wed, 30 May 2018 14:13:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527714839; cv=none; d=google.com; s=arc-20160816; b=jE7deAHH8bf5/c0u/kZQnUZHCrp31CoZ5nnoiwbq1MTxQ5bBb80sObfSUAfThaGoc/ itZUA+JwPkKVimZWcCSfyXOW0giKUPUuIrLVhwZ2I3K8Zu3pJpl/iJYAAJNpKrSjTla+ S3ko20/ymWJ/cPLsYX75vC9HWgfaV4q44JTXcntuVhJHF7ZFt1DRtA3mPtsFAOSgKLM1 PHs60LmkAuNzyepE4w3S+I/tEAza8GTRtlkbRhMw6X8rXA9tcbUC5Ie/a8KQzO9U2BLY SztbEA19liG7U0tJ6FTAk0Y+8NMgfwbYRmGWjFtkXuQLlmdEfUuoozvAn6cU48yedvR0 /VhA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-transfer-encoding:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature :arc-authentication-results; bh=yjYbmMd8x766h/y3jPH28Ev/5Mo0wgKaJBp6rV0V3Y4=; b=EmR3iRNuTlE6YCIKN4g6bz6IXhKY8B/8XJoand68mLtpCZyHKW/057nNTgiOIzPuTl lF+ct1XasaypR7StqMwm6hRlmid/T1bA/vE40on5mPvrhhCd0svhGW/8uWlRNFnw1+7v FhKmrba6G+77iLQzVReaxZhOqU+ov5H/Z1jo31akcNvs0mat5/rMsbrigfTHe0Itt+1J dUQs9qKCdqpgT0zOSfLhtFZykm+VuC9STuOyX6jTbi9OawR3/TxHdkT0UZCDqd9mUASy L4eTm9hh+WlOFPVwmpqSLRu4+uJu07A9LXuKckK0x3Mk5SSOmTOOCoPgAxC05DJrSSw8 N1EQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=UYUxKcNg; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id i73-v6si36931777pfe.27.2018.05.30.14.13.44; Wed, 30 May 2018 14:13:59 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=UYUxKcNg; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932320AbeE3VNG (ORCPT + 99 others); Wed, 30 May 2018 17:13:06 -0400 Received: from mail-pl0-f68.google.com ([209.85.160.68]:36797 "EHLO mail-pl0-f68.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S932078AbeE3VND (ORCPT ); Wed, 30 May 2018 17:13:03 -0400 Received: by mail-pl0-f68.google.com with SMTP id v24-v6so11835704plo.3 for ; Wed, 30 May 2018 14:13:03 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:content-transfer-encoding:in-reply-to :user-agent; bh=yjYbmMd8x766h/y3jPH28Ev/5Mo0wgKaJBp6rV0V3Y4=; b=UYUxKcNgU6FC39bnZ7mIPwKwwCTeTP/ikh436d/crr7B2QEVsfkIvsigTOoBra5ddR QseKQOZSl9ccsRATgfrZe5S2s9rGJOitqiMpn2kHMdu3waTF0SrGxpzCVZUJAGOirNDd yPx1aMiLwc7hu2kTnkt+/u0Pu522Qqfxj7p7g= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:content-transfer-encoding :in-reply-to:user-agent; bh=yjYbmMd8x766h/y3jPH28Ev/5Mo0wgKaJBp6rV0V3Y4=; b=c4+n5CVQePTP223W1OtQUT/67AdOo16T8h3AxmF0tmPNC76Dh9R9w8xl5RhglNFy0n tvADOnAE9oRbndhBtbmAK2whtsH5tyePlb7pDcKC75fpddvO13t2/QdWt2iandGQ44hW EuA/q02JbbSAUMFV1trihVrCd2SdoamV1WPTyYESwZrfxvqfjqlcVNi78LJrm0/BLWvE mEo55ejUS6PCR4MdVtpWHpiqvJj/l40LMCtXNrBpEn3K/z5ZJrx4e4L0Kw4lD1ZKSLut I8uyL98qbX24YI6I7CmY2j5nj2x624JydBdXTlH92alrTkM+iqYqK3iIqQNcWE4knxcu N1tA== X-Gm-Message-State: ALKqPwdGRkiSW5ttx+8tCR28lXc2Yttd+1ju/zYaTbLavnYfXKqNguWC zWATbBFpb4KWTo6leIu3cZVxNw== X-Received: by 2002:a17:902:7244:: with SMTP id c4-v6mr4304596pll.265.1527714783163; Wed, 30 May 2018 14:13:03 -0700 (PDT) Received: from localhost ([2620:0:1000:1501:8e2d:4727:1211:622]) by smtp.gmail.com with ESMTPSA id m14-v6sm57167795pgs.72.2018.05.30.14.13.02 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Wed, 30 May 2018 14:13:02 -0700 (PDT) Date: Wed, 30 May 2018 14:13:01 -0700 From: Matthias Kaehlcke To: Chanwoo Choi Cc: MyungJoo Ham , Kyungmin Park , Arnd Bergmann , Greg Kroah-Hartman , Rob Herring , Mark Rutland , linux-pm@vger.kernel.org, devicetree@vger.kernel.org, linux-kernel@vger.kernel.org, Brian Norris , Douglas Anderson , =?utf-8?B?w5hyamFu?= Eide , John Einar Reitan Subject: Re: [PATCH 02/11] PM / devfreq: Fix handling of min/max_freq == 0 Message-ID: <20180530211301.GA194977@google.com> References: <20180525203043.249193-1-mka@chromium.org> <20180525203043.249193-3-mka@chromium.org> <5B0BA3BB.8060505@samsung.com> <20180529185758.GG168650@google.com> <5B0E5AFE.8090703@samsung.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <5B0E5AFE.8090703@samsung.com> User-Agent: Mutt/1.9.2 (2017-12-15) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, May 30, 2018 at 05:04:14PM +0900, Chanwoo Choi wrote: > Hi, > > On 2018년 05월 30일 03:57, Matthias Kaehlcke wrote: > > On Mon, May 28, 2018 at 03:37:47PM +0900, Chanwoo Choi wrote: > >> Hi, > >> > >> On 2018년 05월 26일 05:30, Matthias Kaehlcke wrote: > >>> Commit ab8f58ad72c4 ("PM / devfreq: Set min/max_freq when adding the > >>> devfreq device") initializes df->min/max_freq with the min/max OPP when > >>> the device is added. Later commit f1d981eaecf8 ("PM / devfreq: Use the > >>> available min/max frequency") adds df->scaling_min/max_freq and the > >>> following to the frequency adjustment code: > >>> > >>> max_freq = MIN(devfreq->scaling_max_freq, devfreq->max_freq); > >>> > >>> With the current handling of min/max_freq this is incorrect: > >>> > >>> Even though df->max_freq is now initialized to a value != 0 user space > >>> can still set it to 0, in this case max_freq would be 0 instead of > >>> df->scaling_max_freq as intended. In consequence the frequency adjustment > >>> is not performed: > >>> > >>> if (max_freq && freq > max_freq) { > >>> freq = max_freq; > >>> > >>> To fix this set df->min/max freq to the min/max OPP in max/max_freq_store, > >>> when the user passes a value of 0. This also prevents df->max_freq from > >>> being set below the min OPP when df->min_freq is 0, and similar for > >>> min_freq. Since it is now guaranteed that df->min/max_freq can't be 0 the > >>> checks for this case can be removed. > >>> > >>> Fixes: f1d981eaecf8 ("PM / devfreq: Use the available min/max frequency") > >>> Signed-off-by: Matthias Kaehlcke > >>> --- > >>> drivers/devfreq/devfreq.c | 30 ++++++++++++++++++------------ > >>> 1 file changed, 18 insertions(+), 12 deletions(-) > >>> > >>> diff --git a/drivers/devfreq/devfreq.c b/drivers/devfreq/devfreq.c > >>> index 0057ef5b0a98..67da4e7b486b 100644 > >>> --- a/drivers/devfreq/devfreq.c > >>> +++ b/drivers/devfreq/devfreq.c > >>> @@ -283,11 +283,11 @@ int update_devfreq(struct devfreq *devfreq) > >>> max_freq = MIN(devfreq->scaling_max_freq, devfreq->max_freq); > >>> min_freq = MAX(devfreq->scaling_min_freq, devfreq->min_freq); > >>> > >>> - if (min_freq && freq < min_freq) { > >>> + if (freq < min_freq) { > >>> freq = min_freq; > >>> flags &= ~DEVFREQ_FLAG_LEAST_UPPER_BOUND; /* Use GLB */ > >>> } > >>> - if (max_freq && freq > max_freq) { > >>> + if (freq > max_freq) { > >>> freq = max_freq; > >>> flags |= DEVFREQ_FLAG_LEAST_UPPER_BOUND; /* Use LUB */ > >>> } > >>> @@ -1123,17 +1123,20 @@ static ssize_t min_freq_store(struct device *dev, struct device_attribute *attr, > >>> struct devfreq *df = to_devfreq(dev); > >>> unsigned long value; > >>> int ret; > >>> - unsigned long max; > >>> > >>> ret = sscanf(buf, "%lu", &value); > >>> if (ret != 1) > >>> return -EINVAL; > >>> > >>> mutex_lock(&df->lock); > >>> - max = df->max_freq; > >>> - if (value && max && value > max) { > >>> - ret = -EINVAL; > >>> - goto unlock; > >>> + > >>> + if (value) { > >>> + if (value > df->max_freq) { > >>> + ret = -EINVAL; > >>> + goto unlock; > >>> + } > >>> + } else { > >>> + value = df->profile->freq_table[df->profile->max_state - 1]; > >>> } > >> > >> If you want to prevent that df->min_freq is zero, > >> you should reinitialize 'value' as following. > >> Because freq_table must be in ascending order. > >> value = df->profile->freq_table[0]; > > > > Thanks for pointing this out! > > > > The devfreq device I tested with (a Mali GPU) uses descending order > > for some reason, and I assumed that's the usual order. > > > > https://chromium.googlesource.com/chromiumos/third_party/kernel/+/chromeos-4.4/drivers/gpu/arm/midgard/backend/gpu/mali_kbase_devfreq.c#208 > > > > It seems the ordering doesn't have any impact beyond this patch. If > > the order isn't mandatory for drivers that set up their own freq_table > > we should probably support both cases to be safe. > > Prior to that 'freq_table' is optional. So, patch[1] initialize the 'freq_table' > by using OPP interface if 'freq_table' is NULL. > [1] commit 0ec09ac2cebe ("PM / devfreq: Set the freq_table of devfreq device") > > Current devfreq recommend the ascending order for 'freq_table'. > But, as you know, it might be not enough to support them. > > I agree that we should support the both cases (ascending or descending order). > > Maybe, it might be not proper to access the freq_table[] directly > because we don't know the ordering style of 'freq_table' > if 'freq_table' is made by devfreq user instead of devfreq core. If we can assume that it is either ascending or descending, but not random order than a simple check if freq_table[0] < freq_table[max_state - 1] would be sufficient. Otherwise we could also determine the min/max after initialization and save the result, though that would leave us with yet another frequency pair, which might be confusing, especially if we don't come up with good names to distinguish between them.