Jegyzet
Az oldalhoz való hozzáférés engedélyezést igényel. Próbálhatod be jelentkezni vagy könyvtárat váltani.
Az oldalhoz való hozzáférés engedélyezést igényel. Megpróbálhatod a könyvtár váltását.
Az alábbi kód bemutatja, hogyan szerezhet be és jelenthet részletes állapotinformációkat a szimbólumkezelőtől a modulok és a megfelelő szimbólumfájlok kereséséről és betöltéséről.
Sokan ismerik a WinDbg hibakeresőt, emlékezhetnek a "!sym zajos" parancsra. Ezt a parancsot a felhasználó annak meghatározására használja, hogy a WinDbg miért képes vagy nem képes szimbólumfájlokat betölteni. Részletes felsorolást jelenít meg mindenről, amit a szimbólumkezelő megpróbál.
Ugyanez a lista bárki számára elérhető, aki ügyfelet fejleszt a DbgHelp szimbólumkezelőben.
Először hívja meg SymSetOptionsSYMOPT_DEBUG. Emiatt a DbgHelp bekapcsolja a hibakeresési értesítéseket.
Miután meghívta SymInitialize, használja a SymRegisterCallback64 függvényt, hogy regisztráljon egy visszahívási függvényt, amelyet a DbgHelp hív meg, amikor egy érdeklődésre számot tartó esemény történik. Ebben a példában a visszahívási függvény neve SymRegisterCallbackProc64. A szimbólumvisszahívási függvények olyan műveleti kódokból állnak, amelyeket típus szerint kezelhetnek. Ebben a példában csak a CBA_EVENT műveleti kódot kezeljük. Ez a függvény egy olyan sztringet ad át, amely részletes információkat tartalmaz egy szimbólum betöltése során történt eseményről. Ez az esemény bármi lehet a végrehajtható lemezképen belüli adatok egy szimbólumfájl sikeres helyére való beolvasásának kísérletétől kezdve. SymRegisterCallbackProc64 megjeleníti a karaktersorozatot, és visszaadja az IGAZértéket.
Fontos
Győződjön meg arról, hogy minden olyan műveletkódhoz, amelyet nem kezel, HAMIS értéket ad vissza, különben meghatározatlan viselkedést tapasztalhat. A műveletkódok és azok következményeinek listájáért tekintse meg SymRegisterCallbackProc64.
Most, hogy a visszahívás regisztrálva lett, ideje betölteni a parancssorban megadott modult SymLoadModuleExmeghívásával.
Végül a kilépés előtt hívja fel SymCleanup.
#include <windows.h>
#include <stdio.h>
#include <tchar.h>
#ifdef UNICODE
#define DBGHELP_TRANSLATE_TCHAR
#endif
#include <dbghelp.h>
// Here is an implementation of a Symbol Callback function.
BOOL
CALLBACK
SymRegisterCallbackProc64(
__in HANDLE hProcess,
__in ULONG ActionCode,
__in_opt ULONG64 CallbackData,
__in_opt ULONG64 UserContext
)
{
UNREFERENCED_PARAMETER(hProcess);
UNREFERENCED_PARAMETER(UserContext);
PIMAGEHLP_CBA_EVENT evt;
// If SYMOPT_DEBUG is set, then the symbol handler will pass
// verbose information on its attempt to load symbols.
// This information be delivered as text strings.
switch (ActionCode)
{
case CBA_EVENT:
evt = (PIMAGEHLP_CBA_EVENT)CallbackData;
_tprintf(_T("%s"), (PTSTR)evt->desc);
break;
// CBA_DEBUG_INFO is the old ActionCode for symbol spew.
// It still works, but we use CBA_EVENT in this example.
#if 0
case CBA_DEBUG_INFO:
_tprintf(_T("%s"), (PTSTR)CallbackData);
break;
#endif
default:
// Return false to any ActionCode we don't handle
// or we could generate some undesirable behavior.
return FALSE;
}
return TRUE;
}
// Main code.
int __cdecl
#ifdef UNICODE
_tmain(
#else
main(
#endif
__in int argc,
__in_ecount(argc) PCTSTR argv[]
)
{
BOOL status;
int rc = -1;
HANDLE hProcess;
DWORD64 module;
if (argc < 2)
{
_tprintf(_T("You must specify an executable image to load.\n"));
return rc;
}
// If we want to se debug spew, we need to set this option.
SymSetOptions(SYMOPT_DEBUG);
// We are not debugging an actual process, so lets use a placeholder
// value of 1 for hProcess just to ID these calls from any other
// series we may want to load. For this simple case, anything will do.
hProcess = (HANDLE)1;
// Initialize the symbol handler. No symbol path.
// Just let dbghelp use _NT_SYMBOL_PATH
status = SymInitialize(hProcess, NULL, false);
if (!status)
{
_tprintf(_T("Error 0x%x calling SymInitialize.\n"), GetLastError());
return rc;
}
// Now register our callback.
status = SymRegisterCallback64(hProcess, SymRegisterCallbackProc64, NULL);
if (!status)
{
_tprintf(_T("Error 0x%x calling SymRegisterCallback64.\n"), GetLastError());
goto cleanup;
}
// Go ahead and load a module for testing.
module = SymLoadModuleEx(hProcess, // our unique id
NULL, // no open file handle to image
argv[1], // name of image to load
NULL, // no module name - dbghelp will get it
0, // no base address - dbghelp will get it
0, // no module size - dbghelp will get it
NULL, // no special MODLOAD_DATA structure
0); // flags
if (!module)
{
_tprintf(_T("Error 0x%x calling SymLoadModuleEx.\n"), GetLastError());
goto cleanup;
}
rc = 0;
cleanup:
SymCleanup(hProcess);
return rc;
}
A SymInitialize második paramétereként NULL megadása azt jelzi, hogy a szimbólumkezelőnek az alapértelmezett keresési útvonal használatával kell megkeresnie a szimbólumfájlokat. Bővebb információért arról, hogyan találja meg a szimbólum kezelő a szimbólumfájlokat, vagy hogyan adhat meg egy alkalmazás szimbólumkeresési útvonalat, olvassa el a Szimbólum elérési útjaicímű részt.
A program futtatása a szimbólum elérési útjának feldolgozását mutatja be. Ahogy a DbgHelp végignézi a szimbólum elérési útját a szimbólumfájl megkereséséhez, ismételten meghívja a SymRegisterCallbackProc64-t, amely megjeleníti a DbgHelp által átadott alábbi sztringeket.
d:\load.exe c:\home\dbghelp.dll
DBGHELP: No header for c:\home\dbghelp.dll. Searching for image on disk
DBGHELP: c:\home\dbghelp.dll - OK
DBGHELP: .\dbghelp.pdb - file not found
DBGHELP: .\dll\dbghelp.pdb - file not found
DBGHELP: .\symbols\dll\dbghelp.pdb - file not found
DBGHELP: .\symbols\dll\dbghelp.pdb - file not found
DBGHELP: cache*c:\symbols\dbghelp.pdb - file not found
DBGHELP: cache*c:\symbols\dll\dbghelp.pdb - file not found
DBGHELP: cache*c:\symbols\symbols\dll\dbghelp.pdb - file not found
DBGHELP: d:\nt.binaries.amd64chk\symbols.pri\dbg\dbghelp.pdb - file not found
DBGHELP: dbghelp - private symbols & lines
dbghelp.pdb