From 8a7dfaa090dc378831100692f4ce92f3244259ef Mon Sep 17 00:00:00 2001 From: Stan Shebs Date: Tue, 19 Jan 1999 00:49:41 +0000 Subject: [PATCH] * target.c (dummy_target): Don't initialize statically. (init_dummy_target): New function, fills in dummy_target. (initialize_targets): Use it. * hpux-thread.c (hpux_thread_ops): Don't initialize statically. (init_hpux_thread_ops): New function, fills in hpux_thread_ops. (_initialize_hpux_thread): Use it. * m3-nat.c (m3_ops): Don't initialize statically. (init_m3_ops): New function, fills in m3_ops. (_initialize_m3): Use it. --- gdb/ChangeLog | 12 +++++ gdb/hpux-thread.c | 121 ++++++++++++++++++---------------------------- gdb/m3-nat.c | 110 ++++++++++++++++------------------------- 3 files changed, 101 insertions(+), 142 deletions(-) diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 855ae130ecb..a3f7237eba3 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,15 @@ +Mon Jan 18 16:40:50 1999 Stan Shebs + + * target.c (dummy_target): Don't initialize statically. + (init_dummy_target): New function, fills in dummy_target. + (initialize_targets): Use it. + * hpux-thread.c (hpux_thread_ops): Don't initialize statically. + (init_hpux_thread_ops): New function, fills in hpux_thread_ops. + (_initialize_hpux_thread): Use it. + * m3-nat.c (m3_ops): Don't initialize statically. + (init_m3_ops): New function, fills in m3_ops. + (_initialize_m3): Use it. + 1999-01-18 Fernando Nasser * sol-thread.c: delete compile time initialization of target_ops diff --git a/gdb/hpux-thread.c b/gdb/hpux-thread.c index 50d1cd6b220..36421f390ab 100644 --- a/gdb/hpux-thread.c +++ b/gdb/hpux-thread.c @@ -1,5 +1,5 @@ /* Low level interface for debugging HPUX/DCE threads for GDB, the GNU debugger. - Copyright 1996 Free Software Foundation, Inc. + Copyright 1996, 1999 Free Software Foundation, Inc. This file is part of GDB. @@ -43,11 +43,11 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. */ #include #include "gdbcore.h" -extern struct target_ops hpux_thread_ops; /* Forward declaration */ - extern int child_suppress_run; extern struct target_ops child_ops; /* target vector for inftarg.c */ +extern void _initialize_hpux_thread PARAMS ((void)); + struct string_map { int num; @@ -62,9 +62,15 @@ static CORE_ADDR P_cma__g_known_threads; static CORE_ADDR P_cma__g_current_thread; static struct cleanup * save_inferior_pid PARAMS ((void)); + static void restore_inferior_pid PARAMS ((int pid)); + static void hpux_thread_resume PARAMS ((int pid, int step, enum target_signal signo)); + +static void init_hpux_thread_ops PARAMS ((void)); + +static struct target_ops hpux_thread_ops; /* @@ -586,80 +592,49 @@ hpux_pid_to_str (pid) return buf; } -struct target_ops hpux_thread_ops = { - "hpux-threads", /* to_shortname */ - "HPUX threads and pthread.", /* to_longname */ - "HPUX threads and pthread support.", /* to_doc */ - hpux_thread_open, /* to_open */ - 0, /* to_close */ - hpux_thread_attach, /* to_attach */ - NULL, /* to_post_attach */ - NULL, /* to_require_attach */ - hpux_thread_detach, /* to_detach */ - NULL, /* to_require_detach */ - hpux_thread_resume, /* to_resume */ - hpux_thread_wait, /* to_wait */ - NULL, /* to_post_wait */ - hpux_thread_fetch_registers, /* to_fetch_registers */ - hpux_thread_store_registers, /* to_store_registers */ - hpux_thread_prepare_to_store, /* to_prepare_to_store */ - hpux_thread_xfer_memory, /* to_xfer_memory */ - hpux_thread_files_info, /* to_files_info */ - memory_insert_breakpoint, /* to_insert_breakpoint */ - memory_remove_breakpoint, /* to_remove_breakpoint */ - terminal_init_inferior, /* to_terminal_init */ - terminal_inferior, /* to_terminal_inferior */ - terminal_ours_for_output, /* to_terminal_ours_for_output */ - terminal_ours, /* to_terminal_ours */ - child_terminal_info, /* to_terminal_info */ - hpux_thread_kill_inferior, /* to_kill */ - 0, /* to_load */ - 0, /* to_lookup_symbol */ - hpux_thread_create_inferior, /* to_create_inferior */ - NULL, /* to_post_startup_inferior */ - NULL, /* to_acknowledge_created_inferior */ - NULL, /* to_clone_and_follow_inferior */ - NULL, /* to_post_follow_inferior_by_clone */ - NULL, /* to_insert_fork_catchpoint */ - NULL, /* to_remove_fork_catchpoint */ - NULL, /* to_insert_vfork_catchpoint */ - NULL, /* to_remove_vfork_catchpoint */ - NULL, /* to_has_forked */ - NULL, /* to_has_vforked */ - NULL, /* to_can_follow_vfork_prior_to_exec */ - NULL, /* to_post_follow_fork */ - hpux_thread_mourn_inferior, /* to_mourn_inferior */ - NULL, /* to_insert_exec_catchpoint */ - NULL, /* to_remove_exec_catchpoint */ - NULL, /* to_has_execd */ - NULL, /* to_reported_exec_events_per_exec_call */ - NULL, /* to_has_syscall_event */ - NULL, /* to_has_exited */ - hpux_thread_can_run, /* to_can_run */ - hpux_thread_notice_signals, /* to_notice_signals */ - hpux_thread_alive, /* to_thread_alive */ - hpux_thread_stop, /* to_stop */ - 0, /* to_query */ - NULL, /* to_enable_exception_callback */ - NULL, /* to_get_current_exception_event */ - NULL, /* to_pid_to_exec_file */ - NULL, /* to_core_file_to_sym_file */ - process_stratum, /* to_stratum */ - 0, /* to_next */ - 1, /* to_has_all_memory */ - 1, /* to_has_memory */ - 1, /* to_has_stack */ - 1, /* to_has_registers */ - 1, /* to_has_execution */ - tc_none, /* to_has_thread_control */ - 0, /* sections */ - 0, /* sections_end */ - OPS_MAGIC /* to_magic */ -}; +static void +init_hpux_thread_ops () +{ + hpux_thread_ops.to_shortname = "hpux-threads"; + hpux_thread_ops.to_longname = "HPUX threads and pthread."; + hpux_thread_ops.to_doc = "HPUX threads and pthread support."; + hpux_thread_ops.to_open = hpux_thread_open; + hpux_thread_ops.to_attach = hpux_thread_attach; + hpux_thread_ops.to_detach = hpux_thread_detach; + hpux_thread_ops.to_resume = hpux_thread_resume; + hpux_thread_ops.to_wait = hpux_thread_wait; + hpux_thread_ops.to_fetch_registers = hpux_thread_fetch_registers; + hpux_thread_ops.to_store_registers = hpux_thread_store_registers; + hpux_thread_ops.to_prepare_to_store = hpux_thread_prepare_to_store; + hpux_thread_ops.to_xfer_memory = hpux_thread_xfer_memory; + hpux_thread_ops.to_files_info = hpux_thread_files_info; + hpux_thread_ops.to_insert_breakpoint = memory_insert_breakpoint; + hpux_thread_ops.to_remove_breakpoint = memory_remove_breakpoint; + hpux_thread_ops.to_terminal_init = terminal_init_inferior; + hpux_thread_ops.to_terminal_inferior = terminal_inferior; + hpux_thread_ops.to_terminal_ours_for_output = terminal_ours_for_output; + hpux_thread_ops.to_terminal_ours = terminal_ours; + hpux_thread_ops.to_terminal_info = child_terminal_info; + hpux_thread_ops.to_kill = hpux_thread_kill_inferior; + hpux_thread_ops.to_create_inferior = hpux_thread_create_inferior; + hpux_thread_ops.to_mourn_inferior = hpux_thread_mourn_inferior; + hpux_thread_ops.to_can_run = hpux_thread_can_run; + hpux_thread_ops.to_notice_signals = hpux_thread_notice_signals; + hpux_thread_ops.to_thread_alive = hpux_thread_thread_alive; + hpux_thread_ops.to_stop = hpux_thread_stop; + hpux_thread_ops.to_stratum = process_stratum; + hpux_thread_ops.to_has_all_memory = 1; + hpux_thread_ops.to_has_memory = 1; + hpux_thread_ops.to_has_stack = 1; + hpux_thread_ops.to_has_registers = 1; + hpux_thread_ops.to_has_execution = 1; + hpux_thread_ops.to_magic = OPS_MAGIC; +} void _initialize_hpux_thread () { + init_hpux_thread_ops (); add_target (&hpux_thread_ops); child_suppress_run = 1; diff --git a/gdb/m3-nat.c b/gdb/m3-nat.c index 43ab3ee11fe..4614f656550 100644 --- a/gdb/m3-nat.c +++ b/gdb/m3-nat.c @@ -1,7 +1,7 @@ /* Interface GDB to Mach 3.0 operating systems. (Most) Mach 3.0 related routines live in this file. - Copyright (C) 1992, 1996 Free Software Foundation, Inc. + Copyright (C) 1992, 1996, 1999 Free Software Foundation, Inc. This file is part of GDB. @@ -260,7 +260,8 @@ int must_suspend_thread = 0; struct cleanup *cleanup_step = NULL_CLEANUP; -extern struct target_ops m3_ops; +static struct target_ops m3_ops; + static void m3_kill_inferior (); #if 0 @@ -4534,79 +4535,50 @@ int pid; return NULL; /* To keep all compilers happy. */ } -struct target_ops m3_ops = { - "mach", /* to_shortname */ - "Mach child process", /* to_longname */ - "Mach child process (started by the \"run\" command).", /* to_doc */ - m3_open, /* to_open */ - 0, /* to_close */ - m3_attach, /* to_attach */ - NULL, /* to_post_attach */ - NULL, /* to_require_attach */ - m3_detach, /* to_detach */ - NULL, /* to_require_detach */ - m3_resume, /* to_resume */ - mach_really_wait, /* to_wait */ - NULL, /* to_post_wait */ - fetch_inferior_registers, /* to_fetch_registers */ - store_inferior_registers, /* to_store_registers */ - m3_prepare_to_store, /* to_prepare_to_store */ - m3_xfer_memory, /* to_xfer_memory */ - m3_files_info, /* to_files_info */ - memory_insert_breakpoint, /* to_insert_breakpoint */ - memory_remove_breakpoint, /* to_remove_breakpoint */ - terminal_init_inferior, /* to_terminal_init */ - terminal_inferior, /* to_terminal_inferior */ - terminal_ours_for_output, /* to_terminal_ours_for_output */ - terminal_ours, /* to_terminal_ours */ - child_terminal_info, /* to_terminal_info */ - m3_kill_inferior, /* to_kill */ - 0, /* to_load */ - 0, /* to_lookup_symbol */ - m3_create_inferior, /* to_create_inferior */ - NULL, /* to_post_startup_inferior */ - NULL, /* to_acknowledge_created_inferior */ - NULL, /* to_clone_and_follow_inferior */ - NULL, /* to_post_follow_inferior_by_clone */ - NULL, /* to_insert_fork_catchpoint */ - NULL, /* to_remove_fork_catchpoint */ - NULL, /* to_insert_vfork_catchpoint */ - NULL, /* to_remove_vfork_catchpoint */ - NULL, /* to_has_forked */ - NULL, /* to_has_vforked */ - NULL, /* to_can_follow_vfork_prior_to_exec */ - NULL, /* to_post_follow_vfork */ - NULL, /* to_insert_exec_catchpoint */ - NULL, /* to_remove_exec_catchpoint */ - NULL, /* to_has_execd */ - NULL, /* to_reported_exec_events_per_exec_call */ - NULL, /* to_has_exited */ - m3_mourn_inferior, /* to_mourn_inferior */ - m3_can_run, /* to_can_run */ - 0, /* to_notice_signals */ - 0, /* to_thread_alive */ - m3_stop, /* to_stop */ - 0, /* to_query */ - m3_pid_to_exec_file, /* to_pid_to_exec_file */ - NULL, /* to_core_file_to_sym_file */ - process_stratum, /* to_stratum */ - 0, /* to_next */ - 1, /* to_has_all_memory */ - 1, /* to_has_memory */ - 1, /* to_has_stack */ - 1, /* to_has_registers */ - 1, /* to_has_execution */ - tc_none, /* to_has_thread_control */ - 0, /* sections */ - 0, /* sections_end */ - OPS_MAGIC /* to_magic */ -}; +static void +init_m3_ops () +{ + m3_ops.to_shortname = "mach"; + m3_ops.to_longname = "Mach child process"; + m3_ops.to_doc = "Mach child process (started by the \"run\" command)."; + m3_ops.to_open = m3_open; + m3_ops.to_attach = m3_attach; + m3_ops.to_detach = m3_detach; + m3_ops.to_resume = m3_resume; + m3_ops.to_wait = mach_really__wait; + m3_ops.to_fetch_registers = fetch_inferior_registers; + m3_ops.to_store_registers = store_inferior_registers; + m3_ops.to_prepare_to_store = m3_prepare_to_store; + m3_ops.to_xfer_memory = m3_xfer_memory; + m3_ops.to_files_info = m3_files_info; + m3_ops.to_insert_breakpoint = memory_insert_breakpoint; + m3_ops.to_remove_breakpoint = memory_remove_breakpoint; + m3_ops.to_terminal_init = terminal_init_inferior; + m3_ops.to_terminal_inferior = terminal_inferior; + m3_ops.to_terminal_ours_for_output = terminal_ours_for_output; + m3_ops.to_terminal_ours = terminal_ours; + m3_ops.to_terminal_info = child_terminal_info; + m3_ops.to_kill = m3_kill_inferior; + m3_ops.to_create_inferior = m3_create_inferior; + m3_ops.to_mourn_inferior = m3_mourn_inferior; + m3_ops.to_can_run = m3_can_run; + m3_ops.to_stop = m3_stop; + m3_ops.to_pid_to_exec_file = m3_pid_to_exec_file; + m3_ops.to_stratum = process_stratum; + m3_ops.to_has_all_memory = 1; + m3_ops.to_has_memory = 1; + m3_ops.to_has_stack = 1; + m3_ops.to_has_registers = 1; + m3_ops.to_has_execution = 1; + m3_ops.to_magic = OPS_MAGIC; +} void _initialize_m3_nat () { kern_return_t ret; + init_m3_ops (); add_target (&m3_ops); ret = mach_port_allocate(mach_task_self(), -- 2.30.2