Received: by 2002:ad5:4acb:0:0:0:0:0 with SMTP id n11csp2248615imw; Wed, 6 Jul 2022 02:40:08 -0700 (PDT) X-Google-Smtp-Source: AGRyM1tv1kt+z3GLPw7ZITQ9pJdj4e4uOM3nWKzymfu6FiC2keA/XPdJueXh9JKCKcNJYo8t5hVz X-Received: by 2002:a17:907:1c97:b0:6f5:22ae:7024 with SMTP id nb23-20020a1709071c9700b006f522ae7024mr36997157ejc.570.1657100407861; Wed, 06 Jul 2022 02:40:07 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1657100407; cv=none; d=google.com; s=arc-20160816; b=gNDL4JLWRx2/WDdG6AnNKLiOUTBoebRB19Gd94Na31pysAX5bKjuUccD01rj3M1fUi qdpesy4XHJSnpQ80DNhOa3U0tyyaCmJPPYzSVRBscs2RJb2hfIOpYzCQZeaRNcZXEPFK CHmOe9vanUF36dj9X1tBSWChAcVnLaO5Z1T2J16F8g38KydVwWGXXuyyF1iRCz4XudxP uYQQZqTRl/52v4wsTXkUcI1k57I92uwP9vq6httuTCY1fbzoVljwu005zweIgaKLC3l2 LKnMy7UG7hmwwkYLPtIUOJkCWlKrTehrIOl2M7eJhZkZNJdswbmhH1Pqn7iilEz5E2Hz dkRw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=Lc1nfuTmRLJC5zrVjNH0l/duy5mbZIyykH5a0W+voY8=; b=VlW7RtsMon9T1+hGSHbd4Kd5HzyMW92rD3W8E+NSpG8ILruURDKifHs47PfcHldCdy H7Lg8U7c3AhLCRuY0LbQixao0WMBYrCwN3+FS2cKO3Alet/e4t852H+veRWkUMccSbk1 wj5m3Yand1aLiCxn6ULGUA0YWp/9mq1asY5rgYDTpVpk0U0uAb7RoTCnbVT2akpoDSM0 ZWQGlK61aCqb8jfpOVXq7JAe8KFWUHfWoIkeII+zAXPyBoo5isUUpucJt5c0UpuXgFMW 0R1+k+vcxtMYtRG+bHJk2ni9t+tTENDK3AIgV0gw4Q16v80+4A9fCRtXxXZ3UlUP/eu+ V8IA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@infradead.org header.s=desiato.20200630 header.b=i8xduWRV; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id nc41-20020a1709071c2900b0072afcdc2876si691059ejc.75.2022.07.06.02.39.43; Wed, 06 Jul 2022 02:40:07 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@infradead.org header.s=desiato.20200630 header.b=i8xduWRV; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232629AbiGFJAf (ORCPT + 99 others); Wed, 6 Jul 2022 05:00:35 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39798 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232642AbiGFJA1 (ORCPT ); Wed, 6 Jul 2022 05:00:27 -0400 Received: from desiato.infradead.org (desiato.infradead.org [IPv6:2001:8b0:10b:1:d65d:64ff:fe57:4e05]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id EABC41A3A1; Wed, 6 Jul 2022 02:00:24 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=desiato.20200630; h=In-Reply-To:Content-Type:MIME-Version: References:Message-ID:Subject:Cc:To:From:Date:Sender:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description; bh=Lc1nfuTmRLJC5zrVjNH0l/duy5mbZIyykH5a0W+voY8=; b=i8xduWRVHzPycpj4aYcRorY6TA XTVVYE1I11IukCdv42nkSkB4f3OUjy3AJBnUNvj4TUakkooAJ1n5Jxvz/d11wUl5GqYcIieozQ864 B2Kq4qM14Ou6J9CVLN/3LK5EtRqKlxLdn/RmXRZRjVpX8V+q58etmYn1WtdVfrGKd1PjTnLKIclOH a+kaMIxwNo1ZpUXKKhskeM8BfC/efZCZUI/kLzOIUxKfbHx5WlpT/PAfH8HC0Vsd+kQRpn60lp6J6 7jOYxvTDvKgYfoTkv2ZeG6LX11dKbzDctVwLJJNREnMQMKg8yLBMcQhZCodE4KYfbJDXW00LAylze g1pP64tw==; Received: from j130084.upc-j.chello.nl ([24.132.130.84] helo=worktop.programming.kicks-ass.net) by desiato.infradead.org with esmtpsa (Exim 4.94.2 #2 (Red Hat Linux)) id 1o90sB-000N9S-20; Wed, 06 Jul 2022 08:59:15 +0000 Received: by worktop.programming.kicks-ass.net (Postfix, from userid 1000) id 875EF980050; Wed, 6 Jul 2022 10:59:00 +0200 (CEST) Date: Wed, 6 Jul 2022 10:59:00 +0200 From: Peter Zijlstra To: Sven Schnelle Cc: Steven Rostedt , Alexander Gordeev , "Eric W. Biederman" , linux-kernel@vger.kernel.org, rjw@rjwysocki.net, Oleg Nesterov , mingo@kernel.org, vincent.guittot@linaro.org, dietmar.eggemann@arm.com, mgorman@suse.de, bigeasy@linutronix.de, Will Deacon , tj@kernel.org, linux-pm@vger.kernel.org, Richard Weinberger , Anton Ivanov , Johannes Berg , linux-um@lists.infradead.org, Chris Zankel , Max Filippov , linux-xtensa@linux-xtensa.org, Kees Cook , Jann Horn , linux-ia64@vger.kernel.org Subject: Re: [PATCH v4 12/12] sched,signal,ptrace: Rework TASK_TRACED, TASK_STOPPED state Message-ID: References: <87a6bv6dl6.fsf_-_@email.froward.int.ebiederm.org> <20220505182645.497868-12-ebiederm@xmission.com> <877d5ajesi.fsf@email.froward.int.ebiederm.org> <20220628191541.34a073fc@gandalf.local.home> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: X-Spam-Status: No, score=-4.4 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE, SPF_NONE,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Jul 06, 2022 at 09:58:55AM +0200, Sven Schnelle wrote: > >> [ 86.218551] kill_chi-343805 6d.... 79990141us : ptrace_stop: JOBCTL_TRACED already set, state=0 <------ valid combination of flags? > > > > Yeah, that's not supposed to be so. JOBCTL_TRACED is supposed to follow > > __TASK_TRACED for now. Set when __TASK_TRACED, cleared when > > TASK_RUNNING. > > > > Specifically {ptrace_,}signal_wake_up() in signal.h clear JOBCTL_TRACED > > when they would wake a __TASK_TRACED task. > > try_to_wake_up() clears TASK_TRACED in this case because a signal > (SIGKILL) has to be delivered. As a test I put the following change > on top, and it "fixes" the problem: > > diff --git a/kernel/sched/core.c b/kernel/sched/core.c > index da0bf6fe9ecd..f2e0f5e70e77 100644 > --- a/kernel/sched/core.c > +++ b/kernel/sched/core.c > @@ -4141,6 +4149,9 @@ try_to_wake_up(struct task_struct *p, unsigned int state, int wake_flags) > * TASK_WAKING such that we can unlock p->pi_lock before doing the > * enqueue, such as ttwu_queue_wakelist(). > */ > + if (p->__state & TASK_TRACED) > + trace_printk("clearing TASK_TRACED 2\n"); > + p->jobctl &= ~JOBCTL_TRACED; > WRITE_ONCE(p->__state, TASK_WAKING); > > /* > > There are several places where the state is changed from TASK_TRACED to > something else without clearing JOBCTL_TRACED. I'm having difficulty spotting them; I find: TASK_WAKEKILL: signal_wake_up() __TASK_TRACED: ptrace_signal_wake_up(), ptrace_unfreeze_traced(), ptrace_resume() And all those sites dutifully clear JOBCTL_TRACED. I'd be most interested in the calstack for the 'clearing TASK_TRACED 2' events to see where we miss a spot.