dbghelp -通过名称获取结构符号

dbghelp - Get struct symbol by name

本文关键字:获取 结构 符号 -通 dbghelp      更新时间:2023-10-16

我正在构建一个符号服务,我希望能够打印结构变量和它们的偏移量。我正在加载所需的pdb,并试图找到一个适合给定掩码的结构体。例如,我想获得结构体_RTL_CRITICAL_SECTION的详细信息。

在使用windbg时,我使用命令dt MSVCP120!_RTL_CRITICAL_SECTION并获得结构信息(正是我想要的)。但是,当我使用代码搜索符号时:

SymEnumSymbols(GetCurrentProcess(), base_addr,"MSVCP120!_RTL_CRITICAL_SECTION", enum_symbols_callback, NULL);
BOOL CALLBACK symbol_processor::enum_symbols_callback(PSYMBOL_INFO pSymInfo, ULONG SymbolSize, PVOID UserContext)
{
    printf("Name = %sn", pSymInfo->Name);
    return TRUE;
}

没有打印…意思是,面具没有对手…当掩码是一个函数时(例如"MSVCP120!std::tr2::sys::_Open_dir")

那么,我如何得到一个结构体的符号…?

谢谢!

编译前文件夹的内容

:>ls -l
-rw-rw-rw-  1 Admin 0 459 2015-09-10 10:23 structshow.cpp

来源
:>cat structshow.cpp
#include <windows.h>
#include <dbghelp.h>
#include <stdio.h>
#pragma comment (lib,"dbghelp.lib")
BOOL CALLBACK mycallback(PSYMBOL_INFO pSymInfo,ULONG,PVOID){
  printf("%sn",pSymInfo->Name);
  return true;
}
int main(){
  HMODULE hmod = LoadLibraryA("c:\windows\system32\ntdll.dll");
  HANDLE hproc = GetCurrentProcess();
  SymInitialize(hproc,"F:\symbols",TRUE);
  SymEnumTypesByName(hproc,(ULONG64)hmod,"*!_R*",mycallback,0);
  return 0;
}
使用

编译

:>..compile.bat
:>if "C:Program FilesMicrosoft Visual Studio 10.0VC" == "" ()
:>cl /Zi /EHsc /nologo /W4 /analyze *.cpp /link /RELEASE structshow.cpp
:>ls -l

编译后文件夹内容

-rw-rw-rw-  1 Admin 0     459 2015-09-10 10:23 structshow.cpp
-rwxrwxrwx  1 Admin 0   89088 2015-09-10 10:29 structshow.exe
-rw-rw-rw-  1 Admin 0   21081 2015-09-10 10:29 structshow.obj
-rw-rw-rw-  1 Admin 0 1002496 2015-09-10 10:29 structshow.pdb
-rw-rw-rw-  1 Admin 0   94208 2015-09-10 10:29 vc100.pdb

使用最新dbghelp.dll

:>copy xxxxdbghelp.dll .
        1 file(s) copied.
:>echo "do not use system dbghelp.dll it is 
outdated SymbolEnumTypesbyName is available in 
dbghelp version 6.8 and above only "

执行编译后的二进制文件

:>structshow.exe
_RTL_USER_PROCESS_PARAMETERS
_RTL_CRITICAL_SECTION <----------------------
_RTL_STACK_TRACE_ENTRY
_RTL_TRACE_BLOCK
_RTL_CRITICAL_SECTION_DEBUG
_RTL_DRIVE_LETTER_CURDIR
_RTL_TRACE_DATABASE
_RTL_TRACE_SEGMENT