Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/i386/stand/efiboot efiboot: don't call WaitForSingl...



details:   https://anonhg.NetBSD.org/src/rev/2d76366b8dd6
branches:  trunk
changeset: 351374:2d76366b8dd6
user:      nonaka <nonaka%NetBSD.org@localhost>
date:      Sat Feb 11 10:15:55 2017 +0000

description:
efiboot: don't call WaitForSingleEvent after ExitBootServices is called.

diffstat:

 sys/arch/i386/stand/efiboot/efiboot.c |  4 +++-
 sys/arch/i386/stand/efiboot/efiboot.h |  3 ++-
 sys/arch/i386/stand/efiboot/panic.c   |  5 +++--
 3 files changed, 8 insertions(+), 4 deletions(-)

diffs (61 lines):

diff -r 22a6f6c26ec8 -r 2d76366b8dd6 sys/arch/i386/stand/efiboot/efiboot.c
--- a/sys/arch/i386/stand/efiboot/efiboot.c     Sat Feb 11 10:13:46 2017 +0000
+++ b/sys/arch/i386/stand/efiboot/efiboot.c     Sat Feb 11 10:15:55 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: efiboot.c,v 1.2 2017/02/11 10:13:46 nonaka Exp $       */
+/*     $NetBSD: efiboot.c,v 1.3 2017/02/11 10:15:55 nonaka Exp $       */
 
 /*-
  * Copyright (c) 2016 Kimihiro Nonaka <nonaka%netbsd.org@localhost>
@@ -35,6 +35,7 @@
 EFI_DEVICE_PATH *efi_bootdp;
 EFI_LOADED_IMAGE *efi_li;
 uintptr_t efi_main_sp;
+bool efi_cleanuped;
 
 static EFI_PHYSICAL_ADDRESS heap_start = EFI_ALLOCATE_MAX_ADDRESS;
 static UINTN heap_size = 1 * 1024 * 1024;                      /* 1MB */
@@ -121,6 +122,7 @@
                if (EFI_ERROR(status))
                        Panic(L"ExitBootServices failed");
        }
+       efi_cleanuped = true;
 
        allocsz = sizeof(struct btinfo_efimemmap) - 1
            + NoEntries * DescriptorSize;
diff -r 22a6f6c26ec8 -r 2d76366b8dd6 sys/arch/i386/stand/efiboot/efiboot.h
--- a/sys/arch/i386/stand/efiboot/efiboot.h     Sat Feb 11 10:13:46 2017 +0000
+++ b/sys/arch/i386/stand/efiboot/efiboot.h     Sat Feb 11 10:15:55 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: efiboot.h,v 1.2 2017/02/11 10:13:46 nonaka Exp $       */
+/*     $NetBSD: efiboot.h,v 1.3 2017/02/11 10:15:55 nonaka Exp $       */
 
 /*-
  * Copyright (c) 2016 Kimihiro Nonaka <nonaka%netbsd.org@localhost>
@@ -48,6 +48,7 @@
 extern EFI_DEVICE_PATH *efi_bootdp;
 extern EFI_LOADED_IMAGE *efi_li;
 extern uintptr_t efi_main_sp;
+extern bool efi_cleanuped;
 void efi_cleanup(void);
 
 /* eficons.c */
diff -r 22a6f6c26ec8 -r 2d76366b8dd6 sys/arch/i386/stand/efiboot/panic.c
--- a/sys/arch/i386/stand/efiboot/panic.c       Sat Feb 11 10:13:46 2017 +0000
+++ b/sys/arch/i386/stand/efiboot/panic.c       Sat Feb 11 10:15:55 2017 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: panic.c,v 1.3 2017/02/05 10:13:43 joerg Exp $  */
+/*     $NetBSD: panic.c,v 1.4 2017/02/11 10:15:55 nonaka Exp $ */
 
 /*-
  * Copyright (c) 2016 Kimihiro Nonaka <nonaka%netbsd.org@localhost>
@@ -54,7 +54,8 @@
 reboot(void)
 {
 
-       WaitForSingleEvent(ST->ConIn->WaitForKey, 0);
+       if (!efi_cleanuped)
+               WaitForSingleEvent(ST->ConIn->WaitForKey, 0);
 
        uefi_call_wrapper(RT->ResetSystem, 4, EfiResetCold, EFI_SUCCESS,
            0, NULL);



Home | Main Index | Thread Index | Old Index