Commit a274689b authored by Eric Pouech's avatar Eric Pouech Committed by Alexandre Julliard

winedbg: Dwarf can emit REGREL symbol information, so handle it.

Factorize a bit more some symbol handling code.
parent 932ad65c
...@@ -65,6 +65,45 @@ static BOOL symbol_get_debug_start(const struct dbg_type* func, ULONG64* start) ...@@ -65,6 +65,45 @@ static BOOL symbol_get_debug_start(const struct dbg_type* func, ULONG64* start)
return FALSE; return FALSE;
} }
static BOOL fill_sym_lvalue(const SYMBOL_INFO* sym, ULONG base,
struct dbg_lvalue* lvalue, char* buffer, size_t sz)
{
if (buffer) buffer[0] = '\0';
if (sym->Flags & SYMFLAG_REGISTER)
{
DWORD* pval;
if (!memory_get_register(sym->Register, &pval, buffer, sz))
return FALSE;
lvalue->cookie = DLV_HOST;
lvalue->addr.Offset = (DWORD_PTR)pval;
}
else if (sym->Flags & SYMFLAG_REGREL)
{
DWORD* pval;
if (!memory_get_register(sym->Register, &pval, buffer, sz))
return FALSE;
lvalue->cookie = DLV_TARGET;
lvalue->addr.Offset = (ULONG)((ULONG64)*pval + sym->Address);
}
else if (sym->Flags & SYMFLAG_LOCAL)
{
lvalue->cookie = DLV_TARGET;
lvalue->addr.Offset = base + sym->Address;
}
else
{
lvalue->cookie = DLV_TARGET;
lvalue->addr.Offset = sym->Address;
}
lvalue->addr.Mode = AddrModeFlat;
lvalue->type.module = sym->ModBase;
lvalue->type.id = sym->TypeIndex;
return TRUE;
}
struct sgv_data struct sgv_data
{ {
#define NUMDBGV 100 #define NUMDBGV 100
...@@ -85,34 +124,13 @@ struct sgv_data ...@@ -85,34 +124,13 @@ struct sgv_data
static BOOL CALLBACK sgv_cb(SYMBOL_INFO* sym, ULONG size, void* ctx) static BOOL CALLBACK sgv_cb(SYMBOL_INFO* sym, ULONG size, void* ctx)
{ {
struct sgv_data* sgv = (struct sgv_data*)ctx; struct sgv_data* sgv = (struct sgv_data*)ctx;
ULONG64 addr; unsigned insp;
unsigned cookie = DLV_TARGET, insp; char tmp[32];
if (sym->Flags & SYMFLAG_REGISTER) if (sym->Flags & SYMFLAG_THUNK)
{
char tmp[32];
DWORD* val;
if (!memory_get_register(sym->Register, &val, tmp, sizeof(tmp)))
{
dbg_printf(" %s (register): %s\n", sym->Name, tmp);
return TRUE;
}
addr = (ULONG64)(DWORD_PTR)val;
cookie = DLV_HOST;
}
else if (sym->Flags & SYMFLAG_LOCAL) /* covers both local & parameters */
{
addr = sgv->frame_offset + sym->Address;
}
else if (sym->Flags & SYMFLAG_THUNK)
{ {
if (!sgv->do_thunks) return TRUE; if (!sgv->do_thunks) return TRUE;
sgv->num_thunks++; sgv->num_thunks++;
addr = sym->Address;
}
else
{
addr = sym->Address;
} }
if (sgv->num >= NUMDBGV) if (sgv->num >= NUMDBGV)
...@@ -139,11 +157,11 @@ static BOOL CALLBACK sgv_cb(SYMBOL_INFO* sym, ULONG size, void* ctx) ...@@ -139,11 +157,11 @@ static BOOL CALLBACK sgv_cb(SYMBOL_INFO* sym, ULONG size, void* ctx)
memmove(&sgv->syms[insp + 1], &sgv->syms[insp], memmove(&sgv->syms[insp + 1], &sgv->syms[insp],
sizeof(sgv->syms[0]) * sgv->num_thunks); sizeof(sgv->syms[0]) * sgv->num_thunks);
} }
sgv->syms[insp].lvalue.cookie = cookie; if (!fill_sym_lvalue(sym, sgv->frame_offset, &sgv->syms[insp].lvalue, tmp, sizeof(tmp)))
sgv->syms[insp].lvalue.addr.Mode = AddrModeFlat; {
sgv->syms[insp].lvalue.addr.Offset = addr; dbg_printf("%s: %s\n", sym->Name, tmp);
sgv->syms[insp].lvalue.type.module = sym->ModBase; return TRUE;
sgv->syms[insp].lvalue.type.id = sym->TypeIndex; }
sgv->syms[insp].flags = sym->Flags; sgv->syms[insp].flags = sym->Flags;
sgv->syms[insp].sym_info = sym->info; sgv->syms[insp].sym_info = sym->info;
sgv->num++; sgv->num++;
...@@ -545,54 +563,24 @@ void symbol_print_local(const SYMBOL_INFO* sym, ULONG base, ...@@ -545,54 +563,24 @@ void symbol_print_local(const SYMBOL_INFO* sym, ULONG base,
BOOL detailed) BOOL detailed)
{ {
struct dbg_lvalue lvalue; struct dbg_lvalue lvalue;
BOOL valtodo = FALSE;
char buffer[64]; char buffer[64];
dbg_printf("%s=", sym->Name); dbg_printf("%s=", sym->Name);
if (sym->Flags & SYMFLAG_REGISTER) if (fill_sym_lvalue(sym, base, &lvalue, buffer, sizeof(buffer)))
{
DWORD* pval;
if (memory_get_register(sym->Register, &pval, buffer + 13, sizeof(buffer) - 13))
{
lvalue.cookie = DLV_HOST;
lvalue.addr.Mode = AddrModeFlat;
lvalue.addr.Offset = (DWORD_PTR)pval;
valtodo = TRUE;
memcpy(buffer, " in register ", 13);
}
else
{
dbg_printf(buffer + 13);
buffer[0] = '\0';
}
}
else if (sym->Flags & SYMFLAG_LOCAL)
{
lvalue.cookie = DLV_TARGET;
lvalue.addr.Mode = AddrModeFlat;
lvalue.addr.Offset = base + sym->Address;
valtodo = TRUE;
buffer[0] = '\0';
}
else
{
dbg_printf("<unexpected symbol flags %lx>\n", sym->Flags);
buffer[0] = '\0';
}
if (valtodo)
{ {
lvalue.type.module = sym->ModBase;
lvalue.type.id = sym->TypeIndex;
print_value(&lvalue, 'x', 1); print_value(&lvalue, 'x', 1);
if (detailed)
dbg_printf(" (%s%s)",
(sym->Flags & SYMFLAG_PARAMETER) ? "parameter" : "local",
buffer);
} }
else
if (detailed)
{ {
dbg_printf(" (%s%s)", dbg_printf(buffer);
(sym->Flags & SYMFLAG_PARAMETER) ? "parameter" : "local", buffer); if (detailed)
dbg_printf(" (%s)",
(sym->Flags & SYMFLAG_PARAMETER) ? "parameter" : "local");
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment