ReactOS  0.4.14-dev-606-g14ebc0b
pdb.c File Reference
#include <ntstatus.h>
#include <windows.h>
#include <dbghelp.h>
#include <cvconst.h>
#include <stdio.h>
#include <delayimp.h>
#include "wine/test.h"
Include dependency graph for pdb.c:

Go to the source code of this file.

Classes

struct  _test_context
 
struct  _test_data
 
struct  _symregcallback_context
 
struct  _symregcallback_test_data
 

Macros

#define WIN32_NO_STATUS
 
#define ok_ulonglong(expression, result)
 
#define init_sym(fInvadeProcess)   init_sym_imp(fInvadeProcess, __FILE__, __LINE__)
 
#define INIT_PSYM(buff)
 

Typedefs

typedef struct _test_context test_context
 
typedef struct _symregcallback_context symregcallback_context
 

Functions

void create_compressed_files ()
 
int extract_msvc_dll (char szFile[MAX_PATH], char szPath[MAX_PATH])
 
void cleanup_msvc_dll ()
 
static HANDLE proc ()
 
static BOOL init_sym_imp (BOOL fInvadeProcess, const char *file, int line)
 
static void deinit_sym ()
 
BOOL get_module_version (_In_ HMODULE mod, _Out_ VS_FIXEDFILEINFO *fileinfo)
 
static void init_dbghelp_version ()
 
static BOOL WINAPI SymRegisterCallbackW64_Stub (HANDLE hProcess, PSYMBOL_REGISTERED_CALLBACK64 CallbackFunction, ULONG64 UserContext)
 
FARPROC WINAPI DliFailHook (unsigned dliNotify, PDelayLoadInfo pdli)
 
static BOOL supports_pdb (HANDLE hProc, DWORD64 BaseAddress)
 
static void test_SymFromName (HANDLE hProc, DWORD64 BaseAddress)
 
static void test_SymFromAddr (HANDLE hProc, DWORD64 BaseAddress)
 
static BOOL CALLBACK EnumSymProc (PSYMBOL_INFO pSymInfo, ULONG SymbolSize, PVOID UserContext)
 
static void test_SymEnumSymbols (HANDLE hProc, DWORD64 BaseAddress)
 
static BOOL CALLBACK SymRegisterCallback64Proc (HANDLE hProcess, ULONG ActionCode, ULONG64 CallbackData, ULONG64 UserContext)
 
static void test_SymRegCallback (HANDLE hProc, const char *szModuleName, BOOL testANSI)
 
 START_TEST (pdb)
 

Variables

static VS_FIXEDFILEINFO dbghelpFileVer
 
static int g_SymRegisterCallbackW64NotFound = 0
 
PfnDliHook __pfnDliFailureHook2 = DliFailHook
 
static struct _test_data test_data []
 
static struct _symregcallback_test_data symregcallback_test_data []
 

Macro Definition Documentation

◆ INIT_PSYM

#define INIT_PSYM (   buff)
Value:
do { \
memset((buff), 0, sizeof((buff))); \
((PSYMBOL_INFO)(buff))->SizeOfStruct = sizeof(SYMBOL_INFO); \
((PSYMBOL_INFO)(buff))->MaxNameLen = MAX_SYM_NAME; \
} while (0)
struct _SYMBOL_INFO * PSYMBOL_INFO
#define MAX_SYM_NAME
Definition: compat.h:632
static unsigned char buff[32768]
Definition: fatten.c:17

Definition at line 55 of file pdb.c.

◆ init_sym

#define init_sym (   fInvadeProcess)    init_sym_imp(fInvadeProcess, __FILE__, __LINE__)

Definition at line 53 of file pdb.c.

◆ ok_ulonglong

#define ok_ulonglong (   expression,
  result 
)
Value:
do { \
ULONG64 _value = (expression); \
ULONG64 _result = (result); \
ok(_value == (result), "Wrong value for '%s', expected: " #result " (%s), got: %s\n", \
#expression, wine_dbgstr_longlong(_result), wine_dbgstr_longlong(_value)); \
} while (0)
static __inline const char * wine_dbgstr_longlong(ULONGLONG ll)
Definition: compat.h:41
GLuint64EXT * result
Definition: glext.h:11304

Definition at line 18 of file pdb.c.

◆ WIN32_NO_STATUS

#define WIN32_NO_STATUS

Definition at line 9 of file pdb.c.

Typedef Documentation

◆ symregcallback_context

◆ test_context

Function Documentation

◆ cleanup_msvc_dll()

void cleanup_msvc_dll ( )

Definition at line 90 of file data.c.

91 {
92  char szFile[MAX_PATH];
93  BOOL ret;
94  const char* dir = tmpdir();
95 
96  sprintf(szFile, "%s\\uffs.pdb", dir);
97  ret = DeleteFileA(szFile);
98  ok(ret, "DeleteFileA failed(%d)\n", GetLastError());
99 
100  sprintf(szFile, "%s\\uffs.dll", dir);
101  ret = DeleteFileA(szFile);
102  ok(ret, "DeleteFileA failed(%d)\n", GetLastError());
104  ok(ret, "RemoveDirectoryA failed(%d)\n", GetLastError());
105 }
static const char * tmpdir()
Definition: data.c:18
DWORD WINAPI GetLastError(VOID)
Definition: except.c:1059
#define sprintf(buf, format,...)
Definition: sprintf.c:55
unsigned int BOOL
Definition: ntddk_ex.h:94
BOOL WINAPI DeleteFileA(IN LPCSTR lpFileName)
Definition: delete.c:24
unsigned int dir
Definition: maze.c:112
#define MAX_PATH
Definition: compat.h:26
int ret
#define ok(value,...)
Definition: atltest.h:57
BOOL WINAPI RemoveDirectoryA(IN LPCSTR lpPathName)
Definition: dir.c:714

Referenced by START_TEST().

◆ create_compressed_files()

void create_compressed_files ( )

◆ deinit_sym()

static void deinit_sym ( )
static

Definition at line 48 of file pdb.c.

49 {
50  SymCleanup(proc());
51 }
BOOL WINAPI SymCleanup(HANDLE hProcess)
Definition: dbghelp.c:416
static HANDLE proc()
Definition: pdb.c:32

Referenced by START_TEST(), and test_SymRegCallback().

◆ DliFailHook()

FARPROC WINAPI DliFailHook ( unsigned  dliNotify,
PDelayLoadInfo  pdli 
)

Definition at line 204 of file pdb.c.

205 {
206  /* Was the failure a function, and did we get info */
207  if (dliNotify == dliFailGetProc && pdli)
208  {
209  /* Is it our function? */
210  if (pdli->dlp.fImportByName && !strcmp(pdli->dlp.szProcName, "SymRegisterCallbackW64"))
211  {
212  /* Redirect execution to the stub */
214  }
215  }
216  /* This is not the function you are looking for, continue default behavior (throw exception) */
217  return NULL;
218 }
static BOOL WINAPI SymRegisterCallbackW64_Stub(HANDLE hProcess, PSYMBOL_REGISTERED_CALLBACK64 CallbackFunction, ULONG64 UserContext)
Definition: pdb.c:197
BOOL fImportByName
Definition: delayimp.h:57
LPCSTR szProcName
Definition: delayimp.h:60
DelayLoadProc dlp
Definition: delayimp.h:71
smooth NULL
Definition: ftsmooth.c:416
int strcmp(const char *String1, const char *String2)
Definition: utclib.c:469
int(* FARPROC)()
Definition: compat.h:28

◆ EnumSymProc()

static BOOL CALLBACK EnumSymProc ( PSYMBOL_INFO  pSymInfo,
ULONG  SymbolSize,
PVOID  UserContext 
)
static

Definition at line 439 of file pdb.c.

440 {
441  test_context* ctx = UserContext;
442 
443  if (ctx->Index < ARRAYSIZE(test_data))
444  {
445  ok_ulonglong(pSymInfo->ModBase, ctx->BaseAddress);
446  ok_ulonglong(pSymInfo->Address, ctx->BaseAddress + test_data[ctx->Index].AddressOffset);
447  ok_hex(pSymInfo->Tag, test_data[ctx->Index].Tag);
448  ok_str(pSymInfo->Name, test_data[ctx->Index].Name);
449 
450  ctx->Index++;
451  }
452  else
453  {
454  ok(0, "Out of bounds (%lu), max is: %i!\n", ctx->Index, ARRAYSIZE(test_data));
455  }
456 
457  return TRUE;
458 }
ULONG Tag
Definition: compat.h:706
CHAR Name[1]
Definition: compat.h:709
#define TRUE
Definition: types.h:120
#define ok_str(x, y)
Definition: atltest.h:127
#define ARRAYSIZE(array)
Definition: filtermapper.c:47
ULONG64 Address
Definition: compat.h:703
#define ok_hex(expression, result)
Definition: atltest.h:94
ULONG64 ModBase
Definition: compat.h:700
#define ok(value,...)
Definition: atltest.h:57
DWORD64 BaseAddress
Definition: pdb.c:417
#define ok_ulonglong(expression, result)
Definition: pdb.c:18
SIZE_T Index
Definition: pdb.c:418

Referenced by test_SymEnumSymbols().

◆ extract_msvc_dll()

int extract_msvc_dll ( char  szFile[MAX_PATH],
char  szPath[MAX_PATH] 
)

Definition at line 72 of file data.c.

73 {
74  const char* dir = tmpdir();
76  ok(ret, "CreateDirectoryA failed(%d)\n", GetLastError());
77 
78  sprintf(szFile, "%s\\uffs.pdb", dir);
79  if (!extract_one(szFile, "msvc_uffs.pdb"))
80  return 0;
81 
82  sprintf(szFile, "%s\\uffs.dll", dir);
83  if (!extract_one(szFile, "msvc_uffs.dll"))
84  return 0;
85 
86  strcpy(szPath, dir);
87  return 1;
88 }
static int extract_one(const char *filename, const char *resid)
Definition: data.c:28
static const char * tmpdir()
Definition: data.c:18
DWORD WINAPI GetLastError(VOID)
Definition: except.c:1059
#define sprintf(buf, format,...)
Definition: sprintf.c:55
unsigned int BOOL
Definition: ntddk_ex.h:94
BOOL WINAPI CreateDirectoryA(IN LPCSTR lpPathName, IN LPSECURITY_ATTRIBUTES lpSecurityAttributes)
Definition: dir.c:37
smooth NULL
Definition: ftsmooth.c:416
unsigned int dir
Definition: maze.c:112
int ret
LPCWSTR szPath
Definition: env.c:35
#define ok(value,...)
Definition: atltest.h:57
char * strcpy(char *DstString, const char *SrcString)
Definition: utclib.c:388

Referenced by START_TEST().

◆ get_module_version()

BOOL get_module_version ( _In_ HMODULE  mod,
_Out_ VS_FIXEDFILEINFO fileinfo 
)

Definition at line 62 of file pdb.c.

65 {
66  BOOL res = FALSE;
67  HRSRC hResInfo;
68  char *errmsg;
69  DWORD dwSize, errcode = 0;
70  UINT uLen;
71  HGLOBAL hResData = 0;
72  LPVOID pRes = NULL;
73  HLOCAL pResCopy = 0;
74  VS_FIXEDFILEINFO *lpFfi;
75 
76  if (fileinfo == NULL)
77  {
78  errmsg = "fileinfo is NULL.\n";
79  goto cleanup;
80  }
81 
83  if (hResInfo == 0)
84  {
85  errmsg = "FindResource failed";
87  goto cleanup;
88  }
89 
90  dwSize = SizeofResource(mod, hResInfo);
91  if (dwSize == 0)
92  {
93  errmsg = "SizeofResource failed";
95  goto cleanup;
96  }
97 
98  hResData = LoadResource(mod, hResInfo);
99  if (hResData == 0)
100  {
101  errmsg = "LoadResource failed";
102  errcode = GetLastError();
103  goto cleanup;
104  }
105 
106  pRes = LockResource(hResData);
107  if (pRes == NULL)
108  {
109  errmsg = "LockResource failed";
110  errcode = GetLastError();
111  goto cleanup;
112  }
113 
114  pResCopy = LocalAlloc(LMEM_FIXED, dwSize);
115  if (pResCopy == NULL)
116  {
117  errmsg = "LocalAlloc failed";
118  errcode = GetLastError();
119  goto cleanup;
120  }
121 
122  CopyMemory(pResCopy, pRes, dwSize);
123 
124  if (VerQueryValueW(pResCopy, L"\\", (LPVOID*)&lpFfi, &uLen))
125  {
126  *fileinfo = *lpFfi;
127  res = TRUE;
128  }
129 
130 cleanup:
131  /* cleanup */
132  if (hResData != 0)
133  FreeResource(hResData);
134  if (pResCopy != NULL)
135  LocalFree(pResCopy);
136  /* if it was good */
137  if (res == TRUE)
138  return TRUE;
139  /* failure path */
140  if (errcode == 0)
141  trace("get_module_version - %s.\n", errmsg);
142  else
143  trace("get_module_version - %s (lasterror %d).\n", errmsg, errcode);
144  return FALSE;
145 }
#define MAKEINTRESOURCE
Definition: winuser.h:591
#define TRUE
Definition: types.h:120
#define FindResource
Definition: winbase.h:3627
DWORD WINAPI GetLastError(VOID)
Definition: except.c:1059
LPVOID WINAPI LockResource(HGLOBAL handle)
Definition: res.c:550
unsigned int BOOL
Definition: ntddk_ex.h:94
BOOL WINAPI FreeResource(HGLOBAL handle)
Definition: res.c:559
HGLOBAL WINAPI LoadResource(HINSTANCE hModule, HRSRC hRsrc)
Definition: res.c:532
smooth NULL
Definition: ftsmooth.c:416
EXPORT int errmsg(char *msg, va_alist)
Definition: comerr.c:192
#define RT_VERSION
Definition: pedump.c:376
#define LMEM_FIXED
Definition: winbase.h:349
int errcode
Definition: crtdefs.h:352
#define trace
Definition: atltest.h:70
#define CopyMemory
Definition: winbase.h:1640
unsigned long DWORD
Definition: ntddk_ex.h:95
static const WCHAR L[]
Definition: oid.c:1250
HLOCAL NTAPI LocalFree(HLOCAL hMem)
Definition: heapmem.c:1577
unsigned int UINT
Definition: ndis.h:50
#define VS_VERSION_INFO
DWORD WINAPI SizeofResource(HINSTANCE hModule, HRSRC hRsrc)
Definition: res.c:568
GLuint res
Definition: glext.h:9613
char * cleanup(char *str)
Definition: wpickclick.c:99
HLOCAL NTAPI LocalAlloc(UINT uFlags, SIZE_T dwBytes)
Definition: heapmem.c:1373
PSDBQUERYRESULT_VISTA PVOID DWORD * dwSize
Definition: env.c:54
static int mod
Definition: i386-dis.c:1273
BOOL WINAPI VerQueryValueW(LPCVOID pBlock, LPCWSTR lpSubBlock, LPVOID *lplpBuffer, PUINT puLen)
Definition: version.c:1049

Referenced by init_dbghelp_version().

◆ init_dbghelp_version()

static void init_dbghelp_version ( )
static

Definition at line 148 of file pdb.c.

149 {
151  WCHAR filenameW[MAX_PATH + 1];
152  HMODULE hDLL;
153  DWORD fileLen;
154  VS_FIXEDFILEINFO fileInfo;
155 
156  memset(&dbghelpFileVer, 0, sizeof(dbghelpFileVer));
157 
158  /* get internal file version */
159  v = ImagehlpApiVersion();
160  if (v == NULL)
161  return;
162 
163  /* get module file version */
164  hDLL = GetModuleHandleW(L"dbghelp.dll");
165  if (hDLL == 0)
166  {
167  ok(FALSE, "Dbghelp.dll is not loaded!\n");
168  return;
169  }
170  if (!get_module_version(hDLL, &fileInfo))
171  memset(&fileInfo, 0, sizeof(fileInfo));
172  dbghelpFileVer = fileInfo;
173 
174  /* get full file path */
175  fileLen = GetModuleFileNameW(hDLL, filenameW, MAX_PATH + 1);
176  if (fileLen == 0)
177  {
178  ok(FALSE, "GetModuleFileNameW for dbghelp.dll failed!\n");
179  return;
180  }
181 
182  trace("Using %S\n", filenameW);
183  trace(" API-Version: %hu.%hu.%hu (%hu)\n",
184  v->MajorVersion, v->MinorVersion, v->Revision, v->Reserved);
185 
186  trace(" Fileversion: %hu.%hu.%hu.%hu\n",
187  HIWORD(fileInfo.dwProductVersionMS),
188  LOWORD(fileInfo.dwProductVersionMS),
189  HIWORD(fileInfo.dwProductVersionLS),
190  LOWORD(fileInfo.dwProductVersionLS));
191 }
DWORD WINAPI GetModuleFileNameW(HINSTANCE hModule, LPWSTR lpFilename, DWORD nSize)
Definition: loader.c:609
BOOL get_module_version(_In_ HMODULE mod, _Out_ VS_FIXEDFILEINFO *fileinfo)
Definition: pdb.c:62
static const WCHAR filenameW[]
Definition: amstream.c:41
static VS_FIXEDFILEINFO dbghelpFileVer
Definition: pdb.c:147
smooth NULL
Definition: ftsmooth.c:416
#define trace
Definition: atltest.h:70
__wchar_t WCHAR
Definition: xmlstorage.h:180
#define MAX_PATH
Definition: compat.h:26
unsigned long DWORD
Definition: ntddk_ex.h:95
static const WCHAR L[]
Definition: oid.c:1250
const GLdouble * v
Definition: gl.h:2040
#define ok(value,...)
Definition: atltest.h:57
DWORD dwProductVersionLS
Definition: compat.h:562
#define HIWORD(l)
Definition: typedefs.h:246
HMODULE WINAPI GetModuleHandleW(LPCWSTR lpModuleName)
Definition: loader.c:847
LPAPI_VERSION WINAPI ImagehlpApiVersion(VOID)
Definition: dbghelp.c:657
#define memset(x, y, z)
Definition: compat.h:39
DWORD dwProductVersionMS
Definition: compat.h:561
#define LOWORD(l)
Definition: pedump.c:82

Referenced by START_TEST().

◆ init_sym_imp()

static BOOL init_sym_imp ( BOOL  fInvadeProcess,
const char file,
int  line 
)
static

Definition at line 37 of file pdb.c.

38 {
39  if (!SymInitialize(proc(), NULL, fInvadeProcess))
40  {
42  ok_(file, line)(0, "Failed to init: 0x%x\n", err);
43  return FALSE;
44  }
45  return TRUE;
46 }
#define TRUE
Definition: types.h:120
DWORD WINAPI GetLastError(VOID)
Definition: except.c:1059
static HANDLE proc()
Definition: pdb.c:32
smooth NULL
Definition: ftsmooth.c:416
BOOL WINAPI SymInitialize(HANDLE hProcess, PCSTR UserSearchPath, BOOL fInvadeProcess)
Definition: dbghelp.c:393
Definition: parser.c:48
unsigned long DWORD
Definition: ntddk_ex.h:95
#define err(...)
#define ok_(x1, x2)
Definition: atltest.h:61
Definition: fci.c:126

◆ proc()

static HANDLE proc ( )
static

Definition at line 32 of file pdb.c.

33 {
34  return GetCurrentProcess();
35 }
HANDLE WINAPI GetCurrentProcess(VOID)
Definition: proc.c:1138

Referenced by _call_procedure(), _TestVesion(), abort_dochost_tasks(), ACTION_CallDllFunction(), add_script_runner(), AddrOf(), ATL::CImage::COMMON::AddrOf(), alloc_async_task(), build_format_strings(), CallWindowProcT(), COMCTL32_SubclassProc(), CUSTOMPROC_wrapper(), DefSubclassProc(), deinit_sym(), device_process_message(), download_to_cache(), dwarfargvalue(), dwarfpctoline(), EnumDateFormatsA(), EnumDateFormatsExA(), EnumDateFormatsExW(), EnumDateFormatsW(), EnumSystemLocalesEx(), EnumTimeFormatsA(), EnumTimeFormatsW(), for_each_iface(), for_each_serializable(), FrLdrAddPageMapping(), FTPFtw(), FTPFtwL2(), get_ndr_types_params(), get_shiminfo(), GetWindowSubclass(), gl_tab_completion(), ATL::CWndProcThunk::Init(), init_async(), init_sym_imp(), IntSyscall(), key_call(), KiInitializeContextThread(), LoadProc(), MACRO_RegisterRoutine(), mmuaddpage(), mmugetpage(), MyUserYield(), ProcessPrefsFile(), push_dochost_task(), push_task(), readproc(), CardWindow::RegisterDropZone(), RemoveWindowSubclass(), RosSymGetAddressInformation(), rpc_broadcast(), rpc_broadcast_exp(), run_customdraw_scenario(), RunDLL(), Set(), CardRegion::SetAddCardProc(), CardButton::SetButtonProc(), CardRegion::SetClickProc(), CardRegion::SetClickReleaseProc(), CardRegion::SetDblClickProc(), CardRegion::SetDragRule(), CardRegion::SetDropRule(), CardRegion::SetRemoveCardProc(), CardWindow::SetResizeProc(), SetWindowSubclass(), START_TEST(), StubGetProcAddress(), Syscall(), test___getmainargs_parent(), test_ActiveXObject(), test_FreeLibrary(), test_GetProcAddress(), test_GetProcessHandleFromHwnd(), test_interthread_messages(), test_invalid_stdin(), Test_layers(), test_LoadLibraryA(), test_LoadLibraryExA(), test_LoadLibraryExW(), test_LoadLibraryW(), test_LresultFromObject(), test_procedures(), Test_repeatlayer(), test_stdout_handle(), test_updown_buddy(), test_wordbreak_proc(), universal(), wined3d_unregister_window(), wined3d_wndproc(), write_iface_fs(), write_param_fs(), and write_proc_func_header().

◆ START_TEST()

START_TEST ( pdb  )

Definition at line 564 of file pdb.c.

565 {
566  char szDllName[MAX_PATH];
567  char szDllPath[MAX_PATH], szOldDir[MAX_PATH];
568 #ifdef _M_IX86
569  HMODULE hMod;
570 #endif
573 
575  Options &= ~(SYMOPT_UNDNAME);
576  //Options |= SYMOPT_DEBUG;
578 
579  if (!extract_msvc_dll(szDllName, szDllPath))
580  {
581  ok(0, "Failed extracting files\n");
582  return;
583  }
584 
586 
587  if (init_sym(FALSE))
588  {
590  BaseAddress = SymLoadModule64(proc(), NULL, szDllName, NULL, 0x600000, 0);
591  dwErr = GetLastError();
592 
593  ok_ulonglong(BaseAddress, 0x600000);
595 
596  if (BaseAddress == 0x600000)
597  {
598  trace("Module loaded by SymLoadModule64\n");
602  }
603 
604  deinit_sym();
605  }
606 
607  /* This needs to load the module by itself */
610 
611 #ifdef _M_IX86
612  hMod = LoadLibraryA(szDllName);
613  if (hMod)
614  {
615  BaseAddress = (DWORD64)(DWORD_PTR)hMod;
616  /* Make sure we can find the pdb */
617  GetCurrentDirectoryA(_countof(szOldDir), szOldDir);
618  SetCurrentDirectoryA(szDllPath);
619  /* Invade process */
620  if (init_sym(TRUE))
621  {
622  trace("Module loaded by LoadLibraryA\n");
626 
627  deinit_sym();
628  }
629  /* Restore working dir */
630  SetCurrentDirectoryA(szOldDir);
631 
632  FreeLibrary(hMod);
633  }
634 #endif
635 
637 }
#define TRUE
Definition: types.h:120
#define ERROR_SUCCESS
Definition: deptool.c:10
static void deinit_sym()
Definition: pdb.c:48
static const WCHAR szDllName[]
Definition: sip.c:61
DWORD WINAPI SymSetOptions(DWORD opts)
Definition: dbghelp.c:443
#define _countof(array)
Definition: fontsub.cpp:30
DWORD WINAPI GetLastError(VOID)
Definition: except.c:1059
static void test_SymFromName(HANDLE hProc, DWORD64 BaseAddress)
Definition: pdb.c:238
static HANDLE proc()
Definition: pdb.c:32
static void test_SymRegCallback(HANDLE hProc, const char *szModuleName, BOOL testANSI)
Definition: pdb.c:520
enum OPTION_FLAGS Options
Definition: stats.c:44
#define ok_hex(expression, result)
Definition: atltest.h:94
void cleanup_msvc_dll()
Definition: data.c:90
HINSTANCE WINAPI DECLSPEC_HOTPATCH LoadLibraryA(LPCSTR lpLibFileName)
Definition: loader.c:111
smooth NULL
Definition: ftsmooth.c:416
DWORD dwErr
Definition: service.c:36
DWORD64 WINAPI SymLoadModule64(HANDLE hProcess, HANDLE hFile, PCSTR ImageName, PCSTR ModuleName, DWORD64 BaseOfDll, DWORD SizeOfDll)
Definition: module.c:673
_In_ HANDLE _Outptr_result_bytebuffer_ ViewSize PVOID * BaseAddress
Definition: mmfuncs.h:404
#define FreeLibrary(x)
Definition: compat.h:413
#define trace
Definition: atltest.h:70
#define MAX_PATH
Definition: compat.h:26
unsigned long DWORD
Definition: ntddk_ex.h:95
#define SetLastError(x)
Definition: compat.h:417
#define SYMOPT_UNDNAME
Definition: compat.h:645
BOOL WINAPI SetCurrentDirectoryA(IN LPCSTR lpPathName)
Definition: path.c:2205
uint32_t DWORD_PTR
Definition: typedefs.h:63
int extract_msvc_dll(char szFile[MAX_PATH], char szPath[MAX_PATH])
Definition: data.c:72
uint64_t DWORD64
Definition: typedefs.h:65
static void init_dbghelp_version()
Definition: pdb.c:148
static void test_SymEnumSymbols(HANDLE hProc, DWORD64 BaseAddress)
Definition: pdb.c:460
#define ok(value,...)
Definition: atltest.h:57
DWORD WINAPI GetCurrentDirectoryA(IN DWORD nBufferLength, OUT LPSTR lpBuffer)
Definition: path.c:2145
#define init_sym(fInvadeProcess)
Definition: pdb.c:53
DWORD WINAPI SymGetOptions(void)
Definition: dbghelp.c:458
#define ok_ulonglong(expression, result)
Definition: pdb.c:18
static void test_SymFromAddr(HANDLE hProc, DWORD64 BaseAddress)
Definition: pdb.c:306

◆ supports_pdb()

static BOOL supports_pdb ( HANDLE  hProc,
DWORD64  BaseAddress 
)
static

Definition at line 225 of file pdb.c.

226 {
227  IMAGEHLP_MODULE64 ModuleInfo;
228  BOOL Ret;
229 
230  memset(&ModuleInfo, 0, sizeof(ModuleInfo));
231  ModuleInfo.SizeOfStruct = sizeof(ModuleInfo);
232  Ret = SymGetModuleInfo64(hProc, BaseAddress, &ModuleInfo);
233 
234  return Ret && ModuleInfo.SymType == SymPdb;
235 }
SYM_TYPE SymType
Definition: compat.h:893
unsigned int BOOL
Definition: ntddk_ex.h:94
DWORD SizeOfStruct
Definition: compat.h:887
_In_ HANDLE _Outptr_result_bytebuffer_ ViewSize PVOID * BaseAddress
Definition: mmfuncs.h:404
Definition: compat.h:716
#define memset(x, y, z)
Definition: compat.h:39
BOOL WINAPI SymGetModuleInfo64(HANDLE hProcess, DWORD64 dwAddr, PIMAGEHLP_MODULE64 ModuleInfo)
Definition: module.c:1013

Referenced by test_SymEnumSymbols(), test_SymFromAddr(), and test_SymFromName().

◆ SymRegisterCallback64Proc()

static BOOL CALLBACK SymRegisterCallback64Proc ( HANDLE  hProcess,
ULONG  ActionCode,
ULONG64  CallbackData,
ULONG64  UserContext 
)
static

Definition at line 496 of file pdb.c.

501 {
503  ctx = (symregcallback_context*)(ULONG_PTR)UserContext;
504 
505  if (ctx->idx > sizeof(symregcallback_test_data))
506  {
507  ok(FALSE, "SymRegisterCallback64Proc: Too many calls.\n");
508  }
509  else
510  {
511  ok(ActionCode == symregcallback_test_data[ctx->idx].ActionCode,
512  "ActionCode (idx %u) expected %u, got %u\n",
513  ctx->idx, symregcallback_test_data[ctx->idx].ActionCode, ActionCode);
514  }
515  ctx->idx++;
516 
517  return FALSE;
518 }
uint32_t ULONG_PTR
Definition: typedefs.h:63
#define ok(value,...)
Definition: atltest.h:57
static struct _symregcallback_test_data symregcallback_test_data[]

Referenced by test_SymRegCallback().

◆ SymRegisterCallbackW64_Stub()

static BOOL WINAPI SymRegisterCallbackW64_Stub ( HANDLE  hProcess,
PSYMBOL_REGISTERED_CALLBACK64  CallbackFunction,
ULONG64  UserContext 
)
static

Definition at line 197 of file pdb.c.

198 {
200  return FALSE;
201 }
static int g_SymRegisterCallbackW64NotFound
Definition: pdb.c:194

Referenced by DliFailHook().

◆ test_SymEnumSymbols()

static void test_SymEnumSymbols ( HANDLE  hProc,
DWORD64  BaseAddress 
)
static

Definition at line 460 of file pdb.c.

461 {
462  BOOL Ret;
463  test_context ctx;
464 
465  ctx.Index = 0;
466  ctx.BaseAddress = BaseAddress;
467 
468  if (!supports_pdb(hProc, ctx.BaseAddress))
469  {
470  skip("dbghelp.dll too old or cannot enumerate symbols!\n");
471  }
472  else
473  {
474  Ret = SymEnumSymbols(hProc, ctx.BaseAddress, NULL, EnumSymProc, &ctx);
475  ok_int(Ret, TRUE);
477  }
478 }
#define TRUE
Definition: types.h:120
#define ARRAYSIZE(array)
Definition: filtermapper.c:47
unsigned int BOOL
Definition: ntddk_ex.h:94
smooth NULL
Definition: ftsmooth.c:416
#define ok_int(expression, result)
Definition: atltest.h:134
_In_ HANDLE _Outptr_result_bytebuffer_ ViewSize PVOID * BaseAddress
Definition: mmfuncs.h:404
BOOL WINAPI SymEnumSymbols(HANDLE hProcess, ULONG64 BaseOfDll, PCSTR Mask, PSYM_ENUMERATESYMBOLS_CALLBACK EnumSymbolsCallback, PVOID UserContext)
Definition: symbol.c:1155
#define skip(...)
Definition: atltest.h:64
DWORD64 BaseAddress
Definition: pdb.c:417
static BOOL CALLBACK EnumSymProc(PSYMBOL_INFO pSymInfo, ULONG SymbolSize, PVOID UserContext)
Definition: pdb.c:439
static BOOL supports_pdb(HANDLE hProc, DWORD64 BaseAddress)
Definition: pdb.c:225
SIZE_T Index
Definition: pdb.c:418

Referenced by START_TEST().

◆ test_SymFromAddr()

static void test_SymFromAddr ( HANDLE  hProc,
DWORD64  BaseAddress 
)
static

Definition at line 306 of file pdb.c.

307 {
308  BOOL Ret;
309  char buffer[sizeof(SYMBOL_INFO) + MAX_SYM_NAME * sizeof(TCHAR)];
310  PSYMBOL_INFO pSymbol = (PSYMBOL_INFO)buffer;
311 
312  DWORD64 Displacement;
313  DWORD dwErr;
314 
315  /* No address found before load address of module */
316  Displacement = 0;
317  INIT_PSYM(buffer);
318  Ret = SymFromAddr(hProc, BaseAddress -1, &Displacement, pSymbol);
319  dwErr = GetLastError();
320  ok_int(Ret, FALSE);
322 
323  /* Right at the start of the module is recognized as the first symbol found */
324  Displacement = 0;
325  INIT_PSYM(buffer);
326  Ret = SymFromAddr(hProc, BaseAddress, &Displacement, pSymbol);
327  ok_int(Ret, TRUE);
328  ok_ulonglong(Displacement, 0xffffffffffffffff);
329  ok_ulonglong(pSymbol->ModBase, BaseAddress);
330  ok_hex(pSymbol->Flags, 0);
331  ok_ulonglong(pSymbol->Address, BaseAddress + 0x1010);
332  ok_hex(pSymbol->Tag, SymTagFunction);
333  ok_str(pSymbol->Name, "DllMain");
334 
335  /* The actual first instruction of the function */
336  Displacement = 0;
337  INIT_PSYM(buffer);
338  Ret = SymFromAddr(hProc, BaseAddress + 0x1010, &Displacement, pSymbol);
339  ok_int(Ret, TRUE);
340  ok_ulonglong(Displacement, 0);
341  ok_ulonglong(pSymbol->ModBase, BaseAddress);
342  ok_hex(pSymbol->Flags, 0);
343  ok_ulonglong(pSymbol->Address, BaseAddress + 0x1010);
344  ok_hex(pSymbol->Tag, SymTagFunction);
345  ok_str(pSymbol->Name, "DllMain");
346 
347  /* The last instruction in the function */
348  Displacement = 0;
349  INIT_PSYM(buffer);
350  Ret = SymFromAddr(hProc, BaseAddress + 0x102D, &Displacement, pSymbol);
351  ok_int(Ret, TRUE);
352  ok_ulonglong(Displacement, 0x1d);
353  ok_ulonglong(pSymbol->ModBase, BaseAddress);
354  ok_hex(pSymbol->Flags, 0);
355  ok_ulonglong(pSymbol->Address, BaseAddress + 0x1010);
356  ok_hex(pSymbol->Tag, SymTagFunction);
357  ok_str(pSymbol->Name, "DllMain");
358 
359  /* The padding below the function */
360  Displacement = 0;
361  INIT_PSYM(buffer);
362  Ret = SymFromAddr(hProc, BaseAddress + 0x102E, &Displacement, pSymbol);
363  ok_int(Ret, TRUE);
364  ok_ulonglong(Displacement, 0x1e);
365  ok_ulonglong(pSymbol->ModBase, BaseAddress);
366  ok_hex(pSymbol->Flags, 0);
367  ok_ulonglong(pSymbol->Address, BaseAddress + 0x1010);
368  ok_hex(pSymbol->Tag, SymTagFunction);
369  ok_str(pSymbol->Name, "DllMain");
370 
371  /* One byte before the next function */
372  Displacement = 0;
373  INIT_PSYM(buffer);
374  Ret = SymFromAddr(hProc, BaseAddress + 0x103f, &Displacement, pSymbol);
375  ok_int(Ret, TRUE);
376  ok_ulonglong(Displacement, 0x2f);
377  ok_ulonglong(pSymbol->ModBase, BaseAddress);
378  ok_hex(pSymbol->Flags, 0);
379  ok_ulonglong(pSymbol->Address, BaseAddress + 0x1010);
380  ok_hex(pSymbol->Tag, SymTagFunction);
381  ok_str(pSymbol->Name, "DllMain");
382 
383  /* First byte of the next function */
384  Displacement = 0;
385  INIT_PSYM(buffer);
386  Ret = SymFromAddr(hProc, BaseAddress + 0x1040, &Displacement, pSymbol);
387  ok_int(Ret, TRUE);
388  ok_ulonglong(Displacement, 0);
389  ok_ulonglong(pSymbol->ModBase, BaseAddress);
390  ok_hex(pSymbol->Flags, 0);
391  ok_ulonglong(pSymbol->Address, BaseAddress + 0x1040);
392  ok_hex(pSymbol->Tag, SymTagFunction);
393  ok_str(pSymbol->Name, "FfsChkdsk");
394 
395  if (!supports_pdb(hProc, BaseAddress))
396  {
397  skip("dbghelp.dll too old or cannot read this symbol!\n");
398  }
399  else
400  {
401  /* .idata */
402  Displacement = 0;
403  INIT_PSYM(buffer);
404  Ret = SymFromAddr(hProc, BaseAddress + 0x2000, &Displacement, pSymbol);
405  ok_int(Ret, TRUE);
406  ok_ulonglong(Displacement, 0);
407  ok_ulonglong(pSymbol->ModBase, BaseAddress);
408  ok_hex(pSymbol->Flags, 0);
409  ok_ulonglong(pSymbol->Address, BaseAddress + 0x2000);
410  ok_hex(pSymbol->Tag, SymTagPublicSymbol);
411  ok_str(pSymbol->Name, "__imp__DbgPrint");
412  }
413 }
ULONG Tag
Definition: compat.h:706
CHAR Name[1]
Definition: compat.h:709
#define TRUE
Definition: types.h:120
#define ok_str(x, y)
Definition: atltest.h:127
ULONG Flags
Definition: compat.h:701
DWORD WINAPI GetLastError(VOID)
Definition: except.c:1059
GLuint buffer
Definition: glext.h:5915
ULONG64 Address
Definition: compat.h:703
#define ok_hex(expression, result)
Definition: atltest.h:94
struct _SYMBOL_INFO * PSYMBOL_INFO
unsigned int BOOL
Definition: ntddk_ex.h:94
ULONG64 ModBase
Definition: compat.h:700
#define ok_int(expression, result)
Definition: atltest.h:134
DWORD dwErr
Definition: service.c:36
char TCHAR
Definition: xmlstorage.h:189
_In_ HANDLE _Outptr_result_bytebuffer_ ViewSize PVOID * BaseAddress
Definition: mmfuncs.h:404
struct _SYMBOL_INFO SYMBOL_INFO
#define MAX_SYM_NAME
Definition: compat.h:632
unsigned long DWORD
Definition: ntddk_ex.h:95
BOOL WINAPI SymFromAddr(HANDLE hProcess, DWORD64 Address, DWORD64 *Displacement, PSYMBOL_INFO Symbol)
Definition: symbol.c:1271
uint64_t DWORD64
Definition: typedefs.h:65
#define INIT_PSYM(buff)
Definition: pdb.c:55
#define skip(...)
Definition: atltest.h:64
#define ok_ulonglong(expression, result)
Definition: pdb.c:18
#define ERROR_MOD_NOT_FOUND
Definition: compat.h:94
static BOOL supports_pdb(HANDLE hProc, DWORD64 BaseAddress)
Definition: pdb.c:225

Referenced by START_TEST().

◆ test_SymFromName()

static void test_SymFromName ( HANDLE  hProc,
DWORD64  BaseAddress 
)
static

Definition at line 238 of file pdb.c.

239 {
240  BOOL Ret;
241  char buffer[sizeof(SYMBOL_INFO) + MAX_SYM_NAME * sizeof(TCHAR)];
242  PSYMBOL_INFO pSymbol = (PSYMBOL_INFO)buffer;
243 
244  if (!supports_pdb(hProc, BaseAddress))
245  {
246  skip("dbghelp.dll too old or cannot enumerate symbols!\n");
247  }
248  else
249  {
250  INIT_PSYM(buffer);
251  Ret = SymFromName(hProc, "DllMain", pSymbol);
252  ok_int(Ret, TRUE);
253  ok_ulonglong(pSymbol->ModBase, BaseAddress);
254  ok_hex(pSymbol->Flags, 0);
255  ok_ulonglong(pSymbol->Address, BaseAddress + 0x1010);
256  ok_hex(pSymbol->Tag, SymTagFunction);
257  ok_str(pSymbol->Name, "DllMain");
258 
259  INIT_PSYM(buffer);
260  Ret = SymFromName(hProc, "_DllMain@12", pSymbol);
261  ok_int(Ret, TRUE);
262  ok_ulonglong(pSymbol->ModBase, BaseAddress);
263  ok_hex(pSymbol->Flags, 0x400000); // ??
264  ok_ulonglong(pSymbol->Address, BaseAddress + 0x1010);
265  ok_hex(pSymbol->Tag, SymTagPublicSymbol);
266  ok_str(pSymbol->Name, "_DllMain@12");
267 
268  INIT_PSYM(buffer);
269  Ret = SymFromName(hProc, "FfsChkdsk", pSymbol);
270  ok_int(Ret, TRUE);
271  ok_ulonglong(pSymbol->ModBase, BaseAddress);
272  ok_hex(pSymbol->Flags, 0);
273  ok_ulonglong(pSymbol->Address, BaseAddress + 0x1040);
274  ok_hex(pSymbol->Tag, SymTagFunction);
275  ok_str(pSymbol->Name, "FfsChkdsk");
276 
277  INIT_PSYM(buffer);
278  Ret = SymFromName(hProc, "_FfsChkdsk@24", pSymbol);
279  ok_int(Ret, TRUE);
280  ok_ulonglong(pSymbol->ModBase, BaseAddress);
281  ok_hex(pSymbol->Flags, 0x400000); // ??
282  ok_ulonglong(pSymbol->Address, BaseAddress + 0x1040);
283  ok_hex(pSymbol->Tag, SymTagPublicSymbol);
284  ok_str(pSymbol->Name, "_FfsChkdsk@24");
285 
286  INIT_PSYM(buffer);
287  Ret = SymFromName(hProc, "FfsFormat", pSymbol);
288  ok_int(Ret, TRUE);
289  ok_ulonglong(pSymbol->ModBase, BaseAddress);
290  ok_hex(pSymbol->Flags, 0);
291  ok_ulonglong(pSymbol->Address, BaseAddress + 0x1070);
292  ok_hex(pSymbol->Tag, SymTagFunction);
293  ok_str(pSymbol->Name, "FfsFormat");
294 
295  INIT_PSYM(buffer);
296  Ret = SymFromName(hProc, "_FfsFormat@24", pSymbol);
297  ok_int(Ret, TRUE);
298  ok_ulonglong(pSymbol->ModBase, BaseAddress);
299  ok_hex(pSymbol->Flags, 0x400000); // ??
300  ok_ulonglong(pSymbol->Address, BaseAddress + 0x1070);
301  ok_hex(pSymbol->Tag, SymTagPublicSymbol);
302  ok_str(pSymbol->Name, "_FfsFormat@24");
303  }
304 }
ULONG Tag
Definition: compat.h:706
CHAR Name[1]
Definition: compat.h:709
#define TRUE
Definition: types.h:120
#define ok_str(x, y)
Definition: atltest.h:127
ULONG Flags
Definition: compat.h:701
GLuint buffer
Definition: glext.h:5915
ULONG64 Address
Definition: compat.h:703
#define ok_hex(expression, result)
Definition: atltest.h:94
struct _SYMBOL_INFO * PSYMBOL_INFO
unsigned int BOOL
Definition: ntddk_ex.h:94
ULONG64 ModBase
Definition: compat.h:700
#define ok_int(expression, result)
Definition: atltest.h:134
char TCHAR
Definition: xmlstorage.h:189
_In_ HANDLE _Outptr_result_bytebuffer_ ViewSize PVOID * BaseAddress
Definition: mmfuncs.h:404
struct _SYMBOL_INFO SYMBOL_INFO
#define MAX_SYM_NAME
Definition: compat.h:632
#define INIT_PSYM(buff)
Definition: pdb.c:55
#define skip(...)
Definition: atltest.h:64
#define ok_ulonglong(expression, result)
Definition: pdb.c:18
BOOL WINAPI SymFromName(HANDLE hProcess, PCSTR Name, PSYMBOL_INFO Symbol)
Definition: symbol.c:1400
static BOOL supports_pdb(HANDLE hProc, DWORD64 BaseAddress)
Definition: pdb.c:225

Referenced by START_TEST().

◆ test_SymRegCallback()

static void test_SymRegCallback ( HANDLE  hProc,
const char szModuleName,
BOOL  testANSI 
)
static

Definition at line 520 of file pdb.c.

521 {
522  BOOL Ret;
523  DWORD dwErr;
526 
527  ctx.idx = 0;
528  ctx.isANSI = testANSI;
529 
530  if (!init_sym(FALSE))
531  return;
532 
533  if (testANSI)
534  {
536  }
537  else
538  {
541  {
542  skip("SymRegisterCallbackW64 not found in dbghelp.dll\n");
543  return;
544  }
545  }
546 
547  ok_int(Ret, TRUE);
548  if (!Ret)
549  return;
550 
552  BaseAddress = SymLoadModule64(hProc, NULL, szModuleName, NULL, 0x600000, 0);
553  dwErr = GetLastError();
554 
555  ok_ulonglong(BaseAddress, 0x600000);
557 
558  /* this is what we want to test ... we expect 5 calls */
559  ok_int(ctx.idx, 5);
560 
561  deinit_sym();
562 }
#define TRUE
Definition: types.h:120
#define ERROR_SUCCESS
Definition: deptool.c:10
static void deinit_sym()
Definition: pdb.c:48
DWORD WINAPI GetLastError(VOID)
Definition: except.c:1059
static BOOL CALLBACK SymRegisterCallback64Proc(HANDLE hProcess, ULONG ActionCode, ULONG64 CallbackData, ULONG64 UserContext)
Definition: pdb.c:496
#define ok_hex(expression, result)
Definition: atltest.h:94
uint32_t ULONG_PTR
Definition: typedefs.h:63
unsigned int BOOL
Definition: ntddk_ex.h:94
BOOL WINAPI SymRegisterCallback64(HANDLE hProcess, PSYMBOL_REGISTERED_CALLBACK64 CallbackFunction, ULONG64 UserContext)
Definition: dbghelp.c:630
smooth NULL
Definition: ftsmooth.c:416
#define ok_int(expression, result)
Definition: atltest.h:134
DWORD dwErr
Definition: service.c:36
DWORD64 WINAPI SymLoadModule64(HANDLE hProcess, HANDLE hFile, PCSTR ImageName, PCSTR ModuleName, DWORD64 BaseOfDll, DWORD SizeOfDll)
Definition: module.c:673
BOOL WINAPI SymRegisterCallbackW64(HANDLE hProcess, PSYMBOL_REGISTERED_CALLBACK64 CallbackFunction, ULONG64 UserContext)
Definition: dbghelp.c:642
_In_ HANDLE _Outptr_result_bytebuffer_ ViewSize PVOID * BaseAddress
Definition: mmfuncs.h:404
unsigned long DWORD
Definition: ntddk_ex.h:95
#define SetLastError(x)
Definition: compat.h:417
unsigned __int64 ULONG64
Definition: imports.h:198
static int g_SymRegisterCallbackW64NotFound
Definition: pdb.c:194
#define init_sym(fInvadeProcess)
Definition: pdb.c:53
#define skip(...)
Definition: atltest.h:64
#define ok_ulonglong(expression, result)
Definition: pdb.c:18
LPCWSTR LPCWSTR szModuleName
Definition: env.c:35

Referenced by START_TEST().

Variable Documentation

◆ __pfnDliFailureHook2

PfnDliHook __pfnDliFailureHook2 = DliFailHook

Definition at line 221 of file pdb.c.

Referenced by START_TEST().

◆ dbghelpFileVer

VS_FIXEDFILEINFO dbghelpFileVer
static

Definition at line 147 of file pdb.c.

Referenced by init_dbghelp_version().

◆ g_SymRegisterCallbackW64NotFound

int g_SymRegisterCallbackW64NotFound = 0
static

Definition at line 194 of file pdb.c.

Referenced by SymRegisterCallbackW64_Stub(), and test_SymRegCallback().

◆ symregcallback_test_data

struct _symregcallback_test_data symregcallback_test_data[]
static
Initial value:
= {
}
#define CBA_DEFERRED_SYMBOL_LOAD_COMPLETE
Definition: compat.h:634
#define CBA_READ_MEMORY
Definition: compat.h:638
#define CBA_DEFERRED_SYMBOL_LOAD_PARTIAL
Definition: compat.h:642
#define CBA_DEFERRED_SYMBOL_LOAD_START
Definition: compat.h:633
#define CBA_DEFERRED_SYMBOL_LOAD_CANCEL
Definition: compat.h:639

Referenced by SymRegisterCallback64Proc().

◆ test_data

Initial value:
= {
{ 0x1070, 36, SymTagFunction, "FfsFormat" },
{ 0x1010, 32, SymTagFunction, "DllMain" },
{ 0x1040, 36, SymTagFunction, "FfsChkdsk" },
{ 0x2100, 0, SymTagPublicSymbol, "__IMPORT_DESCRIPTOR_ntdll" },
{ 0x109a, 0, SymTagPublicSymbol, "_DbgPrint" },
{ 0x2004, 0, SymTagPublicSymbol, "\x7fntdll_NULL_THUNK_DATA" },
{ 0x2000, 0, SymTagPublicSymbol, "__imp__DbgPrint" },
{ 0x2114, 0, SymTagPublicSymbol, "__NULL_IMPORT_DESCRIPTOR" },
}

Referenced by run_from_file(), test_D3DKMTCreateDCFromMemory(), test_emf_WorldTransform(), test_IdnToAscii(), test_IdnToNameprepUnicode(), and test_IdnToUnicode().