* [PATCH v2] MdeModulePkg/Universal/StatusCodeHandler: Fix a bug about log lost
@ 2020-12-17 3:06 Tan, Ming
0 siblings, 0 replies; only message in thread
From: Tan, Ming @ 2020-12-17 3:06 UTC (permalink / raw)
To: devel; +Cc: Dandan Bi, Liming Gao
REF: https://bugzilla.tianocore.org/show_bug.cgi?id=3126
1. If use PeiDxeDebugLibReportStatusCode as DebugLib, then some logs
after ExitBootService() will be lost.
2. The root cause:
2.1 The original code will register a unregister function
of gEfiEventExitBootServicesGuid, this unregister function will call
EFI_RSC_HANDLER_PROTOCOL->Unregister and does not support log through
serial port.
2.2 And some other drivers also register call back funtions of
gEfiEventExitBootServicesGuid.
2.3 Then after the unregister function is called, other call back
functions can't out log if them use RSC as DebugLib.
3. The DxeMain will report status code EFI_SW_BS_PC_EXIT_BOOT_SERVICES
after notify all the call back functions of
gEfiEventExitBootServicesGuid.
4. Solution: the StatusCodeHandlerRuntimeDxe.c will not register a
unregister function of gEfiEventExitBootServicesGuid, but unregister it
after receive the status code of EFI_SW_BS_PC_EXIT_BOOT_SERVICES.
Cc: Dandan Bi <dandan.bi@intel.com>
Cc: Liming Gao <gaoliming@byosoft.com.cn>
Signed-off-by: Ming Tan <ming.tan@intel.com>
---
V2: Add the REF link in commit message.
.../RuntimeDxe/SerialStatusCodeWorker.c | 16 ++++++++++++++++
.../RuntimeDxe/StatusCodeHandlerRuntimeDxe.c | 16 +---------------
2 files changed, 17 insertions(+), 15 deletions(-)
diff --git a/MdeModulePkg/Universal/StatusCodeHandler/RuntimeDxe/SerialStatusCodeWorker.c b/MdeModulePkg/Universal/StatusCodeHandler/RuntimeDxe/SerialStatusCodeWorker.c
index 0b98e7ec63..4ddeb273c1 100644
--- a/MdeModulePkg/Universal/StatusCodeHandler/RuntimeDxe/SerialStatusCodeWorker.c
+++ b/MdeModulePkg/Universal/StatusCodeHandler/RuntimeDxe/SerialStatusCodeWorker.c
@@ -8,6 +8,12 @@
#include "StatusCodeHandlerRuntimeDxe.h"
+VOID
+EFIAPI
+UnregisterBootTimeHandlers (
+ VOID
+ );
+
/**
Convert status code value and extended data to readable ASCII string, send string to serial I/O device.
@@ -151,6 +157,16 @@ SerialStatusCodeReportWorker (
//
SerialPortWrite ((UINT8 *) Buffer, CharCount);
+ //
+ // If register a unregister function of gEfiEventExitBootServicesGuid,
+ // then some log called in ExitBootServices() will be lost,
+ // so unregister the handler after receive the value of exit boot service.
+ //
+ if ((CodeType & EFI_STATUS_CODE_TYPE_MASK) == EFI_PROGRESS_CODE &&
+ Value == (EFI_SOFTWARE_EFI_BOOT_SERVICE | EFI_SW_BS_PC_EXIT_BOOT_SERVICES)) {
+ UnregisterBootTimeHandlers();
+ }
+
return EFI_SUCCESS;
}
diff --git a/MdeModulePkg/Universal/StatusCodeHandler/RuntimeDxe/StatusCodeHandlerRuntimeDxe.c b/MdeModulePkg/Universal/StatusCodeHandler/RuntimeDxe/StatusCodeHandlerRuntimeDxe.c
index a8c0fe5b71..011d03f01b 100644
--- a/MdeModulePkg/Universal/StatusCodeHandler/RuntimeDxe/StatusCodeHandlerRuntimeDxe.c
+++ b/MdeModulePkg/Universal/StatusCodeHandler/RuntimeDxe/StatusCodeHandlerRuntimeDxe.c
@@ -17,16 +17,11 @@ EFI_RSC_HANDLER_PROTOCOL *mRscHandlerProtocol = NULL;
Unregister status code callback functions only available at boot time from
report status code router when exiting boot services.
- @param Event Event whose notification function is being invoked.
- @param Context Pointer to the notification function's context, which is
- always zero in current implementation.
-
**/
VOID
EFIAPI
UnregisterBootTimeHandlers (
- IN EFI_EVENT Event,
- IN VOID *Context
+ VOID
)
{
if (PcdGetBool (PcdStatusCodeUseSerial)) {
@@ -178,15 +173,6 @@ StatusCodeHandlerRuntimeDxeEntry (
mRscHandlerProtocol->Register (RtMemoryStatusCodeReportWorker, TPL_HIGH_LEVEL);
}
- Status = gBS->CreateEventEx (
- EVT_NOTIFY_SIGNAL,
- TPL_NOTIFY,
- UnregisterBootTimeHandlers,
- NULL,
- &gEfiEventExitBootServicesGuid,
- &mExitBootServicesEvent
- );
-
Status = gBS->CreateEventEx (
EVT_NOTIFY_SIGNAL,
TPL_NOTIFY,
--
2.24.0.windows.2
^ permalink raw reply related [flat|nested] only message in thread
only message in thread, other threads:[~2020-12-17 3:06 UTC | newest]
Thread overview: (only message) (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2020-12-17 3:06 [PATCH v2] MdeModulePkg/Universal/StatusCodeHandler: Fix a bug about log lost Tan, Ming
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox