mirror of
https://github.com/acidanthera/audk.git
synced 2025-07-27 07:34:06 +02:00
Fix some corner case for LazyConIn feature
Signed-off-by: chao zhang <chao.b.zhang@intel.com> Reviewed-by : Ni Ruiyu <ruiyu.ni@intel.com> git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@13814 6f19259b-4bc3-4df7-8a09-765794883524
This commit is contained in:
parent
c843ef6796
commit
5676ccca07
@ -1,7 +1,7 @@
|
|||||||
/** @file
|
/** @file
|
||||||
Head file for BDS Architectural Protocol implementation
|
Head file for BDS Architectural Protocol implementation
|
||||||
|
|
||||||
Copyright (c) 2004 - 2011, Intel Corporation. All rights reserved.<BR>
|
Copyright (c) 2004 - 2012, Intel Corporation. All rights reserved.<BR>
|
||||||
This program and the accompanying materials
|
This program and the accompanying materials
|
||||||
are licensed and made available under the terms and conditions of the BSD License
|
are licensed and made available under the terms and conditions of the BSD License
|
||||||
which accompanies this distribution. The full text of the license may be found at
|
which accompanies this distribution. The full text of the license may be found at
|
||||||
@ -34,6 +34,7 @@ WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.
|
|||||||
#include <Guid/StatusCodeDataTypeId.h>
|
#include <Guid/StatusCodeDataTypeId.h>
|
||||||
#include <Guid/LegacyDevOrder.h>
|
#include <Guid/LegacyDevOrder.h>
|
||||||
#include <Guid/BdsHii.h>
|
#include <Guid/BdsHii.h>
|
||||||
|
#include <Guid/ConnectConInEvent.h>
|
||||||
#include <Protocol/GenericMemoryTest.h>
|
#include <Protocol/GenericMemoryTest.h>
|
||||||
#include <Protocol/FormBrowser2.h>
|
#include <Protocol/FormBrowser2.h>
|
||||||
#include <Protocol/HiiConfigAccess.h>
|
#include <Protocol/HiiConfigAccess.h>
|
||||||
|
@ -141,6 +141,7 @@
|
|||||||
gBootManagerFormSetGuid ## SOMETIMES_PRODUCES ## BootManager HII Package
|
gBootManagerFormSetGuid ## SOMETIMES_PRODUCES ## BootManager HII Package
|
||||||
gDeviceManagerFormSetGuid ## SOMETIMES_PRODUCES ## DeviceManager HII Package
|
gDeviceManagerFormSetGuid ## SOMETIMES_PRODUCES ## DeviceManager HII Package
|
||||||
gDriverHealthFormSetGuid ## SOMETIMES_PRODUCES ## DriverHealth HII Package
|
gDriverHealthFormSetGuid ## SOMETIMES_PRODUCES ## DriverHealth HII Package
|
||||||
|
gConnectConInEventGuid ## CONSUMES ## GUID (Connect ConIn Event)
|
||||||
|
|
||||||
[Protocols]
|
[Protocols]
|
||||||
gEfiSimpleFileSystemProtocolGuid ## PROTOCOL CONSUMES
|
gEfiSimpleFileSystemProtocolGuid ## PROTOCOL CONSUMES
|
||||||
|
@ -72,6 +72,24 @@ BdsInitialize (
|
|||||||
return Status;
|
return Status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
An empty function to pass error checking of CreateEventEx ().
|
||||||
|
|
||||||
|
@param Event Event whose notification function is being invoked.
|
||||||
|
@param Context Pointer to the notification function's context,
|
||||||
|
which is implementation-dependent.
|
||||||
|
|
||||||
|
**/
|
||||||
|
VOID
|
||||||
|
EFIAPI
|
||||||
|
BdsEmptyCallbackFunction (
|
||||||
|
IN EFI_EVENT Event,
|
||||||
|
IN VOID *Context
|
||||||
|
)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
||||||
This function attempts to boot for the boot order specified
|
This function attempts to boot for the boot order specified
|
||||||
@ -93,12 +111,14 @@ BdsBootDeviceSelect (
|
|||||||
CHAR16 Buffer[20];
|
CHAR16 Buffer[20];
|
||||||
BOOLEAN BootNextExist;
|
BOOLEAN BootNextExist;
|
||||||
LIST_ENTRY *LinkBootNext;
|
LIST_ENTRY *LinkBootNext;
|
||||||
|
EFI_EVENT ConnectConInEvent;
|
||||||
|
|
||||||
//
|
//
|
||||||
// Got the latest boot option
|
// Got the latest boot option
|
||||||
//
|
//
|
||||||
BootNextExist = FALSE;
|
BootNextExist = FALSE;
|
||||||
LinkBootNext = NULL;
|
LinkBootNext = NULL;
|
||||||
|
ConnectConInEvent = NULL;
|
||||||
InitializeListHead (&BootLists);
|
InitializeListHead (&BootLists);
|
||||||
|
|
||||||
//
|
//
|
||||||
@ -106,6 +126,23 @@ BdsBootDeviceSelect (
|
|||||||
//
|
//
|
||||||
ZeroMem (Buffer, sizeof (Buffer));
|
ZeroMem (Buffer, sizeof (Buffer));
|
||||||
|
|
||||||
|
//
|
||||||
|
// Create Event to signal ConIn connection request
|
||||||
|
//
|
||||||
|
if (PcdGetBool (PcdConInConnectOnDemand)) {
|
||||||
|
Status = gBS->CreateEventEx (
|
||||||
|
EVT_NOTIFY_SIGNAL,
|
||||||
|
TPL_CALLBACK,
|
||||||
|
BdsEmptyCallbackFunction,
|
||||||
|
NULL,
|
||||||
|
&gConnectConInEventGuid,
|
||||||
|
&ConnectConInEvent
|
||||||
|
);
|
||||||
|
if (EFI_ERROR(Status)) {
|
||||||
|
ConnectConInEvent = NULL;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (mBootNext != NULL) {
|
if (mBootNext != NULL) {
|
||||||
//
|
//
|
||||||
// Indicate we have the boot next variable, so this time
|
// Indicate we have the boot next variable, so this time
|
||||||
@ -171,6 +208,13 @@ BdsBootDeviceSelect (
|
|||||||
// Check the boot option list first
|
// Check the boot option list first
|
||||||
//
|
//
|
||||||
if (Link == &BootLists) {
|
if (Link == &BootLists) {
|
||||||
|
//
|
||||||
|
// When LazyConIn enabled, signal connect ConIn event before enter UI
|
||||||
|
//
|
||||||
|
if (PcdGetBool (PcdConInConnectOnDemand) && ConnectConInEvent != NULL) {
|
||||||
|
gBS->SignalEvent (ConnectConInEvent);
|
||||||
|
}
|
||||||
|
|
||||||
//
|
//
|
||||||
// There are two ways to enter here:
|
// There are two ways to enter here:
|
||||||
// 1. There is no active boot option, give user chance to
|
// 1. There is no active boot option, give user chance to
|
||||||
@ -248,6 +292,14 @@ BdsBootDeviceSelect (
|
|||||||
// Boot success, then stop process the boot order, and
|
// Boot success, then stop process the boot order, and
|
||||||
// present the boot manager menu, front page
|
// present the boot manager menu, front page
|
||||||
//
|
//
|
||||||
|
|
||||||
|
//
|
||||||
|
// When LazyConIn enabled, signal connect ConIn Event before enter UI
|
||||||
|
//
|
||||||
|
if (PcdGetBool (PcdConInConnectOnDemand) && ConnectConInEvent != NULL) {
|
||||||
|
gBS->SignalEvent (ConnectConInEvent);
|
||||||
|
}
|
||||||
|
|
||||||
Timeout = 0xffff;
|
Timeout = 0xffff;
|
||||||
PlatformBdsEnterFrontPage (Timeout, FALSE);
|
PlatformBdsEnterFrontPage (Timeout, FALSE);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user