aboutsummaryrefslogtreecommitdiff
path: root/gdb/target-delegates-gen.c
diff options
context:
space:
mode:
Diffstat (limited to 'gdb/target-delegates-gen.c')
-rw-r--r--gdb/target-delegates-gen.c4521
1 files changed, 4521 insertions, 0 deletions
diff --git a/gdb/target-delegates-gen.c b/gdb/target-delegates-gen.c
new file mode 100644
index 0000000..164ddbb
--- /dev/null
+++ b/gdb/target-delegates-gen.c
@@ -0,0 +1,4521 @@
+/* THIS FILE IS GENERATED -*- buffer-read-only: t -*- */
+/* vi:set ro: */
+
+/* Boilerplate target methods for GDB
+
+ Copyright (C) 2013-2025 Free Software Foundation, Inc.
+
+ This file is part of GDB.
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 3 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program. If not, see <http://www.gnu.org/licenses/>. */
+
+/* To regenerate this file, run:
+ ./make-target-delegates.py
+*/
+
+struct dummy_target : public target_ops
+{
+ const target_info &info () const override;
+
+ strata stratum () const override;
+
+ void post_attach (int arg0) override;
+ void detach (inferior *arg0, int arg1) override;
+ void disconnect (const char *arg0, int arg1) override;
+ void resume (ptid_t arg0, int arg1, enum gdb_signal arg2) override;
+ void commit_resumed () override;
+ ptid_t wait (ptid_t arg0, struct target_waitstatus *arg1, target_wait_flags arg2) override;
+ void fetch_registers (struct regcache *arg0, int arg1) override;
+ void store_registers (struct regcache *arg0, int arg1) override;
+ void prepare_to_store (struct regcache *arg0) override;
+ void files_info () override;
+ int insert_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1) override;
+ int remove_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1, enum remove_bp_reason arg2) override;
+ bool stopped_by_sw_breakpoint () override;
+ bool supports_stopped_by_sw_breakpoint () override;
+ bool stopped_by_hw_breakpoint () override;
+ bool supports_stopped_by_hw_breakpoint () override;
+ int can_use_hw_breakpoint (enum bptype arg0, int arg1, int arg2) override;
+ int ranged_break_num_registers () override;
+ int insert_hw_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1) override;
+ int remove_hw_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1) override;
+ int remove_watchpoint (CORE_ADDR arg0, int arg1, enum target_hw_bp_type arg2, struct expression *arg3) override;
+ int insert_watchpoint (CORE_ADDR arg0, int arg1, enum target_hw_bp_type arg2, struct expression *arg3) override;
+ int insert_mask_watchpoint (CORE_ADDR arg0, CORE_ADDR arg1, enum target_hw_bp_type arg2) override;
+ int remove_mask_watchpoint (CORE_ADDR arg0, CORE_ADDR arg1, enum target_hw_bp_type arg2) override;
+ bool stopped_by_watchpoint () override;
+ bool have_steppable_watchpoint () override;
+ bool stopped_data_address (CORE_ADDR *arg0) override;
+ bool watchpoint_addr_within_range (CORE_ADDR arg0, CORE_ADDR arg1, int arg2) override;
+ int region_ok_for_hw_watchpoint (CORE_ADDR arg0, int arg1) override;
+ bool can_accel_watchpoint_condition (CORE_ADDR arg0, int arg1, int arg2, struct expression *arg3) override;
+ int masked_watch_num_registers (CORE_ADDR arg0, CORE_ADDR arg1) override;
+ int can_do_single_step () override;
+ bool supports_terminal_ours () override;
+ void terminal_init () override;
+ void terminal_inferior () override;
+ void terminal_save_inferior () override;
+ void terminal_ours_for_output () override;
+ void terminal_ours () override;
+ void terminal_info (const char *arg0, int arg1) override;
+ void kill () override;
+ void load (const char *arg0, int arg1) override;
+ int insert_fork_catchpoint (int arg0) override;
+ int remove_fork_catchpoint (int arg0) override;
+ int insert_vfork_catchpoint (int arg0) override;
+ int remove_vfork_catchpoint (int arg0) override;
+ void follow_fork (inferior *arg0, ptid_t arg1, target_waitkind arg2, bool arg3, bool arg4) override;
+ void follow_clone (ptid_t arg0) override;
+ int insert_exec_catchpoint (int arg0) override;
+ int remove_exec_catchpoint (int arg0) override;
+ void follow_exec (inferior *arg0, ptid_t arg1, const char *arg2) override;
+ int set_syscall_catchpoint (int arg0, bool arg1, int arg2, gdb::array_view<const int> arg3) override;
+ void mourn_inferior () override;
+ void pass_signals (gdb::array_view<const unsigned char> arg0) override;
+ void program_signals (gdb::array_view<const unsigned char> arg0) override;
+ bool thread_alive (ptid_t arg0) override;
+ void update_thread_list () override;
+ std::string pid_to_str (ptid_t arg0) override;
+ const char *extra_thread_info (thread_info *arg0) override;
+ const char *thread_name (thread_info *arg0) override;
+ thread_info *thread_handle_to_thread_info (const gdb_byte *arg0, int arg1, inferior *arg2) override;
+ gdb::array_view<const_gdb_byte> thread_info_to_thread_handle (struct thread_info *arg0) override;
+ void stop (ptid_t arg0) override;
+ void interrupt () override;
+ void pass_ctrlc () override;
+ void rcmd (const char *arg0, struct ui_file *arg1) override;
+ const char *pid_to_exec_file (int arg0) override;
+ void log_command (const char *arg0) override;
+ const std::vector<target_section> *get_section_table () override;
+ thread_control_capabilities get_thread_control_capabilities () override;
+ bool attach_no_wait () override;
+ bool can_async_p () override;
+ bool is_async_p () override;
+ void async (bool arg0) override;
+ int async_wait_fd () override;
+ bool has_pending_events () override;
+ void thread_events (bool arg0) override;
+ bool supports_set_thread_options (gdb_thread_options arg0) override;
+ bool supports_non_stop () override;
+ bool always_non_stop_p () override;
+ int find_memory_regions (find_memory_region_ftype arg0, void *arg1) override;
+ gdb::unique_xmalloc_ptr<char> make_corefile_notes (bfd *arg0, int *arg1) override;
+ gdb_byte *get_bookmark (const char *arg0, int arg1) override;
+ void goto_bookmark (const gdb_byte *arg0, int arg1) override;
+ CORE_ADDR get_thread_local_address (ptid_t arg0, CORE_ADDR arg1, CORE_ADDR arg2) override;
+ enum target_xfer_status xfer_partial (enum target_object arg0, const char *arg1, gdb_byte *arg2, const gdb_byte *arg3, ULONGEST arg4, ULONGEST arg5, ULONGEST *arg6) override;
+ ULONGEST get_memory_xfer_limit () override;
+ std::vector<mem_region> memory_map () override;
+ void flash_erase (ULONGEST arg0, LONGEST arg1) override;
+ void flash_done () override;
+ const struct target_desc *read_description () override;
+ ptid_t get_ada_task_ptid (long arg0, ULONGEST arg1) override;
+ int auxv_parse (const gdb_byte **arg0, const gdb_byte *arg1, CORE_ADDR *arg2, CORE_ADDR *arg3) override;
+ int search_memory (CORE_ADDR arg0, ULONGEST arg1, const gdb_byte *arg2, ULONGEST arg3, CORE_ADDR *arg4) override;
+ bool can_execute_reverse () override;
+ enum exec_direction_kind execution_direction () override;
+ bool supports_multi_process () override;
+ bool supports_enable_disable_tracepoint () override;
+ bool supports_disable_randomization () override;
+ bool supports_string_tracing () override;
+ bool supports_evaluation_of_breakpoint_conditions () override;
+ bool supports_dumpcore () override;
+ void dumpcore (const char *arg0) override;
+ bool can_run_breakpoint_commands () override;
+ struct gdbarch *thread_architecture (ptid_t arg0) override;
+ bool filesystem_is_local () override;
+ void trace_init () override;
+ void download_tracepoint (struct bp_location *arg0) override;
+ bool can_download_tracepoint () override;
+ void download_trace_state_variable (const trace_state_variable &arg0) override;
+ void enable_tracepoint (struct bp_location *arg0) override;
+ void disable_tracepoint (struct bp_location *arg0) override;
+ void trace_set_readonly_regions () override;
+ void trace_start () override;
+ int get_trace_status (struct trace_status *arg0) override;
+ void get_tracepoint_status (tracepoint *arg0, struct uploaded_tp *arg1) override;
+ void trace_stop () override;
+ int trace_find (enum trace_find_type arg0, int arg1, CORE_ADDR arg2, CORE_ADDR arg3, int *arg4) override;
+ bool get_trace_state_variable_value (int arg0, LONGEST *arg1) override;
+ int save_trace_data (const char *arg0) override;
+ int upload_tracepoints (struct uploaded_tp **arg0) override;
+ int upload_trace_state_variables (struct uploaded_tsv **arg0) override;
+ LONGEST get_raw_trace_data (gdb_byte *arg0, ULONGEST arg1, LONGEST arg2) override;
+ int get_min_fast_tracepoint_insn_len () override;
+ void set_disconnected_tracing (int arg0) override;
+ void set_circular_trace_buffer (int arg0) override;
+ void set_trace_buffer_size (LONGEST arg0) override;
+ bool set_trace_notes (const char *arg0, const char *arg1, const char *arg2) override;
+ int core_of_thread (ptid_t arg0) override;
+ int verify_memory (const gdb_byte *arg0, CORE_ADDR arg1, ULONGEST arg2) override;
+ bool get_tib_address (ptid_t arg0, CORE_ADDR *arg1) override;
+ void set_permissions () override;
+ bool static_tracepoint_marker_at (CORE_ADDR arg0, static_tracepoint_marker *arg1) override;
+ std::vector<static_tracepoint_marker> static_tracepoint_markers_by_strid (const char *arg0) override;
+ traceframe_info_up traceframe_info () override;
+ bool use_agent (bool arg0) override;
+ bool can_use_agent () override;
+ struct btrace_target_info *enable_btrace (thread_info *arg0, const struct btrace_config *arg1) override;
+ void disable_btrace (struct btrace_target_info *arg0) override;
+ void teardown_btrace (struct btrace_target_info *arg0) override;
+ enum btrace_error read_btrace (struct btrace_data *arg0, struct btrace_target_info *arg1, enum btrace_read_type arg2) override;
+ const struct btrace_config *btrace_conf (const struct btrace_target_info *arg0) override;
+ enum record_method record_method (ptid_t arg0) override;
+ void stop_recording () override;
+ void info_record () override;
+ void save_record (const char *arg0) override;
+ bool supports_delete_record () override;
+ void delete_record () override;
+ bool record_is_replaying (ptid_t arg0) override;
+ bool record_will_replay (ptid_t arg0, int arg1) override;
+ void record_stop_replaying () override;
+ void goto_record_begin () override;
+ void goto_record_end () override;
+ void goto_record (ULONGEST arg0) override;
+ void insn_history (int arg0, gdb_disassembly_flags arg1) override;
+ void insn_history_from (ULONGEST arg0, int arg1, gdb_disassembly_flags arg2) override;
+ void insn_history_range (ULONGEST arg0, ULONGEST arg1, gdb_disassembly_flags arg2) override;
+ void call_history (int arg0, record_print_flags arg1) override;
+ void call_history_from (ULONGEST arg0, int arg1, record_print_flags arg2) override;
+ void call_history_range (ULONGEST arg0, ULONGEST arg1, record_print_flags arg2) override;
+ bool augmented_libraries_svr4_read () override;
+ const struct frame_unwind *get_unwinder () override;
+ const struct frame_unwind *get_tailcall_unwinder () override;
+ void prepare_to_generate_core () override;
+ void done_generating_core () override;
+ bool supports_memory_tagging () override;
+ bool fetch_memtags (CORE_ADDR arg0, size_t arg1, gdb::byte_vector &arg2, int arg3) override;
+ bool store_memtags (CORE_ADDR arg0, size_t arg1, const gdb::byte_vector &arg2, int arg3) override;
+ bool is_address_tagged (gdbarch *arg0, CORE_ADDR arg1) override;
+ x86_xsave_layout fetch_x86_xsave_layout () override;
+ bool supports_displaced_step (thread_info *arg0) override;
+ displaced_step_prepare_status displaced_step_prepare (thread_info *arg0, CORE_ADDR &arg1) override;
+ displaced_step_finish_status displaced_step_finish (thread_info *arg0, const target_waitstatus &arg1) override;
+ void displaced_step_restore_all_in_ptid (inferior *arg0, ptid_t arg1) override;
+};
+
+struct debug_target : public target_ops
+{
+ const target_info &info () const override;
+
+ strata stratum () const override;
+
+ void post_attach (int arg0) override;
+ void detach (inferior *arg0, int arg1) override;
+ void disconnect (const char *arg0, int arg1) override;
+ void resume (ptid_t arg0, int arg1, enum gdb_signal arg2) override;
+ void commit_resumed () override;
+ ptid_t wait (ptid_t arg0, struct target_waitstatus *arg1, target_wait_flags arg2) override;
+ void fetch_registers (struct regcache *arg0, int arg1) override;
+ void store_registers (struct regcache *arg0, int arg1) override;
+ void prepare_to_store (struct regcache *arg0) override;
+ void files_info () override;
+ int insert_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1) override;
+ int remove_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1, enum remove_bp_reason arg2) override;
+ bool stopped_by_sw_breakpoint () override;
+ bool supports_stopped_by_sw_breakpoint () override;
+ bool stopped_by_hw_breakpoint () override;
+ bool supports_stopped_by_hw_breakpoint () override;
+ int can_use_hw_breakpoint (enum bptype arg0, int arg1, int arg2) override;
+ int ranged_break_num_registers () override;
+ int insert_hw_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1) override;
+ int remove_hw_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1) override;
+ int remove_watchpoint (CORE_ADDR arg0, int arg1, enum target_hw_bp_type arg2, struct expression *arg3) override;
+ int insert_watchpoint (CORE_ADDR arg0, int arg1, enum target_hw_bp_type arg2, struct expression *arg3) override;
+ int insert_mask_watchpoint (CORE_ADDR arg0, CORE_ADDR arg1, enum target_hw_bp_type arg2) override;
+ int remove_mask_watchpoint (CORE_ADDR arg0, CORE_ADDR arg1, enum target_hw_bp_type arg2) override;
+ bool stopped_by_watchpoint () override;
+ bool have_steppable_watchpoint () override;
+ bool stopped_data_address (CORE_ADDR *arg0) override;
+ bool watchpoint_addr_within_range (CORE_ADDR arg0, CORE_ADDR arg1, int arg2) override;
+ int region_ok_for_hw_watchpoint (CORE_ADDR arg0, int arg1) override;
+ bool can_accel_watchpoint_condition (CORE_ADDR arg0, int arg1, int arg2, struct expression *arg3) override;
+ int masked_watch_num_registers (CORE_ADDR arg0, CORE_ADDR arg1) override;
+ int can_do_single_step () override;
+ bool supports_terminal_ours () override;
+ void terminal_init () override;
+ void terminal_inferior () override;
+ void terminal_save_inferior () override;
+ void terminal_ours_for_output () override;
+ void terminal_ours () override;
+ void terminal_info (const char *arg0, int arg1) override;
+ void kill () override;
+ void load (const char *arg0, int arg1) override;
+ int insert_fork_catchpoint (int arg0) override;
+ int remove_fork_catchpoint (int arg0) override;
+ int insert_vfork_catchpoint (int arg0) override;
+ int remove_vfork_catchpoint (int arg0) override;
+ void follow_fork (inferior *arg0, ptid_t arg1, target_waitkind arg2, bool arg3, bool arg4) override;
+ void follow_clone (ptid_t arg0) override;
+ int insert_exec_catchpoint (int arg0) override;
+ int remove_exec_catchpoint (int arg0) override;
+ void follow_exec (inferior *arg0, ptid_t arg1, const char *arg2) override;
+ int set_syscall_catchpoint (int arg0, bool arg1, int arg2, gdb::array_view<const int> arg3) override;
+ void mourn_inferior () override;
+ void pass_signals (gdb::array_view<const unsigned char> arg0) override;
+ void program_signals (gdb::array_view<const unsigned char> arg0) override;
+ bool thread_alive (ptid_t arg0) override;
+ void update_thread_list () override;
+ std::string pid_to_str (ptid_t arg0) override;
+ const char *extra_thread_info (thread_info *arg0) override;
+ const char *thread_name (thread_info *arg0) override;
+ thread_info *thread_handle_to_thread_info (const gdb_byte *arg0, int arg1, inferior *arg2) override;
+ gdb::array_view<const_gdb_byte> thread_info_to_thread_handle (struct thread_info *arg0) override;
+ void stop (ptid_t arg0) override;
+ void interrupt () override;
+ void pass_ctrlc () override;
+ void rcmd (const char *arg0, struct ui_file *arg1) override;
+ const char *pid_to_exec_file (int arg0) override;
+ void log_command (const char *arg0) override;
+ const std::vector<target_section> *get_section_table () override;
+ thread_control_capabilities get_thread_control_capabilities () override;
+ bool attach_no_wait () override;
+ bool can_async_p () override;
+ bool is_async_p () override;
+ void async (bool arg0) override;
+ int async_wait_fd () override;
+ bool has_pending_events () override;
+ void thread_events (bool arg0) override;
+ bool supports_set_thread_options (gdb_thread_options arg0) override;
+ bool supports_non_stop () override;
+ bool always_non_stop_p () override;
+ int find_memory_regions (find_memory_region_ftype arg0, void *arg1) override;
+ gdb::unique_xmalloc_ptr<char> make_corefile_notes (bfd *arg0, int *arg1) override;
+ gdb_byte *get_bookmark (const char *arg0, int arg1) override;
+ void goto_bookmark (const gdb_byte *arg0, int arg1) override;
+ CORE_ADDR get_thread_local_address (ptid_t arg0, CORE_ADDR arg1, CORE_ADDR arg2) override;
+ enum target_xfer_status xfer_partial (enum target_object arg0, const char *arg1, gdb_byte *arg2, const gdb_byte *arg3, ULONGEST arg4, ULONGEST arg5, ULONGEST *arg6) override;
+ ULONGEST get_memory_xfer_limit () override;
+ std::vector<mem_region> memory_map () override;
+ void flash_erase (ULONGEST arg0, LONGEST arg1) override;
+ void flash_done () override;
+ const struct target_desc *read_description () override;
+ ptid_t get_ada_task_ptid (long arg0, ULONGEST arg1) override;
+ int auxv_parse (const gdb_byte **arg0, const gdb_byte *arg1, CORE_ADDR *arg2, CORE_ADDR *arg3) override;
+ int search_memory (CORE_ADDR arg0, ULONGEST arg1, const gdb_byte *arg2, ULONGEST arg3, CORE_ADDR *arg4) override;
+ bool can_execute_reverse () override;
+ enum exec_direction_kind execution_direction () override;
+ bool supports_multi_process () override;
+ bool supports_enable_disable_tracepoint () override;
+ bool supports_disable_randomization () override;
+ bool supports_string_tracing () override;
+ bool supports_evaluation_of_breakpoint_conditions () override;
+ bool supports_dumpcore () override;
+ void dumpcore (const char *arg0) override;
+ bool can_run_breakpoint_commands () override;
+ struct gdbarch *thread_architecture (ptid_t arg0) override;
+ bool filesystem_is_local () override;
+ void trace_init () override;
+ void download_tracepoint (struct bp_location *arg0) override;
+ bool can_download_tracepoint () override;
+ void download_trace_state_variable (const trace_state_variable &arg0) override;
+ void enable_tracepoint (struct bp_location *arg0) override;
+ void disable_tracepoint (struct bp_location *arg0) override;
+ void trace_set_readonly_regions () override;
+ void trace_start () override;
+ int get_trace_status (struct trace_status *arg0) override;
+ void get_tracepoint_status (tracepoint *arg0, struct uploaded_tp *arg1) override;
+ void trace_stop () override;
+ int trace_find (enum trace_find_type arg0, int arg1, CORE_ADDR arg2, CORE_ADDR arg3, int *arg4) override;
+ bool get_trace_state_variable_value (int arg0, LONGEST *arg1) override;
+ int save_trace_data (const char *arg0) override;
+ int upload_tracepoints (struct uploaded_tp **arg0) override;
+ int upload_trace_state_variables (struct uploaded_tsv **arg0) override;
+ LONGEST get_raw_trace_data (gdb_byte *arg0, ULONGEST arg1, LONGEST arg2) override;
+ int get_min_fast_tracepoint_insn_len () override;
+ void set_disconnected_tracing (int arg0) override;
+ void set_circular_trace_buffer (int arg0) override;
+ void set_trace_buffer_size (LONGEST arg0) override;
+ bool set_trace_notes (const char *arg0, const char *arg1, const char *arg2) override;
+ int core_of_thread (ptid_t arg0) override;
+ int verify_memory (const gdb_byte *arg0, CORE_ADDR arg1, ULONGEST arg2) override;
+ bool get_tib_address (ptid_t arg0, CORE_ADDR *arg1) override;
+ void set_permissions () override;
+ bool static_tracepoint_marker_at (CORE_ADDR arg0, static_tracepoint_marker *arg1) override;
+ std::vector<static_tracepoint_marker> static_tracepoint_markers_by_strid (const char *arg0) override;
+ traceframe_info_up traceframe_info () override;
+ bool use_agent (bool arg0) override;
+ bool can_use_agent () override;
+ struct btrace_target_info *enable_btrace (thread_info *arg0, const struct btrace_config *arg1) override;
+ void disable_btrace (struct btrace_target_info *arg0) override;
+ void teardown_btrace (struct btrace_target_info *arg0) override;
+ enum btrace_error read_btrace (struct btrace_data *arg0, struct btrace_target_info *arg1, enum btrace_read_type arg2) override;
+ const struct btrace_config *btrace_conf (const struct btrace_target_info *arg0) override;
+ enum record_method record_method (ptid_t arg0) override;
+ void stop_recording () override;
+ void info_record () override;
+ void save_record (const char *arg0) override;
+ bool supports_delete_record () override;
+ void delete_record () override;
+ bool record_is_replaying (ptid_t arg0) override;
+ bool record_will_replay (ptid_t arg0, int arg1) override;
+ void record_stop_replaying () override;
+ void goto_record_begin () override;
+ void goto_record_end () override;
+ void goto_record (ULONGEST arg0) override;
+ void insn_history (int arg0, gdb_disassembly_flags arg1) override;
+ void insn_history_from (ULONGEST arg0, int arg1, gdb_disassembly_flags arg2) override;
+ void insn_history_range (ULONGEST arg0, ULONGEST arg1, gdb_disassembly_flags arg2) override;
+ void call_history (int arg0, record_print_flags arg1) override;
+ void call_history_from (ULONGEST arg0, int arg1, record_print_flags arg2) override;
+ void call_history_range (ULONGEST arg0, ULONGEST arg1, record_print_flags arg2) override;
+ bool augmented_libraries_svr4_read () override;
+ const struct frame_unwind *get_unwinder () override;
+ const struct frame_unwind *get_tailcall_unwinder () override;
+ void prepare_to_generate_core () override;
+ void done_generating_core () override;
+ bool supports_memory_tagging () override;
+ bool fetch_memtags (CORE_ADDR arg0, size_t arg1, gdb::byte_vector &arg2, int arg3) override;
+ bool store_memtags (CORE_ADDR arg0, size_t arg1, const gdb::byte_vector &arg2, int arg3) override;
+ bool is_address_tagged (gdbarch *arg0, CORE_ADDR arg1) override;
+ x86_xsave_layout fetch_x86_xsave_layout () override;
+ bool supports_displaced_step (thread_info *arg0) override;
+ displaced_step_prepare_status displaced_step_prepare (thread_info *arg0, CORE_ADDR &arg1) override;
+ displaced_step_finish_status displaced_step_finish (thread_info *arg0, const target_waitstatus &arg1) override;
+ void displaced_step_restore_all_in_ptid (inferior *arg0, ptid_t arg1) override;
+};
+
+void
+target_ops::post_attach (int arg0)
+{
+ this->beneath ()->post_attach (arg0);
+}
+
+void
+dummy_target::post_attach (int arg0)
+{
+}
+
+void
+debug_target::post_attach (int arg0)
+{
+ target_debug_printf_nofunc ("-> %s->post_attach (...)", this->beneath ()->shortname ());
+ this->beneath ()->post_attach (arg0);
+ target_debug_printf_nofunc ("<- %s->post_attach (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_int (arg0).c_str ());
+}
+
+void
+target_ops::detach (inferior *arg0, int arg1)
+{
+ this->beneath ()->detach (arg0, arg1);
+}
+
+void
+dummy_target::detach (inferior *arg0, int arg1)
+{
+}
+
+void
+debug_target::detach (inferior *arg0, int arg1)
+{
+ target_debug_printf_nofunc ("-> %s->detach (...)", this->beneath ()->shortname ());
+ this->beneath ()->detach (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->detach (%s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_inferior_p (arg0).c_str (),
+ target_debug_print_int (arg1).c_str ());
+}
+
+void
+target_ops::disconnect (const char *arg0, int arg1)
+{
+ this->beneath ()->disconnect (arg0, arg1);
+}
+
+void
+dummy_target::disconnect (const char *arg0, int arg1)
+{
+ tcomplain ();
+}
+
+void
+debug_target::disconnect (const char *arg0, int arg1)
+{
+ target_debug_printf_nofunc ("-> %s->disconnect (...)", this->beneath ()->shortname ());
+ this->beneath ()->disconnect (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->disconnect (%s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_const_char_p (arg0).c_str (),
+ target_debug_print_int (arg1).c_str ());
+}
+
+void
+target_ops::resume (ptid_t arg0, int arg1, enum gdb_signal arg2)
+{
+ this->beneath ()->resume (arg0, arg1, arg2);
+}
+
+void
+dummy_target::resume (ptid_t arg0, int arg1, enum gdb_signal arg2)
+{
+ noprocess ();
+}
+
+void
+debug_target::resume (ptid_t arg0, int arg1, enum gdb_signal arg2)
+{
+ target_debug_printf_nofunc ("-> %s->resume (...)", this->beneath ()->shortname ());
+ this->beneath ()->resume (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->resume (%s, %s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_ptid_t (arg0).c_str (),
+ target_debug_print_step (arg1).c_str (),
+ target_debug_print_gdb_signal (arg2).c_str ());
+}
+
+void
+target_ops::commit_resumed ()
+{
+ this->beneath ()->commit_resumed ();
+}
+
+void
+dummy_target::commit_resumed ()
+{
+}
+
+void
+debug_target::commit_resumed ()
+{
+ target_debug_printf_nofunc ("-> %s->commit_resumed (...)", this->beneath ()->shortname ());
+ this->beneath ()->commit_resumed ();
+ target_debug_printf_nofunc ("<- %s->commit_resumed ()",
+ this->beneath ()->shortname ());
+}
+
+ptid_t
+target_ops::wait (ptid_t arg0, struct target_waitstatus *arg1, target_wait_flags arg2)
+{
+ return this->beneath ()->wait (arg0, arg1, arg2);
+}
+
+ptid_t
+dummy_target::wait (ptid_t arg0, struct target_waitstatus *arg1, target_wait_flags arg2)
+{
+ return default_target_wait (this, arg0, arg1, arg2);
+}
+
+ptid_t
+debug_target::wait (ptid_t arg0, struct target_waitstatus *arg1, target_wait_flags arg2)
+{
+ target_debug_printf_nofunc ("-> %s->wait (...)", this->beneath ()->shortname ());
+ ptid_t result
+ = this->beneath ()->wait (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->wait (%s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_ptid_t (arg0).c_str (),
+ target_debug_print_target_waitstatus_p (arg1).c_str (),
+ target_debug_print_target_wait_flags (arg2).c_str (),
+ target_debug_print_ptid_t (result).c_str ());
+ return result;
+}
+
+void
+target_ops::fetch_registers (struct regcache *arg0, int arg1)
+{
+ this->beneath ()->fetch_registers (arg0, arg1);
+}
+
+void
+dummy_target::fetch_registers (struct regcache *arg0, int arg1)
+{
+}
+
+void
+debug_target::fetch_registers (struct regcache *arg0, int arg1)
+{
+ target_debug_printf_nofunc ("-> %s->fetch_registers (...)", this->beneath ()->shortname ());
+ this->beneath ()->fetch_registers (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->fetch_registers (%s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_regcache_p (arg0).c_str (),
+ target_debug_print_int (arg1).c_str ());
+}
+
+void
+target_ops::store_registers (struct regcache *arg0, int arg1)
+{
+ this->beneath ()->store_registers (arg0, arg1);
+}
+
+void
+dummy_target::store_registers (struct regcache *arg0, int arg1)
+{
+ noprocess ();
+}
+
+void
+debug_target::store_registers (struct regcache *arg0, int arg1)
+{
+ target_debug_printf_nofunc ("-> %s->store_registers (...)", this->beneath ()->shortname ());
+ this->beneath ()->store_registers (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->store_registers (%s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_regcache_p (arg0).c_str (),
+ target_debug_print_int (arg1).c_str ());
+}
+
+void
+target_ops::prepare_to_store (struct regcache *arg0)
+{
+ this->beneath ()->prepare_to_store (arg0);
+}
+
+void
+dummy_target::prepare_to_store (struct regcache *arg0)
+{
+ noprocess ();
+}
+
+void
+debug_target::prepare_to_store (struct regcache *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->prepare_to_store (...)", this->beneath ()->shortname ());
+ this->beneath ()->prepare_to_store (arg0);
+ target_debug_printf_nofunc ("<- %s->prepare_to_store (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_regcache_p (arg0).c_str ());
+}
+
+void
+target_ops::files_info ()
+{
+ this->beneath ()->files_info ();
+}
+
+void
+dummy_target::files_info ()
+{
+}
+
+void
+debug_target::files_info ()
+{
+ target_debug_printf_nofunc ("-> %s->files_info (...)", this->beneath ()->shortname ());
+ this->beneath ()->files_info ();
+ target_debug_printf_nofunc ("<- %s->files_info ()",
+ this->beneath ()->shortname ());
+}
+
+int
+target_ops::insert_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1)
+{
+ return this->beneath ()->insert_breakpoint (arg0, arg1);
+}
+
+int
+dummy_target::insert_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1)
+{
+ noprocess ();
+}
+
+int
+debug_target::insert_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1)
+{
+ target_debug_printf_nofunc ("-> %s->insert_breakpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->insert_breakpoint (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->insert_breakpoint (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_gdbarch_p (arg0).c_str (),
+ target_debug_print_bp_target_info_p (arg1).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::remove_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1, enum remove_bp_reason arg2)
+{
+ return this->beneath ()->remove_breakpoint (arg0, arg1, arg2);
+}
+
+int
+dummy_target::remove_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1, enum remove_bp_reason arg2)
+{
+ noprocess ();
+}
+
+int
+debug_target::remove_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1, enum remove_bp_reason arg2)
+{
+ target_debug_printf_nofunc ("-> %s->remove_breakpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->remove_breakpoint (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->remove_breakpoint (%s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_gdbarch_p (arg0).c_str (),
+ target_debug_print_bp_target_info_p (arg1).c_str (),
+ target_debug_print_remove_bp_reason (arg2).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::stopped_by_sw_breakpoint ()
+{
+ return this->beneath ()->stopped_by_sw_breakpoint ();
+}
+
+bool
+dummy_target::stopped_by_sw_breakpoint ()
+{
+ return false;
+}
+
+bool
+debug_target::stopped_by_sw_breakpoint ()
+{
+ target_debug_printf_nofunc ("-> %s->stopped_by_sw_breakpoint (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->stopped_by_sw_breakpoint ();
+ target_debug_printf_nofunc ("<- %s->stopped_by_sw_breakpoint () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::supports_stopped_by_sw_breakpoint ()
+{
+ return this->beneath ()->supports_stopped_by_sw_breakpoint ();
+}
+
+bool
+dummy_target::supports_stopped_by_sw_breakpoint ()
+{
+ return false;
+}
+
+bool
+debug_target::supports_stopped_by_sw_breakpoint ()
+{
+ target_debug_printf_nofunc ("-> %s->supports_stopped_by_sw_breakpoint (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->supports_stopped_by_sw_breakpoint ();
+ target_debug_printf_nofunc ("<- %s->supports_stopped_by_sw_breakpoint () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::stopped_by_hw_breakpoint ()
+{
+ return this->beneath ()->stopped_by_hw_breakpoint ();
+}
+
+bool
+dummy_target::stopped_by_hw_breakpoint ()
+{
+ return false;
+}
+
+bool
+debug_target::stopped_by_hw_breakpoint ()
+{
+ target_debug_printf_nofunc ("-> %s->stopped_by_hw_breakpoint (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->stopped_by_hw_breakpoint ();
+ target_debug_printf_nofunc ("<- %s->stopped_by_hw_breakpoint () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::supports_stopped_by_hw_breakpoint ()
+{
+ return this->beneath ()->supports_stopped_by_hw_breakpoint ();
+}
+
+bool
+dummy_target::supports_stopped_by_hw_breakpoint ()
+{
+ return false;
+}
+
+bool
+debug_target::supports_stopped_by_hw_breakpoint ()
+{
+ target_debug_printf_nofunc ("-> %s->supports_stopped_by_hw_breakpoint (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->supports_stopped_by_hw_breakpoint ();
+ target_debug_printf_nofunc ("<- %s->supports_stopped_by_hw_breakpoint () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+int
+target_ops::can_use_hw_breakpoint (enum bptype arg0, int arg1, int arg2)
+{
+ return this->beneath ()->can_use_hw_breakpoint (arg0, arg1, arg2);
+}
+
+int
+dummy_target::can_use_hw_breakpoint (enum bptype arg0, int arg1, int arg2)
+{
+ return 0;
+}
+
+int
+debug_target::can_use_hw_breakpoint (enum bptype arg0, int arg1, int arg2)
+{
+ target_debug_printf_nofunc ("-> %s->can_use_hw_breakpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->can_use_hw_breakpoint (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->can_use_hw_breakpoint (%s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bptype (arg0).c_str (),
+ target_debug_print_int (arg1).c_str (),
+ target_debug_print_int (arg2).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::ranged_break_num_registers ()
+{
+ return this->beneath ()->ranged_break_num_registers ();
+}
+
+int
+dummy_target::ranged_break_num_registers ()
+{
+ return -1;
+}
+
+int
+debug_target::ranged_break_num_registers ()
+{
+ target_debug_printf_nofunc ("-> %s->ranged_break_num_registers (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->ranged_break_num_registers ();
+ target_debug_printf_nofunc ("<- %s->ranged_break_num_registers () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::insert_hw_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1)
+{
+ return this->beneath ()->insert_hw_breakpoint (arg0, arg1);
+}
+
+int
+dummy_target::insert_hw_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1)
+{
+ return -1;
+}
+
+int
+debug_target::insert_hw_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1)
+{
+ target_debug_printf_nofunc ("-> %s->insert_hw_breakpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->insert_hw_breakpoint (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->insert_hw_breakpoint (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_gdbarch_p (arg0).c_str (),
+ target_debug_print_bp_target_info_p (arg1).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::remove_hw_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1)
+{
+ return this->beneath ()->remove_hw_breakpoint (arg0, arg1);
+}
+
+int
+dummy_target::remove_hw_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1)
+{
+ return -1;
+}
+
+int
+debug_target::remove_hw_breakpoint (struct gdbarch *arg0, struct bp_target_info *arg1)
+{
+ target_debug_printf_nofunc ("-> %s->remove_hw_breakpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->remove_hw_breakpoint (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->remove_hw_breakpoint (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_gdbarch_p (arg0).c_str (),
+ target_debug_print_bp_target_info_p (arg1).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::remove_watchpoint (CORE_ADDR arg0, int arg1, enum target_hw_bp_type arg2, struct expression *arg3)
+{
+ return this->beneath ()->remove_watchpoint (arg0, arg1, arg2, arg3);
+}
+
+int
+dummy_target::remove_watchpoint (CORE_ADDR arg0, int arg1, enum target_hw_bp_type arg2, struct expression *arg3)
+{
+ return -1;
+}
+
+int
+debug_target::remove_watchpoint (CORE_ADDR arg0, int arg1, enum target_hw_bp_type arg2, struct expression *arg3)
+{
+ target_debug_printf_nofunc ("-> %s->remove_watchpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->remove_watchpoint (arg0, arg1, arg2, arg3);
+ target_debug_printf_nofunc ("<- %s->remove_watchpoint (%s, %s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_CORE_ADDR (arg0).c_str (),
+ target_debug_print_int (arg1).c_str (),
+ target_debug_print_target_hw_bp_type (arg2).c_str (),
+ target_debug_print_expression_p (arg3).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::insert_watchpoint (CORE_ADDR arg0, int arg1, enum target_hw_bp_type arg2, struct expression *arg3)
+{
+ return this->beneath ()->insert_watchpoint (arg0, arg1, arg2, arg3);
+}
+
+int
+dummy_target::insert_watchpoint (CORE_ADDR arg0, int arg1, enum target_hw_bp_type arg2, struct expression *arg3)
+{
+ return -1;
+}
+
+int
+debug_target::insert_watchpoint (CORE_ADDR arg0, int arg1, enum target_hw_bp_type arg2, struct expression *arg3)
+{
+ target_debug_printf_nofunc ("-> %s->insert_watchpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->insert_watchpoint (arg0, arg1, arg2, arg3);
+ target_debug_printf_nofunc ("<- %s->insert_watchpoint (%s, %s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_CORE_ADDR (arg0).c_str (),
+ target_debug_print_int (arg1).c_str (),
+ target_debug_print_target_hw_bp_type (arg2).c_str (),
+ target_debug_print_expression_p (arg3).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::insert_mask_watchpoint (CORE_ADDR arg0, CORE_ADDR arg1, enum target_hw_bp_type arg2)
+{
+ return this->beneath ()->insert_mask_watchpoint (arg0, arg1, arg2);
+}
+
+int
+dummy_target::insert_mask_watchpoint (CORE_ADDR arg0, CORE_ADDR arg1, enum target_hw_bp_type arg2)
+{
+ return 1;
+}
+
+int
+debug_target::insert_mask_watchpoint (CORE_ADDR arg0, CORE_ADDR arg1, enum target_hw_bp_type arg2)
+{
+ target_debug_printf_nofunc ("-> %s->insert_mask_watchpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->insert_mask_watchpoint (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->insert_mask_watchpoint (%s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_CORE_ADDR (arg0).c_str (),
+ target_debug_print_CORE_ADDR (arg1).c_str (),
+ target_debug_print_target_hw_bp_type (arg2).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::remove_mask_watchpoint (CORE_ADDR arg0, CORE_ADDR arg1, enum target_hw_bp_type arg2)
+{
+ return this->beneath ()->remove_mask_watchpoint (arg0, arg1, arg2);
+}
+
+int
+dummy_target::remove_mask_watchpoint (CORE_ADDR arg0, CORE_ADDR arg1, enum target_hw_bp_type arg2)
+{
+ return 1;
+}
+
+int
+debug_target::remove_mask_watchpoint (CORE_ADDR arg0, CORE_ADDR arg1, enum target_hw_bp_type arg2)
+{
+ target_debug_printf_nofunc ("-> %s->remove_mask_watchpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->remove_mask_watchpoint (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->remove_mask_watchpoint (%s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_CORE_ADDR (arg0).c_str (),
+ target_debug_print_CORE_ADDR (arg1).c_str (),
+ target_debug_print_target_hw_bp_type (arg2).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::stopped_by_watchpoint ()
+{
+ return this->beneath ()->stopped_by_watchpoint ();
+}
+
+bool
+dummy_target::stopped_by_watchpoint ()
+{
+ return false;
+}
+
+bool
+debug_target::stopped_by_watchpoint ()
+{
+ target_debug_printf_nofunc ("-> %s->stopped_by_watchpoint (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->stopped_by_watchpoint ();
+ target_debug_printf_nofunc ("<- %s->stopped_by_watchpoint () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::have_steppable_watchpoint ()
+{
+ return this->beneath ()->have_steppable_watchpoint ();
+}
+
+bool
+dummy_target::have_steppable_watchpoint ()
+{
+ return false;
+}
+
+bool
+debug_target::have_steppable_watchpoint ()
+{
+ target_debug_printf_nofunc ("-> %s->have_steppable_watchpoint (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->have_steppable_watchpoint ();
+ target_debug_printf_nofunc ("<- %s->have_steppable_watchpoint () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::stopped_data_address (CORE_ADDR *arg0)
+{
+ return this->beneath ()->stopped_data_address (arg0);
+}
+
+bool
+dummy_target::stopped_data_address (CORE_ADDR *arg0)
+{
+ return false;
+}
+
+bool
+debug_target::stopped_data_address (CORE_ADDR *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->stopped_data_address (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->stopped_data_address (arg0);
+ target_debug_printf_nofunc ("<- %s->stopped_data_address (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_CORE_ADDR_p (arg0).c_str (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::watchpoint_addr_within_range (CORE_ADDR arg0, CORE_ADDR arg1, int arg2)
+{
+ return this->beneath ()->watchpoint_addr_within_range (arg0, arg1, arg2);
+}
+
+bool
+dummy_target::watchpoint_addr_within_range (CORE_ADDR arg0, CORE_ADDR arg1, int arg2)
+{
+ return default_watchpoint_addr_within_range (this, arg0, arg1, arg2);
+}
+
+bool
+debug_target::watchpoint_addr_within_range (CORE_ADDR arg0, CORE_ADDR arg1, int arg2)
+{
+ target_debug_printf_nofunc ("-> %s->watchpoint_addr_within_range (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->watchpoint_addr_within_range (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->watchpoint_addr_within_range (%s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_CORE_ADDR (arg0).c_str (),
+ target_debug_print_CORE_ADDR (arg1).c_str (),
+ target_debug_print_int (arg2).c_str (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+int
+target_ops::region_ok_for_hw_watchpoint (CORE_ADDR arg0, int arg1)
+{
+ return this->beneath ()->region_ok_for_hw_watchpoint (arg0, arg1);
+}
+
+int
+dummy_target::region_ok_for_hw_watchpoint (CORE_ADDR arg0, int arg1)
+{
+ return default_region_ok_for_hw_watchpoint (this, arg0, arg1);
+}
+
+int
+debug_target::region_ok_for_hw_watchpoint (CORE_ADDR arg0, int arg1)
+{
+ target_debug_printf_nofunc ("-> %s->region_ok_for_hw_watchpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->region_ok_for_hw_watchpoint (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->region_ok_for_hw_watchpoint (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_CORE_ADDR (arg0).c_str (),
+ target_debug_print_int (arg1).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::can_accel_watchpoint_condition (CORE_ADDR arg0, int arg1, int arg2, struct expression *arg3)
+{
+ return this->beneath ()->can_accel_watchpoint_condition (arg0, arg1, arg2, arg3);
+}
+
+bool
+dummy_target::can_accel_watchpoint_condition (CORE_ADDR arg0, int arg1, int arg2, struct expression *arg3)
+{
+ return false;
+}
+
+bool
+debug_target::can_accel_watchpoint_condition (CORE_ADDR arg0, int arg1, int arg2, struct expression *arg3)
+{
+ target_debug_printf_nofunc ("-> %s->can_accel_watchpoint_condition (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->can_accel_watchpoint_condition (arg0, arg1, arg2, arg3);
+ target_debug_printf_nofunc ("<- %s->can_accel_watchpoint_condition (%s, %s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_CORE_ADDR (arg0).c_str (),
+ target_debug_print_int (arg1).c_str (),
+ target_debug_print_int (arg2).c_str (),
+ target_debug_print_expression_p (arg3).c_str (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+int
+target_ops::masked_watch_num_registers (CORE_ADDR arg0, CORE_ADDR arg1)
+{
+ return this->beneath ()->masked_watch_num_registers (arg0, arg1);
+}
+
+int
+dummy_target::masked_watch_num_registers (CORE_ADDR arg0, CORE_ADDR arg1)
+{
+ return -1;
+}
+
+int
+debug_target::masked_watch_num_registers (CORE_ADDR arg0, CORE_ADDR arg1)
+{
+ target_debug_printf_nofunc ("-> %s->masked_watch_num_registers (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->masked_watch_num_registers (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->masked_watch_num_registers (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_CORE_ADDR (arg0).c_str (),
+ target_debug_print_CORE_ADDR (arg1).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::can_do_single_step ()
+{
+ return this->beneath ()->can_do_single_step ();
+}
+
+int
+dummy_target::can_do_single_step ()
+{
+ return -1;
+}
+
+int
+debug_target::can_do_single_step ()
+{
+ target_debug_printf_nofunc ("-> %s->can_do_single_step (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->can_do_single_step ();
+ target_debug_printf_nofunc ("<- %s->can_do_single_step () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::supports_terminal_ours ()
+{
+ return this->beneath ()->supports_terminal_ours ();
+}
+
+bool
+dummy_target::supports_terminal_ours ()
+{
+ return false;
+}
+
+bool
+debug_target::supports_terminal_ours ()
+{
+ target_debug_printf_nofunc ("-> %s->supports_terminal_ours (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->supports_terminal_ours ();
+ target_debug_printf_nofunc ("<- %s->supports_terminal_ours () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+void
+target_ops::terminal_init ()
+{
+ this->beneath ()->terminal_init ();
+}
+
+void
+dummy_target::terminal_init ()
+{
+}
+
+void
+debug_target::terminal_init ()
+{
+ target_debug_printf_nofunc ("-> %s->terminal_init (...)", this->beneath ()->shortname ());
+ this->beneath ()->terminal_init ();
+ target_debug_printf_nofunc ("<- %s->terminal_init ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::terminal_inferior ()
+{
+ this->beneath ()->terminal_inferior ();
+}
+
+void
+dummy_target::terminal_inferior ()
+{
+}
+
+void
+debug_target::terminal_inferior ()
+{
+ target_debug_printf_nofunc ("-> %s->terminal_inferior (...)", this->beneath ()->shortname ());
+ this->beneath ()->terminal_inferior ();
+ target_debug_printf_nofunc ("<- %s->terminal_inferior ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::terminal_save_inferior ()
+{
+ this->beneath ()->terminal_save_inferior ();
+}
+
+void
+dummy_target::terminal_save_inferior ()
+{
+}
+
+void
+debug_target::terminal_save_inferior ()
+{
+ target_debug_printf_nofunc ("-> %s->terminal_save_inferior (...)", this->beneath ()->shortname ());
+ this->beneath ()->terminal_save_inferior ();
+ target_debug_printf_nofunc ("<- %s->terminal_save_inferior ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::terminal_ours_for_output ()
+{
+ this->beneath ()->terminal_ours_for_output ();
+}
+
+void
+dummy_target::terminal_ours_for_output ()
+{
+}
+
+void
+debug_target::terminal_ours_for_output ()
+{
+ target_debug_printf_nofunc ("-> %s->terminal_ours_for_output (...)", this->beneath ()->shortname ());
+ this->beneath ()->terminal_ours_for_output ();
+ target_debug_printf_nofunc ("<- %s->terminal_ours_for_output ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::terminal_ours ()
+{
+ this->beneath ()->terminal_ours ();
+}
+
+void
+dummy_target::terminal_ours ()
+{
+}
+
+void
+debug_target::terminal_ours ()
+{
+ target_debug_printf_nofunc ("-> %s->terminal_ours (...)", this->beneath ()->shortname ());
+ this->beneath ()->terminal_ours ();
+ target_debug_printf_nofunc ("<- %s->terminal_ours ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::terminal_info (const char *arg0, int arg1)
+{
+ this->beneath ()->terminal_info (arg0, arg1);
+}
+
+void
+dummy_target::terminal_info (const char *arg0, int arg1)
+{
+ default_terminal_info (this, arg0, arg1);
+}
+
+void
+debug_target::terminal_info (const char *arg0, int arg1)
+{
+ target_debug_printf_nofunc ("-> %s->terminal_info (...)", this->beneath ()->shortname ());
+ this->beneath ()->terminal_info (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->terminal_info (%s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_const_char_p (arg0).c_str (),
+ target_debug_print_int (arg1).c_str ());
+}
+
+void
+target_ops::kill ()
+{
+ this->beneath ()->kill ();
+}
+
+void
+dummy_target::kill ()
+{
+ noprocess ();
+}
+
+void
+debug_target::kill ()
+{
+ target_debug_printf_nofunc ("-> %s->kill (...)", this->beneath ()->shortname ());
+ this->beneath ()->kill ();
+ target_debug_printf_nofunc ("<- %s->kill ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::load (const char *arg0, int arg1)
+{
+ this->beneath ()->load (arg0, arg1);
+}
+
+void
+dummy_target::load (const char *arg0, int arg1)
+{
+ tcomplain ();
+}
+
+void
+debug_target::load (const char *arg0, int arg1)
+{
+ target_debug_printf_nofunc ("-> %s->load (...)", this->beneath ()->shortname ());
+ this->beneath ()->load (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->load (%s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_const_char_p (arg0).c_str (),
+ target_debug_print_int (arg1).c_str ());
+}
+
+int
+target_ops::insert_fork_catchpoint (int arg0)
+{
+ return this->beneath ()->insert_fork_catchpoint (arg0);
+}
+
+int
+dummy_target::insert_fork_catchpoint (int arg0)
+{
+ return 1;
+}
+
+int
+debug_target::insert_fork_catchpoint (int arg0)
+{
+ target_debug_printf_nofunc ("-> %s->insert_fork_catchpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->insert_fork_catchpoint (arg0);
+ target_debug_printf_nofunc ("<- %s->insert_fork_catchpoint (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_int (arg0).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::remove_fork_catchpoint (int arg0)
+{
+ return this->beneath ()->remove_fork_catchpoint (arg0);
+}
+
+int
+dummy_target::remove_fork_catchpoint (int arg0)
+{
+ return 1;
+}
+
+int
+debug_target::remove_fork_catchpoint (int arg0)
+{
+ target_debug_printf_nofunc ("-> %s->remove_fork_catchpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->remove_fork_catchpoint (arg0);
+ target_debug_printf_nofunc ("<- %s->remove_fork_catchpoint (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_int (arg0).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::insert_vfork_catchpoint (int arg0)
+{
+ return this->beneath ()->insert_vfork_catchpoint (arg0);
+}
+
+int
+dummy_target::insert_vfork_catchpoint (int arg0)
+{
+ return 1;
+}
+
+int
+debug_target::insert_vfork_catchpoint (int arg0)
+{
+ target_debug_printf_nofunc ("-> %s->insert_vfork_catchpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->insert_vfork_catchpoint (arg0);
+ target_debug_printf_nofunc ("<- %s->insert_vfork_catchpoint (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_int (arg0).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::remove_vfork_catchpoint (int arg0)
+{
+ return this->beneath ()->remove_vfork_catchpoint (arg0);
+}
+
+int
+dummy_target::remove_vfork_catchpoint (int arg0)
+{
+ return 1;
+}
+
+int
+debug_target::remove_vfork_catchpoint (int arg0)
+{
+ target_debug_printf_nofunc ("-> %s->remove_vfork_catchpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->remove_vfork_catchpoint (arg0);
+ target_debug_printf_nofunc ("<- %s->remove_vfork_catchpoint (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_int (arg0).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+void
+target_ops::follow_fork (inferior *arg0, ptid_t arg1, target_waitkind arg2, bool arg3, bool arg4)
+{
+ this->beneath ()->follow_fork (arg0, arg1, arg2, arg3, arg4);
+}
+
+void
+dummy_target::follow_fork (inferior *arg0, ptid_t arg1, target_waitkind arg2, bool arg3, bool arg4)
+{
+ default_follow_fork (this, arg0, arg1, arg2, arg3, arg4);
+}
+
+void
+debug_target::follow_fork (inferior *arg0, ptid_t arg1, target_waitkind arg2, bool arg3, bool arg4)
+{
+ target_debug_printf_nofunc ("-> %s->follow_fork (...)", this->beneath ()->shortname ());
+ this->beneath ()->follow_fork (arg0, arg1, arg2, arg3, arg4);
+ target_debug_printf_nofunc ("<- %s->follow_fork (%s, %s, %s, %s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_inferior_p (arg0).c_str (),
+ target_debug_print_ptid_t (arg1).c_str (),
+ target_debug_print_target_waitkind (arg2).c_str (),
+ target_debug_print_bool (arg3).c_str (),
+ target_debug_print_bool (arg4).c_str ());
+}
+
+void
+target_ops::follow_clone (ptid_t arg0)
+{
+ this->beneath ()->follow_clone (arg0);
+}
+
+void
+dummy_target::follow_clone (ptid_t arg0)
+{
+ default_follow_clone (this, arg0);
+}
+
+void
+debug_target::follow_clone (ptid_t arg0)
+{
+ target_debug_printf_nofunc ("-> %s->follow_clone (...)", this->beneath ()->shortname ());
+ this->beneath ()->follow_clone (arg0);
+ target_debug_printf_nofunc ("<- %s->follow_clone (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_ptid_t (arg0).c_str ());
+}
+
+int
+target_ops::insert_exec_catchpoint (int arg0)
+{
+ return this->beneath ()->insert_exec_catchpoint (arg0);
+}
+
+int
+dummy_target::insert_exec_catchpoint (int arg0)
+{
+ return 1;
+}
+
+int
+debug_target::insert_exec_catchpoint (int arg0)
+{
+ target_debug_printf_nofunc ("-> %s->insert_exec_catchpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->insert_exec_catchpoint (arg0);
+ target_debug_printf_nofunc ("<- %s->insert_exec_catchpoint (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_int (arg0).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::remove_exec_catchpoint (int arg0)
+{
+ return this->beneath ()->remove_exec_catchpoint (arg0);
+}
+
+int
+dummy_target::remove_exec_catchpoint (int arg0)
+{
+ return 1;
+}
+
+int
+debug_target::remove_exec_catchpoint (int arg0)
+{
+ target_debug_printf_nofunc ("-> %s->remove_exec_catchpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->remove_exec_catchpoint (arg0);
+ target_debug_printf_nofunc ("<- %s->remove_exec_catchpoint (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_int (arg0).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+void
+target_ops::follow_exec (inferior *arg0, ptid_t arg1, const char *arg2)
+{
+ this->beneath ()->follow_exec (arg0, arg1, arg2);
+}
+
+void
+dummy_target::follow_exec (inferior *arg0, ptid_t arg1, const char *arg2)
+{
+}
+
+void
+debug_target::follow_exec (inferior *arg0, ptid_t arg1, const char *arg2)
+{
+ target_debug_printf_nofunc ("-> %s->follow_exec (...)", this->beneath ()->shortname ());
+ this->beneath ()->follow_exec (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->follow_exec (%s, %s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_inferior_p (arg0).c_str (),
+ target_debug_print_ptid_t (arg1).c_str (),
+ target_debug_print_const_char_p (arg2).c_str ());
+}
+
+int
+target_ops::set_syscall_catchpoint (int arg0, bool arg1, int arg2, gdb::array_view<const int> arg3)
+{
+ return this->beneath ()->set_syscall_catchpoint (arg0, arg1, arg2, arg3);
+}
+
+int
+dummy_target::set_syscall_catchpoint (int arg0, bool arg1, int arg2, gdb::array_view<const int> arg3)
+{
+ return 1;
+}
+
+int
+debug_target::set_syscall_catchpoint (int arg0, bool arg1, int arg2, gdb::array_view<const int> arg3)
+{
+ target_debug_printf_nofunc ("-> %s->set_syscall_catchpoint (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->set_syscall_catchpoint (arg0, arg1, arg2, arg3);
+ target_debug_printf_nofunc ("<- %s->set_syscall_catchpoint (%s, %s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_int (arg0).c_str (),
+ target_debug_print_bool (arg1).c_str (),
+ target_debug_print_int (arg2).c_str (),
+ target_debug_print_gdb_array_view_const_int (arg3).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+void
+target_ops::mourn_inferior ()
+{
+ this->beneath ()->mourn_inferior ();
+}
+
+void
+dummy_target::mourn_inferior ()
+{
+ default_mourn_inferior (this);
+}
+
+void
+debug_target::mourn_inferior ()
+{
+ target_debug_printf_nofunc ("-> %s->mourn_inferior (...)", this->beneath ()->shortname ());
+ this->beneath ()->mourn_inferior ();
+ target_debug_printf_nofunc ("<- %s->mourn_inferior ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::pass_signals (gdb::array_view<const unsigned char> arg0)
+{
+ this->beneath ()->pass_signals (arg0);
+}
+
+void
+dummy_target::pass_signals (gdb::array_view<const unsigned char> arg0)
+{
+}
+
+void
+debug_target::pass_signals (gdb::array_view<const unsigned char> arg0)
+{
+ target_debug_printf_nofunc ("-> %s->pass_signals (...)", this->beneath ()->shortname ());
+ this->beneath ()->pass_signals (arg0);
+ target_debug_printf_nofunc ("<- %s->pass_signals (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_signals (arg0).c_str ());
+}
+
+void
+target_ops::program_signals (gdb::array_view<const unsigned char> arg0)
+{
+ this->beneath ()->program_signals (arg0);
+}
+
+void
+dummy_target::program_signals (gdb::array_view<const unsigned char> arg0)
+{
+}
+
+void
+debug_target::program_signals (gdb::array_view<const unsigned char> arg0)
+{
+ target_debug_printf_nofunc ("-> %s->program_signals (...)", this->beneath ()->shortname ());
+ this->beneath ()->program_signals (arg0);
+ target_debug_printf_nofunc ("<- %s->program_signals (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_signals (arg0).c_str ());
+}
+
+bool
+target_ops::thread_alive (ptid_t arg0)
+{
+ return this->beneath ()->thread_alive (arg0);
+}
+
+bool
+dummy_target::thread_alive (ptid_t arg0)
+{
+ return false;
+}
+
+bool
+debug_target::thread_alive (ptid_t arg0)
+{
+ target_debug_printf_nofunc ("-> %s->thread_alive (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->thread_alive (arg0);
+ target_debug_printf_nofunc ("<- %s->thread_alive (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_ptid_t (arg0).c_str (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+void
+target_ops::update_thread_list ()
+{
+ this->beneath ()->update_thread_list ();
+}
+
+void
+dummy_target::update_thread_list ()
+{
+}
+
+void
+debug_target::update_thread_list ()
+{
+ target_debug_printf_nofunc ("-> %s->update_thread_list (...)", this->beneath ()->shortname ());
+ this->beneath ()->update_thread_list ();
+ target_debug_printf_nofunc ("<- %s->update_thread_list ()",
+ this->beneath ()->shortname ());
+}
+
+std::string
+target_ops::pid_to_str (ptid_t arg0)
+{
+ return this->beneath ()->pid_to_str (arg0);
+}
+
+std::string
+dummy_target::pid_to_str (ptid_t arg0)
+{
+ return default_pid_to_str (this, arg0);
+}
+
+std::string
+debug_target::pid_to_str (ptid_t arg0)
+{
+ target_debug_printf_nofunc ("-> %s->pid_to_str (...)", this->beneath ()->shortname ());
+ std::string result
+ = this->beneath ()->pid_to_str (arg0);
+ target_debug_printf_nofunc ("<- %s->pid_to_str (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_ptid_t (arg0).c_str (),
+ target_debug_print_std_string (result).c_str ());
+ return result;
+}
+
+const char *
+target_ops::extra_thread_info (thread_info *arg0)
+{
+ return this->beneath ()->extra_thread_info (arg0);
+}
+
+const char *
+dummy_target::extra_thread_info (thread_info *arg0)
+{
+ return NULL;
+}
+
+const char *
+debug_target::extra_thread_info (thread_info *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->extra_thread_info (...)", this->beneath ()->shortname ());
+ const char * result
+ = this->beneath ()->extra_thread_info (arg0);
+ target_debug_printf_nofunc ("<- %s->extra_thread_info (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_thread_info_p (arg0).c_str (),
+ target_debug_print_const_char_p (result).c_str ());
+ return result;
+}
+
+const char *
+target_ops::thread_name (thread_info *arg0)
+{
+ return this->beneath ()->thread_name (arg0);
+}
+
+const char *
+dummy_target::thread_name (thread_info *arg0)
+{
+ return NULL;
+}
+
+const char *
+debug_target::thread_name (thread_info *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->thread_name (...)", this->beneath ()->shortname ());
+ const char * result
+ = this->beneath ()->thread_name (arg0);
+ target_debug_printf_nofunc ("<- %s->thread_name (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_thread_info_p (arg0).c_str (),
+ target_debug_print_const_char_p (result).c_str ());
+ return result;
+}
+
+thread_info *
+target_ops::thread_handle_to_thread_info (const gdb_byte *arg0, int arg1, inferior *arg2)
+{
+ return this->beneath ()->thread_handle_to_thread_info (arg0, arg1, arg2);
+}
+
+thread_info *
+dummy_target::thread_handle_to_thread_info (const gdb_byte *arg0, int arg1, inferior *arg2)
+{
+ return NULL;
+}
+
+thread_info *
+debug_target::thread_handle_to_thread_info (const gdb_byte *arg0, int arg1, inferior *arg2)
+{
+ target_debug_printf_nofunc ("-> %s->thread_handle_to_thread_info (...)", this->beneath ()->shortname ());
+ thread_info * result
+ = this->beneath ()->thread_handle_to_thread_info (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->thread_handle_to_thread_info (%s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_const_gdb_byte_p (arg0).c_str (),
+ target_debug_print_int (arg1).c_str (),
+ target_debug_print_inferior_p (arg2).c_str (),
+ target_debug_print_thread_info_p (result).c_str ());
+ return result;
+}
+
+gdb::array_view<const_gdb_byte>
+target_ops::thread_info_to_thread_handle (struct thread_info *arg0)
+{
+ return this->beneath ()->thread_info_to_thread_handle (arg0);
+}
+
+gdb::array_view<const_gdb_byte>
+dummy_target::thread_info_to_thread_handle (struct thread_info *arg0)
+{
+ return gdb::array_view<const gdb_byte> ();
+}
+
+gdb::array_view<const_gdb_byte>
+debug_target::thread_info_to_thread_handle (struct thread_info *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->thread_info_to_thread_handle (...)", this->beneath ()->shortname ());
+ gdb::array_view<const_gdb_byte> result
+ = this->beneath ()->thread_info_to_thread_handle (arg0);
+ target_debug_printf_nofunc ("<- %s->thread_info_to_thread_handle (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_thread_info_p (arg0).c_str (),
+ target_debug_print_gdb_array_view_const_gdb_byte (result).c_str ());
+ return result;
+}
+
+void
+target_ops::stop (ptid_t arg0)
+{
+ this->beneath ()->stop (arg0);
+}
+
+void
+dummy_target::stop (ptid_t arg0)
+{
+}
+
+void
+debug_target::stop (ptid_t arg0)
+{
+ target_debug_printf_nofunc ("-> %s->stop (...)", this->beneath ()->shortname ());
+ this->beneath ()->stop (arg0);
+ target_debug_printf_nofunc ("<- %s->stop (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_ptid_t (arg0).c_str ());
+}
+
+void
+target_ops::interrupt ()
+{
+ this->beneath ()->interrupt ();
+}
+
+void
+dummy_target::interrupt ()
+{
+}
+
+void
+debug_target::interrupt ()
+{
+ target_debug_printf_nofunc ("-> %s->interrupt (...)", this->beneath ()->shortname ());
+ this->beneath ()->interrupt ();
+ target_debug_printf_nofunc ("<- %s->interrupt ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::pass_ctrlc ()
+{
+ this->beneath ()->pass_ctrlc ();
+}
+
+void
+dummy_target::pass_ctrlc ()
+{
+ default_target_pass_ctrlc (this);
+}
+
+void
+debug_target::pass_ctrlc ()
+{
+ target_debug_printf_nofunc ("-> %s->pass_ctrlc (...)", this->beneath ()->shortname ());
+ this->beneath ()->pass_ctrlc ();
+ target_debug_printf_nofunc ("<- %s->pass_ctrlc ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::rcmd (const char *arg0, struct ui_file *arg1)
+{
+ this->beneath ()->rcmd (arg0, arg1);
+}
+
+void
+dummy_target::rcmd (const char *arg0, struct ui_file *arg1)
+{
+ default_rcmd (this, arg0, arg1);
+}
+
+void
+debug_target::rcmd (const char *arg0, struct ui_file *arg1)
+{
+ target_debug_printf_nofunc ("-> %s->rcmd (...)", this->beneath ()->shortname ());
+ this->beneath ()->rcmd (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->rcmd (%s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_const_char_p (arg0).c_str (),
+ target_debug_print_ui_file_p (arg1).c_str ());
+}
+
+const char *
+target_ops::pid_to_exec_file (int arg0)
+{
+ return this->beneath ()->pid_to_exec_file (arg0);
+}
+
+const char *
+dummy_target::pid_to_exec_file (int arg0)
+{
+ return NULL;
+}
+
+const char *
+debug_target::pid_to_exec_file (int arg0)
+{
+ target_debug_printf_nofunc ("-> %s->pid_to_exec_file (...)", this->beneath ()->shortname ());
+ const char * result
+ = this->beneath ()->pid_to_exec_file (arg0);
+ target_debug_printf_nofunc ("<- %s->pid_to_exec_file (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_int (arg0).c_str (),
+ target_debug_print_const_char_p (result).c_str ());
+ return result;
+}
+
+void
+target_ops::log_command (const char *arg0)
+{
+ this->beneath ()->log_command (arg0);
+}
+
+void
+dummy_target::log_command (const char *arg0)
+{
+}
+
+void
+debug_target::log_command (const char *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->log_command (...)", this->beneath ()->shortname ());
+ this->beneath ()->log_command (arg0);
+ target_debug_printf_nofunc ("<- %s->log_command (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_const_char_p (arg0).c_str ());
+}
+
+const std::vector<target_section> *
+target_ops::get_section_table ()
+{
+ return this->beneath ()->get_section_table ();
+}
+
+const std::vector<target_section> *
+dummy_target::get_section_table ()
+{
+ return default_get_section_table ();
+}
+
+const std::vector<target_section> *
+debug_target::get_section_table ()
+{
+ target_debug_printf_nofunc ("-> %s->get_section_table (...)", this->beneath ()->shortname ());
+ const std::vector<target_section> * result
+ = this->beneath ()->get_section_table ();
+ target_debug_printf_nofunc ("<- %s->get_section_table () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_const_std_vector_target_section_p (result).c_str ());
+ return result;
+}
+
+thread_control_capabilities
+target_ops::get_thread_control_capabilities ()
+{
+ return this->beneath ()->get_thread_control_capabilities ();
+}
+
+thread_control_capabilities
+dummy_target::get_thread_control_capabilities ()
+{
+ return tc_none;
+}
+
+thread_control_capabilities
+debug_target::get_thread_control_capabilities ()
+{
+ target_debug_printf_nofunc ("-> %s->get_thread_control_capabilities (...)", this->beneath ()->shortname ());
+ thread_control_capabilities result
+ = this->beneath ()->get_thread_control_capabilities ();
+ target_debug_printf_nofunc ("<- %s->get_thread_control_capabilities () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_thread_control_capabilities (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::attach_no_wait ()
+{
+ return this->beneath ()->attach_no_wait ();
+}
+
+bool
+dummy_target::attach_no_wait ()
+{
+ return 0;
+}
+
+bool
+debug_target::attach_no_wait ()
+{
+ target_debug_printf_nofunc ("-> %s->attach_no_wait (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->attach_no_wait ();
+ target_debug_printf_nofunc ("<- %s->attach_no_wait () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::can_async_p ()
+{
+ return this->beneath ()->can_async_p ();
+}
+
+bool
+dummy_target::can_async_p ()
+{
+ return false;
+}
+
+bool
+debug_target::can_async_p ()
+{
+ target_debug_printf_nofunc ("-> %s->can_async_p (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->can_async_p ();
+ target_debug_printf_nofunc ("<- %s->can_async_p () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::is_async_p ()
+{
+ return this->beneath ()->is_async_p ();
+}
+
+bool
+dummy_target::is_async_p ()
+{
+ return false;
+}
+
+bool
+debug_target::is_async_p ()
+{
+ target_debug_printf_nofunc ("-> %s->is_async_p (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->is_async_p ();
+ target_debug_printf_nofunc ("<- %s->is_async_p () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+void
+target_ops::async (bool arg0)
+{
+ this->beneath ()->async (arg0);
+}
+
+void
+dummy_target::async (bool arg0)
+{
+ tcomplain ();
+}
+
+void
+debug_target::async (bool arg0)
+{
+ target_debug_printf_nofunc ("-> %s->async (...)", this->beneath ()->shortname ());
+ this->beneath ()->async (arg0);
+ target_debug_printf_nofunc ("<- %s->async (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (arg0).c_str ());
+}
+
+int
+target_ops::async_wait_fd ()
+{
+ return this->beneath ()->async_wait_fd ();
+}
+
+int
+dummy_target::async_wait_fd ()
+{
+ noprocess ();
+}
+
+int
+debug_target::async_wait_fd ()
+{
+ target_debug_printf_nofunc ("-> %s->async_wait_fd (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->async_wait_fd ();
+ target_debug_printf_nofunc ("<- %s->async_wait_fd () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::has_pending_events ()
+{
+ return this->beneath ()->has_pending_events ();
+}
+
+bool
+dummy_target::has_pending_events ()
+{
+ return false;
+}
+
+bool
+debug_target::has_pending_events ()
+{
+ target_debug_printf_nofunc ("-> %s->has_pending_events (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->has_pending_events ();
+ target_debug_printf_nofunc ("<- %s->has_pending_events () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+void
+target_ops::thread_events (bool arg0)
+{
+ this->beneath ()->thread_events (arg0);
+}
+
+void
+dummy_target::thread_events (bool arg0)
+{
+}
+
+void
+debug_target::thread_events (bool arg0)
+{
+ target_debug_printf_nofunc ("-> %s->thread_events (...)", this->beneath ()->shortname ());
+ this->beneath ()->thread_events (arg0);
+ target_debug_printf_nofunc ("<- %s->thread_events (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (arg0).c_str ());
+}
+
+bool
+target_ops::supports_set_thread_options (gdb_thread_options arg0)
+{
+ return this->beneath ()->supports_set_thread_options (arg0);
+}
+
+bool
+dummy_target::supports_set_thread_options (gdb_thread_options arg0)
+{
+ return false;
+}
+
+bool
+debug_target::supports_set_thread_options (gdb_thread_options arg0)
+{
+ target_debug_printf_nofunc ("-> %s->supports_set_thread_options (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->supports_set_thread_options (arg0);
+ target_debug_printf_nofunc ("<- %s->supports_set_thread_options (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_gdb_thread_options (arg0).c_str (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::supports_non_stop ()
+{
+ return this->beneath ()->supports_non_stop ();
+}
+
+bool
+dummy_target::supports_non_stop ()
+{
+ return false;
+}
+
+bool
+debug_target::supports_non_stop ()
+{
+ target_debug_printf_nofunc ("-> %s->supports_non_stop (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->supports_non_stop ();
+ target_debug_printf_nofunc ("<- %s->supports_non_stop () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::always_non_stop_p ()
+{
+ return this->beneath ()->always_non_stop_p ();
+}
+
+bool
+dummy_target::always_non_stop_p ()
+{
+ return false;
+}
+
+bool
+debug_target::always_non_stop_p ()
+{
+ target_debug_printf_nofunc ("-> %s->always_non_stop_p (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->always_non_stop_p ();
+ target_debug_printf_nofunc ("<- %s->always_non_stop_p () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+int
+target_ops::find_memory_regions (find_memory_region_ftype arg0, void *arg1)
+{
+ return this->beneath ()->find_memory_regions (arg0, arg1);
+}
+
+int
+dummy_target::find_memory_regions (find_memory_region_ftype arg0, void *arg1)
+{
+ return dummy_find_memory_regions (this, arg0, arg1);
+}
+
+int
+debug_target::find_memory_regions (find_memory_region_ftype arg0, void *arg1)
+{
+ target_debug_printf_nofunc ("-> %s->find_memory_regions (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->find_memory_regions (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->find_memory_regions (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_find_memory_region_ftype (arg0).c_str (),
+ target_debug_print_void_p (arg1).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+gdb::unique_xmalloc_ptr<char>
+target_ops::make_corefile_notes (bfd *arg0, int *arg1)
+{
+ return this->beneath ()->make_corefile_notes (arg0, arg1);
+}
+
+gdb::unique_xmalloc_ptr<char>
+dummy_target::make_corefile_notes (bfd *arg0, int *arg1)
+{
+ return dummy_make_corefile_notes (this, arg0, arg1);
+}
+
+gdb::unique_xmalloc_ptr<char>
+debug_target::make_corefile_notes (bfd *arg0, int *arg1)
+{
+ target_debug_printf_nofunc ("-> %s->make_corefile_notes (...)", this->beneath ()->shortname ());
+ gdb::unique_xmalloc_ptr<char> result
+ = this->beneath ()->make_corefile_notes (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->make_corefile_notes (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bfd_p (arg0).c_str (),
+ target_debug_print_int_p (arg1).c_str (),
+ target_debug_print_gdb_unique_xmalloc_ptr_char (result).c_str ());
+ return result;
+}
+
+gdb_byte *
+target_ops::get_bookmark (const char *arg0, int arg1)
+{
+ return this->beneath ()->get_bookmark (arg0, arg1);
+}
+
+gdb_byte *
+dummy_target::get_bookmark (const char *arg0, int arg1)
+{
+ tcomplain ();
+}
+
+gdb_byte *
+debug_target::get_bookmark (const char *arg0, int arg1)
+{
+ target_debug_printf_nofunc ("-> %s->get_bookmark (...)", this->beneath ()->shortname ());
+ gdb_byte * result
+ = this->beneath ()->get_bookmark (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->get_bookmark (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_const_char_p (arg0).c_str (),
+ target_debug_print_int (arg1).c_str (),
+ target_debug_print_gdb_byte_p (result).c_str ());
+ return result;
+}
+
+void
+target_ops::goto_bookmark (const gdb_byte *arg0, int arg1)
+{
+ this->beneath ()->goto_bookmark (arg0, arg1);
+}
+
+void
+dummy_target::goto_bookmark (const gdb_byte *arg0, int arg1)
+{
+ tcomplain ();
+}
+
+void
+debug_target::goto_bookmark (const gdb_byte *arg0, int arg1)
+{
+ target_debug_printf_nofunc ("-> %s->goto_bookmark (...)", this->beneath ()->shortname ());
+ this->beneath ()->goto_bookmark (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->goto_bookmark (%s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_const_gdb_byte_p (arg0).c_str (),
+ target_debug_print_int (arg1).c_str ());
+}
+
+CORE_ADDR
+target_ops::get_thread_local_address (ptid_t arg0, CORE_ADDR arg1, CORE_ADDR arg2)
+{
+ return this->beneath ()->get_thread_local_address (arg0, arg1, arg2);
+}
+
+CORE_ADDR
+dummy_target::get_thread_local_address (ptid_t arg0, CORE_ADDR arg1, CORE_ADDR arg2)
+{
+ generic_tls_error ();
+}
+
+CORE_ADDR
+debug_target::get_thread_local_address (ptid_t arg0, CORE_ADDR arg1, CORE_ADDR arg2)
+{
+ target_debug_printf_nofunc ("-> %s->get_thread_local_address (...)", this->beneath ()->shortname ());
+ CORE_ADDR result
+ = this->beneath ()->get_thread_local_address (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->get_thread_local_address (%s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_ptid_t (arg0).c_str (),
+ target_debug_print_CORE_ADDR (arg1).c_str (),
+ target_debug_print_CORE_ADDR (arg2).c_str (),
+ target_debug_print_CORE_ADDR (result).c_str ());
+ return result;
+}
+
+enum target_xfer_status
+target_ops::xfer_partial (enum target_object arg0, const char *arg1, gdb_byte *arg2, const gdb_byte *arg3, ULONGEST arg4, ULONGEST arg5, ULONGEST *arg6)
+{
+ return this->beneath ()->xfer_partial (arg0, arg1, arg2, arg3, arg4, arg5, arg6);
+}
+
+enum target_xfer_status
+dummy_target::xfer_partial (enum target_object arg0, const char *arg1, gdb_byte *arg2, const gdb_byte *arg3, ULONGEST arg4, ULONGEST arg5, ULONGEST *arg6)
+{
+ return TARGET_XFER_E_IO;
+}
+
+enum target_xfer_status
+debug_target::xfer_partial (enum target_object arg0, const char *arg1, gdb_byte *arg2, const gdb_byte *arg3, ULONGEST arg4, ULONGEST arg5, ULONGEST *arg6)
+{
+ target_debug_printf_nofunc ("-> %s->xfer_partial (...)", this->beneath ()->shortname ());
+ enum target_xfer_status result
+ = this->beneath ()->xfer_partial (arg0, arg1, arg2, arg3, arg4, arg5, arg6);
+ target_debug_printf_nofunc ("<- %s->xfer_partial (%s, %s, %s, %s, %s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_target_object (arg0).c_str (),
+ target_debug_print_const_char_p (arg1).c_str (),
+ target_debug_print_gdb_byte_p (arg2).c_str (),
+ target_debug_print_const_gdb_byte_p (arg3).c_str (),
+ target_debug_print_ULONGEST (arg4).c_str (),
+ target_debug_print_ULONGEST (arg5).c_str (),
+ target_debug_print_ULONGEST_p (arg6).c_str (),
+ target_debug_print_target_xfer_status (result).c_str ());
+ return result;
+}
+
+ULONGEST
+target_ops::get_memory_xfer_limit ()
+{
+ return this->beneath ()->get_memory_xfer_limit ();
+}
+
+ULONGEST
+dummy_target::get_memory_xfer_limit ()
+{
+ return ULONGEST_MAX;
+}
+
+ULONGEST
+debug_target::get_memory_xfer_limit ()
+{
+ target_debug_printf_nofunc ("-> %s->get_memory_xfer_limit (...)", this->beneath ()->shortname ());
+ ULONGEST result
+ = this->beneath ()->get_memory_xfer_limit ();
+ target_debug_printf_nofunc ("<- %s->get_memory_xfer_limit () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_ULONGEST (result).c_str ());
+ return result;
+}
+
+std::vector<mem_region>
+target_ops::memory_map ()
+{
+ return this->beneath ()->memory_map ();
+}
+
+std::vector<mem_region>
+dummy_target::memory_map ()
+{
+ return std::vector<mem_region> ();
+}
+
+std::vector<mem_region>
+debug_target::memory_map ()
+{
+ target_debug_printf_nofunc ("-> %s->memory_map (...)", this->beneath ()->shortname ());
+ std::vector<mem_region> result
+ = this->beneath ()->memory_map ();
+ target_debug_printf_nofunc ("<- %s->memory_map () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_std_vector_mem_region (result).c_str ());
+ return result;
+}
+
+void
+target_ops::flash_erase (ULONGEST arg0, LONGEST arg1)
+{
+ this->beneath ()->flash_erase (arg0, arg1);
+}
+
+void
+dummy_target::flash_erase (ULONGEST arg0, LONGEST arg1)
+{
+ tcomplain ();
+}
+
+void
+debug_target::flash_erase (ULONGEST arg0, LONGEST arg1)
+{
+ target_debug_printf_nofunc ("-> %s->flash_erase (...)", this->beneath ()->shortname ());
+ this->beneath ()->flash_erase (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->flash_erase (%s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_ULONGEST (arg0).c_str (),
+ target_debug_print_LONGEST (arg1).c_str ());
+}
+
+void
+target_ops::flash_done ()
+{
+ this->beneath ()->flash_done ();
+}
+
+void
+dummy_target::flash_done ()
+{
+ tcomplain ();
+}
+
+void
+debug_target::flash_done ()
+{
+ target_debug_printf_nofunc ("-> %s->flash_done (...)", this->beneath ()->shortname ());
+ this->beneath ()->flash_done ();
+ target_debug_printf_nofunc ("<- %s->flash_done ()",
+ this->beneath ()->shortname ());
+}
+
+const struct target_desc *
+target_ops::read_description ()
+{
+ return this->beneath ()->read_description ();
+}
+
+const struct target_desc *
+dummy_target::read_description ()
+{
+ return NULL;
+}
+
+const struct target_desc *
+debug_target::read_description ()
+{
+ target_debug_printf_nofunc ("-> %s->read_description (...)", this->beneath ()->shortname ());
+ const struct target_desc * result
+ = this->beneath ()->read_description ();
+ target_debug_printf_nofunc ("<- %s->read_description () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_const_target_desc_p (result).c_str ());
+ return result;
+}
+
+ptid_t
+target_ops::get_ada_task_ptid (long arg0, ULONGEST arg1)
+{
+ return this->beneath ()->get_ada_task_ptid (arg0, arg1);
+}
+
+ptid_t
+dummy_target::get_ada_task_ptid (long arg0, ULONGEST arg1)
+{
+ return default_get_ada_task_ptid (this, arg0, arg1);
+}
+
+ptid_t
+debug_target::get_ada_task_ptid (long arg0, ULONGEST arg1)
+{
+ target_debug_printf_nofunc ("-> %s->get_ada_task_ptid (...)", this->beneath ()->shortname ());
+ ptid_t result
+ = this->beneath ()->get_ada_task_ptid (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->get_ada_task_ptid (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_long (arg0).c_str (),
+ target_debug_print_ULONGEST (arg1).c_str (),
+ target_debug_print_ptid_t (result).c_str ());
+ return result;
+}
+
+int
+target_ops::auxv_parse (const gdb_byte **arg0, const gdb_byte *arg1, CORE_ADDR *arg2, CORE_ADDR *arg3)
+{
+ return this->beneath ()->auxv_parse (arg0, arg1, arg2, arg3);
+}
+
+int
+dummy_target::auxv_parse (const gdb_byte **arg0, const gdb_byte *arg1, CORE_ADDR *arg2, CORE_ADDR *arg3)
+{
+ return default_auxv_parse (this, arg0, arg1, arg2, arg3);
+}
+
+int
+debug_target::auxv_parse (const gdb_byte **arg0, const gdb_byte *arg1, CORE_ADDR *arg2, CORE_ADDR *arg3)
+{
+ target_debug_printf_nofunc ("-> %s->auxv_parse (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->auxv_parse (arg0, arg1, arg2, arg3);
+ target_debug_printf_nofunc ("<- %s->auxv_parse (%s, %s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_const_gdb_byte_pp (arg0).c_str (),
+ target_debug_print_const_gdb_byte_p (arg1).c_str (),
+ target_debug_print_CORE_ADDR_p (arg2).c_str (),
+ target_debug_print_CORE_ADDR_p (arg3).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::search_memory (CORE_ADDR arg0, ULONGEST arg1, const gdb_byte *arg2, ULONGEST arg3, CORE_ADDR *arg4)
+{
+ return this->beneath ()->search_memory (arg0, arg1, arg2, arg3, arg4);
+}
+
+int
+dummy_target::search_memory (CORE_ADDR arg0, ULONGEST arg1, const gdb_byte *arg2, ULONGEST arg3, CORE_ADDR *arg4)
+{
+ return default_search_memory (this, arg0, arg1, arg2, arg3, arg4);
+}
+
+int
+debug_target::search_memory (CORE_ADDR arg0, ULONGEST arg1, const gdb_byte *arg2, ULONGEST arg3, CORE_ADDR *arg4)
+{
+ target_debug_printf_nofunc ("-> %s->search_memory (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->search_memory (arg0, arg1, arg2, arg3, arg4);
+ target_debug_printf_nofunc ("<- %s->search_memory (%s, %s, %s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_CORE_ADDR (arg0).c_str (),
+ target_debug_print_ULONGEST (arg1).c_str (),
+ target_debug_print_const_gdb_byte_p (arg2).c_str (),
+ target_debug_print_ULONGEST (arg3).c_str (),
+ target_debug_print_CORE_ADDR_p (arg4).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::can_execute_reverse ()
+{
+ return this->beneath ()->can_execute_reverse ();
+}
+
+bool
+dummy_target::can_execute_reverse ()
+{
+ return false;
+}
+
+bool
+debug_target::can_execute_reverse ()
+{
+ target_debug_printf_nofunc ("-> %s->can_execute_reverse (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->can_execute_reverse ();
+ target_debug_printf_nofunc ("<- %s->can_execute_reverse () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+enum exec_direction_kind
+target_ops::execution_direction ()
+{
+ return this->beneath ()->execution_direction ();
+}
+
+enum exec_direction_kind
+dummy_target::execution_direction ()
+{
+ return default_execution_direction (this);
+}
+
+enum exec_direction_kind
+debug_target::execution_direction ()
+{
+ target_debug_printf_nofunc ("-> %s->execution_direction (...)", this->beneath ()->shortname ());
+ enum exec_direction_kind result
+ = this->beneath ()->execution_direction ();
+ target_debug_printf_nofunc ("<- %s->execution_direction () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_exec_direction_kind (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::supports_multi_process ()
+{
+ return this->beneath ()->supports_multi_process ();
+}
+
+bool
+dummy_target::supports_multi_process ()
+{
+ return false;
+}
+
+bool
+debug_target::supports_multi_process ()
+{
+ target_debug_printf_nofunc ("-> %s->supports_multi_process (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->supports_multi_process ();
+ target_debug_printf_nofunc ("<- %s->supports_multi_process () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::supports_enable_disable_tracepoint ()
+{
+ return this->beneath ()->supports_enable_disable_tracepoint ();
+}
+
+bool
+dummy_target::supports_enable_disable_tracepoint ()
+{
+ return false;
+}
+
+bool
+debug_target::supports_enable_disable_tracepoint ()
+{
+ target_debug_printf_nofunc ("-> %s->supports_enable_disable_tracepoint (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->supports_enable_disable_tracepoint ();
+ target_debug_printf_nofunc ("<- %s->supports_enable_disable_tracepoint () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::supports_disable_randomization ()
+{
+ return this->beneath ()->supports_disable_randomization ();
+}
+
+bool
+dummy_target::supports_disable_randomization ()
+{
+ return find_default_supports_disable_randomization (this);
+}
+
+bool
+debug_target::supports_disable_randomization ()
+{
+ target_debug_printf_nofunc ("-> %s->supports_disable_randomization (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->supports_disable_randomization ();
+ target_debug_printf_nofunc ("<- %s->supports_disable_randomization () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::supports_string_tracing ()
+{
+ return this->beneath ()->supports_string_tracing ();
+}
+
+bool
+dummy_target::supports_string_tracing ()
+{
+ return false;
+}
+
+bool
+debug_target::supports_string_tracing ()
+{
+ target_debug_printf_nofunc ("-> %s->supports_string_tracing (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->supports_string_tracing ();
+ target_debug_printf_nofunc ("<- %s->supports_string_tracing () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::supports_evaluation_of_breakpoint_conditions ()
+{
+ return this->beneath ()->supports_evaluation_of_breakpoint_conditions ();
+}
+
+bool
+dummy_target::supports_evaluation_of_breakpoint_conditions ()
+{
+ return false;
+}
+
+bool
+debug_target::supports_evaluation_of_breakpoint_conditions ()
+{
+ target_debug_printf_nofunc ("-> %s->supports_evaluation_of_breakpoint_conditions (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->supports_evaluation_of_breakpoint_conditions ();
+ target_debug_printf_nofunc ("<- %s->supports_evaluation_of_breakpoint_conditions () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::supports_dumpcore ()
+{
+ return this->beneath ()->supports_dumpcore ();
+}
+
+bool
+dummy_target::supports_dumpcore ()
+{
+ return false;
+}
+
+bool
+debug_target::supports_dumpcore ()
+{
+ target_debug_printf_nofunc ("-> %s->supports_dumpcore (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->supports_dumpcore ();
+ target_debug_printf_nofunc ("<- %s->supports_dumpcore () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+void
+target_ops::dumpcore (const char *arg0)
+{
+ this->beneath ()->dumpcore (arg0);
+}
+
+void
+dummy_target::dumpcore (const char *arg0)
+{
+}
+
+void
+debug_target::dumpcore (const char *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->dumpcore (...)", this->beneath ()->shortname ());
+ this->beneath ()->dumpcore (arg0);
+ target_debug_printf_nofunc ("<- %s->dumpcore (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_const_char_p (arg0).c_str ());
+}
+
+bool
+target_ops::can_run_breakpoint_commands ()
+{
+ return this->beneath ()->can_run_breakpoint_commands ();
+}
+
+bool
+dummy_target::can_run_breakpoint_commands ()
+{
+ return false;
+}
+
+bool
+debug_target::can_run_breakpoint_commands ()
+{
+ target_debug_printf_nofunc ("-> %s->can_run_breakpoint_commands (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->can_run_breakpoint_commands ();
+ target_debug_printf_nofunc ("<- %s->can_run_breakpoint_commands () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+struct gdbarch *
+target_ops::thread_architecture (ptid_t arg0)
+{
+ return this->beneath ()->thread_architecture (arg0);
+}
+
+struct gdbarch *
+dummy_target::thread_architecture (ptid_t arg0)
+{
+ return NULL;
+}
+
+struct gdbarch *
+debug_target::thread_architecture (ptid_t arg0)
+{
+ target_debug_printf_nofunc ("-> %s->thread_architecture (...)", this->beneath ()->shortname ());
+ struct gdbarch * result
+ = this->beneath ()->thread_architecture (arg0);
+ target_debug_printf_nofunc ("<- %s->thread_architecture (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_ptid_t (arg0).c_str (),
+ target_debug_print_gdbarch_p (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::filesystem_is_local ()
+{
+ return this->beneath ()->filesystem_is_local ();
+}
+
+bool
+dummy_target::filesystem_is_local ()
+{
+ return true;
+}
+
+bool
+debug_target::filesystem_is_local ()
+{
+ target_debug_printf_nofunc ("-> %s->filesystem_is_local (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->filesystem_is_local ();
+ target_debug_printf_nofunc ("<- %s->filesystem_is_local () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+void
+target_ops::trace_init ()
+{
+ this->beneath ()->trace_init ();
+}
+
+void
+dummy_target::trace_init ()
+{
+ tcomplain ();
+}
+
+void
+debug_target::trace_init ()
+{
+ target_debug_printf_nofunc ("-> %s->trace_init (...)", this->beneath ()->shortname ());
+ this->beneath ()->trace_init ();
+ target_debug_printf_nofunc ("<- %s->trace_init ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::download_tracepoint (struct bp_location *arg0)
+{
+ this->beneath ()->download_tracepoint (arg0);
+}
+
+void
+dummy_target::download_tracepoint (struct bp_location *arg0)
+{
+ tcomplain ();
+}
+
+void
+debug_target::download_tracepoint (struct bp_location *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->download_tracepoint (...)", this->beneath ()->shortname ());
+ this->beneath ()->download_tracepoint (arg0);
+ target_debug_printf_nofunc ("<- %s->download_tracepoint (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_bp_location_p (arg0).c_str ());
+}
+
+bool
+target_ops::can_download_tracepoint ()
+{
+ return this->beneath ()->can_download_tracepoint ();
+}
+
+bool
+dummy_target::can_download_tracepoint ()
+{
+ return false;
+}
+
+bool
+debug_target::can_download_tracepoint ()
+{
+ target_debug_printf_nofunc ("-> %s->can_download_tracepoint (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->can_download_tracepoint ();
+ target_debug_printf_nofunc ("<- %s->can_download_tracepoint () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+void
+target_ops::download_trace_state_variable (const trace_state_variable &arg0)
+{
+ this->beneath ()->download_trace_state_variable (arg0);
+}
+
+void
+dummy_target::download_trace_state_variable (const trace_state_variable &arg0)
+{
+ tcomplain ();
+}
+
+void
+debug_target::download_trace_state_variable (const trace_state_variable &arg0)
+{
+ target_debug_printf_nofunc ("-> %s->download_trace_state_variable (...)", this->beneath ()->shortname ());
+ this->beneath ()->download_trace_state_variable (arg0);
+ target_debug_printf_nofunc ("<- %s->download_trace_state_variable (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_const_trace_state_variable_r (arg0).c_str ());
+}
+
+void
+target_ops::enable_tracepoint (struct bp_location *arg0)
+{
+ this->beneath ()->enable_tracepoint (arg0);
+}
+
+void
+dummy_target::enable_tracepoint (struct bp_location *arg0)
+{
+ tcomplain ();
+}
+
+void
+debug_target::enable_tracepoint (struct bp_location *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->enable_tracepoint (...)", this->beneath ()->shortname ());
+ this->beneath ()->enable_tracepoint (arg0);
+ target_debug_printf_nofunc ("<- %s->enable_tracepoint (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_bp_location_p (arg0).c_str ());
+}
+
+void
+target_ops::disable_tracepoint (struct bp_location *arg0)
+{
+ this->beneath ()->disable_tracepoint (arg0);
+}
+
+void
+dummy_target::disable_tracepoint (struct bp_location *arg0)
+{
+ tcomplain ();
+}
+
+void
+debug_target::disable_tracepoint (struct bp_location *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->disable_tracepoint (...)", this->beneath ()->shortname ());
+ this->beneath ()->disable_tracepoint (arg0);
+ target_debug_printf_nofunc ("<- %s->disable_tracepoint (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_bp_location_p (arg0).c_str ());
+}
+
+void
+target_ops::trace_set_readonly_regions ()
+{
+ this->beneath ()->trace_set_readonly_regions ();
+}
+
+void
+dummy_target::trace_set_readonly_regions ()
+{
+ tcomplain ();
+}
+
+void
+debug_target::trace_set_readonly_regions ()
+{
+ target_debug_printf_nofunc ("-> %s->trace_set_readonly_regions (...)", this->beneath ()->shortname ());
+ this->beneath ()->trace_set_readonly_regions ();
+ target_debug_printf_nofunc ("<- %s->trace_set_readonly_regions ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::trace_start ()
+{
+ this->beneath ()->trace_start ();
+}
+
+void
+dummy_target::trace_start ()
+{
+ tcomplain ();
+}
+
+void
+debug_target::trace_start ()
+{
+ target_debug_printf_nofunc ("-> %s->trace_start (...)", this->beneath ()->shortname ());
+ this->beneath ()->trace_start ();
+ target_debug_printf_nofunc ("<- %s->trace_start ()",
+ this->beneath ()->shortname ());
+}
+
+int
+target_ops::get_trace_status (struct trace_status *arg0)
+{
+ return this->beneath ()->get_trace_status (arg0);
+}
+
+int
+dummy_target::get_trace_status (struct trace_status *arg0)
+{
+ return -1;
+}
+
+int
+debug_target::get_trace_status (struct trace_status *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->get_trace_status (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->get_trace_status (arg0);
+ target_debug_printf_nofunc ("<- %s->get_trace_status (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_trace_status_p (arg0).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+void
+target_ops::get_tracepoint_status (tracepoint *arg0, struct uploaded_tp *arg1)
+{
+ this->beneath ()->get_tracepoint_status (arg0, arg1);
+}
+
+void
+dummy_target::get_tracepoint_status (tracepoint *arg0, struct uploaded_tp *arg1)
+{
+ tcomplain ();
+}
+
+void
+debug_target::get_tracepoint_status (tracepoint *arg0, struct uploaded_tp *arg1)
+{
+ target_debug_printf_nofunc ("-> %s->get_tracepoint_status (...)", this->beneath ()->shortname ());
+ this->beneath ()->get_tracepoint_status (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->get_tracepoint_status (%s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_tracepoint_p (arg0).c_str (),
+ target_debug_print_uploaded_tp_p (arg1).c_str ());
+}
+
+void
+target_ops::trace_stop ()
+{
+ this->beneath ()->trace_stop ();
+}
+
+void
+dummy_target::trace_stop ()
+{
+ tcomplain ();
+}
+
+void
+debug_target::trace_stop ()
+{
+ target_debug_printf_nofunc ("-> %s->trace_stop (...)", this->beneath ()->shortname ());
+ this->beneath ()->trace_stop ();
+ target_debug_printf_nofunc ("<- %s->trace_stop ()",
+ this->beneath ()->shortname ());
+}
+
+int
+target_ops::trace_find (enum trace_find_type arg0, int arg1, CORE_ADDR arg2, CORE_ADDR arg3, int *arg4)
+{
+ return this->beneath ()->trace_find (arg0, arg1, arg2, arg3, arg4);
+}
+
+int
+dummy_target::trace_find (enum trace_find_type arg0, int arg1, CORE_ADDR arg2, CORE_ADDR arg3, int *arg4)
+{
+ return -1;
+}
+
+int
+debug_target::trace_find (enum trace_find_type arg0, int arg1, CORE_ADDR arg2, CORE_ADDR arg3, int *arg4)
+{
+ target_debug_printf_nofunc ("-> %s->trace_find (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->trace_find (arg0, arg1, arg2, arg3, arg4);
+ target_debug_printf_nofunc ("<- %s->trace_find (%s, %s, %s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_trace_find_type (arg0).c_str (),
+ target_debug_print_int (arg1).c_str (),
+ target_debug_print_CORE_ADDR (arg2).c_str (),
+ target_debug_print_CORE_ADDR (arg3).c_str (),
+ target_debug_print_int_p (arg4).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::get_trace_state_variable_value (int arg0, LONGEST *arg1)
+{
+ return this->beneath ()->get_trace_state_variable_value (arg0, arg1);
+}
+
+bool
+dummy_target::get_trace_state_variable_value (int arg0, LONGEST *arg1)
+{
+ return false;
+}
+
+bool
+debug_target::get_trace_state_variable_value (int arg0, LONGEST *arg1)
+{
+ target_debug_printf_nofunc ("-> %s->get_trace_state_variable_value (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->get_trace_state_variable_value (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->get_trace_state_variable_value (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_int (arg0).c_str (),
+ target_debug_print_LONGEST_p (arg1).c_str (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+int
+target_ops::save_trace_data (const char *arg0)
+{
+ return this->beneath ()->save_trace_data (arg0);
+}
+
+int
+dummy_target::save_trace_data (const char *arg0)
+{
+ tcomplain ();
+}
+
+int
+debug_target::save_trace_data (const char *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->save_trace_data (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->save_trace_data (arg0);
+ target_debug_printf_nofunc ("<- %s->save_trace_data (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_const_char_p (arg0).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::upload_tracepoints (struct uploaded_tp **arg0)
+{
+ return this->beneath ()->upload_tracepoints (arg0);
+}
+
+int
+dummy_target::upload_tracepoints (struct uploaded_tp **arg0)
+{
+ return 0;
+}
+
+int
+debug_target::upload_tracepoints (struct uploaded_tp **arg0)
+{
+ target_debug_printf_nofunc ("-> %s->upload_tracepoints (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->upload_tracepoints (arg0);
+ target_debug_printf_nofunc ("<- %s->upload_tracepoints (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_uploaded_tp_pp (arg0).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::upload_trace_state_variables (struct uploaded_tsv **arg0)
+{
+ return this->beneath ()->upload_trace_state_variables (arg0);
+}
+
+int
+dummy_target::upload_trace_state_variables (struct uploaded_tsv **arg0)
+{
+ return 0;
+}
+
+int
+debug_target::upload_trace_state_variables (struct uploaded_tsv **arg0)
+{
+ target_debug_printf_nofunc ("-> %s->upload_trace_state_variables (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->upload_trace_state_variables (arg0);
+ target_debug_printf_nofunc ("<- %s->upload_trace_state_variables (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_uploaded_tsv_pp (arg0).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+LONGEST
+target_ops::get_raw_trace_data (gdb_byte *arg0, ULONGEST arg1, LONGEST arg2)
+{
+ return this->beneath ()->get_raw_trace_data (arg0, arg1, arg2);
+}
+
+LONGEST
+dummy_target::get_raw_trace_data (gdb_byte *arg0, ULONGEST arg1, LONGEST arg2)
+{
+ tcomplain ();
+}
+
+LONGEST
+debug_target::get_raw_trace_data (gdb_byte *arg0, ULONGEST arg1, LONGEST arg2)
+{
+ target_debug_printf_nofunc ("-> %s->get_raw_trace_data (...)", this->beneath ()->shortname ());
+ LONGEST result
+ = this->beneath ()->get_raw_trace_data (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->get_raw_trace_data (%s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_gdb_byte_p (arg0).c_str (),
+ target_debug_print_ULONGEST (arg1).c_str (),
+ target_debug_print_LONGEST (arg2).c_str (),
+ target_debug_print_LONGEST (result).c_str ());
+ return result;
+}
+
+int
+target_ops::get_min_fast_tracepoint_insn_len ()
+{
+ return this->beneath ()->get_min_fast_tracepoint_insn_len ();
+}
+
+int
+dummy_target::get_min_fast_tracepoint_insn_len ()
+{
+ return -1;
+}
+
+int
+debug_target::get_min_fast_tracepoint_insn_len ()
+{
+ target_debug_printf_nofunc ("-> %s->get_min_fast_tracepoint_insn_len (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->get_min_fast_tracepoint_insn_len ();
+ target_debug_printf_nofunc ("<- %s->get_min_fast_tracepoint_insn_len () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+void
+target_ops::set_disconnected_tracing (int arg0)
+{
+ this->beneath ()->set_disconnected_tracing (arg0);
+}
+
+void
+dummy_target::set_disconnected_tracing (int arg0)
+{
+}
+
+void
+debug_target::set_disconnected_tracing (int arg0)
+{
+ target_debug_printf_nofunc ("-> %s->set_disconnected_tracing (...)", this->beneath ()->shortname ());
+ this->beneath ()->set_disconnected_tracing (arg0);
+ target_debug_printf_nofunc ("<- %s->set_disconnected_tracing (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_int (arg0).c_str ());
+}
+
+void
+target_ops::set_circular_trace_buffer (int arg0)
+{
+ this->beneath ()->set_circular_trace_buffer (arg0);
+}
+
+void
+dummy_target::set_circular_trace_buffer (int arg0)
+{
+}
+
+void
+debug_target::set_circular_trace_buffer (int arg0)
+{
+ target_debug_printf_nofunc ("-> %s->set_circular_trace_buffer (...)", this->beneath ()->shortname ());
+ this->beneath ()->set_circular_trace_buffer (arg0);
+ target_debug_printf_nofunc ("<- %s->set_circular_trace_buffer (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_int (arg0).c_str ());
+}
+
+void
+target_ops::set_trace_buffer_size (LONGEST arg0)
+{
+ this->beneath ()->set_trace_buffer_size (arg0);
+}
+
+void
+dummy_target::set_trace_buffer_size (LONGEST arg0)
+{
+}
+
+void
+debug_target::set_trace_buffer_size (LONGEST arg0)
+{
+ target_debug_printf_nofunc ("-> %s->set_trace_buffer_size (...)", this->beneath ()->shortname ());
+ this->beneath ()->set_trace_buffer_size (arg0);
+ target_debug_printf_nofunc ("<- %s->set_trace_buffer_size (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_LONGEST (arg0).c_str ());
+}
+
+bool
+target_ops::set_trace_notes (const char *arg0, const char *arg1, const char *arg2)
+{
+ return this->beneath ()->set_trace_notes (arg0, arg1, arg2);
+}
+
+bool
+dummy_target::set_trace_notes (const char *arg0, const char *arg1, const char *arg2)
+{
+ return false;
+}
+
+bool
+debug_target::set_trace_notes (const char *arg0, const char *arg1, const char *arg2)
+{
+ target_debug_printf_nofunc ("-> %s->set_trace_notes (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->set_trace_notes (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->set_trace_notes (%s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_const_char_p (arg0).c_str (),
+ target_debug_print_const_char_p (arg1).c_str (),
+ target_debug_print_const_char_p (arg2).c_str (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+int
+target_ops::core_of_thread (ptid_t arg0)
+{
+ return this->beneath ()->core_of_thread (arg0);
+}
+
+int
+dummy_target::core_of_thread (ptid_t arg0)
+{
+ return -1;
+}
+
+int
+debug_target::core_of_thread (ptid_t arg0)
+{
+ target_debug_printf_nofunc ("-> %s->core_of_thread (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->core_of_thread (arg0);
+ target_debug_printf_nofunc ("<- %s->core_of_thread (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_ptid_t (arg0).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+int
+target_ops::verify_memory (const gdb_byte *arg0, CORE_ADDR arg1, ULONGEST arg2)
+{
+ return this->beneath ()->verify_memory (arg0, arg1, arg2);
+}
+
+int
+dummy_target::verify_memory (const gdb_byte *arg0, CORE_ADDR arg1, ULONGEST arg2)
+{
+ return default_verify_memory (this, arg0, arg1, arg2);
+}
+
+int
+debug_target::verify_memory (const gdb_byte *arg0, CORE_ADDR arg1, ULONGEST arg2)
+{
+ target_debug_printf_nofunc ("-> %s->verify_memory (...)", this->beneath ()->shortname ());
+ int result
+ = this->beneath ()->verify_memory (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->verify_memory (%s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_const_gdb_byte_p (arg0).c_str (),
+ target_debug_print_CORE_ADDR (arg1).c_str (),
+ target_debug_print_ULONGEST (arg2).c_str (),
+ target_debug_print_int (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::get_tib_address (ptid_t arg0, CORE_ADDR *arg1)
+{
+ return this->beneath ()->get_tib_address (arg0, arg1);
+}
+
+bool
+dummy_target::get_tib_address (ptid_t arg0, CORE_ADDR *arg1)
+{
+ tcomplain ();
+}
+
+bool
+debug_target::get_tib_address (ptid_t arg0, CORE_ADDR *arg1)
+{
+ target_debug_printf_nofunc ("-> %s->get_tib_address (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->get_tib_address (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->get_tib_address (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_ptid_t (arg0).c_str (),
+ target_debug_print_CORE_ADDR_p (arg1).c_str (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+void
+target_ops::set_permissions ()
+{
+ this->beneath ()->set_permissions ();
+}
+
+void
+dummy_target::set_permissions ()
+{
+}
+
+void
+debug_target::set_permissions ()
+{
+ target_debug_printf_nofunc ("-> %s->set_permissions (...)", this->beneath ()->shortname ());
+ this->beneath ()->set_permissions ();
+ target_debug_printf_nofunc ("<- %s->set_permissions ()",
+ this->beneath ()->shortname ());
+}
+
+bool
+target_ops::static_tracepoint_marker_at (CORE_ADDR arg0, static_tracepoint_marker *arg1)
+{
+ return this->beneath ()->static_tracepoint_marker_at (arg0, arg1);
+}
+
+bool
+dummy_target::static_tracepoint_marker_at (CORE_ADDR arg0, static_tracepoint_marker *arg1)
+{
+ return false;
+}
+
+bool
+debug_target::static_tracepoint_marker_at (CORE_ADDR arg0, static_tracepoint_marker *arg1)
+{
+ target_debug_printf_nofunc ("-> %s->static_tracepoint_marker_at (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->static_tracepoint_marker_at (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->static_tracepoint_marker_at (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_CORE_ADDR (arg0).c_str (),
+ target_debug_print_static_tracepoint_marker_p (arg1).c_str (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+std::vector<static_tracepoint_marker>
+target_ops::static_tracepoint_markers_by_strid (const char *arg0)
+{
+ return this->beneath ()->static_tracepoint_markers_by_strid (arg0);
+}
+
+std::vector<static_tracepoint_marker>
+dummy_target::static_tracepoint_markers_by_strid (const char *arg0)
+{
+ tcomplain ();
+}
+
+std::vector<static_tracepoint_marker>
+debug_target::static_tracepoint_markers_by_strid (const char *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->static_tracepoint_markers_by_strid (...)", this->beneath ()->shortname ());
+ std::vector<static_tracepoint_marker> result
+ = this->beneath ()->static_tracepoint_markers_by_strid (arg0);
+ target_debug_printf_nofunc ("<- %s->static_tracepoint_markers_by_strid (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_const_char_p (arg0).c_str (),
+ target_debug_print_std_vector_static_tracepoint_marker (result).c_str ());
+ return result;
+}
+
+traceframe_info_up
+target_ops::traceframe_info ()
+{
+ return this->beneath ()->traceframe_info ();
+}
+
+traceframe_info_up
+dummy_target::traceframe_info ()
+{
+ tcomplain ();
+}
+
+traceframe_info_up
+debug_target::traceframe_info ()
+{
+ target_debug_printf_nofunc ("-> %s->traceframe_info (...)", this->beneath ()->shortname ());
+ traceframe_info_up result
+ = this->beneath ()->traceframe_info ();
+ target_debug_printf_nofunc ("<- %s->traceframe_info () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_traceframe_info_up (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::use_agent (bool arg0)
+{
+ return this->beneath ()->use_agent (arg0);
+}
+
+bool
+dummy_target::use_agent (bool arg0)
+{
+ tcomplain ();
+}
+
+bool
+debug_target::use_agent (bool arg0)
+{
+ target_debug_printf_nofunc ("-> %s->use_agent (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->use_agent (arg0);
+ target_debug_printf_nofunc ("<- %s->use_agent (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (arg0).c_str (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::can_use_agent ()
+{
+ return this->beneath ()->can_use_agent ();
+}
+
+bool
+dummy_target::can_use_agent ()
+{
+ return false;
+}
+
+bool
+debug_target::can_use_agent ()
+{
+ target_debug_printf_nofunc ("-> %s->can_use_agent (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->can_use_agent ();
+ target_debug_printf_nofunc ("<- %s->can_use_agent () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+struct btrace_target_info *
+target_ops::enable_btrace (thread_info *arg0, const struct btrace_config *arg1)
+{
+ return this->beneath ()->enable_btrace (arg0, arg1);
+}
+
+struct btrace_target_info *
+dummy_target::enable_btrace (thread_info *arg0, const struct btrace_config *arg1)
+{
+ tcomplain ();
+}
+
+struct btrace_target_info *
+debug_target::enable_btrace (thread_info *arg0, const struct btrace_config *arg1)
+{
+ target_debug_printf_nofunc ("-> %s->enable_btrace (...)", this->beneath ()->shortname ());
+ struct btrace_target_info * result
+ = this->beneath ()->enable_btrace (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->enable_btrace (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_thread_info_p (arg0).c_str (),
+ target_debug_print_const_btrace_config_p (arg1).c_str (),
+ target_debug_print_btrace_target_info_p (result).c_str ());
+ return result;
+}
+
+void
+target_ops::disable_btrace (struct btrace_target_info *arg0)
+{
+ this->beneath ()->disable_btrace (arg0);
+}
+
+void
+dummy_target::disable_btrace (struct btrace_target_info *arg0)
+{
+ tcomplain ();
+}
+
+void
+debug_target::disable_btrace (struct btrace_target_info *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->disable_btrace (...)", this->beneath ()->shortname ());
+ this->beneath ()->disable_btrace (arg0);
+ target_debug_printf_nofunc ("<- %s->disable_btrace (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_btrace_target_info_p (arg0).c_str ());
+}
+
+void
+target_ops::teardown_btrace (struct btrace_target_info *arg0)
+{
+ this->beneath ()->teardown_btrace (arg0);
+}
+
+void
+dummy_target::teardown_btrace (struct btrace_target_info *arg0)
+{
+ tcomplain ();
+}
+
+void
+debug_target::teardown_btrace (struct btrace_target_info *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->teardown_btrace (...)", this->beneath ()->shortname ());
+ this->beneath ()->teardown_btrace (arg0);
+ target_debug_printf_nofunc ("<- %s->teardown_btrace (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_btrace_target_info_p (arg0).c_str ());
+}
+
+enum btrace_error
+target_ops::read_btrace (struct btrace_data *arg0, struct btrace_target_info *arg1, enum btrace_read_type arg2)
+{
+ return this->beneath ()->read_btrace (arg0, arg1, arg2);
+}
+
+enum btrace_error
+dummy_target::read_btrace (struct btrace_data *arg0, struct btrace_target_info *arg1, enum btrace_read_type arg2)
+{
+ tcomplain ();
+}
+
+enum btrace_error
+debug_target::read_btrace (struct btrace_data *arg0, struct btrace_target_info *arg1, enum btrace_read_type arg2)
+{
+ target_debug_printf_nofunc ("-> %s->read_btrace (...)", this->beneath ()->shortname ());
+ enum btrace_error result
+ = this->beneath ()->read_btrace (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->read_btrace (%s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_btrace_data_p (arg0).c_str (),
+ target_debug_print_btrace_target_info_p (arg1).c_str (),
+ target_debug_print_btrace_read_type (arg2).c_str (),
+ target_debug_print_btrace_error (result).c_str ());
+ return result;
+}
+
+const struct btrace_config *
+target_ops::btrace_conf (const struct btrace_target_info *arg0)
+{
+ return this->beneath ()->btrace_conf (arg0);
+}
+
+const struct btrace_config *
+dummy_target::btrace_conf (const struct btrace_target_info *arg0)
+{
+ return NULL;
+}
+
+const struct btrace_config *
+debug_target::btrace_conf (const struct btrace_target_info *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->btrace_conf (...)", this->beneath ()->shortname ());
+ const struct btrace_config * result
+ = this->beneath ()->btrace_conf (arg0);
+ target_debug_printf_nofunc ("<- %s->btrace_conf (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_const_btrace_target_info_p (arg0).c_str (),
+ target_debug_print_const_btrace_config_p (result).c_str ());
+ return result;
+}
+
+enum record_method
+target_ops::record_method (ptid_t arg0)
+{
+ return this->beneath ()->record_method (arg0);
+}
+
+enum record_method
+dummy_target::record_method (ptid_t arg0)
+{
+ return RECORD_METHOD_NONE;
+}
+
+enum record_method
+debug_target::record_method (ptid_t arg0)
+{
+ target_debug_printf_nofunc ("-> %s->record_method (...)", this->beneath ()->shortname ());
+ enum record_method result
+ = this->beneath ()->record_method (arg0);
+ target_debug_printf_nofunc ("<- %s->record_method (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_ptid_t (arg0).c_str (),
+ target_debug_print_record_method (result).c_str ());
+ return result;
+}
+
+void
+target_ops::stop_recording ()
+{
+ this->beneath ()->stop_recording ();
+}
+
+void
+dummy_target::stop_recording ()
+{
+}
+
+void
+debug_target::stop_recording ()
+{
+ target_debug_printf_nofunc ("-> %s->stop_recording (...)", this->beneath ()->shortname ());
+ this->beneath ()->stop_recording ();
+ target_debug_printf_nofunc ("<- %s->stop_recording ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::info_record ()
+{
+ this->beneath ()->info_record ();
+}
+
+void
+dummy_target::info_record ()
+{
+}
+
+void
+debug_target::info_record ()
+{
+ target_debug_printf_nofunc ("-> %s->info_record (...)", this->beneath ()->shortname ());
+ this->beneath ()->info_record ();
+ target_debug_printf_nofunc ("<- %s->info_record ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::save_record (const char *arg0)
+{
+ this->beneath ()->save_record (arg0);
+}
+
+void
+dummy_target::save_record (const char *arg0)
+{
+ tcomplain ();
+}
+
+void
+debug_target::save_record (const char *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->save_record (...)", this->beneath ()->shortname ());
+ this->beneath ()->save_record (arg0);
+ target_debug_printf_nofunc ("<- %s->save_record (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_const_char_p (arg0).c_str ());
+}
+
+bool
+target_ops::supports_delete_record ()
+{
+ return this->beneath ()->supports_delete_record ();
+}
+
+bool
+dummy_target::supports_delete_record ()
+{
+ return false;
+}
+
+bool
+debug_target::supports_delete_record ()
+{
+ target_debug_printf_nofunc ("-> %s->supports_delete_record (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->supports_delete_record ();
+ target_debug_printf_nofunc ("<- %s->supports_delete_record () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+void
+target_ops::delete_record ()
+{
+ this->beneath ()->delete_record ();
+}
+
+void
+dummy_target::delete_record ()
+{
+ tcomplain ();
+}
+
+void
+debug_target::delete_record ()
+{
+ target_debug_printf_nofunc ("-> %s->delete_record (...)", this->beneath ()->shortname ());
+ this->beneath ()->delete_record ();
+ target_debug_printf_nofunc ("<- %s->delete_record ()",
+ this->beneath ()->shortname ());
+}
+
+bool
+target_ops::record_is_replaying (ptid_t arg0)
+{
+ return this->beneath ()->record_is_replaying (arg0);
+}
+
+bool
+dummy_target::record_is_replaying (ptid_t arg0)
+{
+ return false;
+}
+
+bool
+debug_target::record_is_replaying (ptid_t arg0)
+{
+ target_debug_printf_nofunc ("-> %s->record_is_replaying (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->record_is_replaying (arg0);
+ target_debug_printf_nofunc ("<- %s->record_is_replaying (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_ptid_t (arg0).c_str (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::record_will_replay (ptid_t arg0, int arg1)
+{
+ return this->beneath ()->record_will_replay (arg0, arg1);
+}
+
+bool
+dummy_target::record_will_replay (ptid_t arg0, int arg1)
+{
+ return false;
+}
+
+bool
+debug_target::record_will_replay (ptid_t arg0, int arg1)
+{
+ target_debug_printf_nofunc ("-> %s->record_will_replay (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->record_will_replay (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->record_will_replay (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_ptid_t (arg0).c_str (),
+ target_debug_print_int (arg1).c_str (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+void
+target_ops::record_stop_replaying ()
+{
+ this->beneath ()->record_stop_replaying ();
+}
+
+void
+dummy_target::record_stop_replaying ()
+{
+}
+
+void
+debug_target::record_stop_replaying ()
+{
+ target_debug_printf_nofunc ("-> %s->record_stop_replaying (...)", this->beneath ()->shortname ());
+ this->beneath ()->record_stop_replaying ();
+ target_debug_printf_nofunc ("<- %s->record_stop_replaying ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::goto_record_begin ()
+{
+ this->beneath ()->goto_record_begin ();
+}
+
+void
+dummy_target::goto_record_begin ()
+{
+ tcomplain ();
+}
+
+void
+debug_target::goto_record_begin ()
+{
+ target_debug_printf_nofunc ("-> %s->goto_record_begin (...)", this->beneath ()->shortname ());
+ this->beneath ()->goto_record_begin ();
+ target_debug_printf_nofunc ("<- %s->goto_record_begin ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::goto_record_end ()
+{
+ this->beneath ()->goto_record_end ();
+}
+
+void
+dummy_target::goto_record_end ()
+{
+ tcomplain ();
+}
+
+void
+debug_target::goto_record_end ()
+{
+ target_debug_printf_nofunc ("-> %s->goto_record_end (...)", this->beneath ()->shortname ());
+ this->beneath ()->goto_record_end ();
+ target_debug_printf_nofunc ("<- %s->goto_record_end ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::goto_record (ULONGEST arg0)
+{
+ this->beneath ()->goto_record (arg0);
+}
+
+void
+dummy_target::goto_record (ULONGEST arg0)
+{
+ tcomplain ();
+}
+
+void
+debug_target::goto_record (ULONGEST arg0)
+{
+ target_debug_printf_nofunc ("-> %s->goto_record (...)", this->beneath ()->shortname ());
+ this->beneath ()->goto_record (arg0);
+ target_debug_printf_nofunc ("<- %s->goto_record (%s)",
+ this->beneath ()->shortname (),
+ target_debug_print_ULONGEST (arg0).c_str ());
+}
+
+void
+target_ops::insn_history (int arg0, gdb_disassembly_flags arg1)
+{
+ this->beneath ()->insn_history (arg0, arg1);
+}
+
+void
+dummy_target::insn_history (int arg0, gdb_disassembly_flags arg1)
+{
+ tcomplain ();
+}
+
+void
+debug_target::insn_history (int arg0, gdb_disassembly_flags arg1)
+{
+ target_debug_printf_nofunc ("-> %s->insn_history (...)", this->beneath ()->shortname ());
+ this->beneath ()->insn_history (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->insn_history (%s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_int (arg0).c_str (),
+ target_debug_print_gdb_disassembly_flags (arg1).c_str ());
+}
+
+void
+target_ops::insn_history_from (ULONGEST arg0, int arg1, gdb_disassembly_flags arg2)
+{
+ this->beneath ()->insn_history_from (arg0, arg1, arg2);
+}
+
+void
+dummy_target::insn_history_from (ULONGEST arg0, int arg1, gdb_disassembly_flags arg2)
+{
+ tcomplain ();
+}
+
+void
+debug_target::insn_history_from (ULONGEST arg0, int arg1, gdb_disassembly_flags arg2)
+{
+ target_debug_printf_nofunc ("-> %s->insn_history_from (...)", this->beneath ()->shortname ());
+ this->beneath ()->insn_history_from (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->insn_history_from (%s, %s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_ULONGEST (arg0).c_str (),
+ target_debug_print_int (arg1).c_str (),
+ target_debug_print_gdb_disassembly_flags (arg2).c_str ());
+}
+
+void
+target_ops::insn_history_range (ULONGEST arg0, ULONGEST arg1, gdb_disassembly_flags arg2)
+{
+ this->beneath ()->insn_history_range (arg0, arg1, arg2);
+}
+
+void
+dummy_target::insn_history_range (ULONGEST arg0, ULONGEST arg1, gdb_disassembly_flags arg2)
+{
+ tcomplain ();
+}
+
+void
+debug_target::insn_history_range (ULONGEST arg0, ULONGEST arg1, gdb_disassembly_flags arg2)
+{
+ target_debug_printf_nofunc ("-> %s->insn_history_range (...)", this->beneath ()->shortname ());
+ this->beneath ()->insn_history_range (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->insn_history_range (%s, %s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_ULONGEST (arg0).c_str (),
+ target_debug_print_ULONGEST (arg1).c_str (),
+ target_debug_print_gdb_disassembly_flags (arg2).c_str ());
+}
+
+void
+target_ops::call_history (int arg0, record_print_flags arg1)
+{
+ this->beneath ()->call_history (arg0, arg1);
+}
+
+void
+dummy_target::call_history (int arg0, record_print_flags arg1)
+{
+ tcomplain ();
+}
+
+void
+debug_target::call_history (int arg0, record_print_flags arg1)
+{
+ target_debug_printf_nofunc ("-> %s->call_history (...)", this->beneath ()->shortname ());
+ this->beneath ()->call_history (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->call_history (%s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_int (arg0).c_str (),
+ target_debug_print_record_print_flags (arg1).c_str ());
+}
+
+void
+target_ops::call_history_from (ULONGEST arg0, int arg1, record_print_flags arg2)
+{
+ this->beneath ()->call_history_from (arg0, arg1, arg2);
+}
+
+void
+dummy_target::call_history_from (ULONGEST arg0, int arg1, record_print_flags arg2)
+{
+ tcomplain ();
+}
+
+void
+debug_target::call_history_from (ULONGEST arg0, int arg1, record_print_flags arg2)
+{
+ target_debug_printf_nofunc ("-> %s->call_history_from (...)", this->beneath ()->shortname ());
+ this->beneath ()->call_history_from (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->call_history_from (%s, %s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_ULONGEST (arg0).c_str (),
+ target_debug_print_int (arg1).c_str (),
+ target_debug_print_record_print_flags (arg2).c_str ());
+}
+
+void
+target_ops::call_history_range (ULONGEST arg0, ULONGEST arg1, record_print_flags arg2)
+{
+ this->beneath ()->call_history_range (arg0, arg1, arg2);
+}
+
+void
+dummy_target::call_history_range (ULONGEST arg0, ULONGEST arg1, record_print_flags arg2)
+{
+ tcomplain ();
+}
+
+void
+debug_target::call_history_range (ULONGEST arg0, ULONGEST arg1, record_print_flags arg2)
+{
+ target_debug_printf_nofunc ("-> %s->call_history_range (...)", this->beneath ()->shortname ());
+ this->beneath ()->call_history_range (arg0, arg1, arg2);
+ target_debug_printf_nofunc ("<- %s->call_history_range (%s, %s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_ULONGEST (arg0).c_str (),
+ target_debug_print_ULONGEST (arg1).c_str (),
+ target_debug_print_record_print_flags (arg2).c_str ());
+}
+
+bool
+target_ops::augmented_libraries_svr4_read ()
+{
+ return this->beneath ()->augmented_libraries_svr4_read ();
+}
+
+bool
+dummy_target::augmented_libraries_svr4_read ()
+{
+ return false;
+}
+
+bool
+debug_target::augmented_libraries_svr4_read ()
+{
+ target_debug_printf_nofunc ("-> %s->augmented_libraries_svr4_read (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->augmented_libraries_svr4_read ();
+ target_debug_printf_nofunc ("<- %s->augmented_libraries_svr4_read () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+const struct frame_unwind *
+target_ops::get_unwinder ()
+{
+ return this->beneath ()->get_unwinder ();
+}
+
+const struct frame_unwind *
+dummy_target::get_unwinder ()
+{
+ return NULL;
+}
+
+const struct frame_unwind *
+debug_target::get_unwinder ()
+{
+ target_debug_printf_nofunc ("-> %s->get_unwinder (...)", this->beneath ()->shortname ());
+ const struct frame_unwind * result
+ = this->beneath ()->get_unwinder ();
+ target_debug_printf_nofunc ("<- %s->get_unwinder () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_const_frame_unwind_p (result).c_str ());
+ return result;
+}
+
+const struct frame_unwind *
+target_ops::get_tailcall_unwinder ()
+{
+ return this->beneath ()->get_tailcall_unwinder ();
+}
+
+const struct frame_unwind *
+dummy_target::get_tailcall_unwinder ()
+{
+ return NULL;
+}
+
+const struct frame_unwind *
+debug_target::get_tailcall_unwinder ()
+{
+ target_debug_printf_nofunc ("-> %s->get_tailcall_unwinder (...)", this->beneath ()->shortname ());
+ const struct frame_unwind * result
+ = this->beneath ()->get_tailcall_unwinder ();
+ target_debug_printf_nofunc ("<- %s->get_tailcall_unwinder () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_const_frame_unwind_p (result).c_str ());
+ return result;
+}
+
+void
+target_ops::prepare_to_generate_core ()
+{
+ this->beneath ()->prepare_to_generate_core ();
+}
+
+void
+dummy_target::prepare_to_generate_core ()
+{
+}
+
+void
+debug_target::prepare_to_generate_core ()
+{
+ target_debug_printf_nofunc ("-> %s->prepare_to_generate_core (...)", this->beneath ()->shortname ());
+ this->beneath ()->prepare_to_generate_core ();
+ target_debug_printf_nofunc ("<- %s->prepare_to_generate_core ()",
+ this->beneath ()->shortname ());
+}
+
+void
+target_ops::done_generating_core ()
+{
+ this->beneath ()->done_generating_core ();
+}
+
+void
+dummy_target::done_generating_core ()
+{
+}
+
+void
+debug_target::done_generating_core ()
+{
+ target_debug_printf_nofunc ("-> %s->done_generating_core (...)", this->beneath ()->shortname ());
+ this->beneath ()->done_generating_core ();
+ target_debug_printf_nofunc ("<- %s->done_generating_core ()",
+ this->beneath ()->shortname ());
+}
+
+bool
+target_ops::supports_memory_tagging ()
+{
+ return this->beneath ()->supports_memory_tagging ();
+}
+
+bool
+dummy_target::supports_memory_tagging ()
+{
+ return false;
+}
+
+bool
+debug_target::supports_memory_tagging ()
+{
+ target_debug_printf_nofunc ("-> %s->supports_memory_tagging (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->supports_memory_tagging ();
+ target_debug_printf_nofunc ("<- %s->supports_memory_tagging () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::fetch_memtags (CORE_ADDR arg0, size_t arg1, gdb::byte_vector &arg2, int arg3)
+{
+ return this->beneath ()->fetch_memtags (arg0, arg1, arg2, arg3);
+}
+
+bool
+dummy_target::fetch_memtags (CORE_ADDR arg0, size_t arg1, gdb::byte_vector &arg2, int arg3)
+{
+ tcomplain ();
+}
+
+bool
+debug_target::fetch_memtags (CORE_ADDR arg0, size_t arg1, gdb::byte_vector &arg2, int arg3)
+{
+ target_debug_printf_nofunc ("-> %s->fetch_memtags (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->fetch_memtags (arg0, arg1, arg2, arg3);
+ target_debug_printf_nofunc ("<- %s->fetch_memtags (%s, %s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_CORE_ADDR (arg0).c_str (),
+ target_debug_print_size_t (arg1).c_str (),
+ target_debug_print_gdb_byte_vector_r (arg2).c_str (),
+ target_debug_print_int (arg3).c_str (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::store_memtags (CORE_ADDR arg0, size_t arg1, const gdb::byte_vector &arg2, int arg3)
+{
+ return this->beneath ()->store_memtags (arg0, arg1, arg2, arg3);
+}
+
+bool
+dummy_target::store_memtags (CORE_ADDR arg0, size_t arg1, const gdb::byte_vector &arg2, int arg3)
+{
+ tcomplain ();
+}
+
+bool
+debug_target::store_memtags (CORE_ADDR arg0, size_t arg1, const gdb::byte_vector &arg2, int arg3)
+{
+ target_debug_printf_nofunc ("-> %s->store_memtags (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->store_memtags (arg0, arg1, arg2, arg3);
+ target_debug_printf_nofunc ("<- %s->store_memtags (%s, %s, %s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_CORE_ADDR (arg0).c_str (),
+ target_debug_print_size_t (arg1).c_str (),
+ target_debug_print_const_gdb_byte_vector_r (arg2).c_str (),
+ target_debug_print_int (arg3).c_str (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::is_address_tagged (gdbarch *arg0, CORE_ADDR arg1)
+{
+ return this->beneath ()->is_address_tagged (arg0, arg1);
+}
+
+bool
+dummy_target::is_address_tagged (gdbarch *arg0, CORE_ADDR arg1)
+{
+ tcomplain ();
+}
+
+bool
+debug_target::is_address_tagged (gdbarch *arg0, CORE_ADDR arg1)
+{
+ target_debug_printf_nofunc ("-> %s->is_address_tagged (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->is_address_tagged (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->is_address_tagged (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_gdbarch_p (arg0).c_str (),
+ target_debug_print_CORE_ADDR (arg1).c_str (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+x86_xsave_layout
+target_ops::fetch_x86_xsave_layout ()
+{
+ return this->beneath ()->fetch_x86_xsave_layout ();
+}
+
+x86_xsave_layout
+dummy_target::fetch_x86_xsave_layout ()
+{
+ return x86_xsave_layout ();
+}
+
+x86_xsave_layout
+debug_target::fetch_x86_xsave_layout ()
+{
+ target_debug_printf_nofunc ("-> %s->fetch_x86_xsave_layout (...)", this->beneath ()->shortname ());
+ x86_xsave_layout result
+ = this->beneath ()->fetch_x86_xsave_layout ();
+ target_debug_printf_nofunc ("<- %s->fetch_x86_xsave_layout () = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_x86_xsave_layout (result).c_str ());
+ return result;
+}
+
+bool
+target_ops::supports_displaced_step (thread_info *arg0)
+{
+ return this->beneath ()->supports_displaced_step (arg0);
+}
+
+bool
+dummy_target::supports_displaced_step (thread_info *arg0)
+{
+ return default_supports_displaced_step (this, arg0);
+}
+
+bool
+debug_target::supports_displaced_step (thread_info *arg0)
+{
+ target_debug_printf_nofunc ("-> %s->supports_displaced_step (...)", this->beneath ()->shortname ());
+ bool result
+ = this->beneath ()->supports_displaced_step (arg0);
+ target_debug_printf_nofunc ("<- %s->supports_displaced_step (%s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_thread_info_p (arg0).c_str (),
+ target_debug_print_bool (result).c_str ());
+ return result;
+}
+
+displaced_step_prepare_status
+target_ops::displaced_step_prepare (thread_info *arg0, CORE_ADDR &arg1)
+{
+ return this->beneath ()->displaced_step_prepare (arg0, arg1);
+}
+
+displaced_step_prepare_status
+dummy_target::displaced_step_prepare (thread_info *arg0, CORE_ADDR &arg1)
+{
+ return default_displaced_step_prepare (this, arg0, arg1);
+}
+
+displaced_step_prepare_status
+debug_target::displaced_step_prepare (thread_info *arg0, CORE_ADDR &arg1)
+{
+ target_debug_printf_nofunc ("-> %s->displaced_step_prepare (...)", this->beneath ()->shortname ());
+ displaced_step_prepare_status result
+ = this->beneath ()->displaced_step_prepare (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->displaced_step_prepare (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_thread_info_p (arg0).c_str (),
+ target_debug_print_CORE_ADDR_r (arg1).c_str (),
+ target_debug_print_displaced_step_prepare_status (result).c_str ());
+ return result;
+}
+
+displaced_step_finish_status
+target_ops::displaced_step_finish (thread_info *arg0, const target_waitstatus &arg1)
+{
+ return this->beneath ()->displaced_step_finish (arg0, arg1);
+}
+
+displaced_step_finish_status
+dummy_target::displaced_step_finish (thread_info *arg0, const target_waitstatus &arg1)
+{
+ return default_displaced_step_finish (this, arg0, arg1);
+}
+
+displaced_step_finish_status
+debug_target::displaced_step_finish (thread_info *arg0, const target_waitstatus &arg1)
+{
+ target_debug_printf_nofunc ("-> %s->displaced_step_finish (...)", this->beneath ()->shortname ());
+ displaced_step_finish_status result
+ = this->beneath ()->displaced_step_finish (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->displaced_step_finish (%s, %s) = %s",
+ this->beneath ()->shortname (),
+ target_debug_print_thread_info_p (arg0).c_str (),
+ target_debug_print_const_target_waitstatus_r (arg1).c_str (),
+ target_debug_print_displaced_step_finish_status (result).c_str ());
+ return result;
+}
+
+void
+target_ops::displaced_step_restore_all_in_ptid (inferior *arg0, ptid_t arg1)
+{
+ this->beneath ()->displaced_step_restore_all_in_ptid (arg0, arg1);
+}
+
+void
+dummy_target::displaced_step_restore_all_in_ptid (inferior *arg0, ptid_t arg1)
+{
+ default_displaced_step_restore_all_in_ptid (this, arg0, arg1);
+}
+
+void
+debug_target::displaced_step_restore_all_in_ptid (inferior *arg0, ptid_t arg1)
+{
+ target_debug_printf_nofunc ("-> %s->displaced_step_restore_all_in_ptid (...)", this->beneath ()->shortname ());
+ this->beneath ()->displaced_step_restore_all_in_ptid (arg0, arg1);
+ target_debug_printf_nofunc ("<- %s->displaced_step_restore_all_in_ptid (%s, %s)",
+ this->beneath ()->shortname (),
+ target_debug_print_inferior_p (arg0).c_str (),
+ target_debug_print_ptid_t (arg1).c_str ());
+}