mirror of git://sourceware.org/git/glibc.git
2003-12-02 Roland McGrath <roland@redhat.com>
* thread_dbP.h (DB_FUNCTION): New macro. * structs.def: Use it for __nptl_create_event and __nptl_death_event. * db_info.c (DB_FUNCTION): New macro. * td_symbol_list.c (DB_FUNCTION): New macro, prepend "." to symbol name under [HAVE_ASM_GLOBAL_DOT_NAME]. (td_lookup) [HAVE_ASM_GLOBAL_DOT_NAME]: If lookup fails with PS_NOSYM and name starts with a dot, try it without the dot.
This commit is contained in:
parent
2d951ab685
commit
d43147cd89
|
|
@ -71,10 +71,12 @@ DESC (_thread_db_pthread_dtvp,
|
||||||
#define DB_VARIABLE(name) DESC (_thread_db_##name, 0, name)
|
#define DB_VARIABLE(name) DESC (_thread_db_##name, 0, name)
|
||||||
#define DB_ARRAY_VARIABLE(name) ARRAY_DESC (_thread_db_##name, 0, name)
|
#define DB_ARRAY_VARIABLE(name) ARRAY_DESC (_thread_db_##name, 0, name)
|
||||||
#define DB_SYMBOL(name) /* Nothing. */
|
#define DB_SYMBOL(name) /* Nothing. */
|
||||||
|
#define DB_FUNCTION(name) /* Nothing. */
|
||||||
#include "structs.def"
|
#include "structs.def"
|
||||||
#undef DB_STRUCT
|
#undef DB_STRUCT
|
||||||
#undef DB_STRUCT_FIELD
|
#undef DB_STRUCT_FIELD
|
||||||
#undef DB_SYMBOL
|
#undef DB_SYMBOL
|
||||||
|
#undef DB_FUNCTION
|
||||||
#undef DB_VARIABLE
|
#undef DB_VARIABLE
|
||||||
#undef DESC
|
#undef DESC
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -51,8 +51,8 @@ DB_STRUCT_FIELD (td_eventbuf_t, eventdata)
|
||||||
DB_SYMBOL (stack_used)
|
DB_SYMBOL (stack_used)
|
||||||
DB_SYMBOL (__stack_user)
|
DB_SYMBOL (__stack_user)
|
||||||
DB_SYMBOL (nptl_version)
|
DB_SYMBOL (nptl_version)
|
||||||
DB_SYMBOL (__nptl_create_event)
|
DB_FUNCTION (__nptl_create_event)
|
||||||
DB_SYMBOL (__nptl_death_event)
|
DB_FUNCTION (__nptl_death_event)
|
||||||
DB_SYMBOL (__nptl_threads_events)
|
DB_SYMBOL (__nptl_threads_events)
|
||||||
DB_VARIABLE (__nptl_nthreads)
|
DB_VARIABLE (__nptl_nthreads)
|
||||||
DB_VARIABLE (__nptl_last_event)
|
DB_VARIABLE (__nptl_last_event)
|
||||||
|
|
|
||||||
|
|
@ -23,6 +23,12 @@
|
||||||
#include "thread_dbP.h"
|
#include "thread_dbP.h"
|
||||||
|
|
||||||
|
|
||||||
|
#ifdef HAVE_ASM_GLOBAL_DOT_NAME
|
||||||
|
# define DOT "." /* PPC64 requires . prefix on code symbols. */
|
||||||
|
#else
|
||||||
|
# define DOT /* No prefix. */
|
||||||
|
#endif
|
||||||
|
|
||||||
static const char *symbol_list_arr[] =
|
static const char *symbol_list_arr[] =
|
||||||
{
|
{
|
||||||
# define DB_STRUCT(type) \
|
# define DB_STRUCT(type) \
|
||||||
|
|
@ -31,11 +37,14 @@ static const char *symbol_list_arr[] =
|
||||||
[SYM_##type##_FIELD_##field] = "_thread_db_" #type "_" #field,
|
[SYM_##type##_FIELD_##field] = "_thread_db_" #type "_" #field,
|
||||||
# define DB_SYMBOL(name) \
|
# define DB_SYMBOL(name) \
|
||||||
[SYM_##name] = #name,
|
[SYM_##name] = #name,
|
||||||
|
# define DB_FUNCTION(name) \
|
||||||
|
[SYM_##name] = DOT #name,
|
||||||
# define DB_VARIABLE(name) \
|
# define DB_VARIABLE(name) \
|
||||||
[SYM_##name] = #name, \
|
[SYM_##name] = #name, \
|
||||||
[SYM_DESC_##name] = "_thread_db_" #name,
|
[SYM_DESC_##name] = "_thread_db_" #name,
|
||||||
# include "structs.def"
|
# include "structs.def"
|
||||||
# undef DB_STRUCT
|
# undef DB_STRUCT
|
||||||
|
# undef DB_FUNCTION
|
||||||
# undef DB_SYMBOL
|
# undef DB_SYMBOL
|
||||||
# undef DB_VARIABLE
|
# undef DB_VARIABLE
|
||||||
|
|
||||||
|
|
@ -59,6 +68,18 @@ td_symbol_list (void)
|
||||||
ps_err_e
|
ps_err_e
|
||||||
td_lookup (struct ps_prochandle *ps, int idx, psaddr_t *sym_addr)
|
td_lookup (struct ps_prochandle *ps, int idx, psaddr_t *sym_addr)
|
||||||
{
|
{
|
||||||
|
ps_err_e result;
|
||||||
assert (idx >= 0 && idx < SYM_NUM_MESSAGES);
|
assert (idx >= 0 && idx < SYM_NUM_MESSAGES);
|
||||||
return ps_pglobal_lookup (ps, LIBPTHREAD_SO, symbol_list_arr[idx], sym_addr);
|
result = ps_pglobal_lookup (ps, LIBPTHREAD_SO, symbol_list_arr[idx],
|
||||||
|
sym_addr);
|
||||||
|
|
||||||
|
#ifdef HAVE_ASM_GLOBAL_DOT_NAME
|
||||||
|
/* For PowerPC, 64-bit uses dot symbols but 32-bit does not.
|
||||||
|
We could be a 64-bit libthread_db debugging a 32-bit libpthread. */
|
||||||
|
if (result == PS_NOSYM && symbol_list_arr[idx][0] == '.')
|
||||||
|
result = ps_pglobal_lookup (ps, LIBPTHREAD_SO, &symbol_list_arr[idx][1],
|
||||||
|
sym_addr);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
return result;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -36,11 +36,13 @@ enum
|
||||||
# define DB_STRUCT(type) SYM_SIZEOF_##type,
|
# define DB_STRUCT(type) SYM_SIZEOF_##type,
|
||||||
# define DB_STRUCT_FIELD(type, field) SYM_##type##_FIELD_##field,
|
# define DB_STRUCT_FIELD(type, field) SYM_##type##_FIELD_##field,
|
||||||
# define DB_SYMBOL(name) SYM_##name,
|
# define DB_SYMBOL(name) SYM_##name,
|
||||||
|
# define DB_FUNCTION(name) SYM_##name,
|
||||||
# define DB_VARIABLE(name) SYM_##name, SYM_DESC_##name,
|
# define DB_VARIABLE(name) SYM_##name, SYM_DESC_##name,
|
||||||
# include "structs.def"
|
# include "structs.def"
|
||||||
# undef DB_STRUCT
|
# undef DB_STRUCT
|
||||||
# undef DB_STRUCT_FIELD
|
# undef DB_STRUCT_FIELD
|
||||||
# undef DB_SYMBOL
|
# undef DB_SYMBOL
|
||||||
|
# undef DB_FUNCTION
|
||||||
# undef DB_VARIABLE
|
# undef DB_VARIABLE
|
||||||
|
|
||||||
SYM_TH_UNIQUE_CONST_THREAD_AREA,
|
SYM_TH_UNIQUE_CONST_THREAD_AREA,
|
||||||
|
|
@ -88,12 +90,15 @@ struct td_thragent
|
||||||
db_desc_t ta_field_##type##_##field;
|
db_desc_t ta_field_##type##_##field;
|
||||||
# define DB_SYMBOL(name) \
|
# define DB_SYMBOL(name) \
|
||||||
psaddr_t ta_addr_##name;
|
psaddr_t ta_addr_##name;
|
||||||
|
# define DB_FUNCTION(name) \
|
||||||
|
psaddr_t ta_addr_##name;
|
||||||
# define DB_VARIABLE(name) \
|
# define DB_VARIABLE(name) \
|
||||||
psaddr_t ta_addr_##name; \
|
psaddr_t ta_addr_##name; \
|
||||||
db_desc_t ta_var_##name;
|
db_desc_t ta_var_##name;
|
||||||
# include "structs.def"
|
# include "structs.def"
|
||||||
# undef DB_STRUCT
|
# undef DB_STRUCT
|
||||||
# undef DB_STRUCT_FIELD
|
# undef DB_STRUCT_FIELD
|
||||||
|
# undef DB_FUNCTION
|
||||||
# undef DB_SYMBOL
|
# undef DB_SYMBOL
|
||||||
# undef DB_VARIABLE
|
# undef DB_VARIABLE
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue