Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751933AbeACJoF (ORCPT + 1 other); Wed, 3 Jan 2018 04:44:05 -0500 Received: from mail-it0-f65.google.com ([209.85.214.65]:35113 "EHLO mail-it0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751284AbeACJoC (ORCPT ); Wed, 3 Jan 2018 04:44:02 -0500 X-Google-Smtp-Source: ACJfBoscT1hIe1G7HETzWg8GYW1IWL/laTDLjEMn32OT7x5+7ZQqc7SZiiY7rkiTJZFWJBqTgYJYclvnTeRsh6t+Aoo= MIME-Version: 1.0 In-Reply-To: <1514971456-2877-1-git-send-email-leo.yan@linaro.org> References: <1514971456-2877-1-git-send-email-leo.yan@linaro.org> From: Vincent Guittot Date: Wed, 3 Jan 2018 10:43:40 +0100 Message-ID: Subject: Re: [PATCH] thermal: Use power efficient workqueue To: Leo Yan Cc: Zhang Rui , Eduardo Valentin , linux-pm@vger.kernel.org, linux-kernel , Daniel Lezcano Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Return-Path: On 3 January 2018 at 10:24, Leo Yan wrote: > Thermal core framework uses the system_freezable_wq workqueue as its > workqueue for polling temperature. Using system_freezable_wq workqueue > prevents the scheduler to make smart decision about the best place to > schedule the work. > > This commit replaces system_freezable_wq with > system_freezable_power_efficient_wq. With kernel configuration > CONFIG_WQ_POWER_EFFICIENT is enabled, the work can be scheduled on the > best CPU from a power or a performance point of view. > > This commit is inspired by Vincent Guittot patch "netfilter: conntrack: > use power efficient workqueue" and verified on 96boards Hikey960. > > Cc: Eduardo Valentin > Cc: Zhang Rui > Cc: Daniel Lezcano > Cc: Vincent Guittot > Signed-off-by: Leo Yan Acked-by: Vincent Guittot > --- > drivers/thermal/thermal_core.c | 7 ++++--- > 1 file changed, 4 insertions(+), 3 deletions(-) > > diff --git a/drivers/thermal/thermal_core.c b/drivers/thermal/thermal_core.c > index 2b1b0ba..ba90f71 100644 > --- a/drivers/thermal/thermal_core.c > +++ b/drivers/thermal/thermal_core.c > @@ -293,11 +293,12 @@ static void thermal_zone_device_set_polling(struct thermal_zone_device *tz, > int delay) > { > if (delay > 1000) > - mod_delayed_work(system_freezable_wq, &tz->poll_queue, > + mod_delayed_work(system_freezable_power_efficient_wq, > + &tz->poll_queue, > round_jiffies(msecs_to_jiffies(delay))); > else if (delay) > - mod_delayed_work(system_freezable_wq, &tz->poll_queue, > - msecs_to_jiffies(delay)); > + mod_delayed_work(system_freezable_power_efficient_wq, > + &tz->poll_queue, msecs_to_jiffies(delay)); > else > cancel_delayed_work(&tz->poll_queue); > } > -- > 2.7.4 >