]> git.proxmox.com Git - mirror_edk2.git/blobdiff - ShellPkg/Library/UefiShellDebug1CommandsLib/SmbiosView/SmbiosView.c
ShellPkg: Update header file including style
[mirror_edk2.git] / ShellPkg / Library / UefiShellDebug1CommandsLib / SmbiosView / SmbiosView.c
index b59109c455b2aedc755c773c4f2578c49cb56557..6e7c7637a19a4de1dce8354a134ec3990a8b1a2b 100644 (file)
@@ -1,7 +1,8 @@
 /** @file\r
   Tools of clarify the content of the smbios table.\r
 \r
-  Copyright (c) 2005 - 2011, Intel Corporation. All rights reserved.<BR>\r
+  (C) Copyright 2015 Hewlett-Packard Development Company, L.P.<BR>\r
+  Copyright (c) 2005 - 2017, Intel Corporation. All rights reserved.<BR>\r
   This program and the accompanying materials\r
   are licensed and made available under the terms and conditions of the BSD License\r
   which accompanies this distribution.  The full text of the license may be found at\r
 \r
 **/\r
 \r
-#include "../UefiShellDebug1CommandsLib.h"\r
+#include "UefiShellDebug1CommandsLib.h"\r
 #include "LibSmbiosView.h"\r
-#include "smbiosview.h"\r
+#include "SmbiosView.h"\r
 #include "PrintInfo.h"\r
 #include "QueryTable.h"\r
 \r
 UINT8                       gShowType         = SHOW_DETAIL;\r
 STATIC STRUCTURE_STATISTICS *mStatisticsTable = NULL;\r
+STATIC STRUCTURE_STATISTICS *mSmbios64BitStatisticsTable = NULL;\r
 \r
 UINT8  SmbiosMajorVersion;\r
 UINT8  SmbiosMinorVersion;\r
 \r
+UINTN  mNumberOfSmbios64BitStructures;\r
+UINTN  mSmbios64BitTableLength;\r
+\r
 STATIC CONST SHELL_PARAM_ITEM ParamList[] = {\r
   {L"-t", TypeValue},\r
   {L"-h", TypeValue},\r
@@ -32,6 +37,12 @@ STATIC CONST SHELL_PARAM_ITEM ParamList[] = {
   {NULL, TypeMax}\r
   };\r
 \r
+/**\r
+  Function for 'smbiosview' command.\r
+\r
+  @param[in] ImageHandle  Handle to the Image (NULL if Internal).\r
+  @param[in] SystemTable  Pointer to the System Table (NULL if Internal).\r
+**/\r
 SHELL_STATUS\r
 EFIAPI\r
 ShellCommandRunSmbiosView (\r
@@ -42,20 +53,23 @@ ShellCommandRunSmbiosView (
   UINT8               StructType;\r
   UINT16              StructHandle;\r
   EFI_STATUS          Status;\r
+  EFI_STATUS          Status1;\r
+  EFI_STATUS          Status2;\r
   BOOLEAN             RandomView;\r
   LIST_ENTRY          *Package;\r
   CHAR16              *ProblemParam;\r
   SHELL_STATUS        ShellStatus;\r
   CONST CHAR16        *Temp;\r
 \r
-  mStatisticsTable    = NULL;\r
-  Package             = NULL;\r
-  ShellStatus         = SHELL_SUCCESS;\r
+  mStatisticsTable            = NULL;\r
+  mSmbios64BitStatisticsTable = NULL;\r
+  Package                     = NULL;\r
+  ShellStatus                 = SHELL_SUCCESS;\r
 \r
   Status = ShellCommandLineParse (ParamList, &Package, &ProblemParam, TRUE);\r
   if (EFI_ERROR(Status)) {\r
     if (Status == EFI_VOLUME_CORRUPTED && ProblemParam != NULL) {\r
-      ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_PROBLEM), gShellDebug1HiiHandle, ProblemParam);\r
+      ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_PROBLEM), gShellDebug1HiiHandle, L"smbiosview", ProblemParam);  \r
       FreePool(ProblemParam);\r
       ShellStatus = SHELL_INVALID_PARAMETER;\r
     } else {\r
@@ -63,13 +77,13 @@ ShellCommandRunSmbiosView (
     }\r
   } else {\r
     if (ShellCommandLineGetCount(Package) > 1) {\r
-      ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_MANY), gShellDebug1HiiHandle);\r
+      ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_MANY), gShellDebug1HiiHandle, L"smbiosview");  \r
       ShellStatus = SHELL_INVALID_PARAMETER;\r
     } else if (ShellCommandLineGetFlag(Package, L"-t") && ShellCommandLineGetValue(Package, L"-t") == NULL) {\r
-      ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_NO_VALUE), gShellDebug1HiiHandle, L"-t");\r
+      ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_NO_VALUE), gShellDebug1HiiHandle, L"smbiosview", L"-t");  \r
       ShellStatus = SHELL_INVALID_PARAMETER;\r
     } else if (ShellCommandLineGetFlag(Package, L"-h") && ShellCommandLineGetValue(Package, L"-h") == NULL) {\r
-      ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_NO_VALUE), gShellDebug1HiiHandle, L"-h");\r
+      ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_NO_VALUE), gShellDebug1HiiHandle,  L"smbiosview", L"-h");  \r
       ShellStatus = SHELL_INVALID_PARAMETER;\r
     } else if (\r
         (ShellCommandLineGetFlag(Package, L"-t") && ShellCommandLineGetFlag(Package, L"-h")) ||\r
@@ -79,63 +93,109 @@ ShellCommandRunSmbiosView (
         (ShellCommandLineGetFlag(Package, L"-h") && ShellCommandLineGetFlag(Package, L"-a")) ||\r
         (ShellCommandLineGetFlag(Package, L"-s") && ShellCommandLineGetFlag(Package, L"-a"))\r
       ) {\r
-      ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_MANY), gShellDebug1HiiHandle);\r
+      ShellPrintHiiEx(-1, -1, NULL, STRING_TOKEN (STR_GEN_TOO_MANY), gShellDebug1HiiHandle, L"smbiosview");  \r
       ShellStatus = SHELL_INVALID_PARAMETER;\r
     } else {\r
 \r
       //\r
       // Init Lib\r
-      \r
-      Status = LibSmbiosInit ();\r
-      if (EFI_ERROR (Status)) {\r
-        ShellStatus = SHELL_NOT_FOUND;\r
-        goto Done;\r
-      }\r
       //\r
-      // build statistics table\r
-      //\r
-      Status = InitSmbiosTableStatistics ();\r
-      if (EFI_ERROR (Status)) {\r
+      Status1 = LibSmbiosInit ();\r
+      Status2 = LibSmbios64BitInit ();\r
+      if (EFI_ERROR (Status1) && EFI_ERROR (Status2)) {\r
+       ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_LIBSMBIOSVIEW_CANNOT_GET_TABLE), gShellDebug1HiiHandle);\r
         ShellStatus = SHELL_NOT_FOUND;\r
         goto Done;\r
       }\r
-\r
+      \r
       StructType    = STRUCTURE_TYPE_RANDOM;\r
       RandomView    = TRUE;\r
-      //\r
-      // Initialize the StructHandle to be the first handle\r
-      //\r
-      StructHandle  = STRUCTURE_HANDLE_INVALID;\r
-      LibGetSmbiosStructure (&StructHandle, NULL, NULL);\r
-\r
+      \r
       Temp          = ShellCommandLineGetValue(Package, L"-t");\r
       if (Temp != NULL) {\r
         StructType = (UINT8) ShellStrToUintn (Temp);\r
       }\r
-\r
-      Temp = ShellCommandLineGetValue(Package, L"-h");\r
-      if (Temp != NULL) {\r
-        RandomView   = FALSE;\r
-        StructHandle = (UINT16) ShellStrToUintn(Temp);\r
+      \r
+      if (ShellCommandLineGetFlag(Package, L"-a")) {\r
+        gShowType = SHOW_ALL;\r
       }\r
-\r
-      if (ShellCommandLineGetFlag(Package, L"-s")) {\r
-        Status = DisplayStatisticsTable (SHOW_DETAIL);\r
+      \r
+      if (!EFI_ERROR (Status1)) {\r
+        //\r
+        // Initialize the StructHandle to be the first handle\r
+        //\r
+        StructHandle  = INVALID_HANDLE;\r
+        LibGetSmbiosStructure (&StructHandle, NULL, NULL);\r
+        \r
+        Temp = ShellCommandLineGetValue(Package, L"-h");\r
+        if (Temp != NULL) {\r
+          RandomView   = FALSE;\r
+          StructHandle = (UINT16) ShellStrToUintn(Temp);\r
+        }\r
+        //\r
+        // build statistics table\r
+        //\r
+        Status = InitSmbiosTableStatistics ();\r
+        if (EFI_ERROR (Status)) {\r
+          ShellStatus = SHELL_NOT_FOUND;\r
+          goto Done;\r
+        }\r
+        \r
+        if (ShellCommandLineGetFlag(Package, L"-s")) {\r
+          Status = DisplayStatisticsTable (SHOW_DETAIL);\r
+          if (EFI_ERROR(Status)) {\r
+            ShellStatus = SHELL_NOT_FOUND;\r
+          }\r
+          goto Show64Bit;\r
+        }\r
+        \r
+        //\r
+        // Show SMBIOS structure information\r
+        //\r
+        Status = SMBiosView (StructType, StructHandle, gShowType, RandomView);\r
         if (EFI_ERROR(Status)) {\r
           ShellStatus = SHELL_NOT_FOUND;\r
+          goto Done;\r
         }\r
-        goto Done;\r
       }\r
 \r
-      if (ShellCommandLineGetFlag(Package, L"-a")) {\r
-        gShowType = SHOW_ALL;\r
-      }\r
-      //\r
-      // Show SMBIOS structure information\r
-      //\r
-      Status = SMBiosView (StructType, StructHandle, gShowType, RandomView);\r
-      if (EFI_ERROR(Status)) {\r
-        ShellStatus = SHELL_NOT_FOUND;\r
+Show64Bit:\r
+      if (!EFI_ERROR (Status2)) {\r
+        //\r
+        // build statistics table\r
+        //\r
+        Status = InitSmbios64BitTableStatistics ();\r
+        if (EFI_ERROR (Status)) {\r
+          ShellStatus = SHELL_NOT_FOUND;\r
+          goto Done;\r
+        }\r
+        //\r
+        // Initialize the StructHandle to be the first handle\r
+        //\r
+        StructHandle  = INVALID_HANDLE;\r
+        LibGetSmbios64BitStructure (&StructHandle, NULL, NULL);\r
+        \r
+        Temp = ShellCommandLineGetValue(Package, L"-h");\r
+        if (Temp != NULL) {\r
+          RandomView   = FALSE;\r
+          StructHandle = (UINT16) ShellStrToUintn(Temp);\r
+        }\r
+        \r
+        if (ShellCommandLineGetFlag(Package, L"-s")) {\r
+          Status = DisplaySmbios64BitStatisticsTable (SHOW_DETAIL);\r
+          if (EFI_ERROR(Status)) {\r
+            ShellStatus = SHELL_NOT_FOUND;\r
+          }\r
+          goto Done;\r
+        }\r
+        \r
+        //\r
+        // Show SMBIOS structure information\r
+        //\r
+        Status = SMBios64View (StructType, StructHandle, gShowType, RandomView);\r
+        if (EFI_ERROR(Status)) {\r
+          ShellStatus = SHELL_NOT_FOUND;\r
+        }\r
       }\r
     }\r
   }\r
@@ -151,11 +211,20 @@ Done:
     mStatisticsTable = NULL;\r
   }\r
 \r
+  if (mSmbios64BitStatisticsTable != NULL) {\r
+    //\r
+    // Release statistics table\r
+    //\r
+    FreePool (mSmbios64BitStatisticsTable);\r
+    mSmbios64BitStatisticsTable = NULL;\r
+  }\r
+\r
   if (Package != NULL) {\r
     ShellCommandLineFreeVarList (Package);\r
   }\r
 \r
   LibSmbiosCleanup ();\r
+  LibSmbios64BitCleanup ();\r
 \r
   return ShellStatus;\r
 }\r
@@ -173,7 +242,6 @@ Done:
   @retval EFI_BAD_BUFFER_SIZE   structure is out of the range of SMBIOS table.\r
 **/\r
 EFI_STATUS\r
-EFIAPI\r
 SMBiosView (\r
   IN  UINT8   QueryType,\r
   IN  UINT16  QueryHandle,\r
@@ -182,23 +250,12 @@ SMBiosView (
   )\r
 {\r
   UINT16                    Handle;\r
-  UINT8                     Buffer[1024];\r
-  //\r
-  // bigger than SMBIOS_STRUCTURE_TABLE.MaxStructureSize\r
-  //\r
+  UINT8                     *Buffer;\r
   UINT16                    Length;\r
   UINTN                     Index;\r
-  UINT16                    Offset;\r
-  //\r
-  // address offset from structure table head.\r
-  //\r
-  UINT32                    TableHead;\r
-  //\r
-  // structure table head.\r
-  //\r
 \r
-  SMBIOS_STRUCTURE_POINTER  pStruct;\r
-  SMBIOS_STRUCTURE_TABLE    *SMBiosTable;\r
+  SMBIOS_STRUCTURE_POINTER  SmbiosStruct;\r
+  SMBIOS_TABLE_ENTRY_POINT  *SMBiosTable;\r
 \r
   SMBiosTable = NULL;\r
   LibSmbiosGetEPS (&SMBiosTable);\r
@@ -209,7 +266,7 @@ SMBiosView (
 \r
   if (CompareMem (SMBiosTable->AnchorString, "_SM_", 4) == 0) {\r
     //\r
-    // Have get SMBIOS table\r
+    // Have got SMBIOS table\r
     //\r
     SmbiosPrintEPSInfo (SMBiosTable, Option);\r
 \r
@@ -253,30 +310,28 @@ SMBiosView (
     // Searching and display structure info\r
     //\r
     Handle    = QueryHandle;\r
-    TableHead = SMBiosTable->TableAddress;\r
-    Offset    = 0;\r
     for (Index = 0; Index < SMBiosTable->NumberOfSmbiosStructures; Index++) {\r
       //\r
       // if reach the end of table, break..\r
       //\r
-      if (Handle == STRUCTURE_HANDLE_INVALID) {\r
+      if (Handle == INVALID_HANDLE) {\r
         break;\r
       }\r
       //\r
       // handle then point to the next!\r
       //\r
-      if (LibGetSmbiosStructure (&Handle, Buffer, &Length) != DMI_SUCCESS) {\r
+      if (LibGetSmbiosStructure (&Handle, &Buffer, &Length) != DMI_SUCCESS) {\r
         break;\r
       }\r
-      Offset      = (UINT16) (Offset + Length);\r
-      pStruct.Raw = Buffer;\r
+\r
+      SmbiosStruct.Raw = Buffer;\r
 \r
       //\r
       // if QueryType==Random, print this structure.\r
       // if QueryType!=Random, but Hdr->Type==QueryType, also print it.\r
       // only if QueryType != Random and Hdr->Type != QueryType, skiped it.\r
       //\r
-      if (QueryType != STRUCTURE_TYPE_RANDOM && pStruct.Hdr->Type != QueryType) {\r
+      if (QueryType != STRUCTURE_TYPE_RANDOM && SmbiosStruct.Hdr->Type != QueryType) {\r
         continue;\r
       }\r
 \r
@@ -284,14 +339,14 @@ SMBiosView (
       ShellPrintHiiEx(-1,-1,NULL,\r
         STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_TYPE_HANDLE_DUMP_STRUCT),\r
         gShellDebug1HiiHandle,\r
-        pStruct.Hdr->Type,\r
-        pStruct.Hdr->Handle\r
+        SmbiosStruct.Hdr->Type,\r
+        SmbiosStruct.Hdr->Handle\r
        );\r
       ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_INDEX_LENGTH), gShellDebug1HiiHandle, Index, Length);\r
       //\r
       // Addr of structure in structure in table\r
       //\r
-      ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_ADDR), gShellDebug1HiiHandle, TableHead + Offset);\r
+      ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_ADDR), gShellDebug1HiiHandle, (UINTN) Buffer);\r
       DumpHex (0, 0, Length, Buffer);\r
 \r
 /*\r
@@ -310,14 +365,181 @@ SMBiosView (
 \r
       if (gShowType != SHOW_NONE) {\r
         //\r
-        // check structure legality\r
+        // Print structure information\r
+        //\r
+        SmbiosPrintStructure (&SmbiosStruct, gShowType);\r
+        ShellPrintEx(-1,-1,L"\n");\r
+\r
+/*\r
+        //\r
+        // Get internal commands, such as change options.\r
         //\r
-        SmbiosCheckStructure (&pStruct);\r
+        Status = WaitEnter ();\r
+        if (EFI_ERROR (Status)) {\r
+          if (Status == EFI_ABORTED) {\r
+            return EFI_SUCCESS;\r
+          }\r
+\r
+          return Status;\r
+        }\r
+*/\r
+      }\r
+      if (!RandomView) {\r
+        break;\r
+      }\r
+      //\r
+      // Support Execution Interrupt.\r
+      //\r
+      if (ShellGetExecutionBreakFlag ()) {\r
+        return EFI_ABORTED;\r
+      }\r
+    }\r
+\r
+    ShellPrintEx(-1,-1,L"\n=========================================================\n");\r
+    return EFI_SUCCESS;\r
+  }\r
+\r
+  return EFI_BAD_BUFFER_SIZE;\r
+}\r
+\r
+/**\r
+  Query all structures Data from SMBIOS table and Display\r
+  the information to users as required display option.\r
+\r
+  @param[in] QueryType      Structure type to view.\r
+  @param[in] QueryHandle    Structure handle to view.\r
+  @param[in] Option         Display option: none,outline,normal,detail.\r
+  @param[in] RandomView     Support for -h parameter.\r
+\r
+  @retval EFI_SUCCESS           print is successful.\r
+  @retval EFI_BAD_BUFFER_SIZE   structure is out of the range of SMBIOS table.\r
+**/\r
+EFI_STATUS\r
+SMBios64View (\r
+  IN  UINT8   QueryType,\r
+  IN  UINT16  QueryHandle,\r
+  IN  UINT8   Option,\r
+  IN  BOOLEAN RandomView\r
+  )\r
+{\r
+  UINT16                        Handle;\r
+  UINT8                         *Buffer;\r
+  UINT16                        Length;\r
+  UINTN                         Index;\r
+  SMBIOS_STRUCTURE_POINTER      SmbiosStruct;\r
+  SMBIOS_TABLE_3_0_ENTRY_POINT  *SMBiosTable;\r
+\r
+  SMBiosTable = NULL;\r
+  LibSmbios64BitGetEPS (&SMBiosTable);\r
+  if (SMBiosTable == NULL) {\r
+    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_CANNOT_ACCESS_TABLE), gShellDebug1HiiHandle);\r
+    return EFI_BAD_BUFFER_SIZE;\r
+  }\r
+\r
+  if (CompareMem (SMBiosTable->AnchorString, "_SM3_", 5) == 0) {\r
+    //\r
+    // Have got SMBIOS table\r
+    //\r
+    Smbios64BitPrintEPSInfo (SMBiosTable, Option);\r
+\r
+    SmbiosMajorVersion = SMBiosTable->MajorVersion;\r
+    SmbiosMinorVersion = SMBiosTable->MinorVersion;\r
+\r
+    ShellPrintEx(-1,-1,L"=========================================================\n");\r
+    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_QUERY_STRUCT_COND), gShellDebug1HiiHandle);\r
+\r
+    if (QueryType == STRUCTURE_TYPE_RANDOM) {\r
+      ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_QUERYTYPE_RANDOM), gShellDebug1HiiHandle);\r
+    } else {\r
+      ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_QUERYTYPE), gShellDebug1HiiHandle, QueryType);\r
+    }\r
+\r
+    if (RandomView) {\r
+      ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_QUERYHANDLE_RANDOM), gShellDebug1HiiHandle);\r
+    } else {\r
+      ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_QUERYHANDLE), gShellDebug1HiiHandle, QueryHandle);\r
+    }\r
+\r
+    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_SHOWTYPE), gShellDebug1HiiHandle);\r
+    ShellPrintEx(-1,-1,GetShowTypeString (gShowType));\r
+    ShellPrintEx(-1,-1,L"\n\n");\r
+\r
+/*\r
+    //\r
+    // Get internal commands, such as change options.\r
+    //\r
+    Status = WaitEnter ();\r
+    if (EFI_ERROR (Status)) {\r
+      if (Status == EFI_ABORTED) {\r
+        return EFI_SUCCESS;\r
+      }\r
+\r
+      return Status;\r
+    }\r
+*/\r
+\r
+    //\r
+    // Searching and display structure info\r
+    //\r
+    Handle    = QueryHandle;\r
+    for (Index = 0; Index < mNumberOfSmbios64BitStructures; Index++) {\r
+      //\r
+      // if reach the end of table, break..\r
+      //\r
+      if (Handle == INVALID_HANDLE) {\r
+        break;\r
+      }\r
+      //\r
+      // handle then point to the next!\r
+      //\r
+      if (LibGetSmbios64BitStructure (&Handle, &Buffer, &Length) != DMI_SUCCESS) {\r
+        break;\r
+      }\r
+\r
+      SmbiosStruct.Raw = Buffer;\r
+\r
+      //\r
+      // if QueryType==Random, print this structure.\r
+      // if QueryType!=Random, but Hdr->Type==QueryType, also print it.\r
+      // only if QueryType != Random and Hdr->Type != QueryType, skiped it.\r
+      //\r
+      if (QueryType != STRUCTURE_TYPE_RANDOM && SmbiosStruct.Hdr->Type != QueryType) {\r
+        continue;\r
+      }\r
+\r
+      ShellPrintEx(-1,-1,L"\n=========================================================\n");\r
+      ShellPrintHiiEx(-1,-1,NULL,\r
+        STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_TYPE_HANDLE_DUMP_STRUCT),\r
+        gShellDebug1HiiHandle,\r
+        SmbiosStruct.Hdr->Type,\r
+        SmbiosStruct.Hdr->Handle\r
+       );\r
+      ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_INDEX_LENGTH), gShellDebug1HiiHandle, Index, Length);\r
+      //\r
+      // Addr of structure in structure in table\r
+      //\r
+      ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_ADDR), gShellDebug1HiiHandle, (UINTN) Buffer);\r
+      DumpHex (0, 0, Length, Buffer);\r
 \r
+/*\r
+      //\r
+      // Get internal commands, such as change options.\r
+      //\r
+      Status = WaitEnter ();\r
+      if (EFI_ERROR (Status)) {\r
+        if (Status == EFI_ABORTED) {\r
+          return EFI_SUCCESS;\r
+        }\r
+\r
+        return Status;\r
+      }\r
+*/\r
+\r
+      if (gShowType != SHOW_NONE) {\r
         //\r
         // Print structure information\r
         //\r
-        SmbiosPrintStructure (&pStruct, gShowType);\r
+        SmbiosPrintStructure (&SmbiosStruct, gShowType);\r
         ShellPrintEx(-1,-1,L"\n");\r
 \r
 /*\r
@@ -337,6 +559,12 @@ SMBiosView (
       if (!RandomView) {\r
         break;\r
       }\r
+      //\r
+      // Support Execution Interrupt.\r
+      //\r
+      if (ShellGetExecutionBreakFlag ()) {\r
+        return EFI_ABORTED;\r
+      }\r
     }\r
 \r
     ShellPrintEx(-1,-1,L"\n=========================================================\n");\r
@@ -352,20 +580,19 @@ SMBiosView (
   @retval EFI_SUCCESS           print is successful.\r
 **/\r
 EFI_STATUS\r
-EFIAPI\r
 InitSmbiosTableStatistics (\r
   VOID\r
   )\r
 {\r
   UINT16                    Handle;\r
-  UINT8                     Buffer[1024];\r
+  UINT8                     *Buffer;\r
   UINT16                    Length;\r
   UINT16                    Offset;\r
   UINT16                    Index;\r
 \r
-  SMBIOS_STRUCTURE_POINTER  pStruct;\r
-  SMBIOS_STRUCTURE_TABLE    *SMBiosTable;\r
-  STRUCTURE_STATISTICS      *pStatistics;\r
+  SMBIOS_STRUCTURE_POINTER  SmbiosStruct;\r
+  SMBIOS_TABLE_ENTRY_POINT  *SMBiosTable;\r
+  STRUCTURE_STATISTICS      *StatisticsPointer;\r
 \r
   SMBiosTable = NULL;\r
   LibSmbiosGetEPS (&SMBiosTable);\r
@@ -394,40 +621,186 @@ InitSmbiosTableStatistics (
   }\r
 \r
   Offset      = 0;\r
-  pStatistics = mStatisticsTable;\r
+  StatisticsPointer = mStatisticsTable;\r
 \r
   //\r
   // search from the first one\r
   //\r
-  Handle = STRUCTURE_HANDLE_INVALID;\r
+  Handle = INVALID_HANDLE;\r
   LibGetSmbiosStructure (&Handle, NULL, NULL);\r
   for (Index = 1; Index <= SMBiosTable->NumberOfSmbiosStructures; Index++) {\r
     //\r
     // If reach the end of table, break..\r
     //\r
-    if (Handle == STRUCTURE_HANDLE_INVALID) {\r
+    if (Handle == INVALID_HANDLE) {\r
       break;\r
     }\r
     //\r
     // After LibGetSmbiosStructure(), handle then point to the next!\r
     //\r
-    if (LibGetSmbiosStructure (&Handle, Buffer, &Length) != DMI_SUCCESS) {\r
+    if (LibGetSmbiosStructure (&Handle, &Buffer, &Length) != DMI_SUCCESS) {\r
       break;\r
     }\r
 \r
-    pStruct.Raw = Buffer;\r
-    Offset      = (UINT16) (Offset + Length);\r
+    SmbiosStruct.Raw = Buffer;\r
 \r
     //\r
     // general statistics\r
     //\r
-    pStatistics->Index  = Index;\r
-    pStatistics->Type   = pStruct.Hdr->Type;\r
-    pStatistics->Handle = pStruct.Hdr->Handle;\r
-    pStatistics->Length = Length;\r
-    pStatistics->Addr   = Offset;\r
+    StatisticsPointer->Index  = Index;\r
+    StatisticsPointer->Type   = SmbiosStruct.Hdr->Type;\r
+    StatisticsPointer->Handle = SmbiosStruct.Hdr->Handle;\r
+    StatisticsPointer->Length = Length;\r
+    StatisticsPointer->Addr   = Offset;\r
+\r
+    Offset = (UINT16) (Offset + Length);\r
 \r
-    pStatistics         = &mStatisticsTable[Index];\r
+    StatisticsPointer         = &mStatisticsTable[Index];\r
+  }\r
+\r
+  return EFI_SUCCESS;\r
+}\r
+\r
+/**\r
+  @param[in]  Smbios64EntryPoint          SMBIOS 64-bit entry point.\r
+  @param[out] NumberOfSmbios64Structures  The number of structures in 64-bit SMBIOS table.\r
+  @param[out] Smbios64TableLength         The total length of 64-bit SMBIOS table.\r
+\r
+  @retval EFI_SUCCESS                                                  Calculation was successful.\r
+**/\r
+EFI_STATUS\r
+CalculateSmbios64BitStructureCountAndLength (\r
+  SMBIOS_TABLE_3_0_ENTRY_POINT    *Smbios64EntryPoint,\r
+  UINTN                           *NumberOfSmbios64Structures,\r
+  UINTN                           *Smbios64TableLength\r
+)\r
+{\r
+  SMBIOS_STRUCTURE_POINTER        Smbios;\r
+  UINT8                           *Raw;\r
+  \r
+  *Smbios64TableLength = 0;\r
+  *NumberOfSmbios64Structures = 0;\r
+  \r
+  Smbios.Raw = (UINT8 *)(UINTN)(Smbios64EntryPoint->TableAddress);\r
+  while (TRUE) {\r
+    if (Smbios.Hdr->Type == 127) {\r
+      //\r
+      // Reach the end of table type 127\r
+      //\r
+      (*NumberOfSmbios64Structures)++;\r
+      (*Smbios64TableLength) += sizeof (SMBIOS_STRUCTURE);\r
+      return EFI_SUCCESS;\r
+    }\r
+\r
+    Raw = Smbios.Raw;\r
+    //\r
+    // Walk to next structure\r
+    //\r
+    LibGetSmbiosString (&Smbios, (UINT16) (-1));\r
+    //\r
+    // Length = Next structure head - this structure head\r
+    //\r
+    (*Smbios64TableLength) += ((UINTN) Smbios.Raw - (UINTN) Raw);\r
+    if ((*Smbios64TableLength) > Smbios64EntryPoint->TableMaximumSize) {\r
+       //\r
+       // The actual table length exceeds maximum table size,\r
+       // There should be something wrong with SMBIOS table.\r
+       //\r
+       return EFI_INVALID_PARAMETER;\r
+    }\r
+    (*NumberOfSmbios64Structures)++;\r
+  }\r
+}\r
+\r
+/**\r
+  Function to initialize the global mSmbios64BitStatisticsTable object.\r
+\r
+  @retval EFI_SUCCESS           print is successful.\r
+**/\r
+EFI_STATUS\r
+InitSmbios64BitTableStatistics (\r
+  VOID\r
+  )\r
+{\r
+  UINT16                    Handle;\r
+  UINT8                     *Buffer;\r
+  UINT16                    Length;\r
+  UINT16                    Offset;\r
+  UINT16                    Index;\r
+       EFI_STATUS                                                              Status;\r
+  SMBIOS_STRUCTURE_POINTER      SmbiosStruct;\r
+  SMBIOS_TABLE_3_0_ENTRY_POINT  *SMBiosTable;\r
+  STRUCTURE_STATISTICS          *StatisticsPointer;\r
+\r
+  SMBiosTable = NULL;\r
+  LibSmbios64BitGetEPS (&SMBiosTable);\r
+  if (SMBiosTable == NULL) {\r
+    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_CANNOT_ACCESS_TABLE), gShellDebug1HiiHandle);\r
+    return EFI_NOT_FOUND;\r
+  }\r
+\r
+  if (CompareMem (SMBiosTable->AnchorString, "_SM3_", 5) != 0) {\r
+    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_SMBIOS_TABLE), gShellDebug1HiiHandle);\r
+    return EFI_INVALID_PARAMETER;\r
+  }\r
+  //\r
+  // Allocate memory to mSmbios64BitStatisticsTable\r
+  //\r
+  if (mSmbios64BitStatisticsTable != NULL) {\r
+    FreePool (mSmbios64BitStatisticsTable);\r
+    mSmbios64BitStatisticsTable = NULL;\r
+  }\r
+  //\r
+  // Calculate number of smbios structures\r
+  //\r
+  Status = CalculateSmbios64BitStructureCountAndLength (SMBiosTable, &mNumberOfSmbios64BitStructures, &mSmbios64BitTableLength);\r
+  if ((EFI_ERROR (Status)) || (mSmbios64BitTableLength > SMBiosTable->TableMaximumSize)) {\r
+       return EFI_INVALID_PARAMETER;\r
+  }\r
+  \r
+  mSmbios64BitStatisticsTable = (STRUCTURE_STATISTICS *) AllocateZeroPool (mNumberOfSmbios64BitStructures * sizeof (STRUCTURE_STATISTICS));\r
+\r
+  if (mSmbios64BitStatisticsTable == NULL) {\r
+    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_OUT_OF_MEM), gShellDebug1HiiHandle);\r
+    return EFI_OUT_OF_RESOURCES;\r
+  }\r
+\r
+  Offset      = 0;\r
+  StatisticsPointer = mSmbios64BitStatisticsTable;\r
+\r
+  //\r
+  // search from the first one\r
+  //\r
+  Handle = INVALID_HANDLE;\r
+  LibGetSmbios64BitStructure (&Handle, NULL, NULL);\r
+  for (Index = 1; Index <= mNumberOfSmbios64BitStructures; Index++) {\r
+    //\r
+    // If reach the end of table, break..\r
+    //\r
+    if (Handle == INVALID_HANDLE) {\r
+      break;\r
+    }\r
+    //\r
+    // After LibGetSmbios64BitStructure(), handle then point to the next!\r
+    //\r
+    if (LibGetSmbios64BitStructure (&Handle, &Buffer, &Length) != DMI_SUCCESS) {\r
+      break;\r
+    }\r
+\r
+    SmbiosStruct.Raw = Buffer;\r
+\r
+    //\r
+    // general statistics\r
+    //\r
+    StatisticsPointer->Index  = Index;\r
+    StatisticsPointer->Type   = SmbiosStruct.Hdr->Type;\r
+    StatisticsPointer->Handle = SmbiosStruct.Hdr->Handle;\r
+    StatisticsPointer->Length = Length;\r
+    StatisticsPointer->Addr   = Offset;\r
+\r
+    Offset = (UINT16) (Offset + Length);\r
+\r
+    StatisticsPointer         = &mSmbios64BitStatisticsTable[Index];\r
   }\r
 \r
   return EFI_SUCCESS;\r
@@ -441,15 +814,14 @@ InitSmbiosTableStatistics (
   @retval EFI_SUCCESS           print is successful.\r
 **/\r
 EFI_STATUS\r
-EFIAPI\r
 DisplayStatisticsTable (\r
   IN   UINT8   Option\r
   )\r
 {\r
-  UINTN                   Index;\r
-  UINTN                   Num;\r
-  STRUCTURE_STATISTICS    *pStatistics;\r
-  SMBIOS_STRUCTURE_TABLE  *SMBiosTable;\r
+  UINTN                    Index;\r
+  UINTN                    Num;\r
+  STRUCTURE_STATISTICS     *StatisticsPointer;\r
+  SMBIOS_TABLE_ENTRY_POINT *SMBiosTable;\r
 \r
   SMBiosTable = NULL;\r
   if (Option < SHOW_OUTLINE) {\r
@@ -477,22 +849,102 @@ DisplayStatisticsTable (
   }\r
 \r
   ShellPrintEx(-1,-1,L"============================================================\n");\r
-  pStatistics = &mStatisticsTable[0];\r
+  StatisticsPointer = &mStatisticsTable[0];\r
   Num         = SMBiosTable->NumberOfSmbiosStructures;\r
   //\r
   // display statistics table content\r
   //\r
   for (Index = 1; Index <= Num; Index++) {\r
-    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_INDEX), gShellDebug1HiiHandle, pStatistics->Index);\r
-    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_TYPE), gShellDebug1HiiHandle, pStatistics->Type);\r
-    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_HANDLE), gShellDebug1HiiHandle, pStatistics->Handle);\r
+    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_INDEX), gShellDebug1HiiHandle, StatisticsPointer->Index);\r
+    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_TYPE), gShellDebug1HiiHandle, StatisticsPointer->Type);\r
+    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_HANDLE), gShellDebug1HiiHandle, StatisticsPointer->Handle);\r
+    if (Option >= SHOW_DETAIL) {\r
+      ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_OFFSET), gShellDebug1HiiHandle, StatisticsPointer->Addr);\r
+      ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_LENGTH), gShellDebug1HiiHandle, StatisticsPointer->Length);\r
+    }\r
+\r
+    ShellPrintEx(-1,-1,L"\n");\r
+    StatisticsPointer = &mStatisticsTable[Index];\r
+/*\r
+    //\r
+    // Display 20 lines and wait for a page break\r
+    //\r
+    if (Index % 20 == 0) {\r
+      ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_ENTER_CONTINUE), gShellDebug1HiiHandle);\r
+      Status = WaitEnter ();\r
+      if (EFI_ERROR (Status)) {\r
+        if (Status == EFI_ABORTED) {\r
+          return EFI_SUCCESS;\r
+        }\r
+\r
+        return Status;\r
+      }\r
+    }\r
+*/\r
+  }\r
+\r
+  return EFI_SUCCESS;\r
+}\r
+\r
+/**\r
+  Function to display the global mSmbios64BitStatisticsTable object.\r
+\r
+  @param[in] Option             ECHO, NORMAL, or DETAIL control the amount of detail displayed.\r
+\r
+  @retval EFI_SUCCESS           print is successful.\r
+**/\r
+EFI_STATUS\r
+DisplaySmbios64BitStatisticsTable (\r
+  IN   UINT8   Option\r
+  )\r
+{\r
+  UINTN                    Index;\r
+  UINTN                    Num;\r
+  STRUCTURE_STATISTICS     *StatisticsPointer;\r
+  SMBIOS_TABLE_3_0_ENTRY_POINT *SMBiosTable;\r
+\r
+  SMBiosTable = NULL;\r
+  if (Option < SHOW_OUTLINE) {\r
+    return EFI_SUCCESS;\r
+  }\r
+  //\r
+  // display EPS information firstly\r
+  //\r
+  LibSmbios64BitGetEPS (&SMBiosTable);\r
+  if (SMBiosTable == NULL) {\r
+    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_CANNOT_ACCESS_TABLE), gShellDebug1HiiHandle);\r
+    return EFI_UNSUPPORTED;\r
+  }\r
+\r
+  ShellPrintEx(-1,-1,L"\n============================================================\n");\r
+  Smbios64BitPrintEPSInfo (SMBiosTable, Option);\r
+\r
+  if (Option < SHOW_NORMAL) {\r
+    return EFI_SUCCESS;\r
+  }\r
+\r
+  if (mSmbios64BitStatisticsTable == NULL) {\r
+    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_CANNOT_ACCESS_STATS), gShellDebug1HiiHandle);\r
+    return EFI_NOT_FOUND;\r
+  }\r
+\r
+  ShellPrintEx(-1,-1,L"============================================================\n");\r
+  StatisticsPointer = &mSmbios64BitStatisticsTable[0];\r
+  Num         = mNumberOfSmbios64BitStructures;\r
+  //\r
+  // display statistics table content\r
+  //\r
+  for (Index = 1; Index <= Num; Index++) {\r
+    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_INDEX), gShellDebug1HiiHandle, StatisticsPointer->Index);\r
+    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_TYPE), gShellDebug1HiiHandle, StatisticsPointer->Type);\r
+    ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_HANDLE), gShellDebug1HiiHandle, StatisticsPointer->Handle);\r
     if (Option >= SHOW_DETAIL) {\r
-      ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_OFFSET), gShellDebug1HiiHandle, pStatistics->Addr);\r
-      ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_LENGTH), gShellDebug1HiiHandle, pStatistics->Length);\r
+      ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_OFFSET), gShellDebug1HiiHandle, StatisticsPointer->Addr);\r
+      ShellPrintHiiEx(-1,-1,NULL,STRING_TOKEN (STR_SMBIOSVIEW_SMBIOSVIEW_LENGTH), gShellDebug1HiiHandle, StatisticsPointer->Length);\r
     }\r
 \r
     ShellPrintEx(-1,-1,L"\n");\r
-    pStatistics = &mStatisticsTable[Index];\r
+    StatisticsPointer = &mSmbios64BitStatisticsTable[Index];\r
 /*\r
     //\r
     // Display 20 lines and wait for a page break\r
@@ -522,7 +974,6 @@ DisplayStatisticsTable (
   @return   A pointer to a string representing the ShowType (or 'undefined type' if not known).\r
 **/\r
 CHAR16 *\r
-EFIAPI\r
 GetShowTypeString (\r
   UINT8 ShowType\r
   )\r
@@ -552,12 +1003,3 @@ GetShowTypeString (
   }\r
 }\r
 \r
-/*\r
-EFI_STATUS\r
-InitializeSmbiosViewApplicationGetLineHelp (\r
-  OUT CHAR16              **Str\r
-  )\r
-{\r
-  return LibCmdGetStringByToken (STRING_ARRAY_NAME, &EfiSmbiosViewGuid, STRING_TOKEN (STR_SMBIOSVIEW_LINE_HELP), Str);\r
-}\r
-*/\r