Add a GUIDed HOB to init Debug Print error level earlier in DXE. Add NULL PEIM library to init HOB.

Debug Print Error level can be controled by an EFI variable. Update the DXE version of the library to use a HOB if the variable services are not yet availilbe. This allows the variable to be used early in the DXE phase. 

approved-by: andrewfish
reviewed-by: lgao4



git-svn-id: https://edk2.svn.sourceforge.net/svnroot/edk2/trunk/edk2@12516 6f19259b-4bc3-4df7-8a09-765794883524
diff --git a/MdeModulePkg/Include/Guid/DebugMask.h b/MdeModulePkg/Include/Guid/DebugMask.h
index cfb0a69..1e6beb5 100644
--- a/MdeModulePkg/Include/Guid/DebugMask.h
+++ b/MdeModulePkg/Include/Guid/DebugMask.h
@@ -62,6 +62,7 @@
 

 ///

 /// GUID used to store the global debug mask in an the "EFIDebug" EFI Variabe

+/// Also used as a GUIDed HOB that contains a UINT32 debug mask default value

 ///

 #define EFI_GENERIC_VARIABLE_GUID \

   { 0x59d1c24f, 0x50f1, 0x401a, {0xb1, 0x01, 0xf3, 0x3e, 0x0d, 0xae, 0xd4, 0x43} }

diff --git a/MdeModulePkg/Library/DxeDebugPrintErrorLevelLib/DxeDebugPrintErrorLevelLib.c b/MdeModulePkg/Library/DxeDebugPrintErrorLevelLib/DxeDebugPrintErrorLevelLib.c
index 1182e2e..cad5702 100644
--- a/MdeModulePkg/Library/DxeDebugPrintErrorLevelLib/DxeDebugPrintErrorLevelLib.c
+++ b/MdeModulePkg/Library/DxeDebugPrintErrorLevelLib/DxeDebugPrintErrorLevelLib.c
@@ -19,6 +19,7 @@
 

 #include <Library/DebugPrintErrorLevelLib.h>

 #include <Library/PcdLib.h>

+#include <Library/HobLib.h>

 

 #include <Guid/DebugMask.h>

 

@@ -89,10 +90,11 @@
 /// Global variable that contains the current debug error level mask for the

 /// module that is using this library instance.  This variable is initially

 /// set to the PcdDebugPrintErrorLevel value.  If the EFI Variable exists that

-/// contains the global debug print error level mask, then that override the

-/// PcdDebugPrintErrorLevel value.  If the Debug Mask Protocol SetDebugMask()

-/// service is called, then that overrides bit the PcdDebugPrintErrorLevel and

-/// the EFI Variable setting.

+/// contains the global debug print error level mask, then that overrides the

+/// PcdDebugPrintErrorLevel value. The EFI Variable can optionally be 

+/// discovered via a HOB so early DXE drivers can access the variable. If the

+/// Debug Mask Protocol SetDebugMask() service is called, then that overrides 

+/// the PcdDebugPrintErrorLevel and the EFI Variable setting.

 ///

 UINT32            mDebugPrintErrorLevel        = 0;

 

@@ -122,13 +124,13 @@
   IN EFI_SYSTEM_TABLE  *SystemTable

   )

 {

-  EFI_STATUS  Status;

-

+  EFI_STATUS                  Status;

+  

   //

   // Initialize the error level mask from PCD setting.

   //

   mDebugPrintErrorLevel = PcdGet32 (PcdDebugPrintErrorLevel);

-  

+    

   //

   // Install Debug Mask Protocol onto ImageHandle

   //  

@@ -142,7 +144,8 @@
   //

   // Attempt to retrieve the global debug print error level mask from the EFI Variable

   // If the EFI Variable can not be accessed when this module's library constructors are

-  // executed, then the EFI Variable access will be reattempted on every DEBUG() print

+  // executed a HOB can be used to set the global debug print error level. If no value 

+  // was found then the EFI Variable access will be reattempted on every DEBUG() print

   // from this module until the EFI Variable services are available.

   //

   GetDebugPrintErrorLevel ();

@@ -194,6 +197,7 @@
   EFI_TPL     CurrentTpl;

   UINTN       Size;

   UINTN       GlobalErrorLevel;

+  VOID        *Hob;

 

   //

   // If the constructor has not been executed yet, then just return the PCD value.

@@ -203,10 +207,10 @@
   if (mSystemTable == NULL) {

     return PcdGet32 (PcdDebugPrintErrorLevel);

   }

-

+  

   //

-  // Check to see if an attempt has been mde to retrieve the global debug print 

-  // error level mask.  Since this libtrary instance stores the global debug print

+  // Check to see if an attempt has been made to retrieve the global debug print 

+  // error level mask.  Since this library instance stores the global debug print

   // error level mask in an EFI Variable, the EFI Variable should only be accessed

   // once to reduce the overhead of reading the EFI Variable on every debug print

   //  

@@ -242,6 +246,18 @@
           //

           mDebugPrintErrorLevel = (UINT32)GlobalErrorLevel;

         }

+      } else {

+        //

+        // If variable services are not yet availible optionally get the global

+        // debug print error level mask from a HOB.

+        //

+        Hob = GetFirstGuidHob (&gEfiGenericVariableGuid);

+        if (Hob != NULL) {

+          if (GET_GUID_HOB_DATA_SIZE (Hob) == sizeof (UINT32)) {

+            mDebugPrintErrorLevel = *(UINT32 *)GET_GUID_HOB_DATA (Hob);

+            mGlobalErrorLevelInitialized = TRUE;

+          }

+        }

       }

     }

   }

diff --git a/MdeModulePkg/Library/DxeDebugPrintErrorLevelLib/DxeDebugPrintErrorLevelLib.inf b/MdeModulePkg/Library/DxeDebugPrintErrorLevelLib/DxeDebugPrintErrorLevelLib.inf
index a4a44b1..65c0dc0 100644
--- a/MdeModulePkg/Library/DxeDebugPrintErrorLevelLib/DxeDebugPrintErrorLevelLib.inf
+++ b/MdeModulePkg/Library/DxeDebugPrintErrorLevelLib/DxeDebugPrintErrorLevelLib.inf
@@ -39,6 +39,7 @@
 

 [LibraryClasses]

   PcdLib

+  HobLib

   

 [Protocols]

   gEfiDebugMaskProtocolGuid

diff --git a/MdeModulePkg/Library/PeiDebugPrintHobLib/PeiDebugPrintHobLib.c b/MdeModulePkg/Library/PeiDebugPrintHobLib/PeiDebugPrintHobLib.c
new file mode 100644
index 0000000..4bcf003
--- /dev/null
+++ b/MdeModulePkg/Library/PeiDebugPrintHobLib/PeiDebugPrintHobLib.c
@@ -0,0 +1,78 @@
+/** @file

+  NULL Library class that reads Debug Mask variable and if it exists makes a

+  HOB that contains the debug mask.

+

+  Copyright (c) 2011, Apple, Inc. All rights reserved.<BR>

+  This program and the accompanying materials

+  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

+  http://opensource.org/licenses/bsd-license.php

+

+  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,

+  WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.

+

+**/

+

+#include <PiPei.h>

+

+#include <Library/HobLib.h>

+#include <Library/DebugLib.h>

+#include <Library/PeiServicesLib.h>

+

+#include <Ppi/ReadOnlyVariable2.h>

+#include <Guid/DebugMask.h>

+

+

+/**

+  The constructor reads variable and sets HOB

+  

+  @param  FileHandle   The handle of FFS header the loaded driver.

+  @param  PeiServices  The pointer to the PEI services.

+

+  @retval EFI_SUCCESS  The constructor always returns EFI_SUCCESS.

+

+**/

+EFI_STATUS

+EFIAPI

+PeiDebugPrintHobLibConstructor (

+  IN EFI_PEI_FILE_HANDLE        FileHandle,

+  IN CONST EFI_PEI_SERVICES     **PeiServices

+  )

+{

+  EFI_STATUS                      Status;

+  EFI_PEI_READ_ONLY_VARIABLE2_PPI *Variable;

+  UINTN                           Size;

+  UINT64                          GlobalErrorLevel;

+  UINT32                          HobErrorLevel;

+  

+  Status = PeiServicesLocatePpi (

+             &gEfiPeiReadOnlyVariable2PpiGuid,

+             0,

+             NULL,

+             (VOID **)&Variable

+             );

+  if (!EFI_ERROR (Status)) {

+    Size = sizeof (GlobalErrorLevel);

+    Status = Variable->GetVariable ( 

+                         Variable, 

+                         DEBUG_MASK_VARIABLE_NAME,

+                         &gEfiGenericVariableGuid,

+                         NULL,

+                         &Size,

+                         &GlobalErrorLevel

+                         );

+    if (!EFI_ERROR (Status)) {

+      //

+      // Build the GUID'ed HOB for DXE

+      //

+      HobErrorLevel = (UINT32)GlobalErrorLevel;

+      BuildGuidDataHob (

+        &gEfiGenericVariableGuid,

+        &HobErrorLevel,

+        sizeof (HobErrorLevel)

+        );

+    }

+  }

+

+  return EFI_SUCCESS;

+}

diff --git a/MdeModulePkg/Library/PeiDebugPrintHobLib/PeiDebugPrintHobLib.inf b/MdeModulePkg/Library/PeiDebugPrintHobLib/PeiDebugPrintHobLib.inf
new file mode 100644
index 0000000..492f032
--- /dev/null
+++ b/MdeModulePkg/Library/PeiDebugPrintHobLib/PeiDebugPrintHobLib.inf
@@ -0,0 +1,46 @@
+## @file

+#  NULL Library class that reads Debug Mask variable and if it exists makes a

+#  HOB that contains the debug mask.

+#

+#  Copyright (c) 2011, Apple, Inc. All rights reserved.<BR>

+#

+#  This program and the accompanying materials

+#  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

+#  http://opensource.org/licenses/bsd-license.php

+#  THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,

+#  WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.

+#

+#

+##

+

+[Defines]

+  INF_VERSION                    = 0x00010005

+  BASE_NAME                      = PeiDebugPrintHobLib

+  FILE_GUID                      = EB0BDD73-DABB-E74B-BF51-62DC1DA521E1

+  MODULE_TYPE                    = PEIM

+  VERSION_STRING                 = 1.0

+  LIBRARY_CLASS                  = NULL|PEIM

+  CONSTRUCTOR                    = PeiDebugPrintHobLibConstructor

+

+

+[Sources]

+  PeiDebugPrintHobLib.c

+

+

+[Packages]

+  MdePkg/MdePkg.dec

+  MdeModulePkg/MdeModulePkg.dec

+

+[LibraryClasses]

+  PeiServicesLib

+  DebugLib

+

+[Ppis]

+  gEfiPeiReadOnlyVariable2PpiGuid

+

+[Guids]

+  gEfiGenericVariableGuid              

+

+[Depex]

+  gEfiPeiReadOnlyVariable2PpiGuid
\ No newline at end of file
diff --git a/MdeModulePkg/MdeModulePkg.dsc b/MdeModulePkg/MdeModulePkg.dsc
index 7a42d12..dec51cd 100644
--- a/MdeModulePkg/MdeModulePkg.dsc
+++ b/MdeModulePkg/MdeModulePkg.dsc
@@ -244,6 +244,7 @@
   MdeModulePkg/Library/SmmLockBoxLib/SmmLockBoxDxeLib.inf

   MdeModulePkg/Library/SmmLockBoxLib/SmmLockBoxSmmLib.inf

   MdeModulePkg/Library/PiDxeS3BootScriptLib/DxeS3BootScriptLib.inf

+  MdeModulePkg/Library/PeiDebugPrintHobLib/PeiDebugPrintHobLib.inf

 

   MdeModulePkg/Universal/CapsulePei/CapsulePei.inf

   MdeModulePkg/Universal/CapsuleRuntimeDxe/CapsuleRuntimeDxe.inf