Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp748731imm; Fri, 1 Jun 2018 08:53:45 -0700 (PDT) X-Google-Smtp-Source: ADUXVKI0rei8MmFTJ9aZELRWBoGKgz1I366ytwOtq2RW8zhDn93BnC3HCYSSk9eZZMOtorS3gTAe X-Received: by 2002:a63:ab05:: with SMTP id p5-v6mr9348722pgf.280.1527868425212; Fri, 01 Jun 2018 08:53:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527868425; cv=none; d=google.com; s=arc-20160816; b=G1MUfsibm3cbqtez8RDk0cl3dV4hBkoh67mv9eoo01ZTjgNtNomR3SV1LITY8nEfEB uXfIugElP2roe5KmwEKjmU5Ih0FRmi/F8uc5uHtEC/2EA4Z0LQSxNd7qXd3+4TwlWq6F J+rloYkz9sxeUyVbl5Un//NMocUKseBPgczJ9RmAkj6VpObzHlfJ8PGz2VV3CnJcpHKH PuTgef1dTMxpL8hbnGnPw5sBrCGVXuBvOoCoZiyukBlTAsn+6GiVtBt0gPwkyWxxbtx7 fwxZU00w5T9pAHAtSUaIVGGRudSpfNxpwBhOc/CwTzoFyVDFSsCtBI7uvD6t1cXLHkw/ xHFQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature:arc-authentication-results; bh=fKFkZ8/MUOrwRhosnhX2s4KVs2kP5nE5njcl7T1hSi0=; b=O2CLDTybgh+p5Ja1ef8tNCSigmLJLOYsG4he6XIaq7AxVsMwWzSN74QXfkwzUuVl5H pY34B4sFoVCM0FkFBuQDNF6JRseDxX7XbpenGr6Orlz6e5XD5Lcc4MslAOHM1SYONZ6R GLh4uyjQ+4fIsV1OO+fXOacF5vALxTyxIRCL6zz8+vfTTxaxUteAuax0wroJY9Pv0GDs 9vrQt6sk3mquELAqnWGDBD5GEPfrUz7faHXeKykVwV2P/Gdq+smhygsTuJu947GXS/lr ixy8yMDrD2GsdaUoclDaioO+1BakCsjLT1zE5x1epVhvY3wayvA7verb172y8PP9l3Ip h7Fw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b=ot2GxLfe; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j91-v6si39242005pld.402.2018.06.01.08.53.30; Fri, 01 Jun 2018 08:53:45 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@joelfernandes.org header.s=google header.b=ot2GxLfe; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753168AbeFAPwk (ORCPT + 99 others); Fri, 1 Jun 2018 11:52:40 -0400 Received: from mail-pl0-f65.google.com ([209.85.160.65]:36772 "EHLO mail-pl0-f65.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752019AbeFAPwg (ORCPT ); Fri, 1 Jun 2018 11:52:36 -0400 Received: by mail-pl0-f65.google.com with SMTP id v24-v6so15562588plo.3 for ; Fri, 01 Jun 2018 08:52:36 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=joelfernandes.org; s=google; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to:user-agent; bh=fKFkZ8/MUOrwRhosnhX2s4KVs2kP5nE5njcl7T1hSi0=; b=ot2GxLfefIrDkLZNR3BaEC9ulgoZJcwbYosA4GlEB7aOsWPUEXUm/uhwOlDoAE9uVO KtGOinAOxWhj455scJyUue2EZ9GDiTheaRw8qv5v/QJgbAozmDIC+VcsN+BtwOWGsAlF agb4SxnLQhwGykRWhRvrUDeG1GfK5bAMcVy2g= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to:user-agent; bh=fKFkZ8/MUOrwRhosnhX2s4KVs2kP5nE5njcl7T1hSi0=; b=G5bg3w+QshtbAKxhoQFrEcIEbPO+q9fQEbcKQdmivr5EzLs8wwjMgkA6wZ2iNoJSsW yZOVufLpLAepOSQjz7qqpqkHxtWKq94aUrQ5pZ0p5F5yY7UWpXk+3Hq+ZF6vWEsxti1c xllWeawYBUifC2GNDb3EZ9onhk86F2IHxwlBzIINgq2BhzrZFyMiGJgawgF8PBl/fh+o DnmOgy2477uRlD8c4mS+6xJCsR1QNFsng2FuFS7pGwuXfAqYMp7oNCI12W8LdmkN0LCC omEjFr7crq3rULKOHgfZ/GPyoeYC+8nhfo/1Ru4U7PEaetn2TwYszRb846DBjP3s20Sa tL9w== X-Gm-Message-State: ALKqPwcPix4KXf0uNREZjpxasWO04Lf2BhQJ5n2ReAqvVLDPlY4uWPWG E7iLoZd5uFbB4LsJ0L+g8impcw== X-Received: by 2002:a17:902:2d24:: with SMTP id o33-v6mr11821669plb.14.1527868356375; Fri, 01 Jun 2018 08:52:36 -0700 (PDT) Received: from localhost ([2620:0:1000:1600:3122:ea9c:d178:eb]) by smtp.gmail.com with ESMTPSA id 76-v6sm4306539pfr.172.2018.06.01.08.52.35 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Fri, 01 Jun 2018 08:52:35 -0700 (PDT) Date: Fri, 1 Jun 2018 08:52:35 -0700 From: Joel Fernandes To: Byungchul Park Cc: peterz@infradead.org, mingo@kernel.org, rostedt@goodmis.org, tglx@linutronix.de, raistlin@linux.it, linux-kernel@vger.kernel.org, juri.lelli@gmail.com, bristot@redhat.com, kernel-team@lge.com, kernel-team@android.com Subject: Re: [RESEND, v3, 2/2] sched/deadline: Initialize cp->elements[].cpu to an invalid value Message-ID: <20180601155235.GA66123@joelaf.mtv.corp.google.com> References: <1515392081-32320-2-git-send-email-byungchul.park@lge.com> <20180601061255.GA189147@joelaf.mtv.corp.google.com> <20180601061841.GA191514@joelaf.mtv.corp.google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.9.2 (2017-12-15) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Jun 01, 2018 at 04:10:56PM +0900, Byungchul Park wrote: > > On Thu, May 31, 2018 at 11:12:55PM -0700, Joel Fernandes wrote: > > > On Mon, Jan 08, 2018 at 03:14:41PM +0900, byungchul park wrote: > > > > Currently, migrating tasks to cpu0 unconditionally happens when the > > > > heap is empty, since cp->elements[].cpu was initialized to 0(=cpu0). > > > > We have to distinguish between the empty case and cpu0 to avoid the > > > > unnecessary migrations. Therefore, it has to return an invalid value > > > > e.i. -1 in that case. > > > > > > > > Signed-off-by: Byungchul Park > > > > Acked-by: Steven Rostedt (VMware) > > > > Acked-by: Daniel Bristot de Oliveira > > > > --- > > > > kernel/sched/cpudeadline.c | 10 +++++++++- > > > > 1 file changed, 9 insertions(+), 1 deletion(-) > > > > > > > > diff --git a/kernel/sched/cpudeadline.c b/kernel/sched/cpudeadline.c > > > > index 9f02035..bcf903f 100644 > > > > --- a/kernel/sched/cpudeadline.c > > > > +++ b/kernel/sched/cpudeadline.c > > > > @@ -138,6 +138,12 @@ int cpudl_find(struct cpudl *cp, struct task_struct *p, > > > > int best_cpu = cpudl_maximum_cpu(cp); > > > > WARN_ON(best_cpu != -1 && !cpu_present(best_cpu)); > > > > + /* > > > > + * The heap tree is empty for now, just return. > > > > + */ > > > > + if (best_cpu == -1) > > > > + return 0; > > > > + > > > > if (cpumask_test_cpu(best_cpu, &p->cpus_allowed) && > > > > dl_time_before(dl_se->deadline, cpudl_maximum_dl(cp))) { > > > > if (later_mask) > > > > @@ -265,8 +271,10 @@ int cpudl_init(struct cpudl *cp) > > > > return -ENOMEM; > > > > } > > > > - for_each_possible_cpu(i) > > > > + for_each_possible_cpu(i) { > > > > + cp->elements[i].cpu = -1; > > > > cp->elements[i].idx = IDX_INVALID; > > > > > > Shouldn't you also set cp->elements[cpu].cpu to -1 in cpudl_clear (when you > > > set cp->elements[cpu].cpu to IDX_INVALID there)? > > > > I messed up my words, I meant : "when setting cp->elements[cpu].idx to > > IDX_INVALID there". Which means I need to call it a day :-) > > Ah.. I agree with you. It might be a problem when removing the last > element.. Then I think the following change should also be applied > additionally. Right? Yes. > --- > diff --git a/kernel/sched/cpudeadline.c b/kernel/sched/cpudeadline.c > index 8d9562d..44d4c88 100644 > --- a/kernel/sched/cpudeadline.c > +++ b/kernel/sched/cpudeadline.c > @@ -172,12 +172,14 @@ void cpudl_clear(struct cpudl *cp, int cpu) > } else { > new_cpu = cp->elements[cp->size - 1].cpu; > cp->elements[old_idx].dl = cp->elements[cp->size - 1].dl; > - cp->elements[old_idx].cpu = new_cpu; > + cp->elements[old_idx].cpu = (new_cpu == cpu) ? -1 : new_cpu; > cp->size--; > - cp->elements[new_cpu].idx = old_idx; > cp->elements[cpu].idx = IDX_INVALID; > - cpudl_heapify(cp, old_idx); > > + if (new_cpu != cpu) { > + cp->elements[new_cpu].idx = old_idx; > + cpudl_heapify(cp, old_idx); > + } > cpumask_set_cpu(cpu, cp->free_cpus); This looks a bit confusing. How about the following? (untested) thanks, - Joel ---8<----------------------- diff --git a/kernel/sched/cpudeadline.c b/kernel/sched/cpudeadline.c index 50316455ea66..741a97e58c05 100644 --- a/kernel/sched/cpudeadline.c +++ b/kernel/sched/cpudeadline.c @@ -129,6 +129,10 @@ int cpudl_find(struct cpudl *cp, struct task_struct *p, } else { int best_cpu = cpudl_maximum(cp); + /* The max-heap is empty, just return. */ + if (best_cpu == -1) + return 0; + WARN_ON(best_cpu != -1 && !cpu_present(best_cpu)); if (cpumask_test_cpu(best_cpu, &p->cpus_allowed) && @@ -167,6 +171,12 @@ void cpudl_clear(struct cpudl *cp, int cpu) * This could happen if a rq_offline_dl is * called for a CPU without -dl tasks running. */ + } else if (cp->size == 1) { + /* Only one element in max-heap, clear it */ + cp->elements[0].cpu = -1; + cp->elements[cpu].idx = IDX_INVALID; + cp->size--; + cpumask_set_cpu(cpu, cp->free_cpus); } else { new_cpu = cp->elements[cp->size - 1].cpu; cp->elements[old_idx].dl = cp->elements[cp->size - 1].dl; @@ -262,6 +272,9 @@ int cpudl_init(struct cpudl *cp) for_each_possible_cpu(i) cp->elements[i].idx = IDX_INVALID; + /* Mark heap as initially empty */ + cp->elements[0].cpu = -1; + return 0; }