mirror of
https://github.com/bminor/binutils-gdb.git
synced 2025-12-26 09:08:59 +00:00
Support for Windows OS Thread Information Block.
* NEWS: Document new feature. * remote.c (PACKET_qGetTIBAddr): New enum element. (remote_get_tib_address): New function. (init_remote_ops): Set to_get_tib_address field to remote_get_tib_address. (_initialize_remote): Add add_packet_config_cmd for PACKET_qGetTIBAddr. * target.c (update_current_target): Set default value for new to_get_tib_address field. * target.h (target_ops): New field to_get_tib_address. (target_get_tib_address): New macro. * windows-nat.c (thread_info): Add thread_local_base field. (windows_add_thread): Add tlb argument of type 'void *'. (fake_create_process): Adapt windows_add_thread call. (get_windows_debug_event): Idem. (windows_get_tib_address): New function. (init_windows_ops): Set to_get_tib_address field to remote_get_tib_address. (_initialize_windows_nat): Replace info_w32_cmdlist initialization by a call to init_w32_command_list. (info_w32_command, info_w32_cmdlist): Removed from here... to windows-tdep.c file. * windows-tdep.h (info_w32_cmdlist): Declare. (init_w32_command_list): New external function declaration. * windows-tdep.c: Add several headers. (info_w32_cmdlist): to here, made global. (thread_information_32): New struct. (thread_information_64): New struct. (TIB_NAME): New char array. (MAX_TIB32, MAX_TIB64, FULL_TIB_SIZE): New constants. (maint_display_all_tib): New static variable. (windows_get_tlb_type): New function. (tlb_value_read, tlb_value_write): New functions. (tlb_value_funcs): New static struct. (tlb_make_value): New function. (display_one_tib): New function. (display_tib): New function. (show_maint_show_all_tib):New function. (info_w32_command): Moved from windows-nat.c. (init_w32_command_list): New function. (_initialize_windows_tdep): New function. New "maint set/show show-all-tib" command New "$_tlb" internal variable. gdbserver/ChangeLog entry: * server.c (handle_query): Handle 'qGetTIBAddr' query. * target.h (target_ops): New get_tib_address field. * win32-low.h (win32_thread_info): Add thread_local_base field. * win32-low.c (child_add_thread): Add tlb argument. Set thread_local_base field to TLB. (get_child_debug_event): Adapt to child_add_thread change. (win32_get_tib_address): New function. (win32_target_ops): Set get_tib_address field to win32_get_tib_address. * linux-low.c (linux_target_ops): Set get_tib_address field to NULL. doc/ChangeLog entry: gdb.texinfo ($_tlb): Document new automatic convinience variable. (info w32 thread-information-block): Document new command. (qGetTIBAddress): Document new gdbserver query. (maint set/show show-all-tib): Document new command.
This commit is contained in:
@@ -178,7 +178,7 @@ thread_rec (ptid_t ptid, int get_context)
|
||||
|
||||
/* Add a thread to the thread list. */
|
||||
static win32_thread_info *
|
||||
child_add_thread (DWORD pid, DWORD tid, HANDLE h)
|
||||
child_add_thread (DWORD pid, DWORD tid, HANDLE h, void *tlb)
|
||||
{
|
||||
win32_thread_info *th;
|
||||
ptid_t ptid = ptid_build (pid, tid, 0);
|
||||
@@ -189,6 +189,7 @@ child_add_thread (DWORD pid, DWORD tid, HANDLE h)
|
||||
th = xcalloc (1, sizeof (*th));
|
||||
th->tid = tid;
|
||||
th->h = h;
|
||||
th->thread_local_base = (CORE_ADDR) (uintptr_t) tlb;
|
||||
|
||||
add_thread (ptid, th);
|
||||
set_inferior_regcache_data ((struct thread_info *)
|
||||
@@ -1455,7 +1456,8 @@ get_child_debug_event (struct target_waitstatus *ourstatus)
|
||||
/* Record the existence of this thread. */
|
||||
child_add_thread (current_event.dwProcessId,
|
||||
current_event.dwThreadId,
|
||||
current_event.u.CreateThread.hThread);
|
||||
current_event.u.CreateThread.hThread,
|
||||
current_event.u.CreateThread.lpThreadLocalBase);
|
||||
break;
|
||||
|
||||
case EXIT_THREAD_DEBUG_EVENT:
|
||||
@@ -1485,7 +1487,8 @@ get_child_debug_event (struct target_waitstatus *ourstatus)
|
||||
/* Add the main thread. */
|
||||
child_add_thread (current_event.dwProcessId,
|
||||
main_thread_id,
|
||||
current_event.u.CreateProcessInfo.hThread);
|
||||
current_event.u.CreateProcessInfo.hThread,
|
||||
current_event.u.CreateProcessInfo.lpThreadLocalBase);
|
||||
|
||||
ourstatus->value.related_pid = debug_event_ptid (¤t_event);
|
||||
#ifdef _WIN32_WCE
|
||||
@@ -1753,6 +1756,20 @@ wince_hostio_last_error (char *buf)
|
||||
}
|
||||
#endif
|
||||
|
||||
/* Write Windows OS Thread Information Block address. */
|
||||
|
||||
static int
|
||||
win32_get_tib_address (ptid_t ptid, CORE_ADDR *addr)
|
||||
{
|
||||
win32_thread_info *th;
|
||||
th = thread_rec (ptid, 0);
|
||||
if (th == NULL)
|
||||
return 0;
|
||||
if (addr != NULL)
|
||||
*addr = th->thread_local_base;
|
||||
return 1;
|
||||
}
|
||||
|
||||
static struct target_ops win32_target_ops = {
|
||||
win32_create_inferior,
|
||||
win32_attach,
|
||||
@@ -1767,21 +1784,36 @@ static struct target_ops win32_target_ops = {
|
||||
win32_store_inferior_registers,
|
||||
win32_read_inferior_memory,
|
||||
win32_write_inferior_memory,
|
||||
NULL,
|
||||
NULL, /* lookup_symbols */
|
||||
win32_request_interrupt,
|
||||
NULL,
|
||||
NULL, /* read_auxv */
|
||||
win32_insert_point,
|
||||
win32_remove_point,
|
||||
win32_stopped_by_watchpoint,
|
||||
win32_stopped_data_address,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL,
|
||||
NULL, /* read_offsets */
|
||||
NULL, /* get_tls_address */
|
||||
NULL, /* qxfer_spu */
|
||||
#ifdef _WIN32_WCE
|
||||
wince_hostio_last_error,
|
||||
#else
|
||||
hostio_last_error_from_errno,
|
||||
#endif
|
||||
NULL, /* qxfer_osdata */
|
||||
NULL, /* qxfer_siginfo */
|
||||
NULL, /* supports_non_stop */
|
||||
NULL, /* async */
|
||||
NULL, /* start_non_stop */
|
||||
NULL, /* supports_multi_process */
|
||||
NULL, /* handle_monitor_command */
|
||||
NULL, /* core_of_thread */
|
||||
NULL, /* process_qsupported */
|
||||
NULL, /* supports_tracepoints */
|
||||
NULL, /* read_pc */
|
||||
NULL, /* write_pc */
|
||||
NULL, /* thread_stopped */
|
||||
NULL, /* pause_all */
|
||||
win32_get_tib_address,
|
||||
};
|
||||
|
||||
/* Initialize the Win32 backend. */
|
||||
|
||||
Reference in New Issue
Block a user