Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1758499AbcDERF1 (ORCPT ); Tue, 5 Apr 2016 13:05:27 -0400 Received: from mail-wm0-f66.google.com ([74.125.82.66]:34951 "EHLO mail-wm0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753142AbcDERFZ (ORCPT ); Tue, 5 Apr 2016 13:05:25 -0400 Date: Tue, 5 Apr 2016 19:05:11 +0200 From: luca abeni To: Peter Zijlstra Cc: linux-kernel@vger.kernel.org, Ingo Molnar , Juri Lelli Subject: Re: [RFC v2 3/7] Improve the tracking of active utilisation Message-ID: <20160405190511.2b3029a9@utopia> In-Reply-To: <20160405124242.GX3430@twins.programming.kicks-ass.net> References: <1459523553-29089-1-git-send-email-luca.abeni@unitn.it> <1459523553-29089-4-git-send-email-luca.abeni@unitn.it> <20160405124242.GX3430@twins.programming.kicks-ass.net> X-Mailer: Claws Mail 3.12.0 (GTK+ 2.24.28; i686-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1173 Lines: 35 Hi Peter, On Tue, 5 Apr 2016 14:42:42 +0200 Peter Zijlstra wrote: > On Fri, Apr 01, 2016 at 05:12:29PM +0200, Luca Abeni wrote: > > @@ -526,7 +575,18 @@ static void update_dl_entity(struct sched_dl_entity *dl_se, > > struct dl_rq *dl_rq = dl_rq_of_se(dl_se); > > struct rq *rq = rq_of_dl_rq(dl_rq); > > > > - add_running_bw(dl_se, dl_rq); > > + /* > > + * If the "inactive timer" is still active, stop it and leave > > + * the active utilisation unchanged. > > + * Otherwise, increase the active utilisation. > > + * If the timer cannot be cancelled, inactive_task_timer() will > > + * find the task state as TASK_RUNNING, and will do nothing, so > > + * we are still safe. > > + */ > > + if (hrtimer_active(&dl_se->inactive_timer)) > > + hrtimer_try_to_cancel(&dl_se->inactive_timer); > > _try_, what happens if that fails? I think inactive_task_timer() will run, but will see p->state == TASK_RUNNING and will return immediately. I think I have actually seen this happening during my tests, because adding the "if (p->state == TASK_RUNNING)" in inactive_task_timer() fixed some issues that I was seeing. Thanks, Luca