LKML Archive on lore.kernel.org help / color / mirror / Atom feed
From: Viresh Kumar <viresh.kumar@linaro.org> To: Joel Fernandes <joel@joelfernandes.org> Cc: "Rafael J. Wysocki" <rafael@kernel.org>, Juri Lelli <juri.lelli@redhat.com>, Claudio Scordino <claudio@evidence.eu.com>, Linux Kernel Mailing List <linux-kernel@vger.kernel.org>, "Rafael J . Wysocki" <rafael.j.wysocki@intel.com>, Peter Zijlstra <peterz@infradead.org>, Ingo Molnar <mingo@redhat.com>, Patrick Bellasi <patrick.bellasi@arm.com>, Luca Abeni <luca.abeni@santannapisa.it>, Joel Fernandes <joelaf@google.com>, Linux PM <linux-pm@vger.kernel.org> Subject: Re: [RFC PATCH] sched/cpufreq/schedutil: handling urgent frequency requests Date: Wed, 9 May 2018 14:58:23 +0530 [thread overview] Message-ID: <20180509092823.sfph4gomnblb7jgr@vireshk-i7> (raw) In-Reply-To: <20180509090259.GD76874@joelaf.mtv.corp.google.com> On 09-05-18, 02:02, Joel Fernandes wrote: > On Wed, May 09, 2018 at 02:10:01PM +0530, Viresh Kumar wrote: > > Right, none of the above changes are required now. > > I didn't follow what you mean the changes are not required? I was developing > against Linus mainline. Also I replied to Rafael's comment in the other > thread. At least for the shared policy case the entire sequence of sugov_should_update_freq() followed by sugov_update_commit() is executed from within spinlock protected region and you are using the same lock below. And so either the above two routines or the kthread routine below will execute at a given point of time. So in case kthread has started doing the update and acquired the lock, the util update handler will wait until the time work_in_progress is set to false, that's not a problem we are trying to solve here. And if kthread hasn't acquired the lock yet and util handler has started executing sugov_should_update_freq() .... And ^^^ this is where I understood that your earlier change is actually required, so that we accumulate the latest updated next_freq value. And with all that we wouldn't require a while loop in the kthread code. > > > > @@ -381,13 +381,23 @@ sugov_update_shared(struct update_util_data *hook, u64 time, unsigned int flags) > > > > static void sugov_work(struct kthread_work *work) > > > > { > > > > struct sugov_policy *sg_policy = container_of(work, struct sugov_policy, work); > > > > + unsigned int freq; > > > > + > > > > + /* > > > > + * Hold sg_policy->update_lock just enough to handle the case where: > > > > + * if sg_policy->next_freq is updated before work_in_progress is set to > > > > + * false, we may miss queueing the new update request since > > > > + * work_in_progress would appear to be true. > > > > + */ > > > > + raw_spin_lock(&sg_policy->update_lock); > > > > + freq = sg_policy->next_freq; > > > > + sg_policy->work_in_progress = false; > > > > + raw_spin_unlock(&sg_policy->update_lock); > > > > One problem we still have is that sg_policy->update_lock is only used > > in the shared policy case and not in the single CPU per policy case, > > so the race isn't solved there yet. > > True.. I can make the single CPU case acquire the update_lock very briefly > around sugov_update_commit call in sugov_update_single. Rafael was very clear from the beginning that he wouldn't allow a spin lock in the un-shared policy case :) -- viresh
next prev parent reply other threads:[~2018-05-09 9:28 UTC|newest] Thread overview: 25+ messages / expand[flat|nested] mbox.gz Atom feed top 2018-05-07 14:43 [RFC PATCH] sched/cpufreq/schedutil: handling urgent frequency requests Claudio Scordino 2018-05-08 6:54 ` Viresh Kumar 2018-05-08 12:32 ` Claudio Scordino 2018-05-08 20:40 ` Rafael J. Wysocki 2018-05-09 4:54 ` Joel Fernandes 2018-05-09 6:45 ` Juri Lelli 2018-05-09 6:54 ` Viresh Kumar 2018-05-09 7:01 ` Joel Fernandes 2018-05-09 8:05 ` Rafael J. Wysocki 2018-05-09 8:22 ` Joel Fernandes 2018-05-09 8:41 ` Rafael J. Wysocki 2018-05-09 8:23 ` Juri Lelli 2018-05-09 8:25 ` Rafael J. Wysocki 2018-05-09 8:41 ` Juri Lelli 2018-05-09 6:55 ` Joel Fernandes 2018-05-09 8:06 ` Joel Fernandes 2018-05-09 8:30 ` Rafael J. Wysocki 2018-05-09 8:40 ` Viresh Kumar 2018-05-09 9:02 ` Joel Fernandes 2018-05-09 9:28 ` Viresh Kumar [this message] 2018-05-09 10:34 ` Joel Fernandes 2018-05-09 8:51 ` Joel Fernandes 2018-05-09 9:06 ` Rafael J. Wysocki 2018-05-09 9:39 ` Joel Fernandes 2018-05-09 9:48 ` Rafael J. Wysocki
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20180509092823.sfph4gomnblb7jgr@vireshk-i7 \ --to=viresh.kumar@linaro.org \ --cc=claudio@evidence.eu.com \ --cc=joel@joelfernandes.org \ --cc=joelaf@google.com \ --cc=juri.lelli@redhat.com \ --cc=linux-kernel@vger.kernel.org \ --cc=linux-pm@vger.kernel.org \ --cc=luca.abeni@santannapisa.it \ --cc=mingo@redhat.com \ --cc=patrick.bellasi@arm.com \ --cc=peterz@infradead.org \ --cc=rafael.j.wysocki@intel.com \ --cc=rafael@kernel.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox; as well as URLs for NNTP newsgroup(s).