6c95b8df7f
Stan Shebs <stan@codesourcery.com> Add base multi-executable/process support to GDB. gdb/ * Makefile.in (SFILES): Add progspace.c. (COMMON_OBS): Add progspace.o. * progspace.h: New. * progspace.c: New. * breakpoint.h (struct bp_target_info) <placed_address_space>: New field. (struct bp_location) <pspace>: New field. (struct breakpoint) <pspace>: New field. (bpstat_stop_status, breakpoint_here_p) (moribund_breakpoint_here_p, breakpoint_inserted_here_p) (regular_breakpoint_inserted_here_p) (software_breakpoint_inserted_here_p, breakpoint_thread_match) (set_default_breakpoint): Adjust prototypes. (remove_breakpoints_pid, breakpoint_program_space_exit): Declare. (insert_single_step_breakpoint, deprecated_insert_raw_breakpoint): Adjust prototypes. * breakpoint.c (executing_startup): Delete. (default_breakpoint_sspace): New. (breakpoint_restore_shadows): Skip if the address space doesn't match. (update_watchpoint): Record the frame's program space in the breakpoint location. (insert_bp_location): Record the address space in target_info. Adjust to pass the symbol space to solib_name_from_address. (breakpoint_program_space_exit): New. (insert_breakpoint_locations): Switch the symbol space and thread when inserting breakpoints. Don't insert breakpoints in a vfork parent waiting for vfork done if we're not attached to the vfork child. (remove_breakpoints_pid): New. (reattach_breakpoints): Switch to a thread of PID. Ignore breakpoints of other symbol spaces. (create_internal_breakpoint): Store the symbol space in the sal. (create_longjmp_master_breakpoint): Iterate over all symbol spaces. (update_breakpoints_after_exec): Ignore breakpoints for other symbol spaces. (remove_breakpoint): Rename to ... (remove_breakpoint_1): ... this. Pass the breakpoints symbol space to solib_name_from_address. (remove_breakpoint): New. (mark_breakpoints_out): Ignore breakpoints from other symbol spaces. (breakpoint_init_inferior): Ditto. (breakpoint_here_p): Add an address space argument and adjust to use breakpoint_address_match. (moribund_breakpoint_here_p): Ditto. (regular_breakpoint_inserted_here_p): Ditto. (breakpoint_inserted_here_p): Ditto. (software_breakpoint_inserted_here_p): Ditto. (breakpoint_thread_match): Ditto. (bpstat_check_location): Ditto. (bpstat_stop_status): Ditto. (print_breakpoint_location): If there's a location to print, switch the current symbol space. (print_one_breakpoint_location): Add `allflag' argument. (print_one_breakpoint): Ditto. Adjust. (do_captured_breakpoint_query): Adjust. (breakpoint_1): Adjust. (breakpoint_has_pc): Also match the symbol space. (describe_other_breakpoints): Add a symbol space argument and adjust. (set_default_breakpoint): Add a symbol space argument. Set default_breakpoint_sspace. (breakpoint_address_match): New. (check_duplicates_for): Add an address space argument, and adjust. (set_raw_breakpoint): Record the symbol space in the location and in the breakpoint. (set_longjmp_breakpoint): Skip longjmp master breakpoints from other symbol spaces. (remove_thread_event_breakpoints, remove_solib_event_breakpoints) (disable_breakpoints_in_shlibs): Skip breakpoints from other symbol spaces. (disable_breakpoints_in_unloaded_shlib): Match symbol spaces. (create_catchpoint): Set the symbol space in the sal. (disable_breakpoints_before_startup): Skip breakpoints from other symbol spaces. Set executing_startup in the current symbol space. (enable_breakpoints_after_startup): Clear executing_startup in the current symbol space. Skip breakpoints from other symbol spaces. (clone_momentary_breakpoint): Also copy the symbol space. (add_location_to_breakpoint): Set the location's symbol space. (bp_loc_is_permanent): Switch thread and symbol space. (create_breakpoint): Adjust. (expand_line_sal_maybe): Expand comment to mention symbol spaces. Switch thread and symbol space when reading memory. (parse_breakpoint_sals): Set the symbol space in the sal. (break_command_really): Ditto. (skip_prologue_sal): Switch and space. (resolve_sal_pc): Ditto. (watch_command_1): Record the symbol space in the sal. (create_ada_exception_breakpoint): Adjust. (clear_command): Adjust. Match symbol spaces. (update_global_location_list): Use breakpoint_address_match. (breakpoint_re_set_one): Switch thread and space. (breakpoint_re_set): Save symbol space. (breakpoint_re_set_thread): Also reset the symbol space. (deprecated_insert_raw_breakpoint): Add an address space argument. Adjust. (insert_single_step_breakpoint): Ditto. (single_step_breakpoint_inserted_here_p): Ditto. (clear_syscall_counts): New. (_initialize_breakpoint): Install it as inferior_exit observer. * exec.h: Include "progspace.h". (exec_bfd, exec_bfd_mtime): New defines. (exec_close): Declare. * exec.c: Include "gdbthread.h" and "progspace.h". (exec_bfd, exec_bfd_mtime, current_target_sections_1): Delete. (using_exec_ops): New. (exec_close_1): Rename to exec_close, and make public. (exec_close): Rename to exec_close_1, and adjust all callers. Add description. Remove target sections and close executables from all program spaces. (exec_file_attach): Add comment. (add_target_sections): Check on `using_exec_ops' to check if the target should be pushed. (remove_target_sections): Only unpush the target if there are no more target sections in any symbol space. * gdbcore.h: Include "exec.h". (exec_bfd, exec_bfd_mtime): Remove declarations. * frame.h (get_frame_program_space, get_frame_address_space) (frame_unwind_program_space): Declare. * frame.c (struct frame_info) <pspace, aspace>: New fields. (create_sentinel_frame): Add program space argument. Set the pspace and aspace fields of the frame object. (get_current_frame, create_new_frame): Adjust. (get_frame_program_space): New. (frame_unwind_program_space): New. (get_frame_address_space): New. * stack.c (print_frame_info): Adjust. (print_frame): Use the frame's program space. * gdbthread.h (any_live_thread_of_process): Declare. * thread.c (any_live_thread_of_process): New. (switch_to_thread): Switch the program space as well. (restore_selected_frame): Don't warn if trying to restore frame level 0. * inferior.h: Include "progspace.h". (detach_fork): Declare. (struct inferior) <removable, aspace, pspace> <vfork_parent, vfork_child, pending_detach> <waiting_for_vfork_done>: New fields. <terminal_info>: Remove field. <data, num_data>: New fields. (register_inferior_data, register_inferior_data_with_cleanup) (clear_inferior_data, set_inferior_data, inferior_data): Declare. (exit_inferior, exit_inferior_silent, exit_inferior_num_silent) (inferior_appeared): Declare. (find_inferior_pid): Typo. (find_inferior_id, find_inferior_for_program_space): Declare. (set_current_inferior, save_current_inferior, prune_inferiors) (number_of_inferiors): Declare. (inferior_list): Declare. * inferior.c: Include "gdbcore.h" and "symfile.h". (inferior_list): Make public. (delete_inferior_1): Always delete thread silently. (find_inferior_id): Make public. (current_inferior_): New. (current_inferior): Use it. (set_current_inferior): New. (restore_inferior): New. (save_current_inferior): New. (free_inferior): Free the per-inferior data. (add_inferior_silent): Allocate per-inferior data. Call inferior_appeared. (delete_threads_of_inferior): New. (delete_inferior_1): Adjust interface to take an inferior pointer. (delete_inferior): Adjust. (delete_inferior_silent): Adjust. (exit_inferior_1): New. (exit_inferior): New. (exit_inferior_silent): New. (exit_inferior_num_silent): New. (detach_inferior): Adjust. (inferior_appeared): New. (discard_all_inferiors): Adjust. (find_inferior_id): Make public. Assert pid is not zero. (find_inferior_for_program_space): New. (have_inferiors): Check if we have any inferior with pid not zero. (have_live_inferiors): Go over all pushed targets looking for process_stratum. (prune_inferiors): New. (number_of_inferiors): New. (print_inferior): Add executable column. Print vfork parent/child relationships. (inferior_command): Adjust to cope with not running inferiors. (remove_inferior_command): New. (add_inferior_command): New. (clone_inferior_command): New. (struct inferior_data): New. (struct inferior_data_registration): New. (struct inferior_data_registry): New. (inferior_data_registry): New. (register_inferior_data_with_cleanup): New. (register_inferior_data): New. (inferior_alloc_data): New. (inferior_free_data): New. (clear_inferior_data): New. (set_inferior_data): New. (inferior_data): New. (initialize_inferiors): New. (_initialize_inferiors): Register "add-inferior", "remove-inferior" and "clone-inferior" commands. * objfiles.h: Include "progspace.h". (struct objfile) <pspace>: New field. (symfile_objfile, object_files): Don't declare. (ALL_PSPACE_OBJFILES): New. (ALL_PSPACE_OBJFILES_SAFE): New. (ALL_OBJFILES, ALL_OBJFILES_SAFE): Adjust. (ALL_PSPACE_SYMTABS): New. (ALL_PRIMARY_SYMTABS): Adjust. (ALL_PSPACE_PRIMARY_SYMTABS): New. (ALL_PSYMTABS): Adjust. (ALL_PSPACE_PSYMTABS): New. * objfiles.c (object_files, symfile_objfile): Delete. (struct objfile_sspace_info): New. (objfiles_pspace_data): New. (objfiles_pspace_data_cleanup): New. (get_objfile_pspace_data): New. (objfiles_changed_p): Delete. (allocate_objfile): Set the objfile's program space. Adjust to reference objfiles_changed_p in pspace data. (free_objfile): Adjust to reference objfiles_changed_p in pspace data. (objfile_relocate): Ditto. (update_section_map): Add pspace argument. Adjust to iterate over objfiles in the passed in pspace. (find_pc_section): Delete sections and num_sections statics. Adjust to refer to program space's objfiles_changed_p. Adjust to refer to sections and num_sections store in the objfile's pspace data. (objfiles_changed): Adjust to reference objfiles_changed_p in pspace data. (_initialize_objfiles): New. * linespec.c (decode_all_digits, decode_dollar): Set the sal's program space. * source.c (current_source_pspace): New. (get_current_source_symtab_and_line): Set the sal's program space. (set_current_source_symtab_and_line): Set current_source_pspace. (select_source_symtab): Ditto. Use ALL_OBJFILES. (forget_cached_source_info): Iterate over all program spaces. * symfile.c (clear_symtab_users): Adjust. * symmisc.c (print_symbol_bcache_statistics): Iterate over all program spaces. (print_objfile_statistics): Ditto. (maintenance_print_msymbols): Ditto. (maintenance_print_objfiles): Ditto. (maintenance_info_symtabs): Ditto. (maintenance_info_psymtabs): Ditto. * symtab.h (SYMTAB_PSPACE): New. (struct symtab_and_line) <pspace>: New field. * symtab.c (init_sal): Clear the sal's program space. (find_pc_sect_symtab): Set the sal's program space. Switch thread and space. (append_expanded_sal): Add program space argument. Iterate over all program spaces. (expand_line_sal): Iterate over all program spaces. Switch program space. * target.h (enum target_waitkind) <TARGET_WAITKIND_VFORK_DONE>: New. (struct target_ops) <to_thread_address_space>: New field. (target_thread_address_space): Define. * target.c (target_detach): Only remove breakpoints from the inferior we're detaching. (target_thread_address_space): New. * defs.h (initialize_progspace): Declare. * top.c (gdb_init): Call it. * solist.h (struct so_list) <sspace>: New field. * solib.h (struct program_space): Forward declare. (solib_name_from_address): Adjust prototype. * solib.c (so_list_head): Replace with a macro referencing the program space. (update_solib_list): Set the so's program space. (solib_name_from_address): Add a program space argument and adjust. * solib-svr4.c (struct svr4_info) <pid>: Delete field. <interp_text_sect_low, interp_text_sect_high, interp_plt_sect_low> <interp_plt_sect_high>: New fields. (svr4_info_p, svr4_info): Delete. (solib_svr4_sspace_data): New. (get_svr4_info): Rewrite. (svr4_sspace_data_cleanup): New. (open_symbol_file_object): Adjust. (svr4_default_sos): Adjust. (svr4_fetch_objfile_link_map): Adjust. (interp_text_sect_low, interp_text_sect_high, interp_plt_sect_low) (interp_plt_sect_high): Delete. (svr4_in_dynsym_resolve_code): Adjust. (enable_break): Adjust. (svr4_clear_solib): Revert bit that removed the svr4_info here, and reinstate clearing debug_base, debug_loader_offset_p, debug_loader_offset and debug_loader_name. (_initialize_svr4_solib): Register solib_svr4_pspace_data. Don't install an inferior_exit observer anymore. * printcmd.c (struct display) <pspace>: New field. (display_command): Set the display's sspace. (do_one_display): Match the display's sspace. (display_uses_solib_p): Ditto. * linux-fork.c (detach_fork): Moved to infrun.c. (_initialize_linux_fork): Moved "detach-on-fork" command to infrun.c. * infrun.c (detach_fork): Moved from linux-fork.c. (proceed_after_vfork_done): New. (handle_vfork_child_exec_or_exit): New. (follow_exec_mode_replace, follow_exec_mode_keep) (follow_exec_mode_names, follow_exec_mode_string) (show_follow_exec_mode_string): New. (follow_exec): New. Reinstate the mark_breakpoints_out call. Remove shared libraries before attaching new executable. If user wants to keep the inferior, keep it. (displaced_step_fixup): Adjust to pass an address space to the breakpoints module. (resume): Ditto. (clear_proceed_status): In all-stop mode, always clear the proceed status of all threads. (prepare_to_proceed): Adjust to pass an address space to the breakpoints module. (proceed): Ditto. (adjust_pc_after_break): Ditto. (handle_inferior_event): When handling a process exit, switch the program space to the inferior's that had exited. Call handle_vfork_child_exec_or_exit. Adjust to pass an address space to the breakpoints module. In non-stop mode, when following a fork and detach-fork is off, also resume the other branch. Handle TARGET_WAITKIND_VFORK_DONE. Set the program space in sals. (normal_stop): Prune inferiors. (_initialize_infrun): Install the new "follow-exec-mode" command. "detach-on-fork" moved here. * regcache.h (get_regcache_aspace): Declare. * regcache.c (struct regcache) <aspace>: New field. (regcache_xmalloc): Clear the aspace. (get_regcache_aspace): New. (regcache_cpy): Copy the aspace field. (regcache_cpy_no_passthrough): Ditto. (get_thread_regcache): Fetch the thread's address space from the target, and store it in the regcache. * infcall.c (call_function_by_hand): Set the sal's pspace. * arch-utils.c (default_has_shared_address_space): New. * arch-utils.h (default_has_shared_address_space): Declare. * gdbarch.sh (has_shared_address_space): New. * gdbarch.h, gdbarch.c: Regenerate. * linux-tdep.c: Include auxv.h, target.h, elf/common.h. (linux_has_shared_address_space): New. (_initialize_linux_tdep): Declare. * arm-tdep.c (arm_software_single_step): Pass the frame's address space to insert_single_step_breakpoint. * arm-linux-tdep.c (arm_linux_software_single_step): Pass the frame's pspace to breakpoint functions. * cris-tdep.c (crisv32_single_step_through_delay): Ditto. (cris_software_single_step): Ditto. * mips-tdep.c (deal_with_atomic_sequence): Add frame argument. Pass the frame's pspace to breakpoint functions. (mips_software_single_step): Adjust. (mips_single_step_through_delay): Adjust. * rs6000-aix-tdep.c (rs6000_software_single_step): Adjust. * rs6000-tdep.c (ppc_deal_with_atomic_sequence): Adjust. * solib-irix.c (enable_break): Adjust to pass the current frame's address space to breakpoint functions. * sparc-tdep.c (sparc_software_single_step): Ditto. * spu-tdep.c (spu_software_single_step): Ditto. * alpha-tdep.c (alpha_software_single_step): Ditto. * record.c (record_wait): Adjust to pass an address space to the breakpoints module. * fork-child.c (fork_inferior): Set the new inferior's program and address spaces. * inf-ptrace.c (inf_ptrace_follow_fork): Copy the parent's program and address spaces. (inf_ptrace_attach): Set the inferior's program and address spaces. * linux-nat.c: Include "solib.h". (linux_child_follow_fork): Manage parent and child's program and address spaces. Clone the parent's program space if necessary. Don't wait for the vfork to be done here. Refuse to resume if following the vfork parent while leaving the child stopped. (resume_callback): Don't resume a vfork parent. (linux_nat_resume): Also check for pending events in the lp->waitstatus field. (linux_handle_extended_wait): Report TARGET_WAITKIND_VFORK_DONE events to the core. (stop_wait_callback): Don't wait for SIGSTOP on vfork parents. (cancel_breakpoint): Adjust. * linux-thread-db.c (thread_db_wait): Don't remove thread event breakpoints here. (thread_db_mourn_inferior): Don't mark breakpoints out here. Remove thread event breakpoints after mourning. * corelow.c: Include progspace.h. (core_open): Set the inferior's program and address spaces. * remote.c (remote_add_inferior): Set the new inferior's program and address spaces. (remote_start_remote): Update address spaces. (extended_remote_create_inferior_1): Don't init the thread list if we already debugging other inferiors. * darwin-nat.c (darwin_attach): Set the new inferior's program and address spaces. * gnu-nat.c (gnu_attach): Ditto. * go32-nat.c (go32_create_inferior): Ditto. * inf-ttrace.c (inf_ttrace_follow_fork, inf_ttrace_attach): Ditto. * monitor.c (monitor_open): Ditto. * nto-procfs.c (procfs_attach, procfs_create_inferior): Ditto. * procfs.c (do_attach): Ditto. * windows-nat.c (do_initial_windows_stuff): Ditto. * inflow.c (inferior_process_group) (terminal_init_inferior_with_pgrp, terminal_inferior, (terminal_ours_1, inflow_inferior_exit, copy_terminal_info) (child_terminal_info, new_tty_postfork, set_sigint_trap): Adjust to use per-inferior data instead of inferior->terminal_info. (inflow_inferior_data): New. (inflow_new_inferior): Delete. (inflow_inferior_data_cleanup): New. (get_inflow_inferior_data): New. * mi/mi-interp.c (mi_new_inferior): Rename to... (mi_inferior_appeared): ... this. (mi_interpreter_init): Adjust. * tui/tui-disasm.c: Include "progspace.h". (tui_set_disassem_content): Pass an address space to breakpoint_here_p. * NEWS: Mention multi-program debugging support. Mention new commands "add-inferior", "clone-inferior", "remove-inferior", "maint info program-spaces", and new option "set follow-exec-mode". 2009-10-19 Pedro Alves <pedro@codesourcery.com> Stan Shebs <stan@codesourcery.com> gdb/doc/ * observer.texi (new_inferior): Rename to... (inferior_appeared): ... this. 2009-10-19 Pedro Alves <pedro@codesourcery.com> Stan Shebs <stan@codesourcery.com> gdb/testsuite/ * gdb.base/foll-vfork.exp: Adjust to spell out "follow-fork". * gdb.base/foll-exec.exp: Adjust to expect a process id before "Executing new program". * gdb.base/foll-fork.exp: Adjust to spell out "follow-fork". * gdb.base/multi-forks.exp: Ditto. Adjust to the inferior being left listed after having been killed. * gdb.base/attach.exp: Adjust to spell out "symbol-file". * gdb.base/maint.exp: Adjust test. * Makefile.in (ALL_SUBDIRS): Add gdb.multi. * gdb.multi/Makefile.in: New. * gdb.multi/base.exp: New. * gdb.multi/goodbye.c: New. * gdb.multi/hangout.c: New. * gdb.multi/hello.c: New. * gdb.multi/bkpt-multi-exec.c: New. * gdb.multi/bkpt-multi-exec.exp: New. * gdb.multi/crashme.c: New. 2009-10-19 Pedro Alves <pedro@codesourcery.com> Stan Shebs <stan@codesourcery.com> gdb/doc/ * gdb.texinfo (Inferiors): Rename node to ... (Inferiors and Programs): ... this. Mention running multiple programs in the same debug session. <info inferiors>: Mention the new 'Executable' column if "info inferiors". Update examples. Document the "add-inferior", "clone-inferior", "remove-inferior" and "maint info program-spaces" commands. (Process): Rename node to... (Forks): ... this. Document "set|show follow-exec-mode".
3925 lines
133 KiB
C
3925 lines
133 KiB
C
/* *INDENT-OFF* */ /* THIS FILE IS GENERATED */
|
|
|
|
/* Dynamic architecture support for GDB, the GNU debugger.
|
|
|
|
Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007
|
|
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/>. */
|
|
|
|
/* This file was created with the aid of ``gdbarch.sh''.
|
|
|
|
The Bourne shell script ``gdbarch.sh'' creates the files
|
|
``new-gdbarch.c'' and ``new-gdbarch.h and then compares them
|
|
against the existing ``gdbarch.[hc]''. Any differences found
|
|
being reported.
|
|
|
|
If editing this file, please also run gdbarch.sh and merge any
|
|
changes into that script. Conversely, when making sweeping changes
|
|
to this file, modifying gdbarch.sh and using its output may prove
|
|
easier. */
|
|
|
|
|
|
#include "defs.h"
|
|
#include "arch-utils.h"
|
|
|
|
#include "gdbcmd.h"
|
|
#include "inferior.h"
|
|
#include "symcat.h"
|
|
|
|
#include "floatformat.h"
|
|
|
|
#include "gdb_assert.h"
|
|
#include "gdb_string.h"
|
|
#include "reggroups.h"
|
|
#include "osabi.h"
|
|
#include "gdb_obstack.h"
|
|
#include "observer.h"
|
|
#include "regcache.h"
|
|
|
|
/* Static function declarations */
|
|
|
|
static void alloc_gdbarch_data (struct gdbarch *);
|
|
|
|
/* Non-zero if we want to trace architecture code. */
|
|
|
|
#ifndef GDBARCH_DEBUG
|
|
#define GDBARCH_DEBUG 0
|
|
#endif
|
|
int gdbarch_debug = GDBARCH_DEBUG;
|
|
static void
|
|
show_gdbarch_debug (struct ui_file *file, int from_tty,
|
|
struct cmd_list_element *c, const char *value)
|
|
{
|
|
fprintf_filtered (file, _("Architecture debugging is %s.\n"), value);
|
|
}
|
|
|
|
static const char *
|
|
pformat (const struct floatformat **format)
|
|
{
|
|
if (format == NULL)
|
|
return "(null)";
|
|
else
|
|
/* Just print out one of them - this is only for diagnostics. */
|
|
return format[0]->name;
|
|
}
|
|
|
|
|
|
/* Maintain the struct gdbarch object */
|
|
|
|
struct gdbarch
|
|
{
|
|
/* Has this architecture been fully initialized? */
|
|
int initialized_p;
|
|
|
|
/* An obstack bound to the lifetime of the architecture. */
|
|
struct obstack *obstack;
|
|
|
|
/* basic architectural information */
|
|
const struct bfd_arch_info * bfd_arch_info;
|
|
int byte_order;
|
|
int byte_order_for_code;
|
|
enum gdb_osabi osabi;
|
|
const struct target_desc * target_desc;
|
|
|
|
/* target specific vector. */
|
|
struct gdbarch_tdep *tdep;
|
|
gdbarch_dump_tdep_ftype *dump_tdep;
|
|
|
|
/* per-architecture data-pointers */
|
|
unsigned nr_data;
|
|
void **data;
|
|
|
|
/* per-architecture swap-regions */
|
|
struct gdbarch_swap *swap;
|
|
|
|
/* Multi-arch values.
|
|
|
|
When extending this structure you must:
|
|
|
|
Add the field below.
|
|
|
|
Declare set/get functions and define the corresponding
|
|
macro in gdbarch.h.
|
|
|
|
gdbarch_alloc(): If zero/NULL is not a suitable default,
|
|
initialize the new field.
|
|
|
|
verify_gdbarch(): Confirm that the target updated the field
|
|
correctly.
|
|
|
|
gdbarch_dump(): Add a fprintf_unfiltered call so that the new
|
|
field is dumped out
|
|
|
|
``startup_gdbarch()'': Append an initial value to the static
|
|
variable (base values on the host's c-type system).
|
|
|
|
get_gdbarch(): Implement the set/get functions (probably using
|
|
the macro's as shortcuts).
|
|
|
|
*/
|
|
|
|
int bits_big_endian;
|
|
int short_bit;
|
|
int int_bit;
|
|
int long_bit;
|
|
int long_long_bit;
|
|
int float_bit;
|
|
const struct floatformat ** float_format;
|
|
int double_bit;
|
|
const struct floatformat ** double_format;
|
|
int long_double_bit;
|
|
const struct floatformat ** long_double_format;
|
|
int ptr_bit;
|
|
int addr_bit;
|
|
int char_signed;
|
|
gdbarch_read_pc_ftype *read_pc;
|
|
gdbarch_write_pc_ftype *write_pc;
|
|
gdbarch_virtual_frame_pointer_ftype *virtual_frame_pointer;
|
|
gdbarch_pseudo_register_read_ftype *pseudo_register_read;
|
|
gdbarch_pseudo_register_write_ftype *pseudo_register_write;
|
|
int num_regs;
|
|
int num_pseudo_regs;
|
|
int sp_regnum;
|
|
int pc_regnum;
|
|
int ps_regnum;
|
|
int fp0_regnum;
|
|
gdbarch_stab_reg_to_regnum_ftype *stab_reg_to_regnum;
|
|
gdbarch_ecoff_reg_to_regnum_ftype *ecoff_reg_to_regnum;
|
|
gdbarch_sdb_reg_to_regnum_ftype *sdb_reg_to_regnum;
|
|
gdbarch_dwarf2_reg_to_regnum_ftype *dwarf2_reg_to_regnum;
|
|
gdbarch_register_name_ftype *register_name;
|
|
gdbarch_register_type_ftype *register_type;
|
|
gdbarch_dummy_id_ftype *dummy_id;
|
|
int deprecated_fp_regnum;
|
|
gdbarch_push_dummy_call_ftype *push_dummy_call;
|
|
int call_dummy_location;
|
|
gdbarch_push_dummy_code_ftype *push_dummy_code;
|
|
gdbarch_print_registers_info_ftype *print_registers_info;
|
|
gdbarch_print_float_info_ftype *print_float_info;
|
|
gdbarch_print_vector_info_ftype *print_vector_info;
|
|
gdbarch_register_sim_regno_ftype *register_sim_regno;
|
|
gdbarch_cannot_fetch_register_ftype *cannot_fetch_register;
|
|
gdbarch_cannot_store_register_ftype *cannot_store_register;
|
|
gdbarch_get_longjmp_target_ftype *get_longjmp_target;
|
|
int believe_pcc_promotion;
|
|
gdbarch_convert_register_p_ftype *convert_register_p;
|
|
gdbarch_register_to_value_ftype *register_to_value;
|
|
gdbarch_value_to_register_ftype *value_to_register;
|
|
gdbarch_value_from_register_ftype *value_from_register;
|
|
gdbarch_pointer_to_address_ftype *pointer_to_address;
|
|
gdbarch_address_to_pointer_ftype *address_to_pointer;
|
|
gdbarch_integer_to_address_ftype *integer_to_address;
|
|
gdbarch_return_value_ftype *return_value;
|
|
gdbarch_skip_prologue_ftype *skip_prologue;
|
|
gdbarch_skip_main_prologue_ftype *skip_main_prologue;
|
|
gdbarch_inner_than_ftype *inner_than;
|
|
gdbarch_breakpoint_from_pc_ftype *breakpoint_from_pc;
|
|
gdbarch_adjust_breakpoint_address_ftype *adjust_breakpoint_address;
|
|
gdbarch_memory_insert_breakpoint_ftype *memory_insert_breakpoint;
|
|
gdbarch_memory_remove_breakpoint_ftype *memory_remove_breakpoint;
|
|
CORE_ADDR decr_pc_after_break;
|
|
CORE_ADDR deprecated_function_start_offset;
|
|
gdbarch_remote_register_number_ftype *remote_register_number;
|
|
gdbarch_fetch_tls_load_module_address_ftype *fetch_tls_load_module_address;
|
|
CORE_ADDR frame_args_skip;
|
|
gdbarch_unwind_pc_ftype *unwind_pc;
|
|
gdbarch_unwind_sp_ftype *unwind_sp;
|
|
gdbarch_frame_num_args_ftype *frame_num_args;
|
|
gdbarch_frame_align_ftype *frame_align;
|
|
gdbarch_stabs_argument_has_addr_ftype *stabs_argument_has_addr;
|
|
int frame_red_zone_size;
|
|
gdbarch_convert_from_func_ptr_addr_ftype *convert_from_func_ptr_addr;
|
|
gdbarch_addr_bits_remove_ftype *addr_bits_remove;
|
|
gdbarch_smash_text_address_ftype *smash_text_address;
|
|
gdbarch_software_single_step_ftype *software_single_step;
|
|
gdbarch_single_step_through_delay_ftype *single_step_through_delay;
|
|
gdbarch_print_insn_ftype *print_insn;
|
|
gdbarch_skip_trampoline_code_ftype *skip_trampoline_code;
|
|
gdbarch_skip_solib_resolver_ftype *skip_solib_resolver;
|
|
gdbarch_in_solib_return_trampoline_ftype *in_solib_return_trampoline;
|
|
gdbarch_in_function_epilogue_p_ftype *in_function_epilogue_p;
|
|
gdbarch_elf_make_msymbol_special_ftype *elf_make_msymbol_special;
|
|
gdbarch_coff_make_msymbol_special_ftype *coff_make_msymbol_special;
|
|
int cannot_step_breakpoint;
|
|
int have_nonsteppable_watchpoint;
|
|
gdbarch_address_class_type_flags_ftype *address_class_type_flags;
|
|
gdbarch_address_class_type_flags_to_name_ftype *address_class_type_flags_to_name;
|
|
gdbarch_address_class_name_to_type_flags_ftype *address_class_name_to_type_flags;
|
|
gdbarch_register_reggroup_p_ftype *register_reggroup_p;
|
|
gdbarch_fetch_pointer_argument_ftype *fetch_pointer_argument;
|
|
gdbarch_regset_from_core_section_ftype *regset_from_core_section;
|
|
int core_reg_section_encodes_pid;
|
|
struct core_regset_section * core_regset_sections;
|
|
gdbarch_core_xfer_shared_libraries_ftype *core_xfer_shared_libraries;
|
|
gdbarch_core_pid_to_str_ftype *core_pid_to_str;
|
|
const char * gcore_bfd_target;
|
|
int vtable_function_descriptors;
|
|
int vbit_in_delta;
|
|
gdbarch_skip_permanent_breakpoint_ftype *skip_permanent_breakpoint;
|
|
ULONGEST max_insn_length;
|
|
gdbarch_displaced_step_copy_insn_ftype *displaced_step_copy_insn;
|
|
gdbarch_displaced_step_hw_singlestep_ftype *displaced_step_hw_singlestep;
|
|
gdbarch_displaced_step_fixup_ftype *displaced_step_fixup;
|
|
gdbarch_displaced_step_free_closure_ftype *displaced_step_free_closure;
|
|
gdbarch_displaced_step_location_ftype *displaced_step_location;
|
|
gdbarch_overlay_update_ftype *overlay_update;
|
|
gdbarch_core_read_description_ftype *core_read_description;
|
|
gdbarch_static_transform_name_ftype *static_transform_name;
|
|
int sofun_address_maybe_missing;
|
|
gdbarch_process_record_ftype *process_record;
|
|
gdbarch_process_record_signal_ftype *process_record_signal;
|
|
gdbarch_target_signal_from_host_ftype *target_signal_from_host;
|
|
gdbarch_target_signal_to_host_ftype *target_signal_to_host;
|
|
gdbarch_get_siginfo_type_ftype *get_siginfo_type;
|
|
gdbarch_record_special_symbol_ftype *record_special_symbol;
|
|
gdbarch_get_syscall_number_ftype *get_syscall_number;
|
|
int has_global_solist;
|
|
int has_global_breakpoints;
|
|
gdbarch_has_shared_address_space_ftype *has_shared_address_space;
|
|
};
|
|
|
|
|
|
/* The default architecture uses host values (for want of a better
|
|
choice). */
|
|
|
|
extern const struct bfd_arch_info bfd_default_arch_struct;
|
|
|
|
struct gdbarch startup_gdbarch =
|
|
{
|
|
1, /* Always initialized. */
|
|
NULL, /* The obstack. */
|
|
/* basic architecture information */
|
|
&bfd_default_arch_struct, /* bfd_arch_info */
|
|
BFD_ENDIAN_BIG, /* byte_order */
|
|
BFD_ENDIAN_BIG, /* byte_order_for_code */
|
|
GDB_OSABI_UNKNOWN, /* osabi */
|
|
0, /* target_desc */
|
|
/* target specific vector and its dump routine */
|
|
NULL, NULL,
|
|
/*per-architecture data-pointers and swap regions */
|
|
0, NULL, NULL,
|
|
/* Multi-arch values */
|
|
1, /* bits_big_endian */
|
|
8 * sizeof (short), /* short_bit */
|
|
8 * sizeof (int), /* int_bit */
|
|
8 * sizeof (long), /* long_bit */
|
|
8 * sizeof (LONGEST), /* long_long_bit */
|
|
8 * sizeof (float), /* float_bit */
|
|
0, /* float_format */
|
|
8 * sizeof (double), /* double_bit */
|
|
0, /* double_format */
|
|
8 * sizeof (long double), /* long_double_bit */
|
|
0, /* long_double_format */
|
|
8 * sizeof (void*), /* ptr_bit */
|
|
8 * sizeof (void*), /* addr_bit */
|
|
1, /* char_signed */
|
|
0, /* read_pc */
|
|
0, /* write_pc */
|
|
legacy_virtual_frame_pointer, /* virtual_frame_pointer */
|
|
0, /* pseudo_register_read */
|
|
0, /* pseudo_register_write */
|
|
0, /* num_regs */
|
|
0, /* num_pseudo_regs */
|
|
-1, /* sp_regnum */
|
|
-1, /* pc_regnum */
|
|
-1, /* ps_regnum */
|
|
0, /* fp0_regnum */
|
|
no_op_reg_to_regnum, /* stab_reg_to_regnum */
|
|
no_op_reg_to_regnum, /* ecoff_reg_to_regnum */
|
|
no_op_reg_to_regnum, /* sdb_reg_to_regnum */
|
|
no_op_reg_to_regnum, /* dwarf2_reg_to_regnum */
|
|
0, /* register_name */
|
|
0, /* register_type */
|
|
0, /* dummy_id */
|
|
-1, /* deprecated_fp_regnum */
|
|
0, /* push_dummy_call */
|
|
0, /* call_dummy_location */
|
|
0, /* push_dummy_code */
|
|
default_print_registers_info, /* print_registers_info */
|
|
0, /* print_float_info */
|
|
0, /* print_vector_info */
|
|
legacy_register_sim_regno, /* register_sim_regno */
|
|
cannot_register_not, /* cannot_fetch_register */
|
|
cannot_register_not, /* cannot_store_register */
|
|
0, /* get_longjmp_target */
|
|
0, /* believe_pcc_promotion */
|
|
generic_convert_register_p, /* convert_register_p */
|
|
0, /* register_to_value */
|
|
0, /* value_to_register */
|
|
0, /* value_from_register */
|
|
unsigned_pointer_to_address, /* pointer_to_address */
|
|
unsigned_address_to_pointer, /* address_to_pointer */
|
|
0, /* integer_to_address */
|
|
0, /* return_value */
|
|
0, /* skip_prologue */
|
|
0, /* skip_main_prologue */
|
|
0, /* inner_than */
|
|
0, /* breakpoint_from_pc */
|
|
0, /* adjust_breakpoint_address */
|
|
default_memory_insert_breakpoint, /* memory_insert_breakpoint */
|
|
default_memory_remove_breakpoint, /* memory_remove_breakpoint */
|
|
0, /* decr_pc_after_break */
|
|
0, /* deprecated_function_start_offset */
|
|
default_remote_register_number, /* remote_register_number */
|
|
0, /* fetch_tls_load_module_address */
|
|
0, /* frame_args_skip */
|
|
0, /* unwind_pc */
|
|
0, /* unwind_sp */
|
|
0, /* frame_num_args */
|
|
0, /* frame_align */
|
|
default_stabs_argument_has_addr, /* stabs_argument_has_addr */
|
|
0, /* frame_red_zone_size */
|
|
convert_from_func_ptr_addr_identity, /* convert_from_func_ptr_addr */
|
|
core_addr_identity, /* addr_bits_remove */
|
|
core_addr_identity, /* smash_text_address */
|
|
0, /* software_single_step */
|
|
0, /* single_step_through_delay */
|
|
0, /* print_insn */
|
|
0, /* skip_trampoline_code */
|
|
generic_skip_solib_resolver, /* skip_solib_resolver */
|
|
generic_in_solib_return_trampoline, /* in_solib_return_trampoline */
|
|
generic_in_function_epilogue_p, /* in_function_epilogue_p */
|
|
0, /* elf_make_msymbol_special */
|
|
0, /* coff_make_msymbol_special */
|
|
0, /* cannot_step_breakpoint */
|
|
0, /* have_nonsteppable_watchpoint */
|
|
0, /* address_class_type_flags */
|
|
0, /* address_class_type_flags_to_name */
|
|
0, /* address_class_name_to_type_flags */
|
|
default_register_reggroup_p, /* register_reggroup_p */
|
|
0, /* fetch_pointer_argument */
|
|
0, /* regset_from_core_section */
|
|
0, /* core_reg_section_encodes_pid */
|
|
0, /* core_regset_sections */
|
|
0, /* core_xfer_shared_libraries */
|
|
0, /* core_pid_to_str */
|
|
0, /* gcore_bfd_target */
|
|
0, /* vtable_function_descriptors */
|
|
0, /* vbit_in_delta */
|
|
0, /* skip_permanent_breakpoint */
|
|
0, /* max_insn_length */
|
|
0, /* displaced_step_copy_insn */
|
|
default_displaced_step_hw_singlestep, /* displaced_step_hw_singlestep */
|
|
0, /* displaced_step_fixup */
|
|
NULL, /* displaced_step_free_closure */
|
|
NULL, /* displaced_step_location */
|
|
0, /* overlay_update */
|
|
0, /* core_read_description */
|
|
0, /* static_transform_name */
|
|
0, /* sofun_address_maybe_missing */
|
|
0, /* process_record */
|
|
0, /* process_record_signal */
|
|
default_target_signal_from_host, /* target_signal_from_host */
|
|
default_target_signal_to_host, /* target_signal_to_host */
|
|
0, /* get_siginfo_type */
|
|
0, /* record_special_symbol */
|
|
0, /* get_syscall_number */
|
|
0, /* has_global_solist */
|
|
0, /* has_global_breakpoints */
|
|
default_has_shared_address_space, /* has_shared_address_space */
|
|
/* startup_gdbarch() */
|
|
};
|
|
|
|
struct gdbarch *target_gdbarch = &startup_gdbarch;
|
|
|
|
/* Create a new ``struct gdbarch'' based on information provided by
|
|
``struct gdbarch_info''. */
|
|
|
|
struct gdbarch *
|
|
gdbarch_alloc (const struct gdbarch_info *info,
|
|
struct gdbarch_tdep *tdep)
|
|
{
|
|
struct gdbarch *gdbarch;
|
|
|
|
/* Create an obstack for allocating all the per-architecture memory,
|
|
then use that to allocate the architecture vector. */
|
|
struct obstack *obstack = XMALLOC (struct obstack);
|
|
obstack_init (obstack);
|
|
gdbarch = obstack_alloc (obstack, sizeof (*gdbarch));
|
|
memset (gdbarch, 0, sizeof (*gdbarch));
|
|
gdbarch->obstack = obstack;
|
|
|
|
alloc_gdbarch_data (gdbarch);
|
|
|
|
gdbarch->tdep = tdep;
|
|
|
|
gdbarch->bfd_arch_info = info->bfd_arch_info;
|
|
gdbarch->byte_order = info->byte_order;
|
|
gdbarch->byte_order_for_code = info->byte_order_for_code;
|
|
gdbarch->osabi = info->osabi;
|
|
gdbarch->target_desc = info->target_desc;
|
|
|
|
/* Force the explicit initialization of these. */
|
|
gdbarch->bits_big_endian = (gdbarch->byte_order == BFD_ENDIAN_BIG);
|
|
gdbarch->short_bit = 2*TARGET_CHAR_BIT;
|
|
gdbarch->int_bit = 4*TARGET_CHAR_BIT;
|
|
gdbarch->long_bit = 4*TARGET_CHAR_BIT;
|
|
gdbarch->long_long_bit = 2*gdbarch->long_bit;
|
|
gdbarch->float_bit = 4*TARGET_CHAR_BIT;
|
|
gdbarch->double_bit = 8*TARGET_CHAR_BIT;
|
|
gdbarch->long_double_bit = 8*TARGET_CHAR_BIT;
|
|
gdbarch->ptr_bit = gdbarch->int_bit;
|
|
gdbarch->char_signed = -1;
|
|
gdbarch->virtual_frame_pointer = legacy_virtual_frame_pointer;
|
|
gdbarch->num_regs = -1;
|
|
gdbarch->sp_regnum = -1;
|
|
gdbarch->pc_regnum = -1;
|
|
gdbarch->ps_regnum = -1;
|
|
gdbarch->fp0_regnum = -1;
|
|
gdbarch->stab_reg_to_regnum = no_op_reg_to_regnum;
|
|
gdbarch->ecoff_reg_to_regnum = no_op_reg_to_regnum;
|
|
gdbarch->sdb_reg_to_regnum = no_op_reg_to_regnum;
|
|
gdbarch->dwarf2_reg_to_regnum = no_op_reg_to_regnum;
|
|
gdbarch->deprecated_fp_regnum = -1;
|
|
gdbarch->call_dummy_location = AT_ENTRY_POINT;
|
|
gdbarch->print_registers_info = default_print_registers_info;
|
|
gdbarch->register_sim_regno = legacy_register_sim_regno;
|
|
gdbarch->cannot_fetch_register = cannot_register_not;
|
|
gdbarch->cannot_store_register = cannot_register_not;
|
|
gdbarch->convert_register_p = generic_convert_register_p;
|
|
gdbarch->value_from_register = default_value_from_register;
|
|
gdbarch->pointer_to_address = unsigned_pointer_to_address;
|
|
gdbarch->address_to_pointer = unsigned_address_to_pointer;
|
|
gdbarch->memory_insert_breakpoint = default_memory_insert_breakpoint;
|
|
gdbarch->memory_remove_breakpoint = default_memory_remove_breakpoint;
|
|
gdbarch->remote_register_number = default_remote_register_number;
|
|
gdbarch->stabs_argument_has_addr = default_stabs_argument_has_addr;
|
|
gdbarch->convert_from_func_ptr_addr = convert_from_func_ptr_addr_identity;
|
|
gdbarch->addr_bits_remove = core_addr_identity;
|
|
gdbarch->smash_text_address = core_addr_identity;
|
|
gdbarch->skip_trampoline_code = generic_skip_trampoline_code;
|
|
gdbarch->skip_solib_resolver = generic_skip_solib_resolver;
|
|
gdbarch->in_solib_return_trampoline = generic_in_solib_return_trampoline;
|
|
gdbarch->in_function_epilogue_p = generic_in_function_epilogue_p;
|
|
gdbarch->elf_make_msymbol_special = default_elf_make_msymbol_special;
|
|
gdbarch->coff_make_msymbol_special = default_coff_make_msymbol_special;
|
|
gdbarch->register_reggroup_p = default_register_reggroup_p;
|
|
gdbarch->displaced_step_hw_singlestep = default_displaced_step_hw_singlestep;
|
|
gdbarch->displaced_step_fixup = NULL;
|
|
gdbarch->displaced_step_free_closure = NULL;
|
|
gdbarch->displaced_step_location = NULL;
|
|
gdbarch->target_signal_from_host = default_target_signal_from_host;
|
|
gdbarch->target_signal_to_host = default_target_signal_to_host;
|
|
gdbarch->has_shared_address_space = default_has_shared_address_space;
|
|
/* gdbarch_alloc() */
|
|
|
|
return gdbarch;
|
|
}
|
|
|
|
|
|
/* Allocate extra space using the per-architecture obstack. */
|
|
|
|
void *
|
|
gdbarch_obstack_zalloc (struct gdbarch *arch, long size)
|
|
{
|
|
void *data = obstack_alloc (arch->obstack, size);
|
|
memset (data, 0, size);
|
|
return data;
|
|
}
|
|
|
|
|
|
/* Free a gdbarch struct. This should never happen in normal
|
|
operation --- once you've created a gdbarch, you keep it around.
|
|
However, if an architecture's init function encounters an error
|
|
building the structure, it may need to clean up a partially
|
|
constructed gdbarch. */
|
|
|
|
void
|
|
gdbarch_free (struct gdbarch *arch)
|
|
{
|
|
struct obstack *obstack;
|
|
gdb_assert (arch != NULL);
|
|
gdb_assert (!arch->initialized_p);
|
|
obstack = arch->obstack;
|
|
obstack_free (obstack, 0); /* Includes the ARCH. */
|
|
xfree (obstack);
|
|
}
|
|
|
|
|
|
/* Ensure that all values in a GDBARCH are reasonable. */
|
|
|
|
static void
|
|
verify_gdbarch (struct gdbarch *gdbarch)
|
|
{
|
|
struct ui_file *log;
|
|
struct cleanup *cleanups;
|
|
long length;
|
|
char *buf;
|
|
log = mem_fileopen ();
|
|
cleanups = make_cleanup_ui_file_delete (log);
|
|
/* fundamental */
|
|
if (gdbarch->byte_order == BFD_ENDIAN_UNKNOWN)
|
|
fprintf_unfiltered (log, "\n\tbyte-order");
|
|
if (gdbarch->bfd_arch_info == NULL)
|
|
fprintf_unfiltered (log, "\n\tbfd_arch_info");
|
|
/* Check those that need to be defined for the given multi-arch level. */
|
|
/* Skip verify of bits_big_endian, invalid_p == 0 */
|
|
/* Skip verify of short_bit, invalid_p == 0 */
|
|
/* Skip verify of int_bit, invalid_p == 0 */
|
|
/* Skip verify of long_bit, invalid_p == 0 */
|
|
/* Skip verify of long_long_bit, invalid_p == 0 */
|
|
/* Skip verify of float_bit, invalid_p == 0 */
|
|
if (gdbarch->float_format == 0)
|
|
gdbarch->float_format = floatformats_ieee_single;
|
|
/* Skip verify of double_bit, invalid_p == 0 */
|
|
if (gdbarch->double_format == 0)
|
|
gdbarch->double_format = floatformats_ieee_double;
|
|
/* Skip verify of long_double_bit, invalid_p == 0 */
|
|
if (gdbarch->long_double_format == 0)
|
|
gdbarch->long_double_format = floatformats_ieee_double;
|
|
/* Skip verify of ptr_bit, invalid_p == 0 */
|
|
if (gdbarch->addr_bit == 0)
|
|
gdbarch->addr_bit = gdbarch_ptr_bit (gdbarch);
|
|
if (gdbarch->char_signed == -1)
|
|
gdbarch->char_signed = 1;
|
|
/* Skip verify of read_pc, has predicate */
|
|
/* Skip verify of write_pc, has predicate */
|
|
/* Skip verify of virtual_frame_pointer, invalid_p == 0 */
|
|
/* Skip verify of pseudo_register_read, has predicate */
|
|
/* Skip verify of pseudo_register_write, has predicate */
|
|
if (gdbarch->num_regs == -1)
|
|
fprintf_unfiltered (log, "\n\tnum_regs");
|
|
/* Skip verify of num_pseudo_regs, invalid_p == 0 */
|
|
/* Skip verify of sp_regnum, invalid_p == 0 */
|
|
/* Skip verify of pc_regnum, invalid_p == 0 */
|
|
/* Skip verify of ps_regnum, invalid_p == 0 */
|
|
/* Skip verify of fp0_regnum, invalid_p == 0 */
|
|
/* Skip verify of stab_reg_to_regnum, invalid_p == 0 */
|
|
/* Skip verify of ecoff_reg_to_regnum, invalid_p == 0 */
|
|
/* Skip verify of sdb_reg_to_regnum, invalid_p == 0 */
|
|
/* Skip verify of dwarf2_reg_to_regnum, invalid_p == 0 */
|
|
if (gdbarch->register_name == 0)
|
|
fprintf_unfiltered (log, "\n\tregister_name");
|
|
/* Skip verify of register_type, has predicate */
|
|
/* Skip verify of dummy_id, has predicate */
|
|
/* Skip verify of deprecated_fp_regnum, invalid_p == 0 */
|
|
/* Skip verify of push_dummy_call, has predicate */
|
|
/* Skip verify of call_dummy_location, invalid_p == 0 */
|
|
/* Skip verify of push_dummy_code, has predicate */
|
|
/* Skip verify of print_registers_info, invalid_p == 0 */
|
|
/* Skip verify of print_float_info, has predicate */
|
|
/* Skip verify of print_vector_info, has predicate */
|
|
/* Skip verify of register_sim_regno, invalid_p == 0 */
|
|
/* Skip verify of cannot_fetch_register, invalid_p == 0 */
|
|
/* Skip verify of cannot_store_register, invalid_p == 0 */
|
|
/* Skip verify of get_longjmp_target, has predicate */
|
|
/* Skip verify of convert_register_p, invalid_p == 0 */
|
|
/* Skip verify of value_from_register, invalid_p == 0 */
|
|
/* Skip verify of pointer_to_address, invalid_p == 0 */
|
|
/* Skip verify of address_to_pointer, invalid_p == 0 */
|
|
/* Skip verify of integer_to_address, has predicate */
|
|
/* Skip verify of return_value, has predicate */
|
|
if (gdbarch->skip_prologue == 0)
|
|
fprintf_unfiltered (log, "\n\tskip_prologue");
|
|
/* Skip verify of skip_main_prologue, has predicate */
|
|
if (gdbarch->inner_than == 0)
|
|
fprintf_unfiltered (log, "\n\tinner_than");
|
|
if (gdbarch->breakpoint_from_pc == 0)
|
|
fprintf_unfiltered (log, "\n\tbreakpoint_from_pc");
|
|
/* Skip verify of adjust_breakpoint_address, has predicate */
|
|
/* Skip verify of memory_insert_breakpoint, invalid_p == 0 */
|
|
/* Skip verify of memory_remove_breakpoint, invalid_p == 0 */
|
|
/* Skip verify of decr_pc_after_break, invalid_p == 0 */
|
|
/* Skip verify of deprecated_function_start_offset, invalid_p == 0 */
|
|
/* Skip verify of remote_register_number, invalid_p == 0 */
|
|
/* Skip verify of fetch_tls_load_module_address, has predicate */
|
|
/* Skip verify of frame_args_skip, invalid_p == 0 */
|
|
/* Skip verify of unwind_pc, has predicate */
|
|
/* Skip verify of unwind_sp, has predicate */
|
|
/* Skip verify of frame_num_args, has predicate */
|
|
/* Skip verify of frame_align, has predicate */
|
|
/* Skip verify of stabs_argument_has_addr, invalid_p == 0 */
|
|
/* Skip verify of convert_from_func_ptr_addr, invalid_p == 0 */
|
|
/* Skip verify of addr_bits_remove, invalid_p == 0 */
|
|
/* Skip verify of smash_text_address, invalid_p == 0 */
|
|
/* Skip verify of software_single_step, has predicate */
|
|
/* Skip verify of single_step_through_delay, has predicate */
|
|
if (gdbarch->print_insn == 0)
|
|
fprintf_unfiltered (log, "\n\tprint_insn");
|
|
/* Skip verify of skip_trampoline_code, invalid_p == 0 */
|
|
/* Skip verify of skip_solib_resolver, invalid_p == 0 */
|
|
/* Skip verify of in_solib_return_trampoline, invalid_p == 0 */
|
|
/* Skip verify of in_function_epilogue_p, invalid_p == 0 */
|
|
/* Skip verify of elf_make_msymbol_special, invalid_p == 0 */
|
|
/* Skip verify of coff_make_msymbol_special, invalid_p == 0 */
|
|
/* Skip verify of cannot_step_breakpoint, invalid_p == 0 */
|
|
/* Skip verify of have_nonsteppable_watchpoint, invalid_p == 0 */
|
|
/* Skip verify of address_class_type_flags, has predicate */
|
|
/* Skip verify of address_class_type_flags_to_name, has predicate */
|
|
/* Skip verify of address_class_name_to_type_flags, has predicate */
|
|
/* Skip verify of register_reggroup_p, invalid_p == 0 */
|
|
/* Skip verify of fetch_pointer_argument, has predicate */
|
|
/* Skip verify of regset_from_core_section, has predicate */
|
|
/* Skip verify of core_reg_section_encodes_pid, invalid_p == 0 */
|
|
/* Skip verify of core_xfer_shared_libraries, has predicate */
|
|
/* Skip verify of core_pid_to_str, has predicate */
|
|
/* Skip verify of gcore_bfd_target, has predicate */
|
|
/* Skip verify of vtable_function_descriptors, invalid_p == 0 */
|
|
/* Skip verify of vbit_in_delta, invalid_p == 0 */
|
|
/* Skip verify of skip_permanent_breakpoint, has predicate */
|
|
/* Skip verify of max_insn_length, has predicate */
|
|
/* Skip verify of displaced_step_copy_insn, has predicate */
|
|
/* Skip verify of displaced_step_hw_singlestep, invalid_p == 0 */
|
|
/* Skip verify of displaced_step_fixup, has predicate */
|
|
if ((! gdbarch->displaced_step_free_closure) != (! gdbarch->displaced_step_copy_insn))
|
|
fprintf_unfiltered (log, "\n\tdisplaced_step_free_closure");
|
|
if ((! gdbarch->displaced_step_location) != (! gdbarch->displaced_step_copy_insn))
|
|
fprintf_unfiltered (log, "\n\tdisplaced_step_location");
|
|
/* Skip verify of overlay_update, has predicate */
|
|
/* Skip verify of core_read_description, has predicate */
|
|
/* Skip verify of static_transform_name, has predicate */
|
|
/* Skip verify of sofun_address_maybe_missing, invalid_p == 0 */
|
|
/* Skip verify of process_record, has predicate */
|
|
/* Skip verify of process_record_signal, has predicate */
|
|
/* Skip verify of target_signal_from_host, invalid_p == 0 */
|
|
/* Skip verify of target_signal_to_host, invalid_p == 0 */
|
|
/* Skip verify of get_siginfo_type, has predicate */
|
|
/* Skip verify of record_special_symbol, has predicate */
|
|
/* Skip verify of get_syscall_number, has predicate */
|
|
/* Skip verify of has_global_solist, invalid_p == 0 */
|
|
/* Skip verify of has_global_breakpoints, invalid_p == 0 */
|
|
/* Skip verify of has_shared_address_space, invalid_p == 0 */
|
|
buf = ui_file_xstrdup (log, &length);
|
|
make_cleanup (xfree, buf);
|
|
if (length > 0)
|
|
internal_error (__FILE__, __LINE__,
|
|
_("verify_gdbarch: the following are invalid ...%s"),
|
|
buf);
|
|
do_cleanups (cleanups);
|
|
}
|
|
|
|
|
|
/* Print out the details of the current architecture. */
|
|
|
|
void
|
|
gdbarch_dump (struct gdbarch *gdbarch, struct ui_file *file)
|
|
{
|
|
const char *gdb_nm_file = "<not-defined>";
|
|
#if defined (GDB_NM_FILE)
|
|
gdb_nm_file = GDB_NM_FILE;
|
|
#endif
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: GDB_NM_FILE = %s\n",
|
|
gdb_nm_file);
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: addr_bit = %s\n",
|
|
plongest (gdbarch->addr_bit));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: addr_bits_remove = <%s>\n",
|
|
host_address_to_string (gdbarch->addr_bits_remove));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_address_class_name_to_type_flags_p() = %d\n",
|
|
gdbarch_address_class_name_to_type_flags_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: address_class_name_to_type_flags = <%s>\n",
|
|
host_address_to_string (gdbarch->address_class_name_to_type_flags));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_address_class_type_flags_p() = %d\n",
|
|
gdbarch_address_class_type_flags_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: address_class_type_flags = <%s>\n",
|
|
host_address_to_string (gdbarch->address_class_type_flags));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_address_class_type_flags_to_name_p() = %d\n",
|
|
gdbarch_address_class_type_flags_to_name_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: address_class_type_flags_to_name = <%s>\n",
|
|
host_address_to_string (gdbarch->address_class_type_flags_to_name));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: address_to_pointer = <%s>\n",
|
|
host_address_to_string (gdbarch->address_to_pointer));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_adjust_breakpoint_address_p() = %d\n",
|
|
gdbarch_adjust_breakpoint_address_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: adjust_breakpoint_address = <%s>\n",
|
|
host_address_to_string (gdbarch->adjust_breakpoint_address));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: believe_pcc_promotion = %s\n",
|
|
plongest (gdbarch->believe_pcc_promotion));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: bfd_arch_info = %s\n",
|
|
gdbarch_bfd_arch_info (gdbarch)->printable_name);
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: bits_big_endian = %s\n",
|
|
plongest (gdbarch->bits_big_endian));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: breakpoint_from_pc = <%s>\n",
|
|
host_address_to_string (gdbarch->breakpoint_from_pc));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: byte_order = %s\n",
|
|
plongest (gdbarch->byte_order));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: byte_order_for_code = %s\n",
|
|
plongest (gdbarch->byte_order_for_code));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: call_dummy_location = %s\n",
|
|
plongest (gdbarch->call_dummy_location));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: cannot_fetch_register = <%s>\n",
|
|
host_address_to_string (gdbarch->cannot_fetch_register));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: cannot_step_breakpoint = %s\n",
|
|
plongest (gdbarch->cannot_step_breakpoint));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: cannot_store_register = <%s>\n",
|
|
host_address_to_string (gdbarch->cannot_store_register));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: char_signed = %s\n",
|
|
plongest (gdbarch->char_signed));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: coff_make_msymbol_special = <%s>\n",
|
|
host_address_to_string (gdbarch->coff_make_msymbol_special));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: convert_from_func_ptr_addr = <%s>\n",
|
|
host_address_to_string (gdbarch->convert_from_func_ptr_addr));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: convert_register_p = <%s>\n",
|
|
host_address_to_string (gdbarch->convert_register_p));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_core_pid_to_str_p() = %d\n",
|
|
gdbarch_core_pid_to_str_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: core_pid_to_str = <%s>\n",
|
|
host_address_to_string (gdbarch->core_pid_to_str));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_core_read_description_p() = %d\n",
|
|
gdbarch_core_read_description_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: core_read_description = <%s>\n",
|
|
host_address_to_string (gdbarch->core_read_description));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: core_reg_section_encodes_pid = %s\n",
|
|
plongest (gdbarch->core_reg_section_encodes_pid));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: core_regset_sections = %s\n",
|
|
host_address_to_string (gdbarch->core_regset_sections));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_core_xfer_shared_libraries_p() = %d\n",
|
|
gdbarch_core_xfer_shared_libraries_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: core_xfer_shared_libraries = <%s>\n",
|
|
host_address_to_string (gdbarch->core_xfer_shared_libraries));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: decr_pc_after_break = %s\n",
|
|
core_addr_to_string_nz (gdbarch->decr_pc_after_break));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: deprecated_fp_regnum = %s\n",
|
|
plongest (gdbarch->deprecated_fp_regnum));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: deprecated_function_start_offset = %s\n",
|
|
core_addr_to_string_nz (gdbarch->deprecated_function_start_offset));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_displaced_step_copy_insn_p() = %d\n",
|
|
gdbarch_displaced_step_copy_insn_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: displaced_step_copy_insn = <%s>\n",
|
|
host_address_to_string (gdbarch->displaced_step_copy_insn));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_displaced_step_fixup_p() = %d\n",
|
|
gdbarch_displaced_step_fixup_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: displaced_step_fixup = <%s>\n",
|
|
host_address_to_string (gdbarch->displaced_step_fixup));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: displaced_step_free_closure = <%s>\n",
|
|
host_address_to_string (gdbarch->displaced_step_free_closure));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: displaced_step_hw_singlestep = <%s>\n",
|
|
host_address_to_string (gdbarch->displaced_step_hw_singlestep));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: displaced_step_location = <%s>\n",
|
|
host_address_to_string (gdbarch->displaced_step_location));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: double_bit = %s\n",
|
|
plongest (gdbarch->double_bit));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: double_format = %s\n",
|
|
pformat (gdbarch->double_format));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_dummy_id_p() = %d\n",
|
|
gdbarch_dummy_id_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: dummy_id = <%s>\n",
|
|
host_address_to_string (gdbarch->dummy_id));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: dwarf2_reg_to_regnum = <%s>\n",
|
|
host_address_to_string (gdbarch->dwarf2_reg_to_regnum));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: ecoff_reg_to_regnum = <%s>\n",
|
|
host_address_to_string (gdbarch->ecoff_reg_to_regnum));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: elf_make_msymbol_special = <%s>\n",
|
|
host_address_to_string (gdbarch->elf_make_msymbol_special));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_fetch_pointer_argument_p() = %d\n",
|
|
gdbarch_fetch_pointer_argument_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: fetch_pointer_argument = <%s>\n",
|
|
host_address_to_string (gdbarch->fetch_pointer_argument));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_fetch_tls_load_module_address_p() = %d\n",
|
|
gdbarch_fetch_tls_load_module_address_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: fetch_tls_load_module_address = <%s>\n",
|
|
host_address_to_string (gdbarch->fetch_tls_load_module_address));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: float_bit = %s\n",
|
|
plongest (gdbarch->float_bit));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: float_format = %s\n",
|
|
pformat (gdbarch->float_format));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: fp0_regnum = %s\n",
|
|
plongest (gdbarch->fp0_regnum));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_frame_align_p() = %d\n",
|
|
gdbarch_frame_align_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: frame_align = <%s>\n",
|
|
host_address_to_string (gdbarch->frame_align));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: frame_args_skip = %s\n",
|
|
core_addr_to_string_nz (gdbarch->frame_args_skip));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_frame_num_args_p() = %d\n",
|
|
gdbarch_frame_num_args_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: frame_num_args = <%s>\n",
|
|
host_address_to_string (gdbarch->frame_num_args));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: frame_red_zone_size = %s\n",
|
|
plongest (gdbarch->frame_red_zone_size));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_gcore_bfd_target_p() = %d\n",
|
|
gdbarch_gcore_bfd_target_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gcore_bfd_target = %s\n",
|
|
gdbarch->gcore_bfd_target);
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_get_longjmp_target_p() = %d\n",
|
|
gdbarch_get_longjmp_target_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: get_longjmp_target = <%s>\n",
|
|
host_address_to_string (gdbarch->get_longjmp_target));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_get_siginfo_type_p() = %d\n",
|
|
gdbarch_get_siginfo_type_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: get_siginfo_type = <%s>\n",
|
|
host_address_to_string (gdbarch->get_siginfo_type));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_get_syscall_number_p() = %d\n",
|
|
gdbarch_get_syscall_number_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: get_syscall_number = <%s>\n",
|
|
host_address_to_string (gdbarch->get_syscall_number));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: has_global_breakpoints = %s\n",
|
|
plongest (gdbarch->has_global_breakpoints));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: has_global_solist = %s\n",
|
|
plongest (gdbarch->has_global_solist));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: has_shared_address_space = <%s>\n",
|
|
host_address_to_string (gdbarch->has_shared_address_space));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: have_nonsteppable_watchpoint = %s\n",
|
|
plongest (gdbarch->have_nonsteppable_watchpoint));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: in_function_epilogue_p = <%s>\n",
|
|
host_address_to_string (gdbarch->in_function_epilogue_p));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: in_solib_return_trampoline = <%s>\n",
|
|
host_address_to_string (gdbarch->in_solib_return_trampoline));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: inner_than = <%s>\n",
|
|
host_address_to_string (gdbarch->inner_than));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: int_bit = %s\n",
|
|
plongest (gdbarch->int_bit));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_integer_to_address_p() = %d\n",
|
|
gdbarch_integer_to_address_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: integer_to_address = <%s>\n",
|
|
host_address_to_string (gdbarch->integer_to_address));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: long_bit = %s\n",
|
|
plongest (gdbarch->long_bit));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: long_double_bit = %s\n",
|
|
plongest (gdbarch->long_double_bit));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: long_double_format = %s\n",
|
|
pformat (gdbarch->long_double_format));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: long_long_bit = %s\n",
|
|
plongest (gdbarch->long_long_bit));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_max_insn_length_p() = %d\n",
|
|
gdbarch_max_insn_length_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: max_insn_length = %s\n",
|
|
plongest (gdbarch->max_insn_length));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: memory_insert_breakpoint = <%s>\n",
|
|
host_address_to_string (gdbarch->memory_insert_breakpoint));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: memory_remove_breakpoint = <%s>\n",
|
|
host_address_to_string (gdbarch->memory_remove_breakpoint));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: num_pseudo_regs = %s\n",
|
|
plongest (gdbarch->num_pseudo_regs));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: num_regs = %s\n",
|
|
plongest (gdbarch->num_regs));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: osabi = %s\n",
|
|
plongest (gdbarch->osabi));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_overlay_update_p() = %d\n",
|
|
gdbarch_overlay_update_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: overlay_update = <%s>\n",
|
|
host_address_to_string (gdbarch->overlay_update));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: pc_regnum = %s\n",
|
|
plongest (gdbarch->pc_regnum));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: pointer_to_address = <%s>\n",
|
|
host_address_to_string (gdbarch->pointer_to_address));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_print_float_info_p() = %d\n",
|
|
gdbarch_print_float_info_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: print_float_info = <%s>\n",
|
|
host_address_to_string (gdbarch->print_float_info));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: print_insn = <%s>\n",
|
|
host_address_to_string (gdbarch->print_insn));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: print_registers_info = <%s>\n",
|
|
host_address_to_string (gdbarch->print_registers_info));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_print_vector_info_p() = %d\n",
|
|
gdbarch_print_vector_info_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: print_vector_info = <%s>\n",
|
|
host_address_to_string (gdbarch->print_vector_info));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_process_record_p() = %d\n",
|
|
gdbarch_process_record_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: process_record = <%s>\n",
|
|
host_address_to_string (gdbarch->process_record));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_process_record_signal_p() = %d\n",
|
|
gdbarch_process_record_signal_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: process_record_signal = <%s>\n",
|
|
host_address_to_string (gdbarch->process_record_signal));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: ps_regnum = %s\n",
|
|
plongest (gdbarch->ps_regnum));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_pseudo_register_read_p() = %d\n",
|
|
gdbarch_pseudo_register_read_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: pseudo_register_read = <%s>\n",
|
|
host_address_to_string (gdbarch->pseudo_register_read));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_pseudo_register_write_p() = %d\n",
|
|
gdbarch_pseudo_register_write_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: pseudo_register_write = <%s>\n",
|
|
host_address_to_string (gdbarch->pseudo_register_write));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: ptr_bit = %s\n",
|
|
plongest (gdbarch->ptr_bit));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_push_dummy_call_p() = %d\n",
|
|
gdbarch_push_dummy_call_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: push_dummy_call = <%s>\n",
|
|
host_address_to_string (gdbarch->push_dummy_call));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_push_dummy_code_p() = %d\n",
|
|
gdbarch_push_dummy_code_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: push_dummy_code = <%s>\n",
|
|
host_address_to_string (gdbarch->push_dummy_code));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_read_pc_p() = %d\n",
|
|
gdbarch_read_pc_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: read_pc = <%s>\n",
|
|
host_address_to_string (gdbarch->read_pc));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_record_special_symbol_p() = %d\n",
|
|
gdbarch_record_special_symbol_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: record_special_symbol = <%s>\n",
|
|
host_address_to_string (gdbarch->record_special_symbol));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: register_name = <%s>\n",
|
|
host_address_to_string (gdbarch->register_name));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: register_reggroup_p = <%s>\n",
|
|
host_address_to_string (gdbarch->register_reggroup_p));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: register_sim_regno = <%s>\n",
|
|
host_address_to_string (gdbarch->register_sim_regno));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: register_to_value = <%s>\n",
|
|
host_address_to_string (gdbarch->register_to_value));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_register_type_p() = %d\n",
|
|
gdbarch_register_type_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: register_type = <%s>\n",
|
|
host_address_to_string (gdbarch->register_type));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_regset_from_core_section_p() = %d\n",
|
|
gdbarch_regset_from_core_section_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: regset_from_core_section = <%s>\n",
|
|
host_address_to_string (gdbarch->regset_from_core_section));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: remote_register_number = <%s>\n",
|
|
host_address_to_string (gdbarch->remote_register_number));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_return_value_p() = %d\n",
|
|
gdbarch_return_value_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: return_value = <%s>\n",
|
|
host_address_to_string (gdbarch->return_value));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: sdb_reg_to_regnum = <%s>\n",
|
|
host_address_to_string (gdbarch->sdb_reg_to_regnum));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: short_bit = %s\n",
|
|
plongest (gdbarch->short_bit));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_single_step_through_delay_p() = %d\n",
|
|
gdbarch_single_step_through_delay_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: single_step_through_delay = <%s>\n",
|
|
host_address_to_string (gdbarch->single_step_through_delay));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_skip_main_prologue_p() = %d\n",
|
|
gdbarch_skip_main_prologue_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: skip_main_prologue = <%s>\n",
|
|
host_address_to_string (gdbarch->skip_main_prologue));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_skip_permanent_breakpoint_p() = %d\n",
|
|
gdbarch_skip_permanent_breakpoint_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: skip_permanent_breakpoint = <%s>\n",
|
|
host_address_to_string (gdbarch->skip_permanent_breakpoint));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: skip_prologue = <%s>\n",
|
|
host_address_to_string (gdbarch->skip_prologue));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: skip_solib_resolver = <%s>\n",
|
|
host_address_to_string (gdbarch->skip_solib_resolver));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: skip_trampoline_code = <%s>\n",
|
|
host_address_to_string (gdbarch->skip_trampoline_code));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: smash_text_address = <%s>\n",
|
|
host_address_to_string (gdbarch->smash_text_address));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_software_single_step_p() = %d\n",
|
|
gdbarch_software_single_step_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: software_single_step = <%s>\n",
|
|
host_address_to_string (gdbarch->software_single_step));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: sofun_address_maybe_missing = %s\n",
|
|
plongest (gdbarch->sofun_address_maybe_missing));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: sp_regnum = %s\n",
|
|
plongest (gdbarch->sp_regnum));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: stab_reg_to_regnum = <%s>\n",
|
|
host_address_to_string (gdbarch->stab_reg_to_regnum));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: stabs_argument_has_addr = <%s>\n",
|
|
host_address_to_string (gdbarch->stabs_argument_has_addr));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_static_transform_name_p() = %d\n",
|
|
gdbarch_static_transform_name_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: static_transform_name = <%s>\n",
|
|
host_address_to_string (gdbarch->static_transform_name));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: target_desc = %s\n",
|
|
host_address_to_string (gdbarch->target_desc));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: target_signal_from_host = <%s>\n",
|
|
host_address_to_string (gdbarch->target_signal_from_host));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: target_signal_to_host = <%s>\n",
|
|
host_address_to_string (gdbarch->target_signal_to_host));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_unwind_pc_p() = %d\n",
|
|
gdbarch_unwind_pc_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: unwind_pc = <%s>\n",
|
|
host_address_to_string (gdbarch->unwind_pc));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_unwind_sp_p() = %d\n",
|
|
gdbarch_unwind_sp_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: unwind_sp = <%s>\n",
|
|
host_address_to_string (gdbarch->unwind_sp));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: value_from_register = <%s>\n",
|
|
host_address_to_string (gdbarch->value_from_register));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: value_to_register = <%s>\n",
|
|
host_address_to_string (gdbarch->value_to_register));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: vbit_in_delta = %s\n",
|
|
plongest (gdbarch->vbit_in_delta));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: virtual_frame_pointer = <%s>\n",
|
|
host_address_to_string (gdbarch->virtual_frame_pointer));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: vtable_function_descriptors = %s\n",
|
|
plongest (gdbarch->vtable_function_descriptors));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: gdbarch_write_pc_p() = %d\n",
|
|
gdbarch_write_pc_p (gdbarch));
|
|
fprintf_unfiltered (file,
|
|
"gdbarch_dump: write_pc = <%s>\n",
|
|
host_address_to_string (gdbarch->write_pc));
|
|
if (gdbarch->dump_tdep != NULL)
|
|
gdbarch->dump_tdep (gdbarch, file);
|
|
}
|
|
|
|
struct gdbarch_tdep *
|
|
gdbarch_tdep (struct gdbarch *gdbarch)
|
|
{
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_tdep called\n");
|
|
return gdbarch->tdep;
|
|
}
|
|
|
|
|
|
const struct bfd_arch_info *
|
|
gdbarch_bfd_arch_info (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_bfd_arch_info called\n");
|
|
return gdbarch->bfd_arch_info;
|
|
}
|
|
|
|
int
|
|
gdbarch_byte_order (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_byte_order called\n");
|
|
return gdbarch->byte_order;
|
|
}
|
|
|
|
int
|
|
gdbarch_byte_order_for_code (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_byte_order_for_code called\n");
|
|
return gdbarch->byte_order_for_code;
|
|
}
|
|
|
|
enum gdb_osabi
|
|
gdbarch_osabi (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_osabi called\n");
|
|
return gdbarch->osabi;
|
|
}
|
|
|
|
const struct target_desc *
|
|
gdbarch_target_desc (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_target_desc called\n");
|
|
return gdbarch->target_desc;
|
|
}
|
|
|
|
int
|
|
gdbarch_bits_big_endian (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of bits_big_endian, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_bits_big_endian called\n");
|
|
return gdbarch->bits_big_endian;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_bits_big_endian (struct gdbarch *gdbarch,
|
|
int bits_big_endian)
|
|
{
|
|
gdbarch->bits_big_endian = bits_big_endian;
|
|
}
|
|
|
|
int
|
|
gdbarch_short_bit (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of short_bit, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_short_bit called\n");
|
|
return gdbarch->short_bit;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_short_bit (struct gdbarch *gdbarch,
|
|
int short_bit)
|
|
{
|
|
gdbarch->short_bit = short_bit;
|
|
}
|
|
|
|
int
|
|
gdbarch_int_bit (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of int_bit, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_int_bit called\n");
|
|
return gdbarch->int_bit;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_int_bit (struct gdbarch *gdbarch,
|
|
int int_bit)
|
|
{
|
|
gdbarch->int_bit = int_bit;
|
|
}
|
|
|
|
int
|
|
gdbarch_long_bit (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of long_bit, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_long_bit called\n");
|
|
return gdbarch->long_bit;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_long_bit (struct gdbarch *gdbarch,
|
|
int long_bit)
|
|
{
|
|
gdbarch->long_bit = long_bit;
|
|
}
|
|
|
|
int
|
|
gdbarch_long_long_bit (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of long_long_bit, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_long_long_bit called\n");
|
|
return gdbarch->long_long_bit;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_long_long_bit (struct gdbarch *gdbarch,
|
|
int long_long_bit)
|
|
{
|
|
gdbarch->long_long_bit = long_long_bit;
|
|
}
|
|
|
|
int
|
|
gdbarch_float_bit (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of float_bit, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_float_bit called\n");
|
|
return gdbarch->float_bit;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_float_bit (struct gdbarch *gdbarch,
|
|
int float_bit)
|
|
{
|
|
gdbarch->float_bit = float_bit;
|
|
}
|
|
|
|
const struct floatformat **
|
|
gdbarch_float_format (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_float_format called\n");
|
|
return gdbarch->float_format;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_float_format (struct gdbarch *gdbarch,
|
|
const struct floatformat ** float_format)
|
|
{
|
|
gdbarch->float_format = float_format;
|
|
}
|
|
|
|
int
|
|
gdbarch_double_bit (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of double_bit, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_double_bit called\n");
|
|
return gdbarch->double_bit;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_double_bit (struct gdbarch *gdbarch,
|
|
int double_bit)
|
|
{
|
|
gdbarch->double_bit = double_bit;
|
|
}
|
|
|
|
const struct floatformat **
|
|
gdbarch_double_format (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_double_format called\n");
|
|
return gdbarch->double_format;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_double_format (struct gdbarch *gdbarch,
|
|
const struct floatformat ** double_format)
|
|
{
|
|
gdbarch->double_format = double_format;
|
|
}
|
|
|
|
int
|
|
gdbarch_long_double_bit (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of long_double_bit, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_long_double_bit called\n");
|
|
return gdbarch->long_double_bit;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_long_double_bit (struct gdbarch *gdbarch,
|
|
int long_double_bit)
|
|
{
|
|
gdbarch->long_double_bit = long_double_bit;
|
|
}
|
|
|
|
const struct floatformat **
|
|
gdbarch_long_double_format (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_long_double_format called\n");
|
|
return gdbarch->long_double_format;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_long_double_format (struct gdbarch *gdbarch,
|
|
const struct floatformat ** long_double_format)
|
|
{
|
|
gdbarch->long_double_format = long_double_format;
|
|
}
|
|
|
|
int
|
|
gdbarch_ptr_bit (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of ptr_bit, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_ptr_bit called\n");
|
|
return gdbarch->ptr_bit;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_ptr_bit (struct gdbarch *gdbarch,
|
|
int ptr_bit)
|
|
{
|
|
gdbarch->ptr_bit = ptr_bit;
|
|
}
|
|
|
|
int
|
|
gdbarch_addr_bit (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Check variable changed from pre-default. */
|
|
gdb_assert (gdbarch->addr_bit != 0);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_addr_bit called\n");
|
|
return gdbarch->addr_bit;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_addr_bit (struct gdbarch *gdbarch,
|
|
int addr_bit)
|
|
{
|
|
gdbarch->addr_bit = addr_bit;
|
|
}
|
|
|
|
int
|
|
gdbarch_char_signed (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Check variable changed from pre-default. */
|
|
gdb_assert (gdbarch->char_signed != -1);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_char_signed called\n");
|
|
return gdbarch->char_signed;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_char_signed (struct gdbarch *gdbarch,
|
|
int char_signed)
|
|
{
|
|
gdbarch->char_signed = char_signed;
|
|
}
|
|
|
|
int
|
|
gdbarch_read_pc_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->read_pc != NULL;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_read_pc (struct gdbarch *gdbarch, struct regcache *regcache)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->read_pc != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_read_pc called\n");
|
|
return gdbarch->read_pc (regcache);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_read_pc (struct gdbarch *gdbarch,
|
|
gdbarch_read_pc_ftype read_pc)
|
|
{
|
|
gdbarch->read_pc = read_pc;
|
|
}
|
|
|
|
int
|
|
gdbarch_write_pc_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->write_pc != NULL;
|
|
}
|
|
|
|
void
|
|
gdbarch_write_pc (struct gdbarch *gdbarch, struct regcache *regcache, CORE_ADDR val)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->write_pc != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_write_pc called\n");
|
|
gdbarch->write_pc (regcache, val);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_write_pc (struct gdbarch *gdbarch,
|
|
gdbarch_write_pc_ftype write_pc)
|
|
{
|
|
gdbarch->write_pc = write_pc;
|
|
}
|
|
|
|
void
|
|
gdbarch_virtual_frame_pointer (struct gdbarch *gdbarch, CORE_ADDR pc, int *frame_regnum, LONGEST *frame_offset)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->virtual_frame_pointer != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_virtual_frame_pointer called\n");
|
|
gdbarch->virtual_frame_pointer (gdbarch, pc, frame_regnum, frame_offset);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_virtual_frame_pointer (struct gdbarch *gdbarch,
|
|
gdbarch_virtual_frame_pointer_ftype virtual_frame_pointer)
|
|
{
|
|
gdbarch->virtual_frame_pointer = virtual_frame_pointer;
|
|
}
|
|
|
|
int
|
|
gdbarch_pseudo_register_read_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->pseudo_register_read != NULL;
|
|
}
|
|
|
|
void
|
|
gdbarch_pseudo_register_read (struct gdbarch *gdbarch, struct regcache *regcache, int cookednum, gdb_byte *buf)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->pseudo_register_read != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_pseudo_register_read called\n");
|
|
gdbarch->pseudo_register_read (gdbarch, regcache, cookednum, buf);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_pseudo_register_read (struct gdbarch *gdbarch,
|
|
gdbarch_pseudo_register_read_ftype pseudo_register_read)
|
|
{
|
|
gdbarch->pseudo_register_read = pseudo_register_read;
|
|
}
|
|
|
|
int
|
|
gdbarch_pseudo_register_write_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->pseudo_register_write != NULL;
|
|
}
|
|
|
|
void
|
|
gdbarch_pseudo_register_write (struct gdbarch *gdbarch, struct regcache *regcache, int cookednum, const gdb_byte *buf)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->pseudo_register_write != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_pseudo_register_write called\n");
|
|
gdbarch->pseudo_register_write (gdbarch, regcache, cookednum, buf);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_pseudo_register_write (struct gdbarch *gdbarch,
|
|
gdbarch_pseudo_register_write_ftype pseudo_register_write)
|
|
{
|
|
gdbarch->pseudo_register_write = pseudo_register_write;
|
|
}
|
|
|
|
int
|
|
gdbarch_num_regs (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Check variable changed from pre-default. */
|
|
gdb_assert (gdbarch->num_regs != -1);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_num_regs called\n");
|
|
return gdbarch->num_regs;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_num_regs (struct gdbarch *gdbarch,
|
|
int num_regs)
|
|
{
|
|
gdbarch->num_regs = num_regs;
|
|
}
|
|
|
|
int
|
|
gdbarch_num_pseudo_regs (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of num_pseudo_regs, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_num_pseudo_regs called\n");
|
|
return gdbarch->num_pseudo_regs;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_num_pseudo_regs (struct gdbarch *gdbarch,
|
|
int num_pseudo_regs)
|
|
{
|
|
gdbarch->num_pseudo_regs = num_pseudo_regs;
|
|
}
|
|
|
|
int
|
|
gdbarch_sp_regnum (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of sp_regnum, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_sp_regnum called\n");
|
|
return gdbarch->sp_regnum;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_sp_regnum (struct gdbarch *gdbarch,
|
|
int sp_regnum)
|
|
{
|
|
gdbarch->sp_regnum = sp_regnum;
|
|
}
|
|
|
|
int
|
|
gdbarch_pc_regnum (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of pc_regnum, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_pc_regnum called\n");
|
|
return gdbarch->pc_regnum;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_pc_regnum (struct gdbarch *gdbarch,
|
|
int pc_regnum)
|
|
{
|
|
gdbarch->pc_regnum = pc_regnum;
|
|
}
|
|
|
|
int
|
|
gdbarch_ps_regnum (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of ps_regnum, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_ps_regnum called\n");
|
|
return gdbarch->ps_regnum;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_ps_regnum (struct gdbarch *gdbarch,
|
|
int ps_regnum)
|
|
{
|
|
gdbarch->ps_regnum = ps_regnum;
|
|
}
|
|
|
|
int
|
|
gdbarch_fp0_regnum (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of fp0_regnum, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_fp0_regnum called\n");
|
|
return gdbarch->fp0_regnum;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_fp0_regnum (struct gdbarch *gdbarch,
|
|
int fp0_regnum)
|
|
{
|
|
gdbarch->fp0_regnum = fp0_regnum;
|
|
}
|
|
|
|
int
|
|
gdbarch_stab_reg_to_regnum (struct gdbarch *gdbarch, int stab_regnr)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->stab_reg_to_regnum != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_stab_reg_to_regnum called\n");
|
|
return gdbarch->stab_reg_to_regnum (gdbarch, stab_regnr);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_stab_reg_to_regnum (struct gdbarch *gdbarch,
|
|
gdbarch_stab_reg_to_regnum_ftype stab_reg_to_regnum)
|
|
{
|
|
gdbarch->stab_reg_to_regnum = stab_reg_to_regnum;
|
|
}
|
|
|
|
int
|
|
gdbarch_ecoff_reg_to_regnum (struct gdbarch *gdbarch, int ecoff_regnr)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->ecoff_reg_to_regnum != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_ecoff_reg_to_regnum called\n");
|
|
return gdbarch->ecoff_reg_to_regnum (gdbarch, ecoff_regnr);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_ecoff_reg_to_regnum (struct gdbarch *gdbarch,
|
|
gdbarch_ecoff_reg_to_regnum_ftype ecoff_reg_to_regnum)
|
|
{
|
|
gdbarch->ecoff_reg_to_regnum = ecoff_reg_to_regnum;
|
|
}
|
|
|
|
int
|
|
gdbarch_sdb_reg_to_regnum (struct gdbarch *gdbarch, int sdb_regnr)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->sdb_reg_to_regnum != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_sdb_reg_to_regnum called\n");
|
|
return gdbarch->sdb_reg_to_regnum (gdbarch, sdb_regnr);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_sdb_reg_to_regnum (struct gdbarch *gdbarch,
|
|
gdbarch_sdb_reg_to_regnum_ftype sdb_reg_to_regnum)
|
|
{
|
|
gdbarch->sdb_reg_to_regnum = sdb_reg_to_regnum;
|
|
}
|
|
|
|
int
|
|
gdbarch_dwarf2_reg_to_regnum (struct gdbarch *gdbarch, int dwarf2_regnr)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->dwarf2_reg_to_regnum != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_dwarf2_reg_to_regnum called\n");
|
|
return gdbarch->dwarf2_reg_to_regnum (gdbarch, dwarf2_regnr);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_dwarf2_reg_to_regnum (struct gdbarch *gdbarch,
|
|
gdbarch_dwarf2_reg_to_regnum_ftype dwarf2_reg_to_regnum)
|
|
{
|
|
gdbarch->dwarf2_reg_to_regnum = dwarf2_reg_to_regnum;
|
|
}
|
|
|
|
const char *
|
|
gdbarch_register_name (struct gdbarch *gdbarch, int regnr)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->register_name != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_register_name called\n");
|
|
return gdbarch->register_name (gdbarch, regnr);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_register_name (struct gdbarch *gdbarch,
|
|
gdbarch_register_name_ftype register_name)
|
|
{
|
|
gdbarch->register_name = register_name;
|
|
}
|
|
|
|
int
|
|
gdbarch_register_type_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->register_type != NULL;
|
|
}
|
|
|
|
struct type *
|
|
gdbarch_register_type (struct gdbarch *gdbarch, int reg_nr)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->register_type != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_register_type called\n");
|
|
return gdbarch->register_type (gdbarch, reg_nr);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_register_type (struct gdbarch *gdbarch,
|
|
gdbarch_register_type_ftype register_type)
|
|
{
|
|
gdbarch->register_type = register_type;
|
|
}
|
|
|
|
int
|
|
gdbarch_dummy_id_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->dummy_id != NULL;
|
|
}
|
|
|
|
struct frame_id
|
|
gdbarch_dummy_id (struct gdbarch *gdbarch, struct frame_info *this_frame)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->dummy_id != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_dummy_id called\n");
|
|
return gdbarch->dummy_id (gdbarch, this_frame);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_dummy_id (struct gdbarch *gdbarch,
|
|
gdbarch_dummy_id_ftype dummy_id)
|
|
{
|
|
gdbarch->dummy_id = dummy_id;
|
|
}
|
|
|
|
int
|
|
gdbarch_deprecated_fp_regnum (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of deprecated_fp_regnum, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_deprecated_fp_regnum called\n");
|
|
return gdbarch->deprecated_fp_regnum;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_deprecated_fp_regnum (struct gdbarch *gdbarch,
|
|
int deprecated_fp_regnum)
|
|
{
|
|
gdbarch->deprecated_fp_regnum = deprecated_fp_regnum;
|
|
}
|
|
|
|
int
|
|
gdbarch_push_dummy_call_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->push_dummy_call != NULL;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_push_dummy_call (struct gdbarch *gdbarch, struct value *function, struct regcache *regcache, CORE_ADDR bp_addr, int nargs, struct value **args, CORE_ADDR sp, int struct_return, CORE_ADDR struct_addr)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->push_dummy_call != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_push_dummy_call called\n");
|
|
return gdbarch->push_dummy_call (gdbarch, function, regcache, bp_addr, nargs, args, sp, struct_return, struct_addr);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_push_dummy_call (struct gdbarch *gdbarch,
|
|
gdbarch_push_dummy_call_ftype push_dummy_call)
|
|
{
|
|
gdbarch->push_dummy_call = push_dummy_call;
|
|
}
|
|
|
|
int
|
|
gdbarch_call_dummy_location (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of call_dummy_location, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_call_dummy_location called\n");
|
|
return gdbarch->call_dummy_location;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_call_dummy_location (struct gdbarch *gdbarch,
|
|
int call_dummy_location)
|
|
{
|
|
gdbarch->call_dummy_location = call_dummy_location;
|
|
}
|
|
|
|
int
|
|
gdbarch_push_dummy_code_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->push_dummy_code != NULL;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_push_dummy_code (struct gdbarch *gdbarch, CORE_ADDR sp, CORE_ADDR funaddr, struct value **args, int nargs, struct type *value_type, CORE_ADDR *real_pc, CORE_ADDR *bp_addr, struct regcache *regcache)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->push_dummy_code != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_push_dummy_code called\n");
|
|
return gdbarch->push_dummy_code (gdbarch, sp, funaddr, args, nargs, value_type, real_pc, bp_addr, regcache);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_push_dummy_code (struct gdbarch *gdbarch,
|
|
gdbarch_push_dummy_code_ftype push_dummy_code)
|
|
{
|
|
gdbarch->push_dummy_code = push_dummy_code;
|
|
}
|
|
|
|
void
|
|
gdbarch_print_registers_info (struct gdbarch *gdbarch, struct ui_file *file, struct frame_info *frame, int regnum, int all)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->print_registers_info != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_print_registers_info called\n");
|
|
gdbarch->print_registers_info (gdbarch, file, frame, regnum, all);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_print_registers_info (struct gdbarch *gdbarch,
|
|
gdbarch_print_registers_info_ftype print_registers_info)
|
|
{
|
|
gdbarch->print_registers_info = print_registers_info;
|
|
}
|
|
|
|
int
|
|
gdbarch_print_float_info_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->print_float_info != NULL;
|
|
}
|
|
|
|
void
|
|
gdbarch_print_float_info (struct gdbarch *gdbarch, struct ui_file *file, struct frame_info *frame, const char *args)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->print_float_info != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_print_float_info called\n");
|
|
gdbarch->print_float_info (gdbarch, file, frame, args);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_print_float_info (struct gdbarch *gdbarch,
|
|
gdbarch_print_float_info_ftype print_float_info)
|
|
{
|
|
gdbarch->print_float_info = print_float_info;
|
|
}
|
|
|
|
int
|
|
gdbarch_print_vector_info_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->print_vector_info != NULL;
|
|
}
|
|
|
|
void
|
|
gdbarch_print_vector_info (struct gdbarch *gdbarch, struct ui_file *file, struct frame_info *frame, const char *args)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->print_vector_info != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_print_vector_info called\n");
|
|
gdbarch->print_vector_info (gdbarch, file, frame, args);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_print_vector_info (struct gdbarch *gdbarch,
|
|
gdbarch_print_vector_info_ftype print_vector_info)
|
|
{
|
|
gdbarch->print_vector_info = print_vector_info;
|
|
}
|
|
|
|
int
|
|
gdbarch_register_sim_regno (struct gdbarch *gdbarch, int reg_nr)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->register_sim_regno != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_register_sim_regno called\n");
|
|
return gdbarch->register_sim_regno (gdbarch, reg_nr);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_register_sim_regno (struct gdbarch *gdbarch,
|
|
gdbarch_register_sim_regno_ftype register_sim_regno)
|
|
{
|
|
gdbarch->register_sim_regno = register_sim_regno;
|
|
}
|
|
|
|
int
|
|
gdbarch_cannot_fetch_register (struct gdbarch *gdbarch, int regnum)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->cannot_fetch_register != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_cannot_fetch_register called\n");
|
|
return gdbarch->cannot_fetch_register (gdbarch, regnum);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_cannot_fetch_register (struct gdbarch *gdbarch,
|
|
gdbarch_cannot_fetch_register_ftype cannot_fetch_register)
|
|
{
|
|
gdbarch->cannot_fetch_register = cannot_fetch_register;
|
|
}
|
|
|
|
int
|
|
gdbarch_cannot_store_register (struct gdbarch *gdbarch, int regnum)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->cannot_store_register != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_cannot_store_register called\n");
|
|
return gdbarch->cannot_store_register (gdbarch, regnum);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_cannot_store_register (struct gdbarch *gdbarch,
|
|
gdbarch_cannot_store_register_ftype cannot_store_register)
|
|
{
|
|
gdbarch->cannot_store_register = cannot_store_register;
|
|
}
|
|
|
|
int
|
|
gdbarch_get_longjmp_target_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->get_longjmp_target != NULL;
|
|
}
|
|
|
|
int
|
|
gdbarch_get_longjmp_target (struct gdbarch *gdbarch, struct frame_info *frame, CORE_ADDR *pc)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->get_longjmp_target != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_get_longjmp_target called\n");
|
|
return gdbarch->get_longjmp_target (frame, pc);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_get_longjmp_target (struct gdbarch *gdbarch,
|
|
gdbarch_get_longjmp_target_ftype get_longjmp_target)
|
|
{
|
|
gdbarch->get_longjmp_target = get_longjmp_target;
|
|
}
|
|
|
|
int
|
|
gdbarch_believe_pcc_promotion (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_believe_pcc_promotion called\n");
|
|
return gdbarch->believe_pcc_promotion;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_believe_pcc_promotion (struct gdbarch *gdbarch,
|
|
int believe_pcc_promotion)
|
|
{
|
|
gdbarch->believe_pcc_promotion = believe_pcc_promotion;
|
|
}
|
|
|
|
int
|
|
gdbarch_convert_register_p (struct gdbarch *gdbarch, int regnum, struct type *type)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->convert_register_p != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_convert_register_p called\n");
|
|
return gdbarch->convert_register_p (gdbarch, regnum, type);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_convert_register_p (struct gdbarch *gdbarch,
|
|
gdbarch_convert_register_p_ftype convert_register_p)
|
|
{
|
|
gdbarch->convert_register_p = convert_register_p;
|
|
}
|
|
|
|
void
|
|
gdbarch_register_to_value (struct gdbarch *gdbarch, struct frame_info *frame, int regnum, struct type *type, gdb_byte *buf)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->register_to_value != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_register_to_value called\n");
|
|
gdbarch->register_to_value (frame, regnum, type, buf);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_register_to_value (struct gdbarch *gdbarch,
|
|
gdbarch_register_to_value_ftype register_to_value)
|
|
{
|
|
gdbarch->register_to_value = register_to_value;
|
|
}
|
|
|
|
void
|
|
gdbarch_value_to_register (struct gdbarch *gdbarch, struct frame_info *frame, int regnum, struct type *type, const gdb_byte *buf)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->value_to_register != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_value_to_register called\n");
|
|
gdbarch->value_to_register (frame, regnum, type, buf);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_value_to_register (struct gdbarch *gdbarch,
|
|
gdbarch_value_to_register_ftype value_to_register)
|
|
{
|
|
gdbarch->value_to_register = value_to_register;
|
|
}
|
|
|
|
struct value *
|
|
gdbarch_value_from_register (struct gdbarch *gdbarch, struct type *type, int regnum, struct frame_info *frame)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->value_from_register != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_value_from_register called\n");
|
|
return gdbarch->value_from_register (type, regnum, frame);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_value_from_register (struct gdbarch *gdbarch,
|
|
gdbarch_value_from_register_ftype value_from_register)
|
|
{
|
|
gdbarch->value_from_register = value_from_register;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_pointer_to_address (struct gdbarch *gdbarch, struct type *type, const gdb_byte *buf)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->pointer_to_address != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_pointer_to_address called\n");
|
|
return gdbarch->pointer_to_address (gdbarch, type, buf);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_pointer_to_address (struct gdbarch *gdbarch,
|
|
gdbarch_pointer_to_address_ftype pointer_to_address)
|
|
{
|
|
gdbarch->pointer_to_address = pointer_to_address;
|
|
}
|
|
|
|
void
|
|
gdbarch_address_to_pointer (struct gdbarch *gdbarch, struct type *type, gdb_byte *buf, CORE_ADDR addr)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->address_to_pointer != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_address_to_pointer called\n");
|
|
gdbarch->address_to_pointer (gdbarch, type, buf, addr);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_address_to_pointer (struct gdbarch *gdbarch,
|
|
gdbarch_address_to_pointer_ftype address_to_pointer)
|
|
{
|
|
gdbarch->address_to_pointer = address_to_pointer;
|
|
}
|
|
|
|
int
|
|
gdbarch_integer_to_address_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->integer_to_address != NULL;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_integer_to_address (struct gdbarch *gdbarch, struct type *type, const gdb_byte *buf)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->integer_to_address != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_integer_to_address called\n");
|
|
return gdbarch->integer_to_address (gdbarch, type, buf);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_integer_to_address (struct gdbarch *gdbarch,
|
|
gdbarch_integer_to_address_ftype integer_to_address)
|
|
{
|
|
gdbarch->integer_to_address = integer_to_address;
|
|
}
|
|
|
|
int
|
|
gdbarch_return_value_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->return_value != NULL;
|
|
}
|
|
|
|
enum return_value_convention
|
|
gdbarch_return_value (struct gdbarch *gdbarch, struct type *functype, struct type *valtype, struct regcache *regcache, gdb_byte *readbuf, const gdb_byte *writebuf)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->return_value != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_return_value called\n");
|
|
return gdbarch->return_value (gdbarch, functype, valtype, regcache, readbuf, writebuf);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_return_value (struct gdbarch *gdbarch,
|
|
gdbarch_return_value_ftype return_value)
|
|
{
|
|
gdbarch->return_value = return_value;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_skip_prologue (struct gdbarch *gdbarch, CORE_ADDR ip)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->skip_prologue != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_skip_prologue called\n");
|
|
return gdbarch->skip_prologue (gdbarch, ip);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_skip_prologue (struct gdbarch *gdbarch,
|
|
gdbarch_skip_prologue_ftype skip_prologue)
|
|
{
|
|
gdbarch->skip_prologue = skip_prologue;
|
|
}
|
|
|
|
int
|
|
gdbarch_skip_main_prologue_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->skip_main_prologue != NULL;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_skip_main_prologue (struct gdbarch *gdbarch, CORE_ADDR ip)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->skip_main_prologue != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_skip_main_prologue called\n");
|
|
return gdbarch->skip_main_prologue (gdbarch, ip);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_skip_main_prologue (struct gdbarch *gdbarch,
|
|
gdbarch_skip_main_prologue_ftype skip_main_prologue)
|
|
{
|
|
gdbarch->skip_main_prologue = skip_main_prologue;
|
|
}
|
|
|
|
int
|
|
gdbarch_inner_than (struct gdbarch *gdbarch, CORE_ADDR lhs, CORE_ADDR rhs)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->inner_than != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_inner_than called\n");
|
|
return gdbarch->inner_than (lhs, rhs);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_inner_than (struct gdbarch *gdbarch,
|
|
gdbarch_inner_than_ftype inner_than)
|
|
{
|
|
gdbarch->inner_than = inner_than;
|
|
}
|
|
|
|
const gdb_byte *
|
|
gdbarch_breakpoint_from_pc (struct gdbarch *gdbarch, CORE_ADDR *pcptr, int *lenptr)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->breakpoint_from_pc != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_breakpoint_from_pc called\n");
|
|
return gdbarch->breakpoint_from_pc (gdbarch, pcptr, lenptr);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_breakpoint_from_pc (struct gdbarch *gdbarch,
|
|
gdbarch_breakpoint_from_pc_ftype breakpoint_from_pc)
|
|
{
|
|
gdbarch->breakpoint_from_pc = breakpoint_from_pc;
|
|
}
|
|
|
|
int
|
|
gdbarch_adjust_breakpoint_address_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->adjust_breakpoint_address != NULL;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_adjust_breakpoint_address (struct gdbarch *gdbarch, CORE_ADDR bpaddr)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->adjust_breakpoint_address != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_adjust_breakpoint_address called\n");
|
|
return gdbarch->adjust_breakpoint_address (gdbarch, bpaddr);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_adjust_breakpoint_address (struct gdbarch *gdbarch,
|
|
gdbarch_adjust_breakpoint_address_ftype adjust_breakpoint_address)
|
|
{
|
|
gdbarch->adjust_breakpoint_address = adjust_breakpoint_address;
|
|
}
|
|
|
|
int
|
|
gdbarch_memory_insert_breakpoint (struct gdbarch *gdbarch, struct bp_target_info *bp_tgt)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->memory_insert_breakpoint != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_memory_insert_breakpoint called\n");
|
|
return gdbarch->memory_insert_breakpoint (gdbarch, bp_tgt);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_memory_insert_breakpoint (struct gdbarch *gdbarch,
|
|
gdbarch_memory_insert_breakpoint_ftype memory_insert_breakpoint)
|
|
{
|
|
gdbarch->memory_insert_breakpoint = memory_insert_breakpoint;
|
|
}
|
|
|
|
int
|
|
gdbarch_memory_remove_breakpoint (struct gdbarch *gdbarch, struct bp_target_info *bp_tgt)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->memory_remove_breakpoint != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_memory_remove_breakpoint called\n");
|
|
return gdbarch->memory_remove_breakpoint (gdbarch, bp_tgt);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_memory_remove_breakpoint (struct gdbarch *gdbarch,
|
|
gdbarch_memory_remove_breakpoint_ftype memory_remove_breakpoint)
|
|
{
|
|
gdbarch->memory_remove_breakpoint = memory_remove_breakpoint;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_decr_pc_after_break (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of decr_pc_after_break, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_decr_pc_after_break called\n");
|
|
return gdbarch->decr_pc_after_break;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_decr_pc_after_break (struct gdbarch *gdbarch,
|
|
CORE_ADDR decr_pc_after_break)
|
|
{
|
|
gdbarch->decr_pc_after_break = decr_pc_after_break;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_deprecated_function_start_offset (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of deprecated_function_start_offset, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_deprecated_function_start_offset called\n");
|
|
return gdbarch->deprecated_function_start_offset;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_deprecated_function_start_offset (struct gdbarch *gdbarch,
|
|
CORE_ADDR deprecated_function_start_offset)
|
|
{
|
|
gdbarch->deprecated_function_start_offset = deprecated_function_start_offset;
|
|
}
|
|
|
|
int
|
|
gdbarch_remote_register_number (struct gdbarch *gdbarch, int regno)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->remote_register_number != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_remote_register_number called\n");
|
|
return gdbarch->remote_register_number (gdbarch, regno);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_remote_register_number (struct gdbarch *gdbarch,
|
|
gdbarch_remote_register_number_ftype remote_register_number)
|
|
{
|
|
gdbarch->remote_register_number = remote_register_number;
|
|
}
|
|
|
|
int
|
|
gdbarch_fetch_tls_load_module_address_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->fetch_tls_load_module_address != NULL;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_fetch_tls_load_module_address (struct gdbarch *gdbarch, struct objfile *objfile)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->fetch_tls_load_module_address != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_fetch_tls_load_module_address called\n");
|
|
return gdbarch->fetch_tls_load_module_address (objfile);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_fetch_tls_load_module_address (struct gdbarch *gdbarch,
|
|
gdbarch_fetch_tls_load_module_address_ftype fetch_tls_load_module_address)
|
|
{
|
|
gdbarch->fetch_tls_load_module_address = fetch_tls_load_module_address;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_frame_args_skip (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of frame_args_skip, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_frame_args_skip called\n");
|
|
return gdbarch->frame_args_skip;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_frame_args_skip (struct gdbarch *gdbarch,
|
|
CORE_ADDR frame_args_skip)
|
|
{
|
|
gdbarch->frame_args_skip = frame_args_skip;
|
|
}
|
|
|
|
int
|
|
gdbarch_unwind_pc_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->unwind_pc != NULL;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_unwind_pc (struct gdbarch *gdbarch, struct frame_info *next_frame)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->unwind_pc != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_unwind_pc called\n");
|
|
return gdbarch->unwind_pc (gdbarch, next_frame);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_unwind_pc (struct gdbarch *gdbarch,
|
|
gdbarch_unwind_pc_ftype unwind_pc)
|
|
{
|
|
gdbarch->unwind_pc = unwind_pc;
|
|
}
|
|
|
|
int
|
|
gdbarch_unwind_sp_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->unwind_sp != NULL;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_unwind_sp (struct gdbarch *gdbarch, struct frame_info *next_frame)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->unwind_sp != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_unwind_sp called\n");
|
|
return gdbarch->unwind_sp (gdbarch, next_frame);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_unwind_sp (struct gdbarch *gdbarch,
|
|
gdbarch_unwind_sp_ftype unwind_sp)
|
|
{
|
|
gdbarch->unwind_sp = unwind_sp;
|
|
}
|
|
|
|
int
|
|
gdbarch_frame_num_args_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->frame_num_args != NULL;
|
|
}
|
|
|
|
int
|
|
gdbarch_frame_num_args (struct gdbarch *gdbarch, struct frame_info *frame)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->frame_num_args != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_frame_num_args called\n");
|
|
return gdbarch->frame_num_args (frame);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_frame_num_args (struct gdbarch *gdbarch,
|
|
gdbarch_frame_num_args_ftype frame_num_args)
|
|
{
|
|
gdbarch->frame_num_args = frame_num_args;
|
|
}
|
|
|
|
int
|
|
gdbarch_frame_align_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->frame_align != NULL;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_frame_align (struct gdbarch *gdbarch, CORE_ADDR address)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->frame_align != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_frame_align called\n");
|
|
return gdbarch->frame_align (gdbarch, address);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_frame_align (struct gdbarch *gdbarch,
|
|
gdbarch_frame_align_ftype frame_align)
|
|
{
|
|
gdbarch->frame_align = frame_align;
|
|
}
|
|
|
|
int
|
|
gdbarch_stabs_argument_has_addr (struct gdbarch *gdbarch, struct type *type)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->stabs_argument_has_addr != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_stabs_argument_has_addr called\n");
|
|
return gdbarch->stabs_argument_has_addr (gdbarch, type);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_stabs_argument_has_addr (struct gdbarch *gdbarch,
|
|
gdbarch_stabs_argument_has_addr_ftype stabs_argument_has_addr)
|
|
{
|
|
gdbarch->stabs_argument_has_addr = stabs_argument_has_addr;
|
|
}
|
|
|
|
int
|
|
gdbarch_frame_red_zone_size (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_frame_red_zone_size called\n");
|
|
return gdbarch->frame_red_zone_size;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_frame_red_zone_size (struct gdbarch *gdbarch,
|
|
int frame_red_zone_size)
|
|
{
|
|
gdbarch->frame_red_zone_size = frame_red_zone_size;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_convert_from_func_ptr_addr (struct gdbarch *gdbarch, CORE_ADDR addr, struct target_ops *targ)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->convert_from_func_ptr_addr != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_convert_from_func_ptr_addr called\n");
|
|
return gdbarch->convert_from_func_ptr_addr (gdbarch, addr, targ);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_convert_from_func_ptr_addr (struct gdbarch *gdbarch,
|
|
gdbarch_convert_from_func_ptr_addr_ftype convert_from_func_ptr_addr)
|
|
{
|
|
gdbarch->convert_from_func_ptr_addr = convert_from_func_ptr_addr;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_addr_bits_remove (struct gdbarch *gdbarch, CORE_ADDR addr)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->addr_bits_remove != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_addr_bits_remove called\n");
|
|
return gdbarch->addr_bits_remove (gdbarch, addr);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_addr_bits_remove (struct gdbarch *gdbarch,
|
|
gdbarch_addr_bits_remove_ftype addr_bits_remove)
|
|
{
|
|
gdbarch->addr_bits_remove = addr_bits_remove;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_smash_text_address (struct gdbarch *gdbarch, CORE_ADDR addr)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->smash_text_address != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_smash_text_address called\n");
|
|
return gdbarch->smash_text_address (gdbarch, addr);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_smash_text_address (struct gdbarch *gdbarch,
|
|
gdbarch_smash_text_address_ftype smash_text_address)
|
|
{
|
|
gdbarch->smash_text_address = smash_text_address;
|
|
}
|
|
|
|
int
|
|
gdbarch_software_single_step_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->software_single_step != NULL;
|
|
}
|
|
|
|
int
|
|
gdbarch_software_single_step (struct gdbarch *gdbarch, struct frame_info *frame)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->software_single_step != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_software_single_step called\n");
|
|
return gdbarch->software_single_step (frame);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_software_single_step (struct gdbarch *gdbarch,
|
|
gdbarch_software_single_step_ftype software_single_step)
|
|
{
|
|
gdbarch->software_single_step = software_single_step;
|
|
}
|
|
|
|
int
|
|
gdbarch_single_step_through_delay_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->single_step_through_delay != NULL;
|
|
}
|
|
|
|
int
|
|
gdbarch_single_step_through_delay (struct gdbarch *gdbarch, struct frame_info *frame)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->single_step_through_delay != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_single_step_through_delay called\n");
|
|
return gdbarch->single_step_through_delay (gdbarch, frame);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_single_step_through_delay (struct gdbarch *gdbarch,
|
|
gdbarch_single_step_through_delay_ftype single_step_through_delay)
|
|
{
|
|
gdbarch->single_step_through_delay = single_step_through_delay;
|
|
}
|
|
|
|
int
|
|
gdbarch_print_insn (struct gdbarch *gdbarch, bfd_vma vma, struct disassemble_info *info)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->print_insn != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_print_insn called\n");
|
|
return gdbarch->print_insn (vma, info);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_print_insn (struct gdbarch *gdbarch,
|
|
gdbarch_print_insn_ftype print_insn)
|
|
{
|
|
gdbarch->print_insn = print_insn;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_skip_trampoline_code (struct gdbarch *gdbarch, struct frame_info *frame, CORE_ADDR pc)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->skip_trampoline_code != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_skip_trampoline_code called\n");
|
|
return gdbarch->skip_trampoline_code (frame, pc);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_skip_trampoline_code (struct gdbarch *gdbarch,
|
|
gdbarch_skip_trampoline_code_ftype skip_trampoline_code)
|
|
{
|
|
gdbarch->skip_trampoline_code = skip_trampoline_code;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_skip_solib_resolver (struct gdbarch *gdbarch, CORE_ADDR pc)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->skip_solib_resolver != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_skip_solib_resolver called\n");
|
|
return gdbarch->skip_solib_resolver (gdbarch, pc);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_skip_solib_resolver (struct gdbarch *gdbarch,
|
|
gdbarch_skip_solib_resolver_ftype skip_solib_resolver)
|
|
{
|
|
gdbarch->skip_solib_resolver = skip_solib_resolver;
|
|
}
|
|
|
|
int
|
|
gdbarch_in_solib_return_trampoline (struct gdbarch *gdbarch, CORE_ADDR pc, char *name)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->in_solib_return_trampoline != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_in_solib_return_trampoline called\n");
|
|
return gdbarch->in_solib_return_trampoline (gdbarch, pc, name);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_in_solib_return_trampoline (struct gdbarch *gdbarch,
|
|
gdbarch_in_solib_return_trampoline_ftype in_solib_return_trampoline)
|
|
{
|
|
gdbarch->in_solib_return_trampoline = in_solib_return_trampoline;
|
|
}
|
|
|
|
int
|
|
gdbarch_in_function_epilogue_p (struct gdbarch *gdbarch, CORE_ADDR addr)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->in_function_epilogue_p != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_in_function_epilogue_p called\n");
|
|
return gdbarch->in_function_epilogue_p (gdbarch, addr);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_in_function_epilogue_p (struct gdbarch *gdbarch,
|
|
gdbarch_in_function_epilogue_p_ftype in_function_epilogue_p)
|
|
{
|
|
gdbarch->in_function_epilogue_p = in_function_epilogue_p;
|
|
}
|
|
|
|
void
|
|
gdbarch_elf_make_msymbol_special (struct gdbarch *gdbarch, asymbol *sym, struct minimal_symbol *msym)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->elf_make_msymbol_special != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_elf_make_msymbol_special called\n");
|
|
gdbarch->elf_make_msymbol_special (sym, msym);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_elf_make_msymbol_special (struct gdbarch *gdbarch,
|
|
gdbarch_elf_make_msymbol_special_ftype elf_make_msymbol_special)
|
|
{
|
|
gdbarch->elf_make_msymbol_special = elf_make_msymbol_special;
|
|
}
|
|
|
|
void
|
|
gdbarch_coff_make_msymbol_special (struct gdbarch *gdbarch, int val, struct minimal_symbol *msym)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->coff_make_msymbol_special != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_coff_make_msymbol_special called\n");
|
|
gdbarch->coff_make_msymbol_special (val, msym);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_coff_make_msymbol_special (struct gdbarch *gdbarch,
|
|
gdbarch_coff_make_msymbol_special_ftype coff_make_msymbol_special)
|
|
{
|
|
gdbarch->coff_make_msymbol_special = coff_make_msymbol_special;
|
|
}
|
|
|
|
int
|
|
gdbarch_cannot_step_breakpoint (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of cannot_step_breakpoint, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_cannot_step_breakpoint called\n");
|
|
return gdbarch->cannot_step_breakpoint;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_cannot_step_breakpoint (struct gdbarch *gdbarch,
|
|
int cannot_step_breakpoint)
|
|
{
|
|
gdbarch->cannot_step_breakpoint = cannot_step_breakpoint;
|
|
}
|
|
|
|
int
|
|
gdbarch_have_nonsteppable_watchpoint (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of have_nonsteppable_watchpoint, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_have_nonsteppable_watchpoint called\n");
|
|
return gdbarch->have_nonsteppable_watchpoint;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_have_nonsteppable_watchpoint (struct gdbarch *gdbarch,
|
|
int have_nonsteppable_watchpoint)
|
|
{
|
|
gdbarch->have_nonsteppable_watchpoint = have_nonsteppable_watchpoint;
|
|
}
|
|
|
|
int
|
|
gdbarch_address_class_type_flags_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->address_class_type_flags != NULL;
|
|
}
|
|
|
|
int
|
|
gdbarch_address_class_type_flags (struct gdbarch *gdbarch, int byte_size, int dwarf2_addr_class)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->address_class_type_flags != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_address_class_type_flags called\n");
|
|
return gdbarch->address_class_type_flags (byte_size, dwarf2_addr_class);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_address_class_type_flags (struct gdbarch *gdbarch,
|
|
gdbarch_address_class_type_flags_ftype address_class_type_flags)
|
|
{
|
|
gdbarch->address_class_type_flags = address_class_type_flags;
|
|
}
|
|
|
|
int
|
|
gdbarch_address_class_type_flags_to_name_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->address_class_type_flags_to_name != NULL;
|
|
}
|
|
|
|
const char *
|
|
gdbarch_address_class_type_flags_to_name (struct gdbarch *gdbarch, int type_flags)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->address_class_type_flags_to_name != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_address_class_type_flags_to_name called\n");
|
|
return gdbarch->address_class_type_flags_to_name (gdbarch, type_flags);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_address_class_type_flags_to_name (struct gdbarch *gdbarch,
|
|
gdbarch_address_class_type_flags_to_name_ftype address_class_type_flags_to_name)
|
|
{
|
|
gdbarch->address_class_type_flags_to_name = address_class_type_flags_to_name;
|
|
}
|
|
|
|
int
|
|
gdbarch_address_class_name_to_type_flags_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->address_class_name_to_type_flags != NULL;
|
|
}
|
|
|
|
int
|
|
gdbarch_address_class_name_to_type_flags (struct gdbarch *gdbarch, const char *name, int *type_flags_ptr)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->address_class_name_to_type_flags != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_address_class_name_to_type_flags called\n");
|
|
return gdbarch->address_class_name_to_type_flags (gdbarch, name, type_flags_ptr);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_address_class_name_to_type_flags (struct gdbarch *gdbarch,
|
|
gdbarch_address_class_name_to_type_flags_ftype address_class_name_to_type_flags)
|
|
{
|
|
gdbarch->address_class_name_to_type_flags = address_class_name_to_type_flags;
|
|
}
|
|
|
|
int
|
|
gdbarch_register_reggroup_p (struct gdbarch *gdbarch, int regnum, struct reggroup *reggroup)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->register_reggroup_p != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_register_reggroup_p called\n");
|
|
return gdbarch->register_reggroup_p (gdbarch, regnum, reggroup);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_register_reggroup_p (struct gdbarch *gdbarch,
|
|
gdbarch_register_reggroup_p_ftype register_reggroup_p)
|
|
{
|
|
gdbarch->register_reggroup_p = register_reggroup_p;
|
|
}
|
|
|
|
int
|
|
gdbarch_fetch_pointer_argument_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->fetch_pointer_argument != NULL;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_fetch_pointer_argument (struct gdbarch *gdbarch, struct frame_info *frame, int argi, struct type *type)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->fetch_pointer_argument != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_fetch_pointer_argument called\n");
|
|
return gdbarch->fetch_pointer_argument (frame, argi, type);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_fetch_pointer_argument (struct gdbarch *gdbarch,
|
|
gdbarch_fetch_pointer_argument_ftype fetch_pointer_argument)
|
|
{
|
|
gdbarch->fetch_pointer_argument = fetch_pointer_argument;
|
|
}
|
|
|
|
int
|
|
gdbarch_regset_from_core_section_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->regset_from_core_section != NULL;
|
|
}
|
|
|
|
const struct regset *
|
|
gdbarch_regset_from_core_section (struct gdbarch *gdbarch, const char *sect_name, size_t sect_size)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->regset_from_core_section != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_regset_from_core_section called\n");
|
|
return gdbarch->regset_from_core_section (gdbarch, sect_name, sect_size);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_regset_from_core_section (struct gdbarch *gdbarch,
|
|
gdbarch_regset_from_core_section_ftype regset_from_core_section)
|
|
{
|
|
gdbarch->regset_from_core_section = regset_from_core_section;
|
|
}
|
|
|
|
int
|
|
gdbarch_core_reg_section_encodes_pid (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of core_reg_section_encodes_pid, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_core_reg_section_encodes_pid called\n");
|
|
return gdbarch->core_reg_section_encodes_pid;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_core_reg_section_encodes_pid (struct gdbarch *gdbarch,
|
|
int core_reg_section_encodes_pid)
|
|
{
|
|
gdbarch->core_reg_section_encodes_pid = core_reg_section_encodes_pid;
|
|
}
|
|
|
|
struct core_regset_section *
|
|
gdbarch_core_regset_sections (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_core_regset_sections called\n");
|
|
return gdbarch->core_regset_sections;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_core_regset_sections (struct gdbarch *gdbarch,
|
|
struct core_regset_section * core_regset_sections)
|
|
{
|
|
gdbarch->core_regset_sections = core_regset_sections;
|
|
}
|
|
|
|
int
|
|
gdbarch_core_xfer_shared_libraries_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->core_xfer_shared_libraries != NULL;
|
|
}
|
|
|
|
LONGEST
|
|
gdbarch_core_xfer_shared_libraries (struct gdbarch *gdbarch, gdb_byte *readbuf, ULONGEST offset, LONGEST len)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->core_xfer_shared_libraries != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_core_xfer_shared_libraries called\n");
|
|
return gdbarch->core_xfer_shared_libraries (gdbarch, readbuf, offset, len);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_core_xfer_shared_libraries (struct gdbarch *gdbarch,
|
|
gdbarch_core_xfer_shared_libraries_ftype core_xfer_shared_libraries)
|
|
{
|
|
gdbarch->core_xfer_shared_libraries = core_xfer_shared_libraries;
|
|
}
|
|
|
|
int
|
|
gdbarch_core_pid_to_str_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->core_pid_to_str != NULL;
|
|
}
|
|
|
|
char *
|
|
gdbarch_core_pid_to_str (struct gdbarch *gdbarch, ptid_t ptid)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->core_pid_to_str != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_core_pid_to_str called\n");
|
|
return gdbarch->core_pid_to_str (gdbarch, ptid);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_core_pid_to_str (struct gdbarch *gdbarch,
|
|
gdbarch_core_pid_to_str_ftype core_pid_to_str)
|
|
{
|
|
gdbarch->core_pid_to_str = core_pid_to_str;
|
|
}
|
|
|
|
int
|
|
gdbarch_gcore_bfd_target_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->gcore_bfd_target != 0;
|
|
}
|
|
|
|
const char *
|
|
gdbarch_gcore_bfd_target (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Check variable changed from pre-default. */
|
|
gdb_assert (gdbarch->gcore_bfd_target != 0);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_gcore_bfd_target called\n");
|
|
return gdbarch->gcore_bfd_target;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_gcore_bfd_target (struct gdbarch *gdbarch,
|
|
const char * gcore_bfd_target)
|
|
{
|
|
gdbarch->gcore_bfd_target = gcore_bfd_target;
|
|
}
|
|
|
|
int
|
|
gdbarch_vtable_function_descriptors (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of vtable_function_descriptors, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_vtable_function_descriptors called\n");
|
|
return gdbarch->vtable_function_descriptors;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_vtable_function_descriptors (struct gdbarch *gdbarch,
|
|
int vtable_function_descriptors)
|
|
{
|
|
gdbarch->vtable_function_descriptors = vtable_function_descriptors;
|
|
}
|
|
|
|
int
|
|
gdbarch_vbit_in_delta (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of vbit_in_delta, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_vbit_in_delta called\n");
|
|
return gdbarch->vbit_in_delta;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_vbit_in_delta (struct gdbarch *gdbarch,
|
|
int vbit_in_delta)
|
|
{
|
|
gdbarch->vbit_in_delta = vbit_in_delta;
|
|
}
|
|
|
|
int
|
|
gdbarch_skip_permanent_breakpoint_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->skip_permanent_breakpoint != NULL;
|
|
}
|
|
|
|
void
|
|
gdbarch_skip_permanent_breakpoint (struct gdbarch *gdbarch, struct regcache *regcache)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->skip_permanent_breakpoint != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_skip_permanent_breakpoint called\n");
|
|
gdbarch->skip_permanent_breakpoint (regcache);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_skip_permanent_breakpoint (struct gdbarch *gdbarch,
|
|
gdbarch_skip_permanent_breakpoint_ftype skip_permanent_breakpoint)
|
|
{
|
|
gdbarch->skip_permanent_breakpoint = skip_permanent_breakpoint;
|
|
}
|
|
|
|
int
|
|
gdbarch_max_insn_length_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->max_insn_length != 0;
|
|
}
|
|
|
|
ULONGEST
|
|
gdbarch_max_insn_length (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Check variable changed from pre-default. */
|
|
gdb_assert (gdbarch->max_insn_length != 0);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_max_insn_length called\n");
|
|
return gdbarch->max_insn_length;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_max_insn_length (struct gdbarch *gdbarch,
|
|
ULONGEST max_insn_length)
|
|
{
|
|
gdbarch->max_insn_length = max_insn_length;
|
|
}
|
|
|
|
int
|
|
gdbarch_displaced_step_copy_insn_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->displaced_step_copy_insn != NULL;
|
|
}
|
|
|
|
struct displaced_step_closure *
|
|
gdbarch_displaced_step_copy_insn (struct gdbarch *gdbarch, CORE_ADDR from, CORE_ADDR to, struct regcache *regs)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->displaced_step_copy_insn != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_displaced_step_copy_insn called\n");
|
|
return gdbarch->displaced_step_copy_insn (gdbarch, from, to, regs);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_displaced_step_copy_insn (struct gdbarch *gdbarch,
|
|
gdbarch_displaced_step_copy_insn_ftype displaced_step_copy_insn)
|
|
{
|
|
gdbarch->displaced_step_copy_insn = displaced_step_copy_insn;
|
|
}
|
|
|
|
int
|
|
gdbarch_displaced_step_hw_singlestep (struct gdbarch *gdbarch, struct displaced_step_closure *closure)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->displaced_step_hw_singlestep != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_displaced_step_hw_singlestep called\n");
|
|
return gdbarch->displaced_step_hw_singlestep (gdbarch, closure);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_displaced_step_hw_singlestep (struct gdbarch *gdbarch,
|
|
gdbarch_displaced_step_hw_singlestep_ftype displaced_step_hw_singlestep)
|
|
{
|
|
gdbarch->displaced_step_hw_singlestep = displaced_step_hw_singlestep;
|
|
}
|
|
|
|
int
|
|
gdbarch_displaced_step_fixup_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->displaced_step_fixup != NULL;
|
|
}
|
|
|
|
void
|
|
gdbarch_displaced_step_fixup (struct gdbarch *gdbarch, struct displaced_step_closure *closure, CORE_ADDR from, CORE_ADDR to, struct regcache *regs)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->displaced_step_fixup != NULL);
|
|
/* Do not check predicate: gdbarch->displaced_step_fixup != NULL, allow call. */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_displaced_step_fixup called\n");
|
|
gdbarch->displaced_step_fixup (gdbarch, closure, from, to, regs);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_displaced_step_fixup (struct gdbarch *gdbarch,
|
|
gdbarch_displaced_step_fixup_ftype displaced_step_fixup)
|
|
{
|
|
gdbarch->displaced_step_fixup = displaced_step_fixup;
|
|
}
|
|
|
|
void
|
|
gdbarch_displaced_step_free_closure (struct gdbarch *gdbarch, struct displaced_step_closure *closure)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->displaced_step_free_closure != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_displaced_step_free_closure called\n");
|
|
gdbarch->displaced_step_free_closure (gdbarch, closure);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_displaced_step_free_closure (struct gdbarch *gdbarch,
|
|
gdbarch_displaced_step_free_closure_ftype displaced_step_free_closure)
|
|
{
|
|
gdbarch->displaced_step_free_closure = displaced_step_free_closure;
|
|
}
|
|
|
|
CORE_ADDR
|
|
gdbarch_displaced_step_location (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->displaced_step_location != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_displaced_step_location called\n");
|
|
return gdbarch->displaced_step_location (gdbarch);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_displaced_step_location (struct gdbarch *gdbarch,
|
|
gdbarch_displaced_step_location_ftype displaced_step_location)
|
|
{
|
|
gdbarch->displaced_step_location = displaced_step_location;
|
|
}
|
|
|
|
int
|
|
gdbarch_overlay_update_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->overlay_update != NULL;
|
|
}
|
|
|
|
void
|
|
gdbarch_overlay_update (struct gdbarch *gdbarch, struct obj_section *osect)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->overlay_update != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_overlay_update called\n");
|
|
gdbarch->overlay_update (osect);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_overlay_update (struct gdbarch *gdbarch,
|
|
gdbarch_overlay_update_ftype overlay_update)
|
|
{
|
|
gdbarch->overlay_update = overlay_update;
|
|
}
|
|
|
|
int
|
|
gdbarch_core_read_description_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->core_read_description != NULL;
|
|
}
|
|
|
|
const struct target_desc *
|
|
gdbarch_core_read_description (struct gdbarch *gdbarch, struct target_ops *target, bfd *abfd)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->core_read_description != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_core_read_description called\n");
|
|
return gdbarch->core_read_description (gdbarch, target, abfd);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_core_read_description (struct gdbarch *gdbarch,
|
|
gdbarch_core_read_description_ftype core_read_description)
|
|
{
|
|
gdbarch->core_read_description = core_read_description;
|
|
}
|
|
|
|
int
|
|
gdbarch_static_transform_name_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->static_transform_name != NULL;
|
|
}
|
|
|
|
char *
|
|
gdbarch_static_transform_name (struct gdbarch *gdbarch, char *name)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->static_transform_name != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_static_transform_name called\n");
|
|
return gdbarch->static_transform_name (name);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_static_transform_name (struct gdbarch *gdbarch,
|
|
gdbarch_static_transform_name_ftype static_transform_name)
|
|
{
|
|
gdbarch->static_transform_name = static_transform_name;
|
|
}
|
|
|
|
int
|
|
gdbarch_sofun_address_maybe_missing (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of sofun_address_maybe_missing, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_sofun_address_maybe_missing called\n");
|
|
return gdbarch->sofun_address_maybe_missing;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_sofun_address_maybe_missing (struct gdbarch *gdbarch,
|
|
int sofun_address_maybe_missing)
|
|
{
|
|
gdbarch->sofun_address_maybe_missing = sofun_address_maybe_missing;
|
|
}
|
|
|
|
int
|
|
gdbarch_process_record_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->process_record != NULL;
|
|
}
|
|
|
|
int
|
|
gdbarch_process_record (struct gdbarch *gdbarch, struct regcache *regcache, CORE_ADDR addr)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->process_record != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_process_record called\n");
|
|
return gdbarch->process_record (gdbarch, regcache, addr);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_process_record (struct gdbarch *gdbarch,
|
|
gdbarch_process_record_ftype process_record)
|
|
{
|
|
gdbarch->process_record = process_record;
|
|
}
|
|
|
|
int
|
|
gdbarch_process_record_signal_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->process_record_signal != NULL;
|
|
}
|
|
|
|
int
|
|
gdbarch_process_record_signal (struct gdbarch *gdbarch, struct regcache *regcache, enum target_signal signal)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->process_record_signal != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_process_record_signal called\n");
|
|
return gdbarch->process_record_signal (gdbarch, regcache, signal);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_process_record_signal (struct gdbarch *gdbarch,
|
|
gdbarch_process_record_signal_ftype process_record_signal)
|
|
{
|
|
gdbarch->process_record_signal = process_record_signal;
|
|
}
|
|
|
|
enum target_signal
|
|
gdbarch_target_signal_from_host (struct gdbarch *gdbarch, int signo)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->target_signal_from_host != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_target_signal_from_host called\n");
|
|
return gdbarch->target_signal_from_host (gdbarch, signo);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_target_signal_from_host (struct gdbarch *gdbarch,
|
|
gdbarch_target_signal_from_host_ftype target_signal_from_host)
|
|
{
|
|
gdbarch->target_signal_from_host = target_signal_from_host;
|
|
}
|
|
|
|
int
|
|
gdbarch_target_signal_to_host (struct gdbarch *gdbarch, enum target_signal ts)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->target_signal_to_host != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_target_signal_to_host called\n");
|
|
return gdbarch->target_signal_to_host (gdbarch, ts);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_target_signal_to_host (struct gdbarch *gdbarch,
|
|
gdbarch_target_signal_to_host_ftype target_signal_to_host)
|
|
{
|
|
gdbarch->target_signal_to_host = target_signal_to_host;
|
|
}
|
|
|
|
int
|
|
gdbarch_get_siginfo_type_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->get_siginfo_type != NULL;
|
|
}
|
|
|
|
struct type *
|
|
gdbarch_get_siginfo_type (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->get_siginfo_type != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_get_siginfo_type called\n");
|
|
return gdbarch->get_siginfo_type (gdbarch);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_get_siginfo_type (struct gdbarch *gdbarch,
|
|
gdbarch_get_siginfo_type_ftype get_siginfo_type)
|
|
{
|
|
gdbarch->get_siginfo_type = get_siginfo_type;
|
|
}
|
|
|
|
int
|
|
gdbarch_record_special_symbol_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->record_special_symbol != NULL;
|
|
}
|
|
|
|
void
|
|
gdbarch_record_special_symbol (struct gdbarch *gdbarch, struct objfile *objfile, asymbol *sym)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->record_special_symbol != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_record_special_symbol called\n");
|
|
gdbarch->record_special_symbol (gdbarch, objfile, sym);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_record_special_symbol (struct gdbarch *gdbarch,
|
|
gdbarch_record_special_symbol_ftype record_special_symbol)
|
|
{
|
|
gdbarch->record_special_symbol = record_special_symbol;
|
|
}
|
|
|
|
int
|
|
gdbarch_get_syscall_number_p (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
return gdbarch->get_syscall_number != NULL;
|
|
}
|
|
|
|
LONGEST
|
|
gdbarch_get_syscall_number (struct gdbarch *gdbarch, ptid_t ptid)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->get_syscall_number != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_get_syscall_number called\n");
|
|
return gdbarch->get_syscall_number (gdbarch, ptid);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_get_syscall_number (struct gdbarch *gdbarch,
|
|
gdbarch_get_syscall_number_ftype get_syscall_number)
|
|
{
|
|
gdbarch->get_syscall_number = get_syscall_number;
|
|
}
|
|
|
|
int
|
|
gdbarch_has_global_solist (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of has_global_solist, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_has_global_solist called\n");
|
|
return gdbarch->has_global_solist;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_has_global_solist (struct gdbarch *gdbarch,
|
|
int has_global_solist)
|
|
{
|
|
gdbarch->has_global_solist = has_global_solist;
|
|
}
|
|
|
|
int
|
|
gdbarch_has_global_breakpoints (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
/* Skip verify of has_global_breakpoints, invalid_p == 0 */
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_has_global_breakpoints called\n");
|
|
return gdbarch->has_global_breakpoints;
|
|
}
|
|
|
|
void
|
|
set_gdbarch_has_global_breakpoints (struct gdbarch *gdbarch,
|
|
int has_global_breakpoints)
|
|
{
|
|
gdbarch->has_global_breakpoints = has_global_breakpoints;
|
|
}
|
|
|
|
int
|
|
gdbarch_has_shared_address_space (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch != NULL);
|
|
gdb_assert (gdbarch->has_shared_address_space != NULL);
|
|
if (gdbarch_debug >= 2)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_has_shared_address_space called\n");
|
|
return gdbarch->has_shared_address_space (gdbarch);
|
|
}
|
|
|
|
void
|
|
set_gdbarch_has_shared_address_space (struct gdbarch *gdbarch,
|
|
gdbarch_has_shared_address_space_ftype has_shared_address_space)
|
|
{
|
|
gdbarch->has_shared_address_space = has_shared_address_space;
|
|
}
|
|
|
|
|
|
/* Keep a registry of per-architecture data-pointers required by GDB
|
|
modules. */
|
|
|
|
struct gdbarch_data
|
|
{
|
|
unsigned index;
|
|
int init_p;
|
|
gdbarch_data_pre_init_ftype *pre_init;
|
|
gdbarch_data_post_init_ftype *post_init;
|
|
};
|
|
|
|
struct gdbarch_data_registration
|
|
{
|
|
struct gdbarch_data *data;
|
|
struct gdbarch_data_registration *next;
|
|
};
|
|
|
|
struct gdbarch_data_registry
|
|
{
|
|
unsigned nr;
|
|
struct gdbarch_data_registration *registrations;
|
|
};
|
|
|
|
struct gdbarch_data_registry gdbarch_data_registry =
|
|
{
|
|
0, NULL,
|
|
};
|
|
|
|
static struct gdbarch_data *
|
|
gdbarch_data_register (gdbarch_data_pre_init_ftype *pre_init,
|
|
gdbarch_data_post_init_ftype *post_init)
|
|
{
|
|
struct gdbarch_data_registration **curr;
|
|
/* Append the new registraration. */
|
|
for (curr = &gdbarch_data_registry.registrations;
|
|
(*curr) != NULL;
|
|
curr = &(*curr)->next);
|
|
(*curr) = XMALLOC (struct gdbarch_data_registration);
|
|
(*curr)->next = NULL;
|
|
(*curr)->data = XMALLOC (struct gdbarch_data);
|
|
(*curr)->data->index = gdbarch_data_registry.nr++;
|
|
(*curr)->data->pre_init = pre_init;
|
|
(*curr)->data->post_init = post_init;
|
|
(*curr)->data->init_p = 1;
|
|
return (*curr)->data;
|
|
}
|
|
|
|
struct gdbarch_data *
|
|
gdbarch_data_register_pre_init (gdbarch_data_pre_init_ftype *pre_init)
|
|
{
|
|
return gdbarch_data_register (pre_init, NULL);
|
|
}
|
|
|
|
struct gdbarch_data *
|
|
gdbarch_data_register_post_init (gdbarch_data_post_init_ftype *post_init)
|
|
{
|
|
return gdbarch_data_register (NULL, post_init);
|
|
}
|
|
|
|
/* Create/delete the gdbarch data vector. */
|
|
|
|
static void
|
|
alloc_gdbarch_data (struct gdbarch *gdbarch)
|
|
{
|
|
gdb_assert (gdbarch->data == NULL);
|
|
gdbarch->nr_data = gdbarch_data_registry.nr;
|
|
gdbarch->data = GDBARCH_OBSTACK_CALLOC (gdbarch, gdbarch->nr_data, void *);
|
|
}
|
|
|
|
/* Initialize the current value of the specified per-architecture
|
|
data-pointer. */
|
|
|
|
void
|
|
deprecated_set_gdbarch_data (struct gdbarch *gdbarch,
|
|
struct gdbarch_data *data,
|
|
void *pointer)
|
|
{
|
|
gdb_assert (data->index < gdbarch->nr_data);
|
|
gdb_assert (gdbarch->data[data->index] == NULL);
|
|
gdb_assert (data->pre_init == NULL);
|
|
gdbarch->data[data->index] = pointer;
|
|
}
|
|
|
|
/* Return the current value of the specified per-architecture
|
|
data-pointer. */
|
|
|
|
void *
|
|
gdbarch_data (struct gdbarch *gdbarch, struct gdbarch_data *data)
|
|
{
|
|
gdb_assert (data->index < gdbarch->nr_data);
|
|
if (gdbarch->data[data->index] == NULL)
|
|
{
|
|
/* The data-pointer isn't initialized, call init() to get a
|
|
value. */
|
|
if (data->pre_init != NULL)
|
|
/* Mid architecture creation: pass just the obstack, and not
|
|
the entire architecture, as that way it isn't possible for
|
|
pre-init code to refer to undefined architecture
|
|
fields. */
|
|
gdbarch->data[data->index] = data->pre_init (gdbarch->obstack);
|
|
else if (gdbarch->initialized_p
|
|
&& data->post_init != NULL)
|
|
/* Post architecture creation: pass the entire architecture
|
|
(as all fields are valid), but be careful to also detect
|
|
recursive references. */
|
|
{
|
|
gdb_assert (data->init_p);
|
|
data->init_p = 0;
|
|
gdbarch->data[data->index] = data->post_init (gdbarch);
|
|
data->init_p = 1;
|
|
}
|
|
else
|
|
/* The architecture initialization hasn't completed - punt -
|
|
hope that the caller knows what they are doing. Once
|
|
deprecated_set_gdbarch_data has been initialized, this can be
|
|
changed to an internal error. */
|
|
return NULL;
|
|
gdb_assert (gdbarch->data[data->index] != NULL);
|
|
}
|
|
return gdbarch->data[data->index];
|
|
}
|
|
|
|
|
|
/* Keep a registry of the architectures known by GDB. */
|
|
|
|
struct gdbarch_registration
|
|
{
|
|
enum bfd_architecture bfd_architecture;
|
|
gdbarch_init_ftype *init;
|
|
gdbarch_dump_tdep_ftype *dump_tdep;
|
|
struct gdbarch_list *arches;
|
|
struct gdbarch_registration *next;
|
|
};
|
|
|
|
static struct gdbarch_registration *gdbarch_registry = NULL;
|
|
|
|
static void
|
|
append_name (const char ***buf, int *nr, const char *name)
|
|
{
|
|
*buf = xrealloc (*buf, sizeof (char**) * (*nr + 1));
|
|
(*buf)[*nr] = name;
|
|
*nr += 1;
|
|
}
|
|
|
|
const char **
|
|
gdbarch_printable_names (void)
|
|
{
|
|
/* Accumulate a list of names based on the registed list of
|
|
architectures. */
|
|
enum bfd_architecture a;
|
|
int nr_arches = 0;
|
|
const char **arches = NULL;
|
|
struct gdbarch_registration *rego;
|
|
for (rego = gdbarch_registry;
|
|
rego != NULL;
|
|
rego = rego->next)
|
|
{
|
|
const struct bfd_arch_info *ap;
|
|
ap = bfd_lookup_arch (rego->bfd_architecture, 0);
|
|
if (ap == NULL)
|
|
internal_error (__FILE__, __LINE__,
|
|
_("gdbarch_architecture_names: multi-arch unknown"));
|
|
do
|
|
{
|
|
append_name (&arches, &nr_arches, ap->printable_name);
|
|
ap = ap->next;
|
|
}
|
|
while (ap != NULL);
|
|
}
|
|
append_name (&arches, &nr_arches, NULL);
|
|
return arches;
|
|
}
|
|
|
|
|
|
void
|
|
gdbarch_register (enum bfd_architecture bfd_architecture,
|
|
gdbarch_init_ftype *init,
|
|
gdbarch_dump_tdep_ftype *dump_tdep)
|
|
{
|
|
struct gdbarch_registration **curr;
|
|
const struct bfd_arch_info *bfd_arch_info;
|
|
/* Check that BFD recognizes this architecture */
|
|
bfd_arch_info = bfd_lookup_arch (bfd_architecture, 0);
|
|
if (bfd_arch_info == NULL)
|
|
{
|
|
internal_error (__FILE__, __LINE__,
|
|
_("gdbarch: Attempt to register unknown architecture (%d)"),
|
|
bfd_architecture);
|
|
}
|
|
/* Check that we haven't seen this architecture before */
|
|
for (curr = &gdbarch_registry;
|
|
(*curr) != NULL;
|
|
curr = &(*curr)->next)
|
|
{
|
|
if (bfd_architecture == (*curr)->bfd_architecture)
|
|
internal_error (__FILE__, __LINE__,
|
|
_("gdbarch: Duplicate registraration of architecture (%s)"),
|
|
bfd_arch_info->printable_name);
|
|
}
|
|
/* log it */
|
|
if (gdbarch_debug)
|
|
fprintf_unfiltered (gdb_stdlog, "register_gdbarch_init (%s, %s)\n",
|
|
bfd_arch_info->printable_name,
|
|
host_address_to_string (init));
|
|
/* Append it */
|
|
(*curr) = XMALLOC (struct gdbarch_registration);
|
|
(*curr)->bfd_architecture = bfd_architecture;
|
|
(*curr)->init = init;
|
|
(*curr)->dump_tdep = dump_tdep;
|
|
(*curr)->arches = NULL;
|
|
(*curr)->next = NULL;
|
|
}
|
|
|
|
void
|
|
register_gdbarch_init (enum bfd_architecture bfd_architecture,
|
|
gdbarch_init_ftype *init)
|
|
{
|
|
gdbarch_register (bfd_architecture, init, NULL);
|
|
}
|
|
|
|
|
|
/* Look for an architecture using gdbarch_info. */
|
|
|
|
struct gdbarch_list *
|
|
gdbarch_list_lookup_by_info (struct gdbarch_list *arches,
|
|
const struct gdbarch_info *info)
|
|
{
|
|
for (; arches != NULL; arches = arches->next)
|
|
{
|
|
if (info->bfd_arch_info != arches->gdbarch->bfd_arch_info)
|
|
continue;
|
|
if (info->byte_order != arches->gdbarch->byte_order)
|
|
continue;
|
|
if (info->osabi != arches->gdbarch->osabi)
|
|
continue;
|
|
if (info->target_desc != arches->gdbarch->target_desc)
|
|
continue;
|
|
return arches;
|
|
}
|
|
return NULL;
|
|
}
|
|
|
|
|
|
/* Find an architecture that matches the specified INFO. Create a new
|
|
architecture if needed. Return that new architecture. */
|
|
|
|
struct gdbarch *
|
|
gdbarch_find_by_info (struct gdbarch_info info)
|
|
{
|
|
struct gdbarch *new_gdbarch;
|
|
struct gdbarch_registration *rego;
|
|
|
|
/* Fill in missing parts of the INFO struct using a number of
|
|
sources: "set ..."; INFOabfd supplied; and the global
|
|
defaults. */
|
|
gdbarch_info_fill (&info);
|
|
|
|
/* Must have found some sort of architecture. */
|
|
gdb_assert (info.bfd_arch_info != NULL);
|
|
|
|
if (gdbarch_debug)
|
|
{
|
|
fprintf_unfiltered (gdb_stdlog,
|
|
"gdbarch_find_by_info: info.bfd_arch_info %s\n",
|
|
(info.bfd_arch_info != NULL
|
|
? info.bfd_arch_info->printable_name
|
|
: "(null)"));
|
|
fprintf_unfiltered (gdb_stdlog,
|
|
"gdbarch_find_by_info: info.byte_order %d (%s)\n",
|
|
info.byte_order,
|
|
(info.byte_order == BFD_ENDIAN_BIG ? "big"
|
|
: info.byte_order == BFD_ENDIAN_LITTLE ? "little"
|
|
: "default"));
|
|
fprintf_unfiltered (gdb_stdlog,
|
|
"gdbarch_find_by_info: info.osabi %d (%s)\n",
|
|
info.osabi, gdbarch_osabi_name (info.osabi));
|
|
fprintf_unfiltered (gdb_stdlog,
|
|
"gdbarch_find_by_info: info.abfd %s\n",
|
|
host_address_to_string (info.abfd));
|
|
fprintf_unfiltered (gdb_stdlog,
|
|
"gdbarch_find_by_info: info.tdep_info %s\n",
|
|
host_address_to_string (info.tdep_info));
|
|
}
|
|
|
|
/* Find the tdep code that knows about this architecture. */
|
|
for (rego = gdbarch_registry;
|
|
rego != NULL;
|
|
rego = rego->next)
|
|
if (rego->bfd_architecture == info.bfd_arch_info->arch)
|
|
break;
|
|
if (rego == NULL)
|
|
{
|
|
if (gdbarch_debug)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_find_by_info: "
|
|
"No matching architecture\n");
|
|
return 0;
|
|
}
|
|
|
|
/* Ask the tdep code for an architecture that matches "info". */
|
|
new_gdbarch = rego->init (info, rego->arches);
|
|
|
|
/* Did the tdep code like it? No. Reject the change and revert to
|
|
the old architecture. */
|
|
if (new_gdbarch == NULL)
|
|
{
|
|
if (gdbarch_debug)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_find_by_info: "
|
|
"Target rejected architecture\n");
|
|
return NULL;
|
|
}
|
|
|
|
/* Is this a pre-existing architecture (as determined by already
|
|
being initialized)? Move it to the front of the architecture
|
|
list (keeping the list sorted Most Recently Used). */
|
|
if (new_gdbarch->initialized_p)
|
|
{
|
|
struct gdbarch_list **list;
|
|
struct gdbarch_list *this;
|
|
if (gdbarch_debug)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_find_by_info: "
|
|
"Previous architecture %s (%s) selected\n",
|
|
host_address_to_string (new_gdbarch),
|
|
new_gdbarch->bfd_arch_info->printable_name);
|
|
/* Find the existing arch in the list. */
|
|
for (list = ®o->arches;
|
|
(*list) != NULL && (*list)->gdbarch != new_gdbarch;
|
|
list = &(*list)->next);
|
|
/* It had better be in the list of architectures. */
|
|
gdb_assert ((*list) != NULL && (*list)->gdbarch == new_gdbarch);
|
|
/* Unlink THIS. */
|
|
this = (*list);
|
|
(*list) = this->next;
|
|
/* Insert THIS at the front. */
|
|
this->next = rego->arches;
|
|
rego->arches = this;
|
|
/* Return it. */
|
|
return new_gdbarch;
|
|
}
|
|
|
|
/* It's a new architecture. */
|
|
if (gdbarch_debug)
|
|
fprintf_unfiltered (gdb_stdlog, "gdbarch_find_by_info: "
|
|
"New architecture %s (%s) selected\n",
|
|
host_address_to_string (new_gdbarch),
|
|
new_gdbarch->bfd_arch_info->printable_name);
|
|
|
|
/* Insert the new architecture into the front of the architecture
|
|
list (keep the list sorted Most Recently Used). */
|
|
{
|
|
struct gdbarch_list *this = XMALLOC (struct gdbarch_list);
|
|
this->next = rego->arches;
|
|
this->gdbarch = new_gdbarch;
|
|
rego->arches = this;
|
|
}
|
|
|
|
/* Check that the newly installed architecture is valid. Plug in
|
|
any post init values. */
|
|
new_gdbarch->dump_tdep = rego->dump_tdep;
|
|
verify_gdbarch (new_gdbarch);
|
|
new_gdbarch->initialized_p = 1;
|
|
|
|
if (gdbarch_debug)
|
|
gdbarch_dump (new_gdbarch, gdb_stdlog);
|
|
|
|
return new_gdbarch;
|
|
}
|
|
|
|
/* Make the specified architecture current. */
|
|
|
|
void
|
|
deprecated_target_gdbarch_select_hack (struct gdbarch *new_gdbarch)
|
|
{
|
|
gdb_assert (new_gdbarch != NULL);
|
|
gdb_assert (new_gdbarch->initialized_p);
|
|
target_gdbarch = new_gdbarch;
|
|
observer_notify_architecture_changed (new_gdbarch);
|
|
registers_changed ();
|
|
}
|
|
|
|
extern void _initialize_gdbarch (void);
|
|
|
|
void
|
|
_initialize_gdbarch (void)
|
|
{
|
|
struct cmd_list_element *c;
|
|
|
|
add_setshow_zinteger_cmd ("arch", class_maintenance, &gdbarch_debug, _("\
|
|
Set architecture debugging."), _("\
|
|
Show architecture debugging."), _("\
|
|
When non-zero, architecture debugging is enabled."),
|
|
NULL,
|
|
show_gdbarch_debug,
|
|
&setdebuglist, &showdebuglist);
|
|
}
|