Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp1642428ybt; Mon, 15 Jun 2020 05:57:45 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwr0s8jQ0O/CosxQp7LOEY4X3Cc5JNeTx7Exh5VMatimAALv+yopnhB5+PdtQ4NZJErP/7e X-Received: by 2002:a17:906:6d3:: with SMTP id v19mr12733100ejb.306.1592225865458; Mon, 15 Jun 2020 05:57:45 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1592225865; cv=none; d=google.com; s=arc-20160816; b=G5UJ3DwXkKu6t+kWiCg52NDb4ZCqyMQ9BRdDGt0OVh663N3VtsVS4O14NCTUVZPw91 8GGk75fppMbqgRsyrxc6Or9ECDuiT/T3t6tErD/DRviKvJh+60RuNWkP1BUZ+uYlvsjS x1j3uHAlobYQur2vX1jLz8+4XgMTTfKfb7Aeqer0unpQEEJTcQwI/F+xRTj4iyiDaF0y mmCVGYopjTHAJF2Jyqp0HyETKW5113GXoSyiD5wmUaHTmQgjp7jaIaU2+vnkdzoI0c7r wQRekseG9KBdBPC42LQTouaLy4S9I4ee1sIYIoup2XlxilqwFNhWjwPyg8+jh6iqoiZp zARg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=LpqL9i2xKT/stdVPfY21iDNhXvNHas6++utf6Lf7se8=; b=QlJHG7tqJW7gf+G+ZfpWgLs8B4qzRKa2yOn3SEmOf3eK9oqlM8X9vjtT8uMRabuvau HoL570V/r4O3E+4dHmHkv2EzfpspIIHrCNjFBxDk2uvXoai4huw8252IidrwPaOCs0TN 3e3DnP4QcIT62OXTefm/SK9+kOwDspXzuune94Go1OCWCi9Lz0npxJvOc8EfTGr6eDwj V8LLHBMTBVMN32VSpg/biyjk3pPdvb4noCbOU/QwHhPST346MjgAua5Y1X1Gkv+oEj9Z pVpiYEJ2/9Dknn0DqjHPu4WmQtyLjJLLhexnnOaZCIZdzVgNM+rvlNRMw0tfmIe0N7FV 8/eQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=QsRTzAVs; 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 cc20si9967454edb.108.2020.06.15.05.57.22; Mon, 15 Jun 2020 05:57:45 -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; dkim=fail header.i=@infradead.org header.s=bombadil.20170209 header.b=QsRTzAVs; 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 S1730138AbgFOMxx (ORCPT + 99 others); Mon, 15 Jun 2020 08:53:53 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51204 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729955AbgFOMxb (ORCPT ); Mon, 15 Jun 2020 08:53:31 -0400 Received: from bombadil.infradead.org (bombadil.infradead.org [IPv6:2607:7c80:54:e::133]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 8AC39C05BD1E; Mon, 15 Jun 2020 05:53:31 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=infradead.org; s=bombadil.20170209; h=Content-Transfer-Encoding: MIME-Version:References:In-Reply-To:Message-Id:Date:Subject:Cc:To:From:Sender :Reply-To:Content-Type:Content-ID:Content-Description; bh=LpqL9i2xKT/stdVPfY21iDNhXvNHas6++utf6Lf7se8=; b=QsRTzAVsNQPikM5ZFHeCWShrm7 fEPo7IdlP917xlxiMGLRVzx1WO6bcqgKsU6z73WXfeiIneXPIXLxPI0BgdML9ghbMF6S1BlK8h230 37zF/5QjwSwIYbRZkI5EcsVrCYmVsG9RBf/FKcUGk5dP0c1R3Lh0jcHQHK1WsrAy4gASB89YkNV7J Jcq/QLKoICY8559NJV0YhH1CKF/dbMeiyMdnwseQ3BtjBoj0/mrqw3Bn/WAYRHmrFwZDPmgzJqY3V QC5Lr6FciDUyi+WJqxTtjOLbWWUD6bR3dK6eY5KmFmoK3DwVPAlTyuEqY9t1eAi3/PTn9U6C1Cg8I 202/zG1A==; Received: from 195-192-102-148.dyn.cablelink.at ([195.192.102.148] helo=localhost) by bombadil.infradead.org with esmtpsa (Exim 4.92.3 #3 (Red Hat Linux)) id 1jkocE-0000m4-J6; Mon, 15 Jun 2020 12:53:30 +0000 From: Christoph Hellwig To: linux-kernel@vger.kernel.org Cc: "H. Peter Anvin" , Song Liu , Al Viro , Linus Torvalds , linux-raid@vger.kernel.org, linux-fsdevel@vger.kernel.org Subject: [PATCH 02/16] md: move the early init autodetect code to drivers/md/ Date: Mon, 15 Jun 2020 14:53:09 +0200 Message-Id: <20200615125323.930983-3-hch@lst.de> X-Mailer: git-send-email 2.26.2 In-Reply-To: <20200615125323.930983-1-hch@lst.de> References: <20200615125323.930983-1-hch@lst.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-SRS-Rewrite: SMTP reverse-path rewritten from by bombadil.infradead.org. See http://www.infradead.org/rpr.html Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Just like the NFS and CIFS root code this better lives with the driver it is tightly integrated with. Signed-off-by: Christoph Hellwig --- drivers/md/Makefile | 3 +++ init/do_mounts_md.c => drivers/md/md-autodetect.c | 15 +++++++++++++-- include/linux/raid/detect.h | 8 ++++++++ init/Makefile | 1 - init/do_mounts.c | 1 + init/do_mounts.h | 10 ---------- 6 files changed, 25 insertions(+), 13 deletions(-) rename init/do_mounts_md.c => drivers/md/md-autodetect.c (96%) diff --git a/drivers/md/Makefile b/drivers/md/Makefile index 31840f95cd408b..6d3e234dc46a5d 100644 --- a/drivers/md/Makefile +++ b/drivers/md/Makefile @@ -43,6 +43,9 @@ obj-$(CONFIG_MD_FAULTY) += faulty.o obj-$(CONFIG_MD_CLUSTER) += md-cluster.o obj-$(CONFIG_BCACHE) += bcache/ obj-$(CONFIG_BLK_DEV_MD) += md-mod.o +ifeq ($(CONFIG_BLK_DEV_MD),y) +obj-y += md-autodetect.o +endif obj-$(CONFIG_BLK_DEV_DM) += dm-mod.o obj-$(CONFIG_BLK_DEV_DM_BUILTIN) += dm-builtin.o obj-$(CONFIG_DM_UNSTRIPED) += dm-unstripe.o diff --git a/init/do_mounts_md.c b/drivers/md/md-autodetect.c similarity index 96% rename from init/do_mounts_md.c rename to drivers/md/md-autodetect.c index 359363e85ccd0b..fe806f7b9759a1 100644 --- a/init/do_mounts_md.c +++ b/drivers/md/md-autodetect.c @@ -1,10 +1,15 @@ // SPDX-License-Identifier: GPL-2.0 +#include +#include +#include +#include +#include +#include #include +#include #include #include -#include "do_mounts.h" - /* * When md (and any require personalities) are compiled into the kernel * (not a module), arrays can be assembles are boot time using with AUTODETECT @@ -114,6 +119,12 @@ static int __init md_setup(char *str) return 1; } +static inline int create_dev(char *name, dev_t dev) +{ + ksys_unlink(name); + return ksys_mknod(name, S_IFBLK|0600, new_encode_dev(dev)); +} + static void __init md_setup_drive(void) { int minor, i, ent, partitioned; diff --git a/include/linux/raid/detect.h b/include/linux/raid/detect.h index 37dd3f40cd316e..1f029a71c3ef05 100644 --- a/include/linux/raid/detect.h +++ b/include/linux/raid/detect.h @@ -1,3 +1,11 @@ /* SPDX-License-Identifier: GPL-2.0 */ void md_autodetect_dev(dev_t dev); + +#ifdef CONFIG_BLK_DEV_MD +void md_run_setup(void); +#else +static inline void md_run_setup(void) +{ +} +#endif diff --git a/init/Makefile b/init/Makefile index 57499b1ff4714d..6bc37f64b3617c 100644 --- a/init/Makefile +++ b/init/Makefile @@ -18,7 +18,6 @@ obj-y += init_task.o mounts-y := do_mounts.o mounts-$(CONFIG_BLK_DEV_RAM) += do_mounts_rd.o mounts-$(CONFIG_BLK_DEV_INITRD) += do_mounts_initrd.o -mounts-$(CONFIG_BLK_DEV_MD) += do_mounts_md.o # dependencies on generated files need to be listed explicitly $(obj)/version.o: include/generated/compile.h diff --git a/init/do_mounts.c b/init/do_mounts.c index 29d326b6c29d2d..1a4dfa17fb2899 100644 --- a/init/do_mounts.c +++ b/init/do_mounts.c @@ -23,6 +23,7 @@ #include #include #include +#include #include #include "do_mounts.h" diff --git a/init/do_mounts.h b/init/do_mounts.h index 7513d1c14d13fe..50d6c8941e15a1 100644 --- a/init/do_mounts.h +++ b/init/do_mounts.h @@ -41,13 +41,3 @@ bool __init initrd_load(void); static inline bool initrd_load(void) { return false; } #endif - -#ifdef CONFIG_BLK_DEV_MD - -void md_run_setup(void); - -#else - -static inline void md_run_setup(void) {} - -#endif -- 2.26.2