Received: by 2002:ad5:4acb:0:0:0:0:0 with SMTP id n11csp1502973imw; Tue, 5 Jul 2022 10:33:55 -0700 (PDT) X-Google-Smtp-Source: AGRyM1vEexKDXJxITPUHh26KGct6FckpVDeVByLcdoHnAm1NogMDidnSkkeeIF54ELKVTl8DhyWR X-Received: by 2002:a17:907:a078:b0:72a:e78f:c277 with SMTP id ia24-20020a170907a07800b0072ae78fc277mr3743203ejc.702.1657042434876; Tue, 05 Jul 2022 10:33:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1657042434; cv=none; d=google.com; s=arc-20160816; b=zoWvjGEHtFBEYNek7tpfjwprSixo8unueXoozcmDDbNLXK5qw85ksF43BOr/UOCYQc 3GUkj2SGXlHZ4v/uKaspaWC0g4IzWDEj0gwvonVS4kZh7cMOJLgJ41SKzvXOCnZjSSWP M5CX6TQcKHzosyGil/CSv3ZFTBMAvku9dNcYLCCZydGfVGGPPI0Payb34/sX89nM17f2 dqfyHW8esDvbjs55Bqhk+GALBopkrVfxoniCVX87FmtOq5M4feff92KiQTwg2AM0goYY LmcJoZoFIGucGgqtg1C7GYOMcMK3WdaRO+BQTxf2RCxL0IP9WBBddeI6CKibMkIuQr+u g/Gg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:user-agent:message-id:in-reply-to :date:references:subject:cc:to:from:dkim-signature; bh=9N75wjLDX8o6KAh0utPiax3Xv9dz6tDhDCKOTSG4ivU=; b=QxPhEohmHm9dgICCYK8lflDiNDLTn0tPK5YKgLso5t2KXwYmOWxm5jb8fRr7AdCkLe giefvUwyscso0Gjb0Xjv5YdQeGha3XKMho0yxbbrs90ON9JowrX5QIsqWizKYwh5gj9H 5HZfOXa/MhwgBb+QUjLzx5ZVMfYoEd6tOLI1Xc4pwoN2o0ZfQGNYLiv+FjMFKYhe47kx lfWH0756pnAyvX0XbQ7Z71tktvNC0k2MmoJuhomJrM2B01HR5Z8xc8GdHmYtaNYnBesR 8h8oCyYD70bpsrr6On/e5wfQ2KcDaX/KfFwIdL6upf6PaJl2pqzf29DqM74/X49YuQ7s yiow== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ibm.com header.s=pp1 header.b=AWvXLaZo; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=ibm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id x4-20020a05640226c400b00435adb7520asi2304609edd.338.2022.07.05.10.33.30; Tue, 05 Jul 2022 10:33:54 -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=@ibm.com header.s=pp1 header.b=AWvXLaZo; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=ibm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S233030AbiGERac (ORCPT + 99 others); Tue, 5 Jul 2022 13:30:32 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:49736 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232875AbiGERaR (ORCPT ); Tue, 5 Jul 2022 13:30:17 -0400 Received: from mx0b-001b2d01.pphosted.com (mx0b-001b2d01.pphosted.com [148.163.158.5]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 48AE5B7F6; Tue, 5 Jul 2022 10:29:31 -0700 (PDT) Received: from pps.filterd (m0098417.ppops.net [127.0.0.1]) by mx0a-001b2d01.pphosted.com (8.17.1.5/8.17.1.5) with ESMTP id 265Fl0Ge006407; Tue, 5 Jul 2022 17:28:57 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ibm.com; h=from : to : cc : subject : references : date : in-reply-to : message-id : content-type : mime-version; s=pp1; bh=9N75wjLDX8o6KAh0utPiax3Xv9dz6tDhDCKOTSG4ivU=; b=AWvXLaZozSsf/DJ43QL8FziD0+TK5a/nd59NwCLewNSka6oZlLfjil3p03IWUzKV4PoF Hdkwb0o8mPsMtDZocv6uVPSEnbK9kTNqMcQGKjG7NrnwaQClpMpesp+q0Xy0di9Cai1y GHlgW5ykFNSvOXfMpCYB8NYVXfGbM4ORJxfvuLamPzerupaNMTzFa2qj3FZ32aVP/7VK 9FKHStEgfXGhkqwtFlR9buh/FqaJg+Z7b3JA6sDqE+rL6PJO5VP6zEambkTKwC3bm7Yq qX9RvU4VYCdktXItXDPLp9IZLGqdIcDE0zOovvO5D/Im8M1RSzj5H4k9k/5BdCpNDBXg 6Q== Received: from pps.reinject (localhost [127.0.0.1]) by mx0a-001b2d01.pphosted.com (PPS) with ESMTPS id 3h4r88as3d-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Tue, 05 Jul 2022 17:28:56 +0000 Received: from m0098417.ppops.net (m0098417.ppops.net [127.0.0.1]) by pps.reinject (8.17.1.5/8.17.1.5) with ESMTP id 265GunqN002368; Tue, 5 Jul 2022 17:28:56 GMT Received: from ppma06fra.de.ibm.com (48.49.7a9f.ip4.static.sl-reverse.com [159.122.73.72]) by mx0a-001b2d01.pphosted.com (PPS) with ESMTPS id 3h4r88as28-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Tue, 05 Jul 2022 17:28:55 +0000 Received: from pps.filterd (ppma06fra.de.ibm.com [127.0.0.1]) by ppma06fra.de.ibm.com (8.16.1.2/8.16.1.2) with SMTP id 265HLXBr016197; Tue, 5 Jul 2022 17:28:53 GMT Received: from b06cxnps4075.portsmouth.uk.ibm.com (d06relay12.portsmouth.uk.ibm.com [9.149.109.197]) by ppma06fra.de.ibm.com with ESMTP id 3h2d9hu8he-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=NOT); Tue, 05 Jul 2022 17:28:53 +0000 Received: from d06av23.portsmouth.uk.ibm.com (d06av23.portsmouth.uk.ibm.com [9.149.105.59]) by b06cxnps4075.portsmouth.uk.ibm.com (8.14.9/8.14.9/NCO v10.0) with ESMTP id 265HSp6k20316562 (version=TLSv1/SSLv3 cipher=DHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Tue, 5 Jul 2022 17:28:51 GMT Received: from d06av23.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id E5FA0A404D; Tue, 5 Jul 2022 17:28:50 +0000 (GMT) Received: from d06av23.portsmouth.uk.ibm.com (unknown [127.0.0.1]) by IMSVA (Postfix) with ESMTP id 2C253A4051; Tue, 5 Jul 2022 17:28:50 +0000 (GMT) Received: from tuxmaker.linux.ibm.com (unknown [9.152.85.9]) by d06av23.portsmouth.uk.ibm.com (Postfix) with ESMTPS; Tue, 5 Jul 2022 17:28:50 +0000 (GMT) From: Sven Schnelle To: Steven Rostedt Cc: 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, Peter Zijlstra , 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 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> Date: Tue, 05 Jul 2022 19:28:49 +0200 In-Reply-To: (Sven Schnelle's message of "Tue, 05 Jul 2022 15:47:44 +0200") Message-ID: User-Agent: Gnus/5.13 (Gnus v5.13) Emacs/28.0.50 (gnu/linux) Content-Type: multipart/mixed; boundary="=-=-=" X-TM-AS-GCONF: 00 X-Proofpoint-ORIG-GUID: -qyJtpU87oLahswla1ldbNpMgErU_p4r X-Proofpoint-GUID: yg1QWNqTofD8zoBpLXcSvlEGhO9YQi8o X-Proofpoint-UnRewURL: 0 URL was un-rewritten MIME-Version: 1.0 X-Proofpoint-Virus-Version: vendor=baseguard engine=ICAP:2.0.205,Aquarius:18.0.883,Hydra:6.0.517,FMLib:17.11.122.1 definitions=2022-07-05_14,2022-06-28_01,2022-06-22_01 X-Proofpoint-Spam-Details: rule=outbound_notspam policy=outbound score=0 spamscore=0 priorityscore=1501 bulkscore=0 clxscore=1015 impostorscore=0 mlxscore=0 adultscore=0 suspectscore=0 mlxlogscore=788 lowpriorityscore=0 malwarescore=0 phishscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.12.0-2204290000 definitions=main-2207050074 X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_EF,RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_PASS, 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 --=-=-= Content-Type: text/plain Content-Transfer-Encoding: Sven Schnelle writes: > Steven Rostedt writes: > >> On Tue, 21 Jun 2022 17:15:47 +0200 >> Alexander Gordeev wrote: >> >>> So I assume (checked actually) the return 0 below from kernel/sched/core.c: >>> wait_task_inactive() is where it bails out: >>> >>> 3303 while (task_running(rq, p)) { >>> 3304 if (match_state && unlikely(READ_ONCE(p->__state) != match_state)) >>> 3305 return 0; >>> 3306 cpu_relax(); >>> 3307 } >>> >>> Yet, the child task is always found in __TASK_TRACED state (as seen >>> in crash dumps): >>> >>> > 101447 11342 13 ce3a8100 RU 0.0 10040 4412 strace >>> 101450 101447 0 bb04b200 TR 0.0 2272 1136 kill_child >>> 108261 101447 2 d0b10100 TR 0.0 2272 532 kill_child >>> crash> task bb04b200 __state >>> PID: 101450 TASK: bb04b200 CPU: 0 COMMAND: "kill_child" >>> __state = 8, >>> >>> crash> task d0b10100 __state >>> PID: 108261 TASK: d0b10100 CPU: 2 COMMAND: "kill_child" >>> __state = 8, >> >> If you are using crash, can you enable all trace events? >> >> Then you should be able to extract the ftrace ring buffer from crash using >> the trace.so extend (https://github.com/fujitsu/crash-trace) >> >> I guess it should still work with s390. >> >> Then you can see the events that lead up to the crash. I think there's a race in ptrace_check_attach(). It first calls ptrace_freeze_task(), which checks whether JOBCTL_TRACED is set. If it is (and a few other conditions match) it will set ret = 0. Later outside of siglock and tasklist_lock it will call wait_task_inactive, assuming the target is in TASK_TRACED, but it isn't. ptrace_stop(), which runs on another CPU, does: set_special_state(TASK_TRACED); current->jobctl |= JOBCTL_TRACED; which looks ok on first sight, but in this case JOBCTL is already set, so the reading CPU will immediately move on to wait_task_inactive(), before JOBCTL_TRACED is set. I don't know whether this is a valid combination. I never looked into JOBCTL_* semantics, but i guess now is a good time to do so. I added some debugging statements, and that gives: [ 86.218488] kill_chi-300545 2d.... 79990135us : ptrace_stop: state 8 [ 86.218492] kill_chi-300545 2d.... 79990136us : signal_generate: sig=17 errno=0 code=4 comm=strace pid=300542 grp=1 res=1 [ 86.218496] kill_chi-300545 2d.... 79990136us : sched_stat_runtime: comm=kill_child pid=300545 runtime=3058 [ns] vruntime=606165713178 [ns] [ 86.218500] kill_chi-300545 2d.... 79990136us : sched_switch: prev_comm=kill_child prev_pid=300545 prev_prio=120 prev_state=t ==> next_comm=swapper/2 next_pid=0 next_prio=120 [ 86.218504] strace-300542 7..... 79990139us : sys_ptrace -> 0x50 [ 86.218508] strace-300542 7..... 79990139us : sys_write(fd: 2, buf: 2aa198f7ad0, count: 12) [ 86.218512] strace-300542 7..... 79990140us : sys_write -> 0x12 [ 86.218515] -0 6dNh.. 79990140us : sched_wakeup: comm=kill_child pid=343805 prio=120 target_cpu=006 [ 86.218519] -0 6d.... 79990140us : sched_switch: prev_comm=swapper/6 prev_pid=0 prev_prio=120 prev_state=R ==> next_comm=kill_child next_pid=343805 next_prio=120 [ 86.218524] strace-300542 7..... 79990140us : sys_write(fd: 2, buf: 2aa198f7ad0, count: 19) [ 86.218527] strace-300542 7..... 79990141us : sys_write -> 0x19 [ 86.218531] kill_chi-343805 6..... 79990141us : sys_sched_yield -> 0xffffffffffffffda [ 86.218535] strace-300542 7..... 79990141us : sys_ptrace(request: 18, pid: 53efd, addr: 0, data: 0) [ 86.218539] kill_chi-343805 6d.... 79990141us : signal_deliver: sig=9 errno=0 code=0 sa_handler=0 sa_flags=0 [ 86.218543] strace-300542 7d.... 79990141us : ptrace_check_attach: task_is_traced: 1, fatal signal pending: 0 [ 86.218547] strace-300542 7..... 79990141us : ptrace_check_attach: child->pid = 343805, child->__flags=0 [ 86.218551] kill_chi-343805 6d.... 79990141us : ptrace_stop: JOBCTL_TRACED already set, state=0 <------ valid combination of flags? [ 86.218554] kill_chi-343805 6d.... 79990141us : ptrace_stop: state 8 [ 86.218558] kill_chi-343805 6d.... 79990142us : signal_generate: sig=17 errno=0 code=4 comm=strace pid=300542 grp=1 res=1 [ 86.218562] kill_chi-343805 6d.... 79990142us : sched_stat_runtime: comm=kill_child pid=343805 runtime=2135 [ns] vruntime=556109013931 [ns] [ 86.218566] strace-300542 7..... 79990142us : wait_task_inactive: NO MATCH: state 0, match_state 8, pid 343805 [ 86.218570] kill_chi-343805 6d.... 79990142us : sched_switch: prev_comm=kill_child prev_pid=343805 prev_prio=120 prev_state=t ==>next_comm=swapper/6 next_pid=0 next_prio=120 --=-=-= Content-Type: text/x-diff Content-Disposition: inline; filename=ptrace-debug.patch diff --git a/include/linux/sched.h b/include/linux/sched.h index c46f3a63b758..c2ddc47271b8 100644 --- a/include/linux/sched.h +++ b/include/linux/sched.h @@ -154,8 +154,8 @@ struct task_group; } while (0) #else -# define debug_normal_state_change(cond) do { } while (0) -# define debug_special_state_change(cond) do { } while (0) +# define debug_normal_state_change(cond) do { trace_printk("state %d\n", cond); } while (0) +# define debug_special_state_change(cond) do { trace_printk("state %d\n", cond); } while (0) # define debug_rtlock_wait_set_state() do { } while (0) # define debug_rtlock_wait_restore_state() do { } while (0) #endif diff --git a/kernel/ptrace.c b/kernel/ptrace.c index 156a99283b11..2cb2ae8acf23 100644 --- a/kernel/ptrace.c +++ b/kernel/ptrace.c @@ -202,6 +202,7 @@ static bool ptrace_freeze_traced(struct task_struct *task) spin_lock_irq(&task->sighand->siglock); if (task_is_traced(task) && !looks_like_a_spurious_pid(task) && !__fatal_signal_pending(task)) { + trace_printk("task_is_traced: %d, fatal signal pending: %d\n", task_is_traced(task), __fatal_signal_pending(task)); task->jobctl |= JOBCTL_PTRACE_FROZEN; ret = true; } @@ -263,8 +264,10 @@ static int ptrace_check_attach(struct task_struct *child, bool ignore_state) * child->sighand can't be NULL, release_task() * does ptrace_unlink() before __exit_signal(). */ - if (ignore_state || ptrace_freeze_traced(child)) + if (ignore_state || ptrace_freeze_traced(child)) { + trace_printk("child->pid = %d, child->__flags=%d\n", child->pid, child->__state); ret = 0; + } } read_unlock(&tasklist_lock); diff --git a/kernel/sched/core.c b/kernel/sched/core.c index da0bf6fe9ecd..73bb4c7882d0 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c @@ -3301,8 +3301,10 @@ unsigned long wait_task_inactive(struct task_struct *p, unsigned int match_state * is actually now running somewhere else! */ while (task_running(rq, p)) { - if (match_state && unlikely(READ_ONCE(p->__state) != match_state)) + if (match_state && unlikely(READ_ONCE(p->__state) != match_state)) { + trace_printk("NO MATCH: state %d, match_state %d, pid %d\n", p->__state, match_state, p->pid); return 0; + } cpu_relax(); } diff --git a/kernel/signal.c b/kernel/signal.c index edb1dc9b00dc..0ea8e6b6a641 100644 --- a/kernel/signal.c +++ b/kernel/signal.c @@ -2232,6 +2232,8 @@ static int ptrace_stop(int exit_code, int why, unsigned long message, if (!current->ptrace || __fatal_signal_pending(current)) return exit_code; + if (current->jobctl & JOBCTL_TRACED) + trace_printk("JOBCTL_TRACED already set, state=%d\n", current->__state); set_special_state(TASK_TRACED); current->jobctl |= JOBCTL_TRACED; --=-=-= Content-Type: text/plain I'll continue debugging tomorrow, but maybe this helps already. --=-=-=--