Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/stand/efiboot Generalize boot.cfg workaround for ISO9660...
details: https://anonhg.NetBSD.org/src/rev/a747ce1a580e
branches: trunk
changeset: 983639:a747ce1a580e
user: rin <rin%NetBSD.org@localhost>
date: Mon May 31 11:12:42 2021 +0000
description:
Generalize boot.cfg workaround for ISO9660; fallback to default_device
whenever efi_file_path() fails (due to broken firmware), in addition to
the case of ISO9660 (for which efi_file_path() succeeds but does not
work correctly).
diffstat:
sys/stand/efiboot/boot.c | 22 +++++++++-------------
1 files changed, 9 insertions(+), 13 deletions(-)
diffs (40 lines):
diff -r ba8ca7112281 -r a747ce1a580e sys/stand/efiboot/boot.c
--- a/sys/stand/efiboot/boot.c Mon May 31 10:57:02 2021 +0000
+++ b/sys/stand/efiboot/boot.c Mon May 31 11:12:42 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: boot.c,v 1.29 2020/11/28 14:02:09 jmcneill Exp $ */
+/* $NetBSD: boot.c,v 1.30 2021/05/31 11:12:42 rin Exp $ */
/*-
* Copyright (c) 2016 Kimihiro Nonaka <nonaka%netbsd.org@localhost>
@@ -132,22 +132,18 @@
static int
bootcfg_path(char *pathbuf, size_t pathbuflen)
{
- /*
- * Special handling of boot.cfg on ISO9660 because fs protocol doesn't
- * seem to work.
- */
- if (default_fstype == FS_ISO9660) {
- snprintf(pathbuf, pathbuflen, "%s:%s", default_device, BOOTCFG_FILENAME);
- return 0;
- }
/*
- * Fall back to fs protocol for loading boot.cfg
+ * Fallback to default_device
+ * - for ISO9660 (efi_file_path() succeeds but does not work correctly)
+ * - or whenever efi_file_path() fails (due to broken firmware)
*/
- if (efi_bootdp == NULL)
- return ENXIO;
+ if (default_fstype == FS_ISO9660 || efi_bootdp == NULL ||
+ efi_file_path(efi_bootdp, BOOTCFG_FILENAME, pathbuf, pathbuflen))
+ snprintf(pathbuf, pathbuflen, "%s:%s", default_device,
+ BOOTCFG_FILENAME);
- return efi_file_path(efi_bootdp, BOOTCFG_FILENAME, pathbuf, pathbuflen);
+ return 0;
}
void
Home |
Main Index |
Thread Index |
Old Index