Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp1011336pxv; Fri, 9 Jul 2021 15:02:47 -0700 (PDT) X-Google-Smtp-Source: ABdhPJw+taCuLUQ7Xvu1T6zahDhRR5T7S7GlTq3IvpNBcqMHL9awgvGGP/uxh6SEVvYjo3rrhbnt X-Received: by 2002:a5e:c905:: with SMTP id z5mr5017738iol.85.1625868167399; Fri, 09 Jul 2021 15:02:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1625868167; cv=none; d=google.com; s=arc-20160816; b=ILkcmdru9d9xRGuIGvmdfMW5MG5uwRkI97YoAEXQ6rcyufDihvlb0Ew0F7cKPfxyCl Xc/L5YJOoGSWVuNKu7ePDf0Z+mbeJ0/xgcChzUwRkMSqK4QFQEK2OpkLfPduSfYw2WvZ +pPMFcI0CfSbXOzWBJQeeTSwpSmn180XLxgN+KojXb2VXuEKH3UOXUNCCE8mvVySy8kg XImyAcUe91etS8XBG/RHDMg2XliKFqxD0QiBaMnsqnAHNrwn7M5nGspT7nGlxGki52sz BvSeiqgtLVCUJcHTBDhJH3tSz6yVo/t991FQdBPjt7OT4xrXN7ODjs2/5RXCIHO7NmHR CHFw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:references:subject:cc:to:from:date :user-agent:message-id; bh=nLozk7DAaGsViky1eSrj70x6aySa+f2qSNiSYM4UEO8=; b=Yb/SEcwTZXXj1gaK//xYNI4bCi3/dEDUkIPHv/JR9UQQgS5QTSRcs9OnHnm22MlydH U7l7XsUoGrMu+FJqUtYXSXQNfJEoXFMul2OJeyEYd9JOdvoJGlyUawwfuUmVqgJ4EGLn AyYcha9EZR+P3g6YR49mBOAr5v/KJoN/Hyn6/GSTCa4CvVgMYj6Hzch4Z/+6M7FsUdmr 5mFFv4tDO1YWgSbM95lUwNM+ABTaCwx7MxaJRTFsmxRymdbRed4gEd36nh3MCb3YKGYW 7eQk+JfgoTzXFMH+E9KkMbRH9ej4P8J7t5PcjtH5V6sDSBOn7O521zfHKpPilOHTYriX nfaQ== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id k11si7341037ilo.114.2021.07.09.15.02.34; Fri, 09 Jul 2021 15:02:47 -0700 (PDT) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231404AbhGIWDK (ORCPT + 99 others); Fri, 9 Jul 2021 18:03:10 -0400 Received: from mail.kernel.org ([198.145.29.99]:50430 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231183AbhGIWDD (ORCPT ); Fri, 9 Jul 2021 18:03:03 -0400 Received: from gandalf.local.home (cpe-66-24-58-225.stny.res.rr.com [66.24.58.225]) (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 2131F613C2; Fri, 9 Jul 2021 22:00:19 +0000 (UTC) Received: from rostedt by gandalf.local.home with local (Exim 4.94.2) (envelope-from ) id 1m1yXi-000CKx-5i; Fri, 09 Jul 2021 18:00:18 -0400 Message-ID: <20210709220018.003428207@goodmis.org> User-Agent: quilt/0.66 Date: Fri, 09 Jul 2021 17:59:58 -0400 From: Steven Rostedt To: linux-kernel@vger.kernel.org, linux-rt-users Cc: Thomas Gleixner , Carsten Emde , Sebastian Andrzej Siewior , John Kacur , Daniel Wagner , Tom Zanussi , "Srivatsa S. Bhat" , stable@kernel.org, "Peter Zijlstra (Intel)" , Ingo Molnar , Valentin Schneider , Paul Gortmaker Subject: [PATCH RT 5/8] sched: Fix affine_move_task() self-concurrency References: <20210709215953.122804544@goodmis.org> MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 5.10.47-rt46-rc1 stable review patch. If anyone has any objections, please let me know. ------------------ From: Peter Zijlstra commit 9e81889c7648d48dd5fe13f41cbc99f3c362484a upstream. Consider: sched_setaffinity(p, X); sched_setaffinity(p, Y); Then the first will install p->migration_pending = &my_pending; and issue stop_one_cpu_nowait(pending); and the second one will read p->migration_pending and _also_ issue: stop_one_cpu_nowait(pending), the _SAME_ @pending. This causes stopper list corruption. Add set_affinity_pending::stop_pending, to indicate if a stopper is in progress. Fixes: 6d337eab041d ("sched: Fix migrate_disable() vs set_cpus_allowed_ptr()") Cc: stable@kernel.org Signed-off-by: Peter Zijlstra (Intel) Signed-off-by: Ingo Molnar Reviewed-by: Valentin Schneider Link: https://lkml.kernel.org/r/20210224131355.649146419@infradead.org Signed-off-by: Paul Gortmaker Signed-off-by: Steven Rostedt (VMware) --- kernel/sched/core.c | 15 ++++++++++++--- 1 file changed, 12 insertions(+), 3 deletions(-) diff --git a/kernel/sched/core.c b/kernel/sched/core.c index 9cbe12d8c5bd..20588a59300d 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c @@ -1900,6 +1900,7 @@ struct migration_arg { struct set_affinity_pending { refcount_t refs; + unsigned int stop_pending; struct completion done; struct cpu_stop_work stop_work; struct migration_arg arg; @@ -2018,12 +2019,15 @@ static int migration_cpu_stop(void *data) * determine is_migration_disabled() and so have to chase after * it. */ + WARN_ON_ONCE(!pending->stop_pending); task_rq_unlock(rq, p, &rf); stop_one_cpu_nowait(task_cpu(p), migration_cpu_stop, &pending->arg, &pending->stop_work); return 0; } out: + if (pending) + pending->stop_pending = false; task_rq_unlock(rq, p, &rf); if (complete) @@ -2219,7 +2223,7 @@ static int affine_move_task(struct rq *rq, struct task_struct *p, struct rq_flag int dest_cpu, unsigned int flags) { struct set_affinity_pending my_pending = { }, *pending = NULL; - bool complete = false; + bool stop_pending, complete = false; /* Can the task run on the task's current CPU? If so, we're done */ if (cpumask_test_cpu(task_cpu(p), &p->cpus_mask)) { @@ -2292,14 +2296,19 @@ static int affine_move_task(struct rq *rq, struct task_struct *p, struct rq_flag * anything else we cannot do is_migration_disabled(), punt * and have the stopper function handle it all race-free. */ + stop_pending = pending->stop_pending; + if (!stop_pending) + pending->stop_pending = true; refcount_inc(&pending->refs); /* pending->{arg,stop_work} */ if (flags & SCA_MIGRATE_ENABLE) p->migration_flags &= ~MDF_PUSH; task_rq_unlock(rq, p, rf); - stop_one_cpu_nowait(cpu_of(rq), migration_cpu_stop, - &pending->arg, &pending->stop_work); + if (!stop_pending) { + stop_one_cpu_nowait(cpu_of(rq), migration_cpu_stop, + &pending->arg, &pending->stop_work); + } if (flags & SCA_MIGRATE_ENABLE) return 0; -- 2.30.2