Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/stand/efiboot Add module support.
details: https://anonhg.NetBSD.org/src/rev/4ee40d6cfb99
branches: trunk
changeset: 1011169:4ee40d6cfb99
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Sun Jun 21 17:24:26 2020 +0000
description:
Add module support.
diffstat:
sys/stand/efiboot/Makefile.efiboot | 8 +-
sys/stand/efiboot/boot.c | 50 +++++++++++-
sys/stand/efiboot/bootaa64/Makefile | 3 +-
sys/stand/efiboot/bootarm/Makefile | 3 +-
sys/stand/efiboot/efifdt.c | 17 +++-
sys/stand/efiboot/efifdt.h | 3 +-
sys/stand/efiboot/exec.c | 31 +++++++-
sys/stand/efiboot/module.c | 153 ++++++++++++++++++++++++++++++++++++
sys/stand/efiboot/module.h | 37 ++++++++
sys/stand/efiboot/version | 3 +-
10 files changed, 298 insertions(+), 10 deletions(-)
diffs (truncated from 457 to 300 lines):
diff -r 9d329c0fcd94 -r 4ee40d6cfb99 sys/stand/efiboot/Makefile.efiboot
--- a/sys/stand/efiboot/Makefile.efiboot Sun Jun 21 17:17:01 2020 +0000
+++ b/sys/stand/efiboot/Makefile.efiboot Sun Jun 21 17:24:26 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile.efiboot,v 1.13 2020/05/14 19:19:08 riastradh Exp $
+# $NetBSD: Makefile.efiboot,v 1.14 2020/06/21 17:24:26 jmcneill Exp $
S= ${.CURDIR}/../../..
@@ -21,8 +21,10 @@
.PATH: ${EFIDIR}/gnuefi
SOURCES= crt0-efi-${GNUEFIARCH}.S reloc_${GNUEFIARCH}.c
-SOURCES+= boot.c conf.c console.c dev_net.c devopen.c exec.c panic.c prompt.c
-SOURCES+= efiboot.c efichar.c efidev.c efienv.c efigetsecs.c efifdt.c efifile.c efiblock.c efinet.c efipxe.c efiacpi.c efirng.c smbios.c
+SOURCES+= boot.c conf.c console.c dev_net.c devopen.c exec.c module.c \
+ panic.c prompt.c
+SOURCES+= efiboot.c efichar.c efidev.c efienv.c efigetsecs.c efifdt.c \
+ efifile.c efiblock.c efinet.c efipxe.c efiacpi.c efirng.c smbios.c
.PATH: ${S}/external/bsd/libfdt/dist
CPPFLAGS+= -I${S}/external/bsd/libfdt/dist
diff -r 9d329c0fcd94 -r 4ee40d6cfb99 sys/stand/efiboot/boot.c
--- a/sys/stand/efiboot/boot.c Sun Jun 21 17:17:01 2020 +0000
+++ b/sys/stand/efiboot/boot.c Sun Jun 21 17:24:26 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: boot.c,v 1.21 2020/05/14 19:19:08 riastradh Exp $ */
+/* $NetBSD: boot.c,v 1.22 2020/06/21 17:24:26 jmcneill Exp $ */
/*-
* Copyright (c) 2016 Kimihiro Nonaka <nonaka%netbsd.org@localhost>
@@ -33,6 +33,7 @@
#include "efiacpi.h"
#include "efienv.h"
#include "efirng.h"
+#include "module.h"
#include <sys/bootblock.h>
#include <sys/boot_flag.h>
@@ -90,6 +91,9 @@
void command_plist(char *);
void command_initrd(char *);
void command_rndseed(char *);
+void command_modules(char *);
+void command_load(char *);
+void command_unload(char *);
void command_ls(char *);
void command_mem(char *);
void command_printenv(char *);
@@ -107,6 +111,9 @@
{ "plist", command_plist, "plist [dev:][filename]" },
{ "initrd", command_initrd, "initrd [dev:][filename]" },
{ "rndseed", command_rndseed, "rndseed [dev:][filename]" },
+ { "modules", command_modules, "modules [{on|off|reset}]" },
+ { "load", command_load, "load <module_name>" },
+ { "unload", command_unload, "unload <module_name>" },
{ "ls", command_ls, "ls [hdNn:/path]" },
{ "mem", command_mem, "mem" },
{ "printenv", command_printenv, "printenv [key]" },
@@ -193,6 +200,47 @@
}
void
+command_modules(char *arg)
+{
+ if (arg && *arg) {
+ if (strcmp(arg, "on") == 0)
+ module_enable(1);
+ else if (strcmp(arg, "off") == 0)
+ module_enable(0);
+ else if (strcmp(arg, "reset") == 0)
+ module_remove_all();
+ else {
+ command_help("");
+ return;
+ }
+ } else {
+ printf("modules are %sabled\n", module_enabled ? "en" : "dis");
+ }
+}
+
+void
+command_load(char *arg)
+{
+ if (!arg || !*arg) {
+ command_help("");
+ return;
+ }
+
+ module_add(arg);
+}
+
+void
+command_unload(char *arg)
+{
+ if (!arg || !*arg) {
+ command_help("");
+ return;
+ }
+
+ module_remove(arg);
+}
+
+void
command_ls(char *arg)
{
ls(arg);
diff -r 9d329c0fcd94 -r 4ee40d6cfb99 sys/stand/efiboot/bootaa64/Makefile
--- a/sys/stand/efiboot/bootaa64/Makefile Sun Jun 21 17:17:01 2020 +0000
+++ b/sys/stand/efiboot/bootaa64/Makefile Sun Jun 21 17:24:26 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile,v 1.7 2020/01/25 11:24:20 jmcneill Exp $
+# $NetBSD: Makefile,v 1.8 2020/06/21 17:24:26 jmcneill Exp $
PROG= bootaa64.efi
OBJFMT= binary
@@ -12,6 +12,7 @@
CFLAGS+= -DEFIBOOT_RUNTIME_ADDRESS=0xffff800000000000L
CFLAGS+= -DEFIBOOT_RUNTIME_SIZE=0x40000000UL
CFLAGS+= -DEFIBOOT_ACPI
+CFLAGS+= -DEFIBOOT_MODULE_MACHINE=\"evbarm\"
.include "${.CURDIR}/../Makefile.efiboot"
diff -r 9d329c0fcd94 -r 4ee40d6cfb99 sys/stand/efiboot/bootarm/Makefile
--- a/sys/stand/efiboot/bootarm/Makefile Sun Jun 21 17:17:01 2020 +0000
+++ b/sys/stand/efiboot/bootarm/Makefile Sun Jun 21 17:24:26 2020 +0000
@@ -1,4 +1,4 @@
-# $NetBSD: Makefile,v 1.4 2020/01/25 11:24:20 jmcneill Exp $
+# $NetBSD: Makefile,v 1.5 2020/06/21 17:24:26 jmcneill Exp $
PROG= bootarm.efi
OBJFMT= binary
@@ -11,6 +11,7 @@
COPTS+= -mfloat-abi=soft -mno-unaligned-access -ffreestanding -fno-unwind-tables
CFLAGS+= -DEFIBOOT_ALIGN=0x1000000
+CFLAGS+= -DEFIBOOT_MODULE_MACHINE=\"evbarm\"
LDFLAGS+= -N
.include "${.CURDIR}/../Makefile.efiboot"
diff -r 9d329c0fcd94 -r 4ee40d6cfb99 sys/stand/efiboot/efifdt.c
--- a/sys/stand/efiboot/efifdt.c Sun Jun 21 17:17:01 2020 +0000
+++ b/sys/stand/efiboot/efifdt.c Sun Jun 21 17:24:26 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: efifdt.c,v 1.23 2020/05/14 19:21:53 riastradh Exp $ */
+/* $NetBSD: efifdt.c,v 1.24 2020/06/21 17:24:26 jmcneill Exp $ */
/*-
* Copyright (c) 2019 Jason R. Thorpe
@@ -425,3 +425,18 @@
fdt_setprop_u64(fdt_data, chosen, "netbsd,efirng-end",
efirng_addr + efirng_size);
}
+
+/* pass in module information */
+void
+efi_fdt_module(const char *module_name, u_long module_addr, u_long module_size)
+{
+ int chosen;
+
+ if (module_size == 0)
+ return;
+
+ chosen = efi_fdt_chosen();
+ fdt_appendprop_string(fdt_data, chosen, "netbsd,module-names", module_name);
+ fdt_appendprop_u64(fdt_data, chosen, "netbsd,modules", module_addr);
+ fdt_appendprop_u64(fdt_data, chosen, "netbsd,modules", module_size);
+}
diff -r 9d329c0fcd94 -r 4ee40d6cfb99 sys/stand/efiboot/efifdt.h
--- a/sys/stand/efiboot/efifdt.h Sun Jun 21 17:17:01 2020 +0000
+++ b/sys/stand/efiboot/efifdt.h Sun Jun 21 17:24:26 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: efifdt.h,v 1.8 2020/05/14 19:20:08 riastradh Exp $ */
+/* $NetBSD: efifdt.h,v 1.9 2020/06/21 17:24:26 jmcneill Exp $ */
/*-
* Copyright (c) 2018 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -39,5 +39,6 @@
void efi_fdt_initrd(u_long, u_long);
void efi_fdt_rndseed(u_long, u_long);
void efi_fdt_efirng(u_long, u_long);
+void efi_fdt_module(const char *, u_long, u_long);
void efi_fdt_init(u_long, u_long);
void efi_fdt_fini(void);
diff -r 9d329c0fcd94 -r 4ee40d6cfb99 sys/stand/efiboot/exec.c
--- a/sys/stand/efiboot/exec.c Sun Jun 21 17:17:01 2020 +0000
+++ b/sys/stand/efiboot/exec.c Sun Jun 21 17:24:26 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: exec.c,v 1.15 2020/05/23 16:40:41 thorpej Exp $ */
+/* $NetBSD: exec.c,v 1.16 2020/06/21 17:24:26 jmcneill Exp $ */
/*-
* Copyright (c) 2019 Jason R. Thorpe
@@ -32,7 +32,9 @@
#include "efifdt.h"
#include "efiacpi.h"
#include "efirng.h"
+#include "module.h"
+#include <sys/param.h>
#include <sys/reboot.h>
extern char twiddle_toggle;
@@ -276,6 +278,32 @@
}
static void
+load_module(const char *module_name)
+{
+ EFI_PHYSICAL_ADDRESS addr;
+ u_long size;
+ char path[PATH_MAX];
+
+ snprintf(path, sizeof(path), "%s/%s/%s.kmod", module_prefix,
+ module_name, module_name);
+
+ if (load_file(path, 0, false, &addr, &size) != 0 || addr == 0 || size == 0)
+ return;
+
+ efi_fdt_module(module_name, (u_long)addr, size);
+}
+
+static void
+load_modules(const char *kernel_name)
+{
+ if (!module_enabled)
+ return;
+
+ module_init(kernel_name);
+ module_foreach(load_module);
+}
+
+static void
generate_efirng(void)
{
EFI_PHYSICAL_ADDRESS addr;
@@ -387,6 +415,7 @@
&rndseed_addr, &rndseed_size);
efi_fdt_init((marks[MARK_END] + FDT_ALIGN) & ~FDT_ALIGN, FDT_ALIGN + 1);
+ load_modules(fname);
load_fdt_overlays();
efi_fdt_initrd(initrd_addr, initrd_size);
efi_fdt_rndseed(rndseed_addr, rndseed_size);
diff -r 9d329c0fcd94 -r 4ee40d6cfb99 sys/stand/efiboot/module.c
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/sys/stand/efiboot/module.c Sun Jun 21 17:24:26 2020 +0000
@@ -0,0 +1,153 @@
+/* $NetBSD: module.c,v 1.1 2020/06/21 17:24:26 jmcneill Exp $ */
+
+/*-
+ * Copyright (c) 2020 The NetBSD Foundation, Inc.
+ * All rights reserved.
+ *
+ * This code is derived from software contributed to The NetBSD Foundation
+ * by Jared McNeill <jmcneill%invisible.ca@localhost>.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
+ * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
+ * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ * POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include "efiboot.h"
+#include "module.h"
+
+#include <sys/queue.h>
+
+int module_enabled = 1;
+char module_prefix[128];
+
+struct boot_module {
+ char *module_name;
+ TAILQ_ENTRY(boot_module) entries;
+};
+TAILQ_HEAD(, boot_module) boot_modules = TAILQ_HEAD_INITIALIZER(boot_modules);
+
+static const char *
+module_machine(void)
+{
+ return EFIBOOT_MODULE_MACHINE;
+}
+
Home |
Main Index |
Thread Index |
Old Index