Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp512387imm; Fri, 5 Oct 2018 07:27:42 -0700 (PDT) X-Google-Smtp-Source: ACcGV61zEONNjWCFs4VD/sEunpMkh7zZDPw2zhgw08as3a5WuNc4p9AWOEebjUd9CVK1JTcu2x01 X-Received: by 2002:a62:e091:: with SMTP id d17-v6mr12033706pfm.214.1538749662116; Fri, 05 Oct 2018 07:27:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1538749662; cv=none; d=google.com; s=arc-20160816; b=zKi28f4e8yFKz80Npyqch7h5iFNHDa5QJxsFG46ceq9mx5MF5xJ5NlI/fCqT2BYRA8 9fwlPsjgN6hPAO8krbyuvwiGUvNCvAmkw7YaujZmDC2yrKV5xhzaju2tHg4pN6wfFLPg jDkoNlN6n1uYf9OJvB8RD1QgNnzvxpbHNeTpWJnwtxKNJgkW+8/oFk48iOgbCS0T5TAc 3jRVMIpDZK9Hj/QNw0LZDyIPUKoGS0TDtvdAR949oYS1vRvwKaMTtRWJjL555yC12+Q/ 3+Hgj/3CHcEyOeVlHcnkzFhpOy1jK0D2uFy/N1a270dlzk+G8mUQAXdCPgdVnTEIyn24 +urQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date; bh=rxq/qGoL9NhoNUwbUNmKbOzgdlc3JZCIO0o7tXqXSKM=; b=VcZwFZaRHXY+XIRCu75vYJgIwkzqFrhSFLmzLS6c9gQMvV/39InZpQHsBrKd0r3D/j pi0qpe1H3MLold8vRTOWwx6ezfBOBIt44p3Cp9G4VokxheR85QZ9I4meIomLmV0QjmN2 pD7una+1G0QGEBp/zjz3HOv9ga/MjqjBDcelndQOYRJskDEhI9fVY9bIR9ymvPjEXUuM Dc5mc6CDgUaI3NwBT9QWRIWqWgU8cEZi67HSfeYFqasqPdet0KQmb2zoqlSxUKiaxbFW uuQZMc+nQmiQJTcrqMBVpCpOqe+UKaKgfdgGxLZ4Hn4vX+TO8EDo9s4GjHnCEHl/8cJO JjAQ== ARC-Authentication-Results: i=1; mx.google.com; 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 33-v6si9474808plv.241.2018.10.05.07.27.26; Fri, 05 Oct 2018 07:27:42 -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; 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 S1728877AbeJEVZ6 (ORCPT + 99 others); Fri, 5 Oct 2018 17:25:58 -0400 Received: from mail.kernel.org ([198.145.29.99]:52240 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727968AbeJEVZ5 (ORCPT ); Fri, 5 Oct 2018 17:25:57 -0400 Received: from gandalf.local.home (cpe-66-24-56-78.stny.res.rr.com [66.24.56.78]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 67B462087D; Fri, 5 Oct 2018 14:27:00 +0000 (UTC) Date: Fri, 5 Oct 2018 10:26:58 -0400 From: Steven Rostedt To: Peng Hao Cc: mingo@redhat.com, peterz@infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v3] sched/rt : return accurate release rq lock info Message-ID: <20181005102658.38ecde83@gandalf.local.home> In-Reply-To: <1538778131-44406-1-git-send-email-peng.hao2@zte.com.cn> References: <1538778131-44406-1-git-send-email-peng.hao2@zte.com.cn> X-Mailer: Claws Mail 3.16.0 (GTK+ 2.24.32; x86_64-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 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, 6 Oct 2018 06:22:11 +0800 Peng Hao wrote: > find_lock_lowest_rq may or not releease rq lock when return > lowest_rq=NULL, but it is fuzzy. > If not releasing rq lock, it is unnecessary to re-call > pick_next_pushable_task. > When CONFIG_PREEMPT=n, not releasing rq lock and return > lowest_rq=null frequently happens in a simple test case: > Four different rt priority tasks run on limited two cpus. > Thanks for Steven Rostedt's advice. > > Signed-off-by: Peng Hao > --- > kernel/sched/rt.c | 6 ++++-- > 1 file changed, 4 insertions(+), 2 deletions(-) > > diff --git a/kernel/sched/rt.c b/kernel/sched/rt.c > index 2e2955a..be0fc43 100644 > --- a/kernel/sched/rt.c > +++ b/kernel/sched/rt.c > @@ -1754,7 +1754,7 @@ static struct rq *find_lock_lowest_rq(struct task_struct *task, struct rq *rq) > !task_on_rq_queued(task))) { > > double_unlock_balance(rq, lowest_rq); > - lowest_rq = NULL; > + lowest_rq = RETRY_TASK; > break; > } > } > @@ -1830,7 +1830,9 @@ static int push_rt_task(struct rq *rq) > > /* find_lock_lowest_rq locks the rq if found */ > lowest_rq = find_lock_lowest_rq(next_task, rq); > - if (!lowest_rq) { > + if (!lowest_rq) > + goto out; > + if (lowest_rq == RETRY_TASK) { This probably makes no difference, and can be blown off as just a preference, but should this be: if (!lowest_rq) { goto out; } else if (lowest_rq == RETRY_TASK) { The logic is the same regardless, so it's really just a matter of taste. That said: Reviewed-by: Steven Rostedt (VMware) -- Steve > struct task_struct *task; > /* > * find_lock_lowest_rq releases rq->lock