2024.04.14
实验环境:

UEFI Shell命令行执行dmem命令的输出:

EFFD0018到底指向什么?

演示如何在NDB中观察鲜活的gST,这个极为重要的全局变量:

x Shell!gST
00000000`e9d68cc0  Shell!gST 
dq 0`e9d68cc0 l1
00000000`e9d68cc0  00000000`effd0018
dt -r EFI_SYSTEM_TABLE 0`effd0018
   +0x000 Hdr              : 
      +0x000 Signature        : 0x54535953`20494249
      +0x008 Revision         : 0x20046
      +0x00c HeaderSize       : 0x78
      +0x010 CRC32            : 0x98d251b8
      +0x014 Reserved         : 0
   +0x018 FirmwareVendor   : (null) 
   +0x020 FirmwareRevision : 0x10000
   +0x028 ConsoleInHandle  : 0x00000000`ef22a918 
   +0x030 ConIn            : (null) 
   +0x038 ConsoleOutHandle : 0x00000000`eeb75d18 
   +0x040 ConOut           : (null) 
   +0x048 StandardErrorHandle : 0x00000000`ef228e98 
   +0x050 StdErr           : (null) 
   +0x058 RuntimeServices  : (null) 
   +0x060 BootServices     : (null) 
   +0x068 NumberOfTableEntries : 0xd
   +0x070 ConfigurationTable : (null) 
?? sizeof(EFI_SYSTEM_TABLE)
unsigned int64 0x78
dqs 0`effd0018 l78/8
00000000`effd0018  54535953`20494249
00000000`effd0020  00000078`00020046
00000000`effd0028  00000000`98d251b8
00000000`effd0030  00000000`effde318
00000000`effd0038  00000000`00010000
00000000`effd0040  00000000`ef22a918
00000000`effd0048  00000000`eaa0e400 ConSplitterDxe!mConIn+0x10
00000000`effd0050  00000000`eeb75d18
00000000`effd0058  00000000`eeb3b020
00000000`effd0060  00000000`ef228e98
00000000`effd0068  00000000`eaa0e190 ConSplitterDxe!mStdErr+0x10
00000000`effd0070  00000000`effdff18
00000000`effd0078  00000000`3ec531d8 DxeCore!mBootServices
00000000`effd0080  00000000`0000000d
00000000`effd0088  00000000`effdfb18
dt EFI_CONFIGURATION_TABLE
   +0x000 VendorGuid       : 
   +0x010 VendorTable      : Ptr64 Void
dt EFI_CONFIGURATION_TABLE 0`effdfb18
   +0x000 VendorGuid       : 
   +0x010 VendorTable      : 0x00000000`3ec546f8 
db 0`3ec546f8
00000000`3ec546f8  01 00 00 00 00 00 00 00-00 36 6e 01 00 00 00 00  .........6n.....
00000000`3ec54708  00 00 00 00 00 00 00 00-ff ff ff ff ff ff ff ff  ................
00000000`3ec54718  d8 31 c5 3e 00 00 00 00-10 00 00 00 00 00 00 00  .1.>............
00000000`3ec54728  18 f7 df ef 00 00 00 00-18 f6 df ef 00 00 00 00  ................
00000000`3ec54738  00 00 00 00 00 00 00 00-00 00 00 00 00 00 00 00  ................
00000000`3ec54748  00 00 00 00 00 00 00 00-50 47 c5 3e 00 00 00 00  ........PG.>....
00000000`3ec54758  50 47 c5 3e 00 00 00 00-60 47 c5 3e 00 00 00 00  PG.>....`G.>....
00000000`3ec54768  60 47 c5 3e 00 00 00 00-70 47 c5 3e 00 00 00 00  `G.>....pG.>....
dq 0`3ec546f8
00000000`3ec546f8  00000000`00000001 00000000`016e3600
00000000`3ec54708  00000000`00000000 ffffffff`ffffffff
00000000`3ec54718  00000000`3ec531d8 00000000`00000010
00000000`3ec54728  00000000`efdff718 00000000`efdff618
00000000`3ec54738  00000000`00000000 00000000`00000000
00000000`3ec54748  00000000`00000000 00000000`3ec54750
00000000`3ec54758  00000000`3ec54750 00000000`3ec54760
00000000`3ec54768  00000000`3ec54760 00000000`3ec54770
dt -r EFI_RUNTIME_SERVICES 0`effdff18
   +0x000 Hdr              : 
      +0x000 Signature        : 0x56524553`544e5552
      +0x008 Revision         : 0x20046
      +0x00c HeaderSize       : 0x88
      +0x010 CRC32            : 0x1925f001
      +0x014 Reserved         : 0
   +0x018 GetTime          : (null) 
   +0x020 SetTime          : (null) 
   +0x028 GetWakeupTime    : (null) 
   +0x030 SetWakeupTime    : (null) 
   +0x038 SetVirtualAddressMap : (null) 
   +0x040 ConvertPointer   : (null) 
   +0x048 GetVariable      : (null) 
   +0x050 GetNextVariableName : (null) 
   +0x058 SetVariable      : (null) 
   +0x060 GetNextHighMonotonicCount : (null) 
   +0x068 ResetSystem      : (null) 
   +0x070 UpdateCapsule    : (null) 
   +0x078 QueryCapsuleCapabilities : (null) 
   +0x080 QueryVariableInfo : (null) 
dqs 0`effdff18 l88/8
00000000`effdff18  56524553`544e5552
00000000`effdff20  00000088`00020046
00000000`effdff28  00000000`1925f001
00000000`effdff30  00000000`eaa21740 RealTimeClock!gST+0xffffffff`ffff1678
00000000`effdff38  00000000`eaa21514 RealTimeClock!gST+0xffffffff`ffff144c
00000000`effdff40  00000000`eaa20024 RealTimeClock!gST+0xffffffff`fffeff5c
00000000`effdff48  00000000`eaa20060 RealTimeClock!gST+0xffffffff`fffeff98
00000000`effdff50  00000000`eaf818d4 RuntimeDxe!gST+0xffffffff`ffff17a4
00000000`effdff58  00000000`eaf80008 RuntimeDxe!gST+0xffffffff`fffefed8
00000000`effdff60  00000000`eacc509c VariableRuntimeDxe!gST+0xffffffff`ffff4be4
00000000`effdff68  00000000`eacc1894 VariableRuntimeDxe!gST+0xffffffff`ffff13dc
00000000`effdff70  00000000`eacc723c VariableRuntimeDxe!gST+0xffffffff`ffff6d84
00000000`effdff78  00000000`eaef01d0 EmbeddedMonotonicCounter!gST+0xffffffff`ffff0188
00000000`effdff80  00000000`eac01700 Reset!gST+0xffffffff`ffff1698
00000000`effdff88  00000000`eaac1434 CapsuleRuntimeDxe!gST+0xffffffff`ffff13bc
00000000`effdff90  00000000`eaac1334 CapsuleRuntimeDxe!gST+0xffffffff`ffff12bc
00000000`effdff98  00000000`eacc11c4 VariableRuntimeDxe!gST+0xffffffff`ffff0d0c

结合源代码:

重要数据结构(所在位置):

///
/// EFI Runtime Services Table.
///
typedef struct {
  ///
  /// The table header for the EFI Runtime Services Table.
  ///
  EFI_TABLE_HEADER                  Hdr;

  //
  // Time Services
  //
  EFI_GET_TIME                      GetTime;
  EFI_SET_TIME                      SetTime;
  EFI_GET_WAKEUP_TIME               GetWakeupTime;
  EFI_SET_WAKEUP_TIME               SetWakeupTime;

  //
  // Virtual Memory Services
  //
  EFI_SET_VIRTUAL_ADDRESS_MAP       SetVirtualAddressMap;
  EFI_CONVERT_POINTER               ConvertPointer;

  //
  // Variable Services
  //
  EFI_GET_VARIABLE                  GetVariable;
  EFI_GET_NEXT_VARIABLE_NAME        GetNextVariableName;
  EFI_SET_VARIABLE                  SetVariable;

  //
  // Miscellaneous Services
  //
  EFI_GET_NEXT_HIGH_MONO_COUNT      GetNextHighMonotonicCount;
  EFI_RESET_SYSTEM                  ResetSystem;

  //
  // UEFI 2.0 Capsule Services
  //
  EFI_UPDATE_CAPSULE                UpdateCapsule;
  EFI_QUERY_CAPSULE_CAPABILITIES    QueryCapsuleCapabilities;

  //
  // Miscellaneous UEFI 2.0 Service
  //
  EFI_QUERY_VARIABLE_INFO           QueryVariableInfo;
} EFI_RUNTIME_SERVICES;

#define EFI_BOOT_SERVICES_SIGNATURE  SIGNATURE_64 ('B','O','O','T','S','E','R','V')
#define EFI_BOOT_SERVICES_REVISION   EFI_SPECIFICATION_VERSION

///
/// EFI Boot Services Table.
///
typedef struct {
  ///
  /// The table header for the EFI Boot Services Table.
  ///
  EFI_TABLE_HEADER                              Hdr;

  //
  // Task Priority Services
  //
  EFI_RAISE_TPL                                 RaiseTPL;
  EFI_RESTORE_TPL                               RestoreTPL;

  //
  // Memory Services
  //
  EFI_ALLOCATE_PAGES                            AllocatePages;
  EFI_FREE_PAGES                                FreePages;
  EFI_GET_MEMORY_MAP                            GetMemoryMap;
  EFI_ALLOCATE_POOL                             AllocatePool;
  EFI_FREE_POOL                                 FreePool;

  //
  // Event & Timer Services
  //
  EFI_CREATE_EVENT                              CreateEvent;
  EFI_SET_TIMER                                 SetTimer;
  EFI_WAIT_FOR_EVENT                            WaitForEvent;
  EFI_SIGNAL_EVENT                              SignalEvent;
  EFI_CLOSE_EVENT                               CloseEvent;
  EFI_CHECK_EVENT                               CheckEvent;

  //
  // Protocol Handler Services
  //
  EFI_INSTALL_PROTOCOL_INTERFACE                InstallProtocolInterface;
  EFI_REINSTALL_PROTOCOL_INTERFACE              ReinstallProtocolInterface;
  EFI_UNINSTALL_PROTOCOL_INTERFACE              UninstallProtocolInterface;
  EFI_HANDLE_PROTOCOL                           HandleProtocol;
  VOID                                          *Reserved;
  EFI_REGISTER_PROTOCOL_NOTIFY                  RegisterProtocolNotify;
  EFI_LOCATE_HANDLE                             LocateHandle;
  EFI_LOCATE_DEVICE_PATH                        LocateDevicePath;
  EFI_INSTALL_CONFIGURATION_TABLE               InstallConfigurationTable;

  //
  // Image Services
  //
  EFI_IMAGE_LOAD                                LoadImage;
  EFI_IMAGE_START                               StartImage;
  EFI_EXIT                                      Exit;
  EFI_IMAGE_UNLOAD                              UnloadImage;
  EFI_EXIT_BOOT_SERVICES                        ExitBootServices;

  //
  // Miscellaneous Services
  //
  EFI_GET_NEXT_MONOTONIC_COUNT                  GetNextMonotonicCount;
  EFI_STALL                                     Stall;
  EFI_SET_WATCHDOG_TIMER                        SetWatchdogTimer;

  //
  // DriverSupport Services
  //
  EFI_CONNECT_CONTROLLER                        ConnectController;
  EFI_DISCONNECT_CONTROLLER                     DisconnectController;

  //
  // Open and Close Protocol Services
  //
  EFI_OPEN_PROTOCOL                             OpenProtocol;
  EFI_CLOSE_PROTOCOL                            CloseProtocol;
  EFI_OPEN_PROTOCOL_INFORMATION                 OpenProtocolInformation;

  //
  // Library Services
  //
  EFI_PROTOCOLS_PER_HANDLE                      ProtocolsPerHandle;
  EFI_LOCATE_HANDLE_BUFFER                      LocateHandleBuffer;
  EFI_LOCATE_PROTOCOL                           LocateProtocol;
  EFI_INSTALL_MULTIPLE_PROTOCOL_INTERFACES      InstallMultipleProtocolInterfaces;
  EFI_UNINSTALL_MULTIPLE_PROTOCOL_INTERFACES    UninstallMultipleProtocolInterfaces;

  //
  // 32-bit CRC Services
  //
  EFI_CALCULATE_CRC32                           CalculateCrc32;

  //
  // Miscellaneous Services
  //
  EFI_COPY_MEM                                  CopyMem;
  EFI_SET_MEM                                   SetMem;
  EFI_CREATE_EVENT_EX                           CreateEventEx;
} EFI_BOOT_SERVICES;

///
/// Contains a set of GUID/pointer pairs comprised of the ConfigurationTable field in the
/// EFI System Table.
///
typedef struct {
  ///
  /// The 128-bit GUID value that uniquely identifies the system configuration table.
  ///
  EFI_GUID    VendorGuid;
  ///
  /// A pointer to the table associated with VendorGuid.
  ///
  VOID        *VendorTable;
} EFI_CONFIGURATION_TABLE;

///
/// EFI System Table
///
typedef struct {
  ///
  /// The table header for the EFI System Table.
  ///
  EFI_TABLE_HEADER                   Hdr;
  ///
  /// A pointer to a null terminated string that identifies the vendor
  /// that produces the system firmware for the platform.
  ///
  CHAR16                             *FirmwareVendor;
  ///
  /// A firmware vendor specific value that identifies the revision
  /// of the system firmware for the platform.
  ///
  UINT32                             FirmwareRevision;
  ///
  /// The handle for the active console input device. This handle must support
  /// EFI_SIMPLE_TEXT_INPUT_PROTOCOL and EFI_SIMPLE_TEXT_INPUT_EX_PROTOCOL.
  ///
  EFI_HANDLE                         ConsoleInHandle;
  ///
  /// A pointer to the EFI_SIMPLE_TEXT_INPUT_PROTOCOL interface that is
  /// associated with ConsoleInHandle.
  ///
  EFI_SIMPLE_TEXT_INPUT_PROTOCOL     *ConIn;
  ///
  /// The handle for the active console output device.
  ///
  EFI_HANDLE                         ConsoleOutHandle;
  ///
  /// A pointer to the EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL interface
  /// that is associated with ConsoleOutHandle.
  ///
  EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL    *ConOut;
  ///
  /// The handle for the active standard error console device.
  /// This handle must support the EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL.
  ///
  EFI_HANDLE                         StandardErrorHandle;
  ///
  /// A pointer to the EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL interface
  /// that is associated with StandardErrorHandle.
  ///
  EFI_SIMPLE_TEXT_OUTPUT_PROTOCOL    *StdErr;
  ///
  /// A pointer to the EFI Runtime Services Table.
  ///
  EFI_RUNTIME_SERVICES               *RuntimeServices;
  ///
  /// A pointer to the EFI Boot Services Table.
  ///
  EFI_BOOT_SERVICES                  *BootServices;
  ///
  /// The number of system configuration tables in the buffer ConfigurationTable.
  ///
  UINTN                              NumberOfTableEntries;
  ///
  /// A pointer to the system configuration tables.
  /// The number of entries in the table is NumberOfTableEntries.
  ///
  EFI_CONFIGURATION_TABLE            *ConfigurationTable;
} EFI_SYSTEM_TABLE;

/**
  This is the declaration of an EFI image entry point. This entry point is
  the same for UEFI Applications, UEFI OS Loaders, and UEFI Drivers including
  both device drivers and bus drivers.

  @param[in]  ImageHandle       The firmware allocated handle for the UEFI image.
  @param[in]  SystemTable       A pointer to the EFI System Table.

  @retval EFI_SUCCESS           The operation completed successfully.
  @retval Others                An unexpected error occurred.
**/
typedef
EFI_STATUS
(EFIAPI *EFI_IMAGE_ENTRY_POINT)(
  IN  EFI_HANDLE                   ImageHandle,
  IN  EFI_SYSTEM_TABLE             *SystemTable
  );

用NDB将下面的UEFI的Shell命令跟踪观察学习一遍,对于熟悉UEFI将是有帮助的:

作者:朱博渊  创建时间:2024-04-14 15:47
最后编辑:朱博渊  更新时间:2024-12-20 17:01