Received: by 2002:a6b:500f:0:0:0:0:0 with SMTP id e15csp6457432iob; Tue, 10 May 2022 20:11:55 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzVfnUWoWZ5FCNRaD5bXDWXe3VSXUIkzLViCxHG7Y1LKLxblNLUln/xvIxvOnhB4J9dJlF5 X-Received: by 2002:a17:903:3009:b0:15c:f92b:7fba with SMTP id o9-20020a170903300900b0015cf92b7fbamr23009191pla.82.1652238715686; Tue, 10 May 2022 20:11:55 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1652238715; cv=none; d=google.com; s=arc-20160816; b=rsIzKqUad9MNK2zCZDz3WtaBAHRfXBbDLQzYtznk3j9WIqGV7iGz5hiIW2T09hCfvS z6RzpBUF9IZgkYzerJtcYUyc3zXLnWneSqG48YwEfagvUoqkRGZPczC9o1DZjSVjAiy0 fED+hXs9cWNtgc/Jl5dmZogLVSjqS2VLdzagF9ZaPaFRQgE+T+bPDWzHu5ThoXRpc1Y8 c3XwszKytEaMbzle6KDbMK5aMgWl0mZNMNHyV8rB9EpM6DESOk6Atpdxjt/KjVBd1fFq sAzSXLuMKUYN7d8BwaCSFp/UOaBw4flf9QmGQpSSSTcBp7nKp2tpFVocwmEpa2GR/6aT T9Ag== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:mime-version:message-id:date:references :in-reply-to:subject:cc:to:dkim-signature:dkim-signature:from; bh=w3ElTKcPgRcfhSXCODsdQ9SYsvPTENqPkhqSJjkaUnk=; b=N8rLsmgMFOleXmLYKRDP0cnOtu0eHx/oFamLw45DSfgdQM1jqZtFFTCQpR1hSYftTW f1gwlPC1pgDIF+RRrKT9m509ynzE3KHDmT3DZiwHXAiBwdiIzEnrt1g/b+F6gcLwOW0T nvI57F1fLr5cXOFRBomA6jWHYSfdbKkWDI6GJ+NP2FMZtIBvRN/Qh31elApzTIRHi9pX i80mLU4QZQfX3qzzmgh9ifT8nSxop57EoC7wasWZa1EQyfyGw/p885yNlbrblnGV4RhH clOzVN3W8AR96ef3Jufz+pS3VPk697ogI//nn2p93mjM/dpVDWTs8MC+72hT8MtELjRJ DVLA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linutronix.de header.s=2020 header.b=2FSm4oOq; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e; 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=QUARANTINE dis=NONE) header.from=linutronix.de Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id c20-20020a6566d4000000b003816043f0e2si1535510pgw.727.2022.05.10.20.11.39; Tue, 10 May 2022 20:11:55 -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=@linutronix.de header.s=2020 header.b=2FSm4oOq; dkim=neutral (no key) header.i=@linutronix.de header.s=2020e; 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=QUARANTINE dis=NONE) header.from=linutronix.de Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1345608AbiEJPJN (ORCPT + 99 others); Tue, 10 May 2022 11:09:13 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:39822 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1345615AbiEJPIv (ORCPT ); Tue, 10 May 2022 11:08:51 -0400 Received: from galois.linutronix.de (Galois.linutronix.de [IPv6:2a0a:51c0:0:12e:550::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 307132E6A9; Tue, 10 May 2022 07:38:29 -0700 (PDT) From: Thomas Gleixner DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020; t=1652193507; 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: in-reply-to:in-reply-to:references:references; bh=w3ElTKcPgRcfhSXCODsdQ9SYsvPTENqPkhqSJjkaUnk=; b=2FSm4oOqMOc7u7DOArxh7vypRuFLzQJ4f5e7uumNWZk1I+wP6rN1Z+BamxxgNm/HkkJ8dS jbuzVvdMTYuHKMYIdn3pJkzvOHvrtKjxkW5KQCOiLLd87+XgT1YCNZ7cZ3D75oQSIjPAbJ 3MI6F+cGiQbGDDLe0QmgNkbGSBVbUVM5Is/ozOGVwpE47NGGUx6NXo3tJweiXw1f2yIHV9 f3oKOyk0z/V2PomejDHplZTRKP9rSVl69cpaHnnuluzzxUokX3JCs5rygHZql3fiIvNDkg QQKtbUKUOoW1hWOjc4Wij3nCbiFffRmPCss0ja1b96xfU7R1+MpTAUbvCEhisA== DKIM-Signature: v=1; a=ed25519-sha256; c=relaxed/relaxed; d=linutronix.de; s=2020e; t=1652193507; 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: in-reply-to:in-reply-to:references:references; bh=w3ElTKcPgRcfhSXCODsdQ9SYsvPTENqPkhqSJjkaUnk=; b=uPf15/pRgDbttbexXqULpEddKepYTDu4nFjxb45VjXxHv5/WFbZRbyE2QG0KSbWW24RYCN +ZKev2VYi08SYNDg== To: "Eric W. Biederman" , linux-arch@vger.kernel.org Cc: Tejun Heo , Peter Zijlstra , Vincent Guittot , Al Viro , Jens Axboe , Linus Torvalds , linux-kernel@vger.kernel.org, "Eric W. Biederman" , stable@vger.kernel.org, =?utf-8?B?0JzQsNC60YHQuNC8INCa0YPRgtGP0LLQuNC9?= Subject: Re: [PATCH 1/7] kthread: Don't allocate kthread_struct for init and umh In-Reply-To: <20220506141512.516114-1-ebiederm@xmission.com> References: <87mtfu4up3.fsf@email.froward.int.ebiederm.org> <20220506141512.516114-1-ebiederm@xmission.com> Date: Tue, 10 May 2022 16:38:27 +0200 Message-ID: <87fslhpi58.ffs@tglx> MIME-Version: 1.0 Content-Type: text/plain 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_PASS,T_SCC_BODY_TEXT_LINE,URIBL_BLOCKED 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 Fri, May 06 2022 at 09:15, Eric W. Biederman wrote: > * the init task will end up wanting to create kthreads, which, if > * we schedule it before we create kthreadd, will OOPS. > */ > - pid = kernel_thread(kernel_init, NULL, CLONE_FS); > + pid = user_mode_thread(kernel_init, NULL, CLONE_FS); So init does not have PF_KTHREAD set anymore, which causes this to go sideways with a NULL pointer dereference in get_mm_counter() on next: get_mm_counter include/linux/mm.h:1996 [inline] get_mm_rss include/linux/mm.h:2049 [inline] task_nr_scan_windows.isra.0+0x23/0x120 kernel/sched/fair.c:1123 task_scan_min kernel/sched/fair.c:1144 [inline] task_scan_start+0x6c/0x400 kernel/sched/fair.c:1150 task_tick_numa kernel/sched/fair.c:2944 [inline] task_tick_fair+0xaeb/0xef0 kernel/sched/fair.c:11186 scheduler_tick+0x20a/0x5e0 kernel/sched/core.c:5380 https://lore.kernel.org/lkml/0000000000008a9fbb05dea76400@google.com because the fence in task_tick_numa(): if ((curr->flags & (PF_EXITING | PF_KTHREAD)) || work->next != work) return; is not longer sufficient. It needs also to bail if !curr->mm. I'm worried that there are more of these issues lurking. Haven't looked yet. Thanks, tglx