Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys Now that the ufs module has been split out from ffs and ...
details: https://anonhg.NetBSD.org/src/rev/6e6018df463c
branches: trunk
changeset: 457430:6e6018df463c
user: pgoyette <pgoyette%NetBSD.org@localhost>
date: Mon Jun 24 13:58:24 2019 +0000
description:
Now that the ufs module has been split out from ffs and ext2fs, we need
to update the boot-loader to push all modules required to support the
booted filesystem. We treat the fsmod string as a slash-separated list
of module names (relative to kern.module.path), rather than as a single
module path name.
Note that ffsv1 and ffsv2 are still exempted from the boot-loader's
auto-push, but the list of required filesystems is still noted in the
source.
Also note that arch/sandpoint needs a similar change. I have not made
this change because I am totally unable to test it.
Tested on my kernel with _no_ built-in file-systems and with the ffs
bootloader settings of fsmod enabled.
diffstat:
sys/arch/i386/stand/lib/exec.c | 46 +++++++++++++++++++++++++++++++++++---
sys/arch/i386/stand/lib/libi386.h | 3 +-
sys/lib/libsa/ext2fs.c | 4 +-
sys/lib/libsa/ffsv1.c | 6 ++++-
sys/lib/libsa/ffsv2.c | 6 ++++-
5 files changed, 56 insertions(+), 9 deletions(-)
diffs (159 lines):
diff -r 3055a4089e36 -r 6e6018df463c sys/arch/i386/stand/lib/exec.c
--- a/sys/arch/i386/stand/lib/exec.c Mon Jun 24 13:57:30 2019 +0000
+++ b/sys/arch/i386/stand/lib/exec.c Mon Jun 24 13:58:24 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: exec.c,v 1.71 2019/06/24 02:48:51 pgoyette Exp $ */
+/* $NetBSD: exec.c,v 1.72 2019/06/24 13:58:24 pgoyette Exp $ */
/*
* Copyright (c) 2008, 2009 The NetBSD Foundation, Inc.
@@ -121,6 +121,8 @@
#define MODULE_WARNING_SEC 5
+#define MAXMODNAME 32 /* from <sys/module.h> */
+
extern struct btinfo_console btinfo_console;
boot_module_t *boot_modules;
@@ -190,6 +192,42 @@
return module_add_common(name, BM_TYPE_FS);
}
+/*
+ * Add a /-separated list of module names to the boot list
+ */
+void
+module_add_split(const char *name, uint8_t type)
+{
+ char mod_name[MAXMODNAME];
+ int i;
+ const char *mp = name;
+ char *ep;
+
+ while (*mp) { /* scan list of module names */
+ i = MAXMODNAME;
+ ep = mod_name;
+ while (--i) { /* scan for end of first name */
+ *ep = *mp;
+ if (*ep == '/') /* NUL-terminate the name */
+ *ep = '\0';
+
+ if (*ep == 0 ) { /* add non-empty name */
+ if (ep != mod_name)
+ module_add_common(mod_name, type);
+ break;
+ }
+ ep++; mp++;
+ }
+ if (*ep != 0) {
+ printf("module name too long\n");
+ return;
+ }
+ if (*mp == '/') { /* skip separator if more */
+ mp++;
+ }
+ }
+}
+
static void
module_add_common(const char *name, uint8_t type)
{
@@ -305,7 +343,7 @@
/* If the root fs type is unusual, load its module. */
if (fsmod != NULL)
- module_add_common(fsmod, BM_TYPE_KMOD);
+ module_add_split(fsmod, BM_TYPE_KMOD);
bi_prekern.kernpa_start = kernpa_start;
bi_prekern.kernpa_end = kernpa_end;
@@ -383,7 +421,7 @@
/* If the root fs type is unusual, load its module. */
if (fsmod != NULL)
- module_add_common(fsmod, BM_TYPE_KMOD);
+ module_add_split(fsmod, BM_TYPE_KMOD);
/*
* Gather some information for the kernel. Do this after the
@@ -572,7 +610,7 @@
/* If the root fs type is unusual, load its module. */
if (fsmod != NULL)
- module_add_common(fsmod, BM_TYPE_KMOD);
+ module_add_split(fsmod, BM_TYPE_KMOD);
for (bm = boot_modules; bm; bm = bm->bm_next) {
fd = module_open(bm, 0, kdev, base_path, false);
diff -r 3055a4089e36 -r 6e6018df463c sys/arch/i386/stand/lib/libi386.h
--- a/sys/arch/i386/stand/lib/libi386.h Mon Jun 24 13:57:30 2019 +0000
+++ b/sys/arch/i386/stand/lib/libi386.h Mon Jun 24 13:58:24 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: libi386.h,v 1.42 2017/03/12 05:33:48 nonaka Exp $ */
+/* $NetBSD: libi386.h,v 1.43 2019/06/24 13:58:24 pgoyette Exp $ */
/*
* Copyright (c) 1996
@@ -145,6 +145,7 @@
void rnd_add(char *);
void fs_add(char *);
void userconf_add(char *);
+void module_add_split(const char *, uint8_t);
struct btinfo_framebuffer;
void framebuffer_configure(struct btinfo_framebuffer *);
diff -r 3055a4089e36 -r 6e6018df463c sys/lib/libsa/ext2fs.c
--- a/sys/lib/libsa/ext2fs.c Mon Jun 24 13:57:30 2019 +0000
+++ b/sys/lib/libsa/ext2fs.c Mon Jun 24 13:58:24 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ext2fs.c,v 1.27 2019/04/05 20:09:29 christos Exp $ */
+/* $NetBSD: ext2fs.c,v 1.28 2019/06/24 13:58:24 pgoyette Exp $ */
/*
* Copyright (c) 1997 Manuel Bouyer.
@@ -692,7 +692,7 @@
if (rc)
ext2fs_close(f);
else
- fsmod = "ext2fs";
+ fsmod = "ufs/ext2fs";
return rc;
}
diff -r 3055a4089e36 -r 6e6018df463c sys/lib/libsa/ffsv1.c
--- a/sys/lib/libsa/ffsv1.c Mon Jun 24 13:57:30 2019 +0000
+++ b/sys/lib/libsa/ffsv1.c Mon Jun 24 13:58:24 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ffsv1.c,v 1.6 2012/05/21 21:34:16 dsl Exp $ */
+/* $NetBSD: ffsv1.c,v 1.7 2019/06/24 13:58:24 pgoyette Exp $ */
#define LIBSA_FFSv1
@@ -15,4 +15,8 @@
#define ufs_dinode ufs1_dinode
#define indp_t int32_t
+#if 0
+#define FSMOD "wapbl/ufs/ffs"
+#endif
+
#include "ufs.c"
diff -r 3055a4089e36 -r 6e6018df463c sys/lib/libsa/ffsv2.c
--- a/sys/lib/libsa/ffsv2.c Mon Jun 24 13:57:30 2019 +0000
+++ b/sys/lib/libsa/ffsv2.c Mon Jun 24 13:58:24 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ffsv2.c,v 1.6 2012/05/21 21:34:16 dsl Exp $ */
+/* $NetBSD: ffsv2.c,v 1.7 2019/06/24 13:58:24 pgoyette Exp $ */
#define LIBSA_FFSv2
@@ -15,4 +15,8 @@
#define ufs_dinode ufs2_dinode
#define indp_t int64_t
+#if 0
+#define FSMOD "wapbl/ufs/ffs"
+#endif
+
#include "ufs.c"
Home |
Main Index |
Thread Index |
Old Index