Commit | Line | Data |
---|---|---|
c0e8c252 | 1 | /* Dynamic architecture support for GDB, the GNU debugger. |
d7bd68ca AC |
2 | |
3 | Copyright 1998, 1999, 2000, 2002 Free Software Foundation, Inc. | |
c0e8c252 AC |
4 | |
5 | This file is part of GDB. | |
6 | ||
7 | This program is free software; you can redistribute it and/or modify | |
8 | it under the terms of the GNU General Public License as published by | |
9 | the Free Software Foundation; either version 2 of the License, or | |
10 | (at your option) any later version. | |
11 | ||
12 | This program is distributed in the hope that it will be useful, | |
13 | but WITHOUT ANY WARRANTY; without even the implied warranty of | |
14 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
15 | GNU General Public License for more details. | |
16 | ||
17 | You should have received a copy of the GNU General Public License | |
18 | along with this program; if not, write to the Free Software | |
19 | Foundation, Inc., 59 Temple Place - Suite 330, | |
20 | Boston, MA 02111-1307, USA. */ | |
21 | ||
22 | #ifndef GDBARCH_UTILS_H | |
23 | #define GDBARCH_UTILS_H | |
24 | ||
da3331ec AC |
25 | struct gdbarch; |
26 | struct frame_info; | |
27 | struct minimal_symbol; | |
28 | struct type; | |
29 | struct gdbarch_info; | |
30 | ||
c0e8c252 AC |
31 | /* gdbarch trace variable */ |
32 | extern int gdbarch_debug; | |
33 | ||
34 | /* Fallback for register convertible. */ | |
781a750d | 35 | extern gdbarch_deprecated_register_convertible_ftype deprecated_register_convertible_not; |
c0e8c252 | 36 | |
c8f9d51c JB |
37 | extern CORE_ADDR generic_cannot_extract_struct_value_address (char *dummy); |
38 | ||
049ee0e4 AC |
39 | /* Implementation of extract return value that grubs around in the |
40 | register cache. */ | |
41 | extern gdbarch_extract_return_value_ftype legacy_extract_return_value; | |
42 | ||
ebba8386 AC |
43 | /* Implementation of store return value that grubs the register cache. */ |
44 | extern gdbarch_store_return_value_ftype legacy_store_return_value; | |
45 | ||
c0e8c252 AC |
46 | /* Frameless functions not identifable. */ |
47 | extern gdbarch_frameless_function_invocation_ftype generic_frameless_function_invocation_not; | |
48 | ||
71a9f22e JB |
49 | /* Only structures, unions, and arrays are returned using the struct |
50 | convention. Note that arrays are never passed by value in the C | |
51 | language family, so that case is irrelevant for C. */ | |
52 | extern gdbarch_return_value_on_stack_ftype generic_return_value_on_stack_not; | |
53 | ||
c0e8c252 | 54 | /* Map onto old REGISTER_NAMES. */ |
fa88f677 | 55 | extern const char *legacy_register_name (int i); |
c0e8c252 | 56 | |
2bf0cb65 EZ |
57 | /* Accessor for old global function pointer for disassembly. */ |
58 | extern int legacy_print_insn (bfd_vma vma, disassemble_info *info); | |
59 | ||
c0e8c252 AC |
60 | /* Backward compatible call_dummy_words. */ |
61 | extern LONGEST legacy_call_dummy_words[]; | |
62 | extern int legacy_sizeof_call_dummy_words; | |
63 | ||
64 | /* Typical remote_translate_xfer_address */ | |
65 | extern gdbarch_remote_translate_xfer_address_ftype generic_remote_translate_xfer_address; | |
66 | ||
dad41f9a AC |
67 | /* Generic implementation of prologue_frameless_p. Just calls |
68 | SKIP_PROLOG and checks the return value to see if it actually | |
69 | changed. */ | |
70 | extern gdbarch_prologue_frameless_p_ftype generic_prologue_frameless_p; | |
71 | ||
3339cf8b AC |
72 | /* The only possible cases for inner_than. */ |
73 | extern int core_addr_lessthan (CORE_ADDR lhs, CORE_ADDR rhs); | |
74 | extern int core_addr_greaterthan (CORE_ADDR lhs, CORE_ADDR rhs); | |
75 | ||
f0d4cc9e AC |
76 | /* Floating point values. */ |
77 | extern const struct floatformat *default_float_format (struct gdbarch *gdbarch); | |
78 | extern const struct floatformat *default_double_format (struct gdbarch *gdbarch); | |
79 | ||
b4a20239 AC |
80 | /* The following DEPRECATED interfaces are for pre- multi-arch legacy |
81 | targets. */ | |
82 | ||
83 | /* DEPRECATED pre- multi-arch interface. Explicitly set the dynamic | |
b7d6b182 | 84 | target-system-dependent parameters based on bfd_architecture and |
b4a20239 AC |
85 | machine. This function is deprecated, use |
86 | set_gdbarch_from_arch_machine(). */ | |
87 | ||
88 | extern void set_architecture_from_arch_mach (enum bfd_architecture, unsigned long); | |
89 | ||
b7d6b182 | 90 | /* DEPRECATED pre- multi-arch interface. Notify the target dependent |
b4a20239 AC |
91 | backend of a change to the selected architecture. A zero return |
92 | status indicates that the target did not like the change. */ | |
93 | ||
94 | extern int (*target_architecture_hook) (const struct bfd_arch_info *); | |
95 | ||
875e1767 | 96 | /* Identity function on a CORE_ADDR. Just returns its parameter. */ |
f517ea4e | 97 | |
875e1767 | 98 | extern CORE_ADDR core_addr_identity (CORE_ADDR addr); |
f517ea4e | 99 | |
88c72b7d AC |
100 | /* No-op conversion of reg to regnum. */ |
101 | ||
102 | extern int no_op_reg_to_regnum (int reg); | |
103 | ||
e02bc4cc DS |
104 | /* Default prepare_to_procced. */ |
105 | ||
106 | extern int default_prepare_to_proceed (int select_it); | |
107 | ||
108 | extern int generic_prepare_to_proceed (int select_it); | |
c347ee3e | 109 | |
7824d2f2 | 110 | /* Versions of init_frame_pc(). Do nothing; do the default. */ |
10312cc4 | 111 | |
97f46953 | 112 | extern CORE_ADDR init_frame_pc_noop (int fromleaf, struct frame_info *prev); |
10312cc4 | 113 | |
97f46953 | 114 | extern CORE_ADDR init_frame_pc_default (int fromleaf, struct frame_info *prev); |
7824d2f2 | 115 | |
a2cf933a EZ |
116 | /* Do nothing version of elf_make_msymbol_special. */ |
117 | ||
118 | void default_elf_make_msymbol_special (asymbol *sym, struct minimal_symbol *msym); | |
119 | ||
120 | /* Do nothing version of coff_make_msymbol_special. */ | |
121 | ||
122 | void default_coff_make_msymbol_special (int val, struct minimal_symbol *msym); | |
123 | ||
01fb7433 AC |
124 | /* Version of cannot_fetch_register() / cannot_store_register() that |
125 | always fails. */ | |
126 | ||
127 | int cannot_register_not (int regnum); | |
128 | ||
39d4ef09 | 129 | /* Legacy version of target_virtual_frame_pointer(). Assumes that |
0ba6dca9 AC |
130 | there is an DEPRECATED_FP_REGNUM and that it is the same, cooked or |
131 | raw. */ | |
39d4ef09 AC |
132 | |
133 | extern gdbarch_virtual_frame_pointer_ftype legacy_virtual_frame_pointer; | |
134 | ||
bdcd319a CV |
135 | extern CORE_ADDR generic_skip_trampoline_code (CORE_ADDR pc); |
136 | ||
68e9cc94 CV |
137 | extern int generic_in_solib_call_trampoline (CORE_ADDR pc, char *name); |
138 | ||
d50355b6 MS |
139 | extern int generic_in_solib_return_trampoline (CORE_ADDR pc, char *name); |
140 | ||
c12260ac CV |
141 | extern int generic_in_function_epilogue_p (struct gdbarch *gdbarch, CORE_ADDR pc); |
142 | ||
b2e75d78 AC |
143 | /* Assume that the world is sane, a registers raw and virtual size |
144 | both match its type. */ | |
46cd78fb | 145 | |
b2e75d78 | 146 | extern int generic_register_size (int regnum); |
ce29138a | 147 | |
a7e3c2ad AC |
148 | /* Assume that the world is sane, the registers are all adjacent. */ |
149 | extern int generic_register_byte (int regnum); | |
150 | ||
d7bd68ca AC |
151 | /* Prop up old targets that use various IN_SIGTRAMP() macros. */ |
152 | extern int legacy_pc_in_sigtramp (CORE_ADDR pc, char *name); | |
153 | ||
13d01224 AC |
154 | /* The orginal register_convert*() functions were overloaded. They |
155 | were used to both: convert between virtual and raw register formats | |
156 | (something that is discouraged); and to convert a register to the | |
157 | type of a corresponding variable. These legacy functions preserve | |
158 | that overloaded behavour in existing targets. */ | |
159 | extern int legacy_convert_register_p (int regnum); | |
160 | extern void legacy_register_to_value (int regnum, struct type *type, char *from, char *to); | |
161 | extern void legacy_value_to_register (struct type *type, int regnum, char *from, char *to); | |
162 | ||
4182591f AC |
163 | /* For compatibility with older architectures, returns |
164 | (LEGACY_SIM_REGNO_IGNORE) when the register doesn't have a valid | |
165 | name. */ | |
166 | ||
167 | extern int legacy_register_sim_regno (int regnum); | |
168 | ||
fb6ecb0f AC |
169 | /* Initialize a ``struct info''. Can't use memset(0) since some |
170 | default values are not zero. */ | |
171 | extern void gdbarch_info_init (struct gdbarch_info *info); | |
172 | ||
c0e8c252 | 173 | #endif |