Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp420560pxf; Thu, 18 Mar 2021 03:54:07 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwPNjkOs9/27iDjw4jcyn4b4dcM9uElJj5STfQ1/RzLhqeNSzqj8hbPS6shUAs0NqbeHS9A X-Received: by 2002:a50:fc94:: with SMTP id f20mr2834350edq.370.1616064846864; Thu, 18 Mar 2021 03:54:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1616064846; cv=none; d=google.com; s=arc-20160816; b=kUWvx63OiWfJBaqc5nu0AO1HzE8B7x6JsHJGz4YeCe0m7CfpMmNJGt337sDtlVnEio TcCKBg3cTT7t05slFmXxdb+WskoBbsVieol0p7c8DoxwBBXeettc83kOJkKl8tbJI7oH Fn/ohzKLX4QrD1Z4p2uXn8xkjttYoY3rV5SLAGkZzPO8ghC3lwxtgoYZk6S+P42cKKws z6N3QeCar3Ee9xTPZP/4ZrBo82DMYMfC4FnjyvQ4nSr5LpGiGictMcdsXEFo0rsltrWc v9TP1CCnVypePvkd5C1KDzAmQTTYUCB4AbFAMEq46sc/vFYI1YfwFjZsRhjq7Sr2CQTs 8j6Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:cc:to:subject :message-id:date:from:in-reply-to:references:mime-version :dkim-signature; bh=71whWkxb2bBJl6dByqv/ZV5tqOK3zTPTnTkWqrB5g3w=; b=suL91nAxQQLsKIvtyxZzx+pxf+zBKJ/VluWo4bT1wBMRUGmTNJbssPP2wiB76swAQ9 K/dh/5aeW3tWaevp/cCj/zTnY9x9EdvS8xsaFuHmV1Y+qjD2Ryhe5v26QIagqIHUq6qr OHJhZxfO1NxuRr1G0GEnxa+DcXUhCZuRS2B1JTcAs9sch43oxuTkShe0l+ACefEjU/uN WIATQzOOjam47oD/bQ6iGg0OvwPirL5+IHy8p3X+qIXVgK0VMpwloboJxqyHTGYjCHGQ yUYT9ep/KAhy4HGqraYzODl08qWosxl3fXdf9/6ktE0ctZwJIaiALRPpFHTOhJLVtJ11 LFgQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=bwqRZdym; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id hr14si1324603ejc.394.2021.03.18.03.53.44; Thu, 18 Mar 2021 03:54:06 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=bwqRZdym; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230337AbhCRKwV (ORCPT + 99 others); Thu, 18 Mar 2021 06:52:21 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:35770 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230355AbhCRKwC (ORCPT ); Thu, 18 Mar 2021 06:52:02 -0400 Received: from mail-ot1-x335.google.com (mail-ot1-x335.google.com [IPv6:2607:f8b0:4864:20::335]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id A1440C06174A; Thu, 18 Mar 2021 03:52:02 -0700 (PDT) Received: by mail-ot1-x335.google.com with SMTP id g8-20020a9d6c480000b02901b65ca2432cso4762210otq.3; Thu, 18 Mar 2021 03:52:02 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc:content-transfer-encoding; bh=71whWkxb2bBJl6dByqv/ZV5tqOK3zTPTnTkWqrB5g3w=; b=bwqRZdymz0/7pp2mJALHV5sfACZV5MD6hI3FWQxE3BF6IysHTdb4GclYFwCDcw2N0m 9+zScQaepoxgfYEAIWZFv+jpydiBUZbHN3SjvmNGxInpoViZ7bMNJ3ItJrGSLfblZCQr GacTqAB9kPg5QHqd7DhxLc8V7kvufWjA/5a7+Yj56BULmm4ES5isCP+dhmfJh7nj6OI6 LtOCbA30JEgq7INg0oNsfsL4jjkYskAbFfg2OiIKMB7oiedSOwhanITuVunNFyiiJPG+ mMN6sYCuRhG/r386j5wBmbul4zfojfcbU5rKO/KzMk4XhkroxMVtzASfQhP8XTBQfK+G LfUA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc:content-transfer-encoding; bh=71whWkxb2bBJl6dByqv/ZV5tqOK3zTPTnTkWqrB5g3w=; b=TjZLuR9TrLQyzNbJMS687T0dX0yU9hgXVzbeEHO72zy/kg1kNiqKYkn0197N0vgxfx P0KbymcJOyBZ7lX7/1BBjf+QIGOvNe+JsHswJCE1FH8yRLQNH8Hg8BWwJkTY/ohh/LCw luNLleUmLTP/MW7ZGf4+GXtKgQVXtyXKBKkDCoKmV6twDpjJXTqd6iPK9xaHWPJfz7Lo Kqb6FcSMFfrY1GleDrhSn5zSS0jaF6rIXhKerH4nm+5osgf8ZpavZnvlXbQgaFAK/OLk ft/xfWO0ynqfu87GyN6bWGzEN2eC0+0RdA7BzgcM1uNrx9IlZFrnKjhSaYA73MmoskzX fRDQ== X-Gm-Message-State: AOAM530KwhitENYVytVxpOX7sFtrPBJz2cxqbThJIa3gSgaf3o4ftrmJ JzfOXXJMy/aI5IW13oz6Ao5lElDdJ89n9J+XgQY= X-Received: by 2002:a05:6830:34a2:: with SMTP id c34mr6778381otu.52.1616064722022; Thu, 18 Mar 2021 03:52:02 -0700 (PDT) MIME-Version: 1.0 References: <1615294733-22761-1-git-send-email-aisheng.dong@nxp.com> <1615294733-22761-8-git-send-email-aisheng.dong@nxp.com> <31be2267-8988-f162-f5a6-6e6389bbf1fb@samsung.com> <0e518145-5cae-63f1-c32f-e6207fdeae54@samsung.com> <4b5a0c61-2bab-8b00-621c-25f1244fee92@samsung.com> In-Reply-To: <4b5a0c61-2bab-8b00-621c-25f1244fee92@samsung.com> From: Dong Aisheng Date: Thu, 18 Mar 2021 18:51:50 +0800 Message-ID: Subject: Re: [PATCH 07/11] PM / devfreq: check get_dev_status before start monitor To: Chanwoo Choi Cc: Chanwoo Choi , Dong Aisheng , Linux PM , "moderated list:ARM/FREESCALE IMX / MXC ARM ARCHITECTURE" , Sascha Hauer , Shawn Guo , dl-linux-imx , open list , myungjoo.ham@samsung.com, kyungmin.park@samsung.com, Abel Vesa Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, Mar 18, 2021 at 5:42 PM Chanwoo Choi wrote: > > On 3/18/21 6:54 PM, Chanwoo Choi wrote: > > On 3/18/21 5:03 PM, Dong Aisheng wrote: > >> Hi Chanwoo, > >> > >> On Sat, Mar 13, 2021 at 2:45 PM Dong Aisheng wrot= e: > >>> > >>> On Sat, Mar 13, 2021 at 12:09 AM Chanwoo Choi wr= ote: > >>>> > >>>> On 21. 3. 12. =EC=98=A4=ED=9B=84 7:57, Dong Aisheng wrote: > >>>>> On Thu, Mar 11, 2021 at 2:54 PM Chanwoo Choi wrote: > >>>>>> > >>>>>> On 3/10/21 1:56 PM, Dong Aisheng wrote: > >>>>>>> On Wed, Mar 10, 2021 at 11:08 AM Chanwoo Choi wrote: > >>>>>>>> > >>>>>>>> On 3/10/21 11:56 AM, Dong Aisheng wrote: > >>>>>>>>> On Wed, Mar 10, 2021 at 12:12 AM Chanwoo Choi wrote: > >>>>>>>>>> > >>>>>>>>>> On 21. 3. 10. =EC=98=A4=EC=A0=84 12:58, Chanwoo Choi wrote: > >>>>>>>>>>> On 21. 3. 9. =EC=98=A4=ED=9B=84 9:58, Dong Aisheng wrote: > >>>>>>>>>>>> The devfreq monitor depends on the device to provide load in= formation > >>>>>>>>>>>> by .get_dev_status() to calculate the next target freq. > >>>>>>>>>>>> > >>>>>>>>>>>> And this will cause changing governor to simple ondemand fai= l > >>>>>>>>>>>> if device can't support. > >>>>>>>>>>>> > >>>>>>>>>>>> Signed-off-by: Dong Aisheng > >>>>>>>>>>>> --- > >>>>>>>>>>>> drivers/devfreq/devfreq.c | 10 +++++++--- > >>>>>>>>>>>> drivers/devfreq/governor.h | 2 +- > >>>>>>>>>>>> drivers/devfreq/governor_simpleondemand.c | 3 +-- > >>>>>>>>>>>> 3 files changed, 9 insertions(+), 6 deletions(-) > >>>>>>>>>>>> > >>>>>>>>>>>> diff --git a/drivers/devfreq/devfreq.c b/drivers/devfreq/dev= freq.c > >>>>>>>>>>>> index 7231fe6862a2..d1787b6c7d7c 100644 > >>>>>>>>>>>> --- a/drivers/devfreq/devfreq.c > >>>>>>>>>>>> +++ b/drivers/devfreq/devfreq.c > >>>>>>>>>>>> @@ -482,10 +482,13 @@ static void devfreq_monitor(struct wor= k_struct > >>>>>>>>>>>> *work) > >>>>>>>>>>>> * to be called from governor in response to DEVFREQ_GOV_= START > >>>>>>>>>>>> * event when device is added to devfreq framework. > >>>>>>>>>>>> */ > >>>>>>>>>>>> -void devfreq_monitor_start(struct devfreq *devfreq) > >>>>>>>>>>>> +int devfreq_monitor_start(struct devfreq *devfreq) > >>>>>>>>>>>> { > >>>>>>>>>>>> if (IS_SUPPORTED_FLAG(devfreq->governor->flags, IRQ_D= RIVEN)) > >>>>>>>>>>>> - return; > >>>>>>>>>>>> + return 0; > >>>>>>>>>>>> + > >>>>>>>>>>>> + if (!devfreq->profile->get_dev_status) > >>>>>>>>>>>> + return -EINVAL; > >>>>>>>>>> > >>>>>>>>>> Again, I think that get_dev_status is not used for all governo= rs. > >>>>>>>>>> So that it cause the governor start fail. Don't check whether > >>>>>>>>>> .get_dev_status is NULL or not. > >>>>>>>>>> > >>>>>>>>> > >>>>>>>>> I'm not quite understand your point. > >>>>>>>>> it is used by governor_simpleondemand.c and tegra_devfreq_gover= nor. > >>>>>>>>> get_target_freq -> devfreq_update_stats -> get_dev_status > >>>>>>>> > >>>>>>>> The devfreq can add the new governor by anyone. > >>>>>>>> So these functions like devfreq_monitor_* have to support > >>>>>>>> the governors and also must support the governor to be added > >>>>>>>> in the future. > >>>>>>> > >>>>>>> Yes, but devfreq_monitor_* is only used by polling mode, right? > >>>>>>> The governor using it has to implement get_dev_status unless > >>>>>>> there's an exception in the future. > >>>>>>> > >>>>>>> Currently this patch wants to address the issue that user can swi= tch > >>>>>>> to ondemand governor (polling mode) by sysfs even devices does > >>>>>>> not support it (no get_dev_status implemented). > >>>>>> > >>>>>> As I commented, I'll fix this issue. If devfreq driver doesn't imp= lement > >>>>>> the .get_dev_status, don't show it via available_governors. I thin= k that > >>>>>> it is fundamental solution to fix this issue. > >>>>> > >>>>> Sounds good > >>>>> > >>>>>> So on this version, > >>>>>> don't add the this conditional statement on this function > >>>>>> > >>>>> > >>>>> Almost all this patch did is adding a checking for get_dev_status. > >>>>> So do you mean drop this patch? > >>>>> I wonder it's still a necessary checking to explicitly tell devfreq= monitor > >>>>> users that get_dev_status is needed during governor startup. > >>>> > >>>> I think that the it is enough to check .get_dev_status in > >>>> devfreq_update_stats. We have to check it on where it is used. > >>>> > >>> > >>> I think the drawback of only checking .get_dev_status in > >>> devfreq_update_stats is: > >>> 1. devfreq will still register successfully and ondemand governor sta= rts ok > >>> 2. ondemand governor will still be shown in sysfs which is something > >>> you want to fix > >>> 3. devfreq will end up printing endless error messages in devfreq_mon= itor worker > >>> "dvfs failed with (%d) error" as the possible missing .get_dev_st= atus > > > > I think that devfreq_monitor_start have to handle only work instance. > > This approach is too considering the deep check list. > > I want to resolve this periodical error log with different solution. > > > > Actually, we have to reject the registration of devfreq device > > when calling devfreq_add_device instead of checking .get_dev_status > > in devfreq_monitor_start(). > > > I'll reject the registration of devfreq device if the mandatory > function pointer of struct devfreq_dev_profile are not initialized. > - .get_dev_status > If some governors like simple_ondemand, have to initialize it. > So, I need to add the new flag to specify this feature. > - .target is mandatory for all devfreq devices. I'll check it. Okay, thanks Then i will drop this patch and resend series with your other comments addressed. Regards Aisheng > > > > > > >>> > >>> So i wonder if you don't like changing the common devfreq_monitor_sta= rt in order > >>> to make it look common for all governors, then we probably still need > >>> to fix it in > >>> ondemand governor in order to avoid the possible above issues. > >>> > >>> static int devfreq_simple_ondemand_handler(struct devfreq *devfreq, > >>> unsigned int event, void *data) > >>> { > >>> switch (event) { > >>> case DEVFREQ_GOV_START: > >>> if (!devfreq->profile->get_dev_status) > >>> return -EINVAL; > >>> > >>> return devfreq_monitor_start(devfreq); > >>> ... > >>> } > >>> > >>> How do you think? > >> > >> Any feedback? > >> > >> I'm waiting for your confirmation whether dropping this one, > >> then I can re-sent the series. > >> > >> Regards > >> Aisheng > >> > >>> > >>> Regards > >>> Aisheng > >>> > >>> > >>>>> > >>>>>> And on next version, please use the capital letter for first chara= cter > >>>>>> on patch title as following: > >>>>>> > >>>>>> - PM / devfreq: Check get_dev_status before start monitor > >>>>>> > >>>>> > >>>>> Okay to me. > >>>>> Thanks for the suggestion. > >>>>> > >>>>> Regards > >>>>> Aisheng > >>>>> > >>>>>>> > >>>>>>> Regards > >>>>>>> Aisheng > >>>>>>> > >>>>>>>> > >>>>>>>>> > >>>>>>>>> Without checking, device can switch to ondemand governor if it = does not support. > >>>>>>>>> > >>>>>>>>> Am i missed something? > >>>>>>>>> > >>>>>>>>> Regards > >>>>>>>>> Aisheng > >>>>>>>>> > >>>>>>>>>>>> switch (devfreq->profile->timer) { > >>>>>>>>>>>> case DEVFREQ_TIMER_DEFERRABLE: > >>>>>>>>>>>> @@ -495,12 +498,13 @@ void devfreq_monitor_start(struct devf= req *devfreq) > >>>>>>>>>>>> INIT_DELAYED_WORK(&devfreq->work, devfreq_monitor= ); > >>>>>>>>>>>> break; > >>>>>>>>>>>> default: > >>>>>>>>>>>> - return; > >>>>>>>>>>>> + return -EINVAL; > >>>>>>>>>>>> } > >>>>>>>>>>>> if (devfreq->profile->polling_ms) > >>>>>>>>>>>> queue_delayed_work(devfreq_wq, &devfreq->work, > >>>>>>>>>>>> msecs_to_jiffies(devfreq->profile->polling_ms= )); > >>>>>>>>>>>> + return 0; > >>>>>>>>>>>> } > >>>>>>>>>>>> EXPORT_SYMBOL(devfreq_monitor_start); > >>>>>>>>>>>> diff --git a/drivers/devfreq/governor.h b/drivers/devfreq/go= vernor.h > >>>>>>>>>>>> index 5cee3f64fe2b..31af6d072a10 100644 > >>>>>>>>>>>> --- a/drivers/devfreq/governor.h > >>>>>>>>>>>> +++ b/drivers/devfreq/governor.h > >>>>>>>>>>>> @@ -75,7 +75,7 @@ struct devfreq_governor { > >>>>>>>>>>>> unsigned int event, void *data); > >>>>>>>>>>>> }; > >>>>>>>>>>>> -void devfreq_monitor_start(struct devfreq *devfreq); > >>>>>>>>>>>> +int devfreq_monitor_start(struct devfreq *devfreq); > >>>>>>>>>>>> void devfreq_monitor_stop(struct devfreq *devfreq); > >>>>>>>>>>>> void devfreq_monitor_suspend(struct devfreq *devfreq); > >>>>>>>>>>>> void devfreq_monitor_resume(struct devfreq *devfreq); > >>>>>>>>>>>> diff --git a/drivers/devfreq/governor_simpleondemand.c > >>>>>>>>>>>> b/drivers/devfreq/governor_simpleondemand.c > >>>>>>>>>>>> index d57b82a2b570..ea287b57cbf3 100644 > >>>>>>>>>>>> --- a/drivers/devfreq/governor_simpleondemand.c > >>>>>>>>>>>> +++ b/drivers/devfreq/governor_simpleondemand.c > >>>>>>>>>>>> @@ -89,8 +89,7 @@ static int devfreq_simple_ondemand_handler= (struct > >>>>>>>>>>>> devfreq *devfreq, > >>>>>>>>>>>> { > >>>>>>>>>>>> switch (event) { > >>>>>>>>>>>> case DEVFREQ_GOV_START: > >>>>>>>>>>>> - devfreq_monitor_start(devfreq); > >>>>>>>>>>>> - break; > >>>>>>>>>>>> + return devfreq_monitor_start(devfreq); > >>>>>>>>>>>> case DEVFREQ_GOV_STOP: > >>>>>>>>>>>> devfreq_monitor_stop(devfreq); > >>>>>>>>>>>> > >>>>>>>>>>> > >>>>>>>>>>> Need to handle the all points of devfreq_monitor_start() usag= e. > >>>>>>>>>>> please check the tegra30-devfreq.c for this update. > >>>>>>>>>>> > >>>>>>>>>>> $ grep -rn "devfreq_monitor_start" drivers/ > >>>>>>>>>>> drivers/devfreq/governor_simpleondemand.c:92: > >>>>>>>>>>> devfreq_monitor_start(devfreq); > >>>>>>>>>>> drivers/devfreq/tegra30-devfreq.c:744: > >>>>>>>>>>> devfreq_monitor_start(devfreq); > >>>>>>>>>>> ...... > >>>>>>>>>>> > >>>>>>>>>> > >>>>>>>>>> > >>>>>>>>>> -- > >>>>>>>>>> Best Regards, > >>>>>>>>>> Samsung Electronics > >>>>>>>>>> Chanwoo Choi > >>>>>>>>> > >>>>>>>>> > >>>>>>>> > >>>>>>>> > >>>>>>>> -- > >>>>>>>> Best Regards, > >>>>>>>> Chanwoo Choi > >>>>>>>> Samsung Electronics > >>>>>>> > >>>>>>> > >>>>>> > >>>>>> > >>>>>> -- > >>>>>> Best Regards, > >>>>>> Chanwoo Choi > >>>>>> Samsung Electronics > >>>> > >>>> > >>>> -- > >>>> Best Regards, > >>>> Samsung Electronics > >>>> Chanwoo Choi > >> > >> > > > > > > > -- > Best Regards, > Chanwoo Choi > Samsung Electronics