Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp2283072pxu; Mon, 7 Dec 2020 02:27:26 -0800 (PST) X-Google-Smtp-Source: ABdhPJy9g32bb9Kg1VS58EiqYJ90RT02CpXQMwl7e9OFV9TMQT938RtiBMhQfjK7hr8EFsOzqfqs X-Received: by 2002:aa7:c049:: with SMTP id k9mr19062185edo.49.1607336846077; Mon, 07 Dec 2020 02:27:26 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1607336846; cv=none; d=google.com; s=arc-20160816; b=NeFnkzI6bRuGrgQeuI+NEXdHdROiX0CU3ZU5e3h5As0vGUoA7Wl2OQgwGg5wkxPVhy aLEajYRIDlQIV2XTgBze5fk7uLT6OUrYizqry7O3BXN+3Xuj6aqOXFe+1mxQCbUm1nN6 unK+VCSvCa8x1UWtF0wq1Impx1r+iMdyXA9JLh1DZFOwehPnpjErkTQ5y14bNULFN6LQ DPxCiTXTU+MYSse9wSR8ZDFg93W2Iw2jJV7JW/L470JD9pHb0AlFQXxCYhw27mF8Hb+j tEOLMWSoxowYx0fvI7bBAhHJwQ2pRnyas5rxvc/AFAah836bqQI9DbmL8E7UgxZIXfBe 4nCw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:organization:references:in-reply-to:date:cc:to:from :subject:message-id:dkim-signature; bh=Z29GeURbS80t941pnzdyshdYfYbAY9RA3phQHjsW7+I=; b=mI2mY2gyhNKBSbp5Y+iHXtXZmZemUF7QyYr4UW4VPp4uk8Fa44Q4u/cLsG6DEltnG/ 4t3P4yPJWFHFuzUe7SLLy+DUaHPL/+8SQ+sRk/JzECJIJQFFdkdvxbsm6nkd9l/WfL1X Jj7G14feTc2jeMIfBIZWCIQS34ThTr96q8mtgzt+yRZM1WHhVj8MDq+2Yusd3Wm7Q162 NamiYW6evm22XsMZzcRWSx4rbfl+qDB8ODyM7yj3ZBIzN52g4c1fFtr1G5kIWaGD0pSV SILc4UxbP0ZwJ59sCUnjAqD+2jtew+UGY0MEV55M5rbbY99uG0VZHTuFPCDodNezQxGo eRWw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=XAL5E3XU; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a6si1932862ejs.282.2020.12.07.02.27.02; Mon, 07 Dec 2020 02:27:26 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=XAL5E3XU; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726578AbgLGKXb (ORCPT + 99 others); Mon, 7 Dec 2020 05:23:31 -0500 Received: from us-smtp-delivery-124.mimecast.com ([63.128.21.124]:27859 "EHLO us-smtp-delivery-124.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726396AbgLGKXb (ORCPT ); Mon, 7 Dec 2020 05:23:31 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1607336525; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=Z29GeURbS80t941pnzdyshdYfYbAY9RA3phQHjsW7+I=; b=XAL5E3XUQIAXlhJKKDc67e0DVtVDYehn4F7SzbGPNdsU24kQKFZJwS2fHzWEoIM8L9Jjgp RbFgwIdXrSi0QUCkjlkI1SXKff5VPaviZbjlv/nvmHPacewP1H3vHTcgOwsULB/oE5b4db rHl5hvVgtwPx6ehK927rcsGYftF39dU= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-386-cMUuWF0qNRmfVZVnlHVCjA-1; Mon, 07 Dec 2020 05:22:01 -0500 X-MC-Unique: cMUuWF0qNRmfVZVnlHVCjA-1 Received: from smtp.corp.redhat.com (int-mx07.intmail.prod.int.phx2.redhat.com [10.5.11.22]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 205311005504; Mon, 7 Dec 2020 10:22:00 +0000 (UTC) Received: from ovpn-113-92.phx2.redhat.com (ovpn-113-92.phx2.redhat.com [10.3.113.92]) by smtp.corp.redhat.com (Postfix) with ESMTP id 3798910016FF; Mon, 7 Dec 2020 10:21:59 +0000 (UTC) Message-ID: Subject: Re: [PATCH] sched/fair: Don't migrate with src_cpu == dst_cpu From: Scott Wood To: Peter Zijlstra Cc: Ingo Molnar , Vincent Guittot , Dietmar Eggemann , Mel Gorman , linux-kernel@vger.kernel.org, linux-rt-users@vger.kernel.org, Sebastian Andrzej Siewior Date: Mon, 07 Dec 2020 04:21:58 -0600 In-Reply-To: <20201203084723.GG2414@hirez.programming.kicks-ass.net> References: <20201203060449.3352126-1-swood@redhat.com> <20201203084723.GG2414@hirez.programming.kicks-ass.net> Organization: Red Hat Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.36.5 (3.36.5-1.fc32) MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Scanned-By: MIMEDefang 2.84 on 10.5.11.22 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Thu, 2020-12-03 at 09:47 +0100, Peter Zijlstra wrote: > On Thu, Dec 03, 2020 at 12:04:49AM -0600, Scott Wood wrote: > > Besides being a waste of time to try to move tasks to where they already > > are, this avoids triggering the WARN_ON_ONCE(is_migration_disabled(p)) > > in set_task_cpu(). > > > > Signed-off-by: Scott Wood > > --- > > Patch is against tip/master. Assertion was seen by running rteval on > > the > > RT tree. > > > > kernel/sched/fair.c | 3 ++- > > 1 file changed, 2 insertions(+), 1 deletion(-) > > > > diff --git a/kernel/sched/fair.c b/kernel/sched/fair.c > > index e7e21ac479a2..f443626164d4 100644 > > --- a/kernel/sched/fair.c > > +++ b/kernel/sched/fair.c > > @@ -7574,7 +7574,8 @@ int can_migrate_task(struct task_struct *p, struct > > lb_env *env) > > > > /* Prevent to re-select dst_cpu via env's CPUs: */ > > for_each_cpu_and(cpu, env->dst_grpmask, env->cpus) { > > - if (cpumask_test_cpu(cpu, p->cpus_ptr)) { > > + if (cpu != env->src_cpu && > > + cpumask_test_cpu(cpu, p->cpus_ptr)) { > > env->flags |= LBF_DST_PINNED; > > env->new_dst_cpu = cpu; > > break; > > Do we have _any_ clue as to how we ended up in that situation? The above > sounds like it should be a WARN and we should avoid getting here in the > first place. My initial impression was that there simply wasn't anything stopping it from happening, but digging deeper it looks like it's specific to NUMA domains with overlapping CPUs. -Scott