From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753080AbdCFFRE (ORCPT ); Mon, 6 Mar 2017 00:17:04 -0500 Received: from mail-pg0-f51.google.com ([74.125.83.51]:34542 "EHLO mail-pg0-f51.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752945AbdCFFQz (ORCPT ); Mon, 6 Mar 2017 00:16:55 -0500 Date: Mon, 6 Mar 2017 10:38:05 +0530 From: Viresh Kumar To: Patrick Bellasi Cc: linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org, Steven Rostedt , Vincent Guittot , John Stultz , Juri Lelli , Todd Kjos , Tim Murray , Andres Oportus , Joel Fernandes , Morten Rasmussen , Dietmar Eggemann , Chris Redpath , Ingo Molnar , Peter Zijlstra , "Rafael J . Wysocki" Subject: Re: [PATCH 2/6] cpufreq: schedutil: ignore the sugov kthread for frequencies selections Message-ID: <20170306050805.GF8206@vireshk-i7> References: <1488469507-32463-1-git-send-email-patrick.bellasi@arm.com> <1488469507-32463-3-git-send-email-patrick.bellasi@arm.com> <20170303051943.GI13760@vireshk-i7> <20170303121247.GA10420@e110439-lin> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20170303121247.GA10420@e110439-lin> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 03-03-17, 12:12, Patrick Bellasi wrote: > On 03-Mar 10:49, Viresh Kumar wrote: > > I always wanted to avoid such hacks when I moved to the RT thread :( > > Indeed, it is a bit of an hack... but still it's true that this is a > "special" RT thread which must not bias OPP selection. I agree. We have a problem in hand and we need to fix it somehow. > > I was discussing the exact same problem with Vincent few days back and > > one of the ideas we had was to clear the flags when any RT task is > > dequeued from a rq. > > That's a possible solution, however at dequeue time we don't know > what's going on right after. We can end up picking up another RT task. > Thus we can reset the flag when it's not really required, and this > open for possible races... I don't have much knowledge of the scheduler right now and so I will not be able to tell the exact places where we can clear the flag. So, dequeue was just one of the places I could think of logically. My idea was to make sure that we clear the RT and DL flags once we know that we don't have any more RT/DL work to do. Dequeue or any other place that would suit better, but we should be clearing it. And once that is done, we wouldn't be required to have hacks like what this patch is doing. > > AFAIU, the problem we are discussing here > > shouldn't normally occur while the sugov RT thread is running as the > > work_in_progress flag makes sure we don't reevaluate the load while > > the RT thread is updating the frequency. > > True... > > > The problem perhaps occurs as the flag for CPU X is never cleared, > > and so on the next callback from the scheduler (after the frequency > > is updated and work_in_progress is cleared) we move to the highest > > frequency. > > ... right. > > > So what about clearing the flags, just like the previous patch, when > > the RT or DL task has finished? > > As a general goal I think it would be useful to feed input only when > the scheduler knows something is going to happen. That's why in the > last patch of these series I'm proposing to remove updates from > update_curr_rt() and replace it with calls in most interesting events, > like enqueue/pickup instead of dequeue. Sure, I liked that. I am just wondering if we can have such a location to clear the RT/DL flags. > > Sorry for the noise if it was all nonsense :) > > That's absolutely not nonsense, thanks for the feedback. > > I agree with you that the solution proposed by this patch sound a bit > of an hack, but still we can argue that using an RT task to change an > OPP is by itself a sort-of an hack. Just for the sake of argument, why do you think so ? :) That work needs to get done via some sort of task, wq or RT thread, etc. We chose RT to make sure we do it in time and never delay it. The ugliness happened because we hit max frequency on RT task, which will be optimized later on. -- viresh