Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/stand/efiboot Load boot.cfg from the EFI system partitio...
details: https://anonhg.NetBSD.org/src/rev/ece51ec1e79f
branches: trunk
changeset: 1011381:ece51ec1e79f
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Sat Jun 27 17:23:08 2020 +0000
description:
Load boot.cfg from the EFI system partition instead of the first FFS
partition on that device.
diffstat:
sys/stand/efiboot/boot.c | 10 +++++++---
sys/stand/efiboot/efifile.c | 21 ++++++++++++++++++++-
sys/stand/efiboot/efifile.h | 4 +++-
3 files changed, 30 insertions(+), 5 deletions(-)
diffs (89 lines):
diff -r 80f4613b7104 -r ece51ec1e79f sys/stand/efiboot/boot.c
--- a/sys/stand/efiboot/boot.c Sat Jun 27 17:22:12 2020 +0000
+++ b/sys/stand/efiboot/boot.c Sat Jun 27 17:23:08 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: boot.c,v 1.24 2020/06/26 03:23:04 thorpej Exp $ */
+/* $NetBSD: boot.c,v 1.25 2020/06/27 17:23:08 jmcneill Exp $ */
/*-
* Copyright (c) 2016 Kimihiro Nonaka <nonaka%netbsd.org@localhost>
@@ -29,6 +29,7 @@
#include "efiboot.h"
#include "efiblock.h"
+#include "efifile.h"
#include "efifdt.h"
#include "efiacpi.h"
#include "efienv.h"
@@ -539,11 +540,15 @@
void
boot(void)
{
+ char pathbuf[80];
int currname, c;
read_env();
- parsebootconf(BOOTCFG_FILENAME);
+ if (efi_bootdp != NULL && efi_file_path(efi_bootdp, BOOTCFG_FILENAME, pathbuf, sizeof(pathbuf)) == 0) {
+ twiddle_toggle = 1;
+ parsebootconf(pathbuf);
+ }
if (bootcfg_info.clear)
uefi_call_wrapper(ST->ConOut->ClearScreen, 1, ST->ConOut);
@@ -551,7 +556,6 @@
print_banner();
/* Display menu if configured */
- twiddle_toggle = 1;
if (bootcfg_info.nummenu > 0) {
doboottypemenu(); /* No return */
}
diff -r 80f4613b7104 -r ece51ec1e79f sys/stand/efiboot/efifile.c
--- a/sys/stand/efiboot/efifile.c Sat Jun 27 17:22:12 2020 +0000
+++ b/sys/stand/efiboot/efifile.c Sat Jun 27 17:23:08 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: efifile.c,v 1.3 2018/08/26 21:28:18 jmcneill Exp $ */
+/* $NetBSD: efifile.c,v 1.4 2020/06/27 17:23:08 jmcneill Exp $ */
/*-
* Copyright (c) 2018 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -146,3 +146,22 @@
return 0;
}
+
+int
+efi_file_path(EFI_DEVICE_PATH *dp, const char *fname, char *buf, size_t buflen)
+{
+ UINTN vol;
+ int depth;
+
+ depth = efi_device_path_depth(dp, END_DEVICE_PATH_TYPE);
+
+ for (vol = 0; vol < efi_nvol; vol++) {
+ if (efi_device_path_ncmp(dp, DevicePathFromHandle(efi_vol[vol]), depth) == 0)
+ break;
+ }
+ if (vol == efi_nvol)
+ return ENOENT;
+
+ snprintf(buf, buflen, "fs%u:%s", (u_int)vol, fname);
+ return 0;
+}
diff -r 80f4613b7104 -r ece51ec1e79f sys/stand/efiboot/efifile.h
--- a/sys/stand/efiboot/efifile.h Sat Jun 27 17:22:12 2020 +0000
+++ b/sys/stand/efiboot/efifile.h Sat Jun 27 17:23:08 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: efifile.h,v 1.1 2018/08/24 02:01:06 jmcneill Exp $ */
+/* $NetBSD: efifile.h,v 1.2 2020/06/27 17:23:08 jmcneill Exp $ */
/*-
* Copyright (c) 2018 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -31,3 +31,5 @@
int efi_file_open(struct open_file *, ...);
int efi_file_close(struct open_file *);
int efi_file_strategy(void *, int, daddr_t, size_t, void *, size_t *);
+int efi_file_path(EFI_DEVICE_PATH *, const char *, char *, size_t);
+
Home |
Main Index |
Thread Index |
Old Index