]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - gdb/gdbarch.h
* doublest.c (floatformat_from_length): Use the right element from
[thirdparty/binutils-gdb.git] / gdb / gdbarch.h
CommitLineData
59233f88
AC
1/* *INDENT-OFF* */ /* THIS FILE IS GENERATED */
2
adf40b2e 3/* Dynamic architecture support for GDB, the GNU debugger.
79d45cd4 4
424163ea
DJ
5 Copyright (C) 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006
6 Free Software Foundation, Inc.
c906108c 7
c5aa993b 8 This file is part of GDB.
c906108c 9
c5aa993b
JM
10 This program is free software; you can redistribute it and/or modify
11 it under the terms of the GNU General Public License as published by
12 the Free Software Foundation; either version 2 of the License, or
13 (at your option) any later version.
c906108c 14
c5aa993b
JM
15 This program is distributed in the hope that it will be useful,
16 but WITHOUT ANY WARRANTY; without even the implied warranty of
17 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 GNU General Public License for more details.
c906108c 19
c5aa993b
JM
20 You should have received a copy of the GNU General Public License
21 along with this program; if not, write to the Free Software
197e01b6
EZ
22 Foundation, Inc., 51 Franklin Street, Fifth Floor,
23 Boston, MA 02110-1301, USA. */
c906108c 24
104c1213
JM
25/* This file was created with the aid of ``gdbarch.sh''.
26
52204a0b 27 The Bourne shell script ``gdbarch.sh'' creates the files
104c1213
JM
28 ``new-gdbarch.c'' and ``new-gdbarch.h and then compares them
29 against the existing ``gdbarch.[hc]''. Any differences found
30 being reported.
31
32 If editing this file, please also run gdbarch.sh and merge any
52204a0b 33 changes into that script. Conversely, when making sweeping changes
104c1213
JM
34 to this file, modifying gdbarch.sh and using its output may prove
35 easier. */
adf40b2e 36
c906108c
SS
37#ifndef GDBARCH_H
38#define GDBARCH_H
39
da3331ec
AC
40struct floatformat;
41struct ui_file;
cce74817
JM
42struct frame_info;
43struct value;
b6af0555 44struct objfile;
a2cf933a 45struct minimal_symbol;
049ee0e4 46struct regcache;
b59ff9d5 47struct reggroup;
6ce6d90f 48struct regset;
a89aa300 49struct disassemble_info;
e2d0e7eb 50struct target_ops;
030f20e1 51struct obstack;
8181d85f 52struct bp_target_info;
424163ea 53struct target_desc;
0f71a2f6 54
0f71a2f6
JM
55extern struct gdbarch *current_gdbarch;
56
0f71a2f6
JM
57
58/* The following are pre-initialized by GDBARCH. */
59
104c1213 60extern const struct bfd_arch_info * gdbarch_bfd_arch_info (struct gdbarch *gdbarch);
0f71a2f6 61/* set_gdbarch_bfd_arch_info() - not applicable - pre-initialized. */
5010d38b 62#if !defined (GDB_TM_FILE) && defined (TARGET_ARCHITECTURE)
83905903
AC
63#error "Non multi-arch definition of TARGET_ARCHITECTURE"
64#endif
c25083af 65#if !defined (TARGET_ARCHITECTURE)
0f71a2f6
JM
66#define TARGET_ARCHITECTURE (gdbarch_bfd_arch_info (current_gdbarch))
67#endif
0f71a2f6 68
104c1213 69extern int gdbarch_byte_order (struct gdbarch *gdbarch);
0f71a2f6 70/* set_gdbarch_byte_order() - not applicable - pre-initialized. */
5010d38b 71#if !defined (GDB_TM_FILE) && defined (TARGET_BYTE_ORDER)
83905903
AC
72#error "Non multi-arch definition of TARGET_BYTE_ORDER"
73#endif
c25083af 74#if !defined (TARGET_BYTE_ORDER)
0f71a2f6
JM
75#define TARGET_BYTE_ORDER (gdbarch_byte_order (current_gdbarch))
76#endif
0f71a2f6 77
4be87837
DJ
78extern enum gdb_osabi gdbarch_osabi (struct gdbarch *gdbarch);
79/* set_gdbarch_osabi() - not applicable - pre-initialized. */
5010d38b 80#if !defined (GDB_TM_FILE) && defined (TARGET_OSABI)
4be87837
DJ
81#error "Non multi-arch definition of TARGET_OSABI"
82#endif
c25083af 83#if !defined (TARGET_OSABI)
4be87837
DJ
84#define TARGET_OSABI (gdbarch_osabi (current_gdbarch))
85#endif
4be87837 86
424163ea
DJ
87extern const struct target_desc * gdbarch_target_desc (struct gdbarch *gdbarch);
88/* set_gdbarch_target_desc() - not applicable - pre-initialized. */
89
0f71a2f6 90
99e7bb18 91/* The following are initialized by the target dependent code. */
0f71a2f6 92
66b43ecb
AC
93/* Number of bits in a char or unsigned char for the target machine.
94 Just like CHAR_BIT in <limits.h> but describes the target machine.
57010b1c 95 v:TARGET_CHAR_BIT:int:char_bit::::8 * sizeof (char):8::0:
66b43ecb
AC
96
97 Number of bits in a short or unsigned short for the target machine. */
c4093a6a 98
104c1213
JM
99extern int gdbarch_short_bit (struct gdbarch *gdbarch);
100extern void set_gdbarch_short_bit (struct gdbarch *gdbarch, int short_bit);
5010d38b 101#if !defined (GDB_TM_FILE) && defined (TARGET_SHORT_BIT)
83905903
AC
102#error "Non multi-arch definition of TARGET_SHORT_BIT"
103#endif
c25083af 104#if !defined (TARGET_SHORT_BIT)
0f71a2f6
JM
105#define TARGET_SHORT_BIT (gdbarch_short_bit (current_gdbarch))
106#endif
0f71a2f6 107
66b43ecb
AC
108/* Number of bits in an int or unsigned int for the target machine. */
109
104c1213
JM
110extern int gdbarch_int_bit (struct gdbarch *gdbarch);
111extern void set_gdbarch_int_bit (struct gdbarch *gdbarch, int int_bit);
5010d38b 112#if !defined (GDB_TM_FILE) && defined (TARGET_INT_BIT)
83905903
AC
113#error "Non multi-arch definition of TARGET_INT_BIT"
114#endif
c25083af 115#if !defined (TARGET_INT_BIT)
0f71a2f6
JM
116#define TARGET_INT_BIT (gdbarch_int_bit (current_gdbarch))
117#endif
0f71a2f6 118
66b43ecb
AC
119/* Number of bits in a long or unsigned long for the target machine. */
120
104c1213
JM
121extern int gdbarch_long_bit (struct gdbarch *gdbarch);
122extern void set_gdbarch_long_bit (struct gdbarch *gdbarch, int long_bit);
5010d38b 123#if !defined (GDB_TM_FILE) && defined (TARGET_LONG_BIT)
83905903
AC
124#error "Non multi-arch definition of TARGET_LONG_BIT"
125#endif
c25083af 126#if !defined (TARGET_LONG_BIT)
0f71a2f6
JM
127#define TARGET_LONG_BIT (gdbarch_long_bit (current_gdbarch))
128#endif
0f71a2f6 129
66b43ecb
AC
130/* Number of bits in a long long or unsigned long long for the target
131 machine. */
132
104c1213
JM
133extern int gdbarch_long_long_bit (struct gdbarch *gdbarch);
134extern void set_gdbarch_long_long_bit (struct gdbarch *gdbarch, int long_long_bit);
5010d38b 135#if !defined (GDB_TM_FILE) && defined (TARGET_LONG_LONG_BIT)
83905903
AC
136#error "Non multi-arch definition of TARGET_LONG_LONG_BIT"
137#endif
c25083af 138#if !defined (TARGET_LONG_LONG_BIT)
0f71a2f6
JM
139#define TARGET_LONG_LONG_BIT (gdbarch_long_long_bit (current_gdbarch))
140#endif
0f71a2f6 141
456fcf94
AC
142/* The ABI default bit-size and format for "float", "double", and "long
143 double". These bit/format pairs should eventually be combined into
8da61cc4
DJ
144 a single object. For the moment, just initialize them as a pair.
145 Each format describes both the big and little endian layouts (if
146 useful). */
66b43ecb 147
104c1213
JM
148extern int gdbarch_float_bit (struct gdbarch *gdbarch);
149extern void set_gdbarch_float_bit (struct gdbarch *gdbarch, int float_bit);
5010d38b 150#if !defined (GDB_TM_FILE) && defined (TARGET_FLOAT_BIT)
83905903
AC
151#error "Non multi-arch definition of TARGET_FLOAT_BIT"
152#endif
c25083af 153#if !defined (TARGET_FLOAT_BIT)
0f71a2f6
JM
154#define TARGET_FLOAT_BIT (gdbarch_float_bit (current_gdbarch))
155#endif
0f71a2f6 156
8da61cc4
DJ
157extern const struct floatformat ** gdbarch_float_format (struct gdbarch *gdbarch);
158extern void set_gdbarch_float_format (struct gdbarch *gdbarch, const struct floatformat ** float_format);
5010d38b 159#if !defined (GDB_TM_FILE) && defined (TARGET_FLOAT_FORMAT)
456fcf94
AC
160#error "Non multi-arch definition of TARGET_FLOAT_FORMAT"
161#endif
162#if !defined (TARGET_FLOAT_FORMAT)
163#define TARGET_FLOAT_FORMAT (gdbarch_float_format (current_gdbarch))
164#endif
66b43ecb 165
104c1213
JM
166extern int gdbarch_double_bit (struct gdbarch *gdbarch);
167extern void set_gdbarch_double_bit (struct gdbarch *gdbarch, int double_bit);
5010d38b 168#if !defined (GDB_TM_FILE) && defined (TARGET_DOUBLE_BIT)
83905903
AC
169#error "Non multi-arch definition of TARGET_DOUBLE_BIT"
170#endif
c25083af 171#if !defined (TARGET_DOUBLE_BIT)
0f71a2f6
JM
172#define TARGET_DOUBLE_BIT (gdbarch_double_bit (current_gdbarch))
173#endif
0f71a2f6 174
8da61cc4
DJ
175extern const struct floatformat ** gdbarch_double_format (struct gdbarch *gdbarch);
176extern void set_gdbarch_double_format (struct gdbarch *gdbarch, const struct floatformat ** double_format);
5010d38b 177#if !defined (GDB_TM_FILE) && defined (TARGET_DOUBLE_FORMAT)
456fcf94
AC
178#error "Non multi-arch definition of TARGET_DOUBLE_FORMAT"
179#endif
180#if !defined (TARGET_DOUBLE_FORMAT)
181#define TARGET_DOUBLE_FORMAT (gdbarch_double_format (current_gdbarch))
182#endif
66b43ecb 183
104c1213
JM
184extern int gdbarch_long_double_bit (struct gdbarch *gdbarch);
185extern void set_gdbarch_long_double_bit (struct gdbarch *gdbarch, int long_double_bit);
5010d38b 186#if !defined (GDB_TM_FILE) && defined (TARGET_LONG_DOUBLE_BIT)
83905903
AC
187#error "Non multi-arch definition of TARGET_LONG_DOUBLE_BIT"
188#endif
c25083af 189#if !defined (TARGET_LONG_DOUBLE_BIT)
0f71a2f6
JM
190#define TARGET_LONG_DOUBLE_BIT (gdbarch_long_double_bit (current_gdbarch))
191#endif
0f71a2f6 192
8da61cc4
DJ
193extern const struct floatformat ** gdbarch_long_double_format (struct gdbarch *gdbarch);
194extern void set_gdbarch_long_double_format (struct gdbarch *gdbarch, const struct floatformat ** long_double_format);
5010d38b 195#if !defined (GDB_TM_FILE) && defined (TARGET_LONG_DOUBLE_FORMAT)
456fcf94
AC
196#error "Non multi-arch definition of TARGET_LONG_DOUBLE_FORMAT"
197#endif
198#if !defined (TARGET_LONG_DOUBLE_FORMAT)
199#define TARGET_LONG_DOUBLE_FORMAT (gdbarch_long_double_format (current_gdbarch))
200#endif
201
52204a0b
DT
202/* For most targets, a pointer on the target and its representation as an
203 address in GDB have the same size and "look the same". For such a
204 target, you need only set TARGET_PTR_BIT / ptr_bit and TARGET_ADDR_BIT
205 / addr_bit will be set from it.
206
207 If TARGET_PTR_BIT and TARGET_ADDR_BIT are different, you'll probably
208 also need to set POINTER_TO_ADDRESS and ADDRESS_TO_POINTER as well.
209
210 ptr_bit is the size of a pointer on the target */
66b43ecb 211
66b43ecb
AC
212extern int gdbarch_ptr_bit (struct gdbarch *gdbarch);
213extern void set_gdbarch_ptr_bit (struct gdbarch *gdbarch, int ptr_bit);
5010d38b 214#if !defined (GDB_TM_FILE) && defined (TARGET_PTR_BIT)
83905903
AC
215#error "Non multi-arch definition of TARGET_PTR_BIT"
216#endif
c25083af 217#if !defined (TARGET_PTR_BIT)
66b43ecb
AC
218#define TARGET_PTR_BIT (gdbarch_ptr_bit (current_gdbarch))
219#endif
66b43ecb 220
52204a0b
DT
221/* addr_bit is the size of a target address as represented in gdb */
222
52204a0b
DT
223extern int gdbarch_addr_bit (struct gdbarch *gdbarch);
224extern void set_gdbarch_addr_bit (struct gdbarch *gdbarch, int addr_bit);
5010d38b 225#if !defined (GDB_TM_FILE) && defined (TARGET_ADDR_BIT)
83905903
AC
226#error "Non multi-arch definition of TARGET_ADDR_BIT"
227#endif
c25083af 228#if !defined (TARGET_ADDR_BIT)
52204a0b
DT
229#define TARGET_ADDR_BIT (gdbarch_addr_bit (current_gdbarch))
230#endif
52204a0b 231
66b43ecb
AC
232/* Number of bits in a BFD_VMA for the target object file format. */
233
66b43ecb
AC
234extern int gdbarch_bfd_vma_bit (struct gdbarch *gdbarch);
235extern void set_gdbarch_bfd_vma_bit (struct gdbarch *gdbarch, int bfd_vma_bit);
5010d38b 236#if !defined (GDB_TM_FILE) && defined (TARGET_BFD_VMA_BIT)
83905903
AC
237#error "Non multi-arch definition of TARGET_BFD_VMA_BIT"
238#endif
c25083af 239#if !defined (TARGET_BFD_VMA_BIT)
66b43ecb
AC
240#define TARGET_BFD_VMA_BIT (gdbarch_bfd_vma_bit (current_gdbarch))
241#endif
66b43ecb 242
4e409299
JB
243/* One if `char' acts like `signed char', zero if `unsigned char'. */
244
4e409299
JB
245extern int gdbarch_char_signed (struct gdbarch *gdbarch);
246extern void set_gdbarch_char_signed (struct gdbarch *gdbarch, int char_signed);
5010d38b 247#if !defined (GDB_TM_FILE) && defined (TARGET_CHAR_SIGNED)
4e409299
JB
248#error "Non multi-arch definition of TARGET_CHAR_SIGNED"
249#endif
c25083af 250#if !defined (TARGET_CHAR_SIGNED)
4e409299
JB
251#define TARGET_CHAR_SIGNED (gdbarch_char_signed (current_gdbarch))
252#endif
4e409299 253
cde9ea48
AC
254#if defined (TARGET_READ_PC)
255/* Legacy for systems yet to multi-arch TARGET_READ_PC */
256#if !defined (TARGET_READ_PC_P)
257#define TARGET_READ_PC_P() (1)
258#endif
259#endif
260
cde9ea48 261extern int gdbarch_read_pc_p (struct gdbarch *gdbarch);
5010d38b 262#if !defined (GDB_TM_FILE) && defined (TARGET_READ_PC_P)
cde9ea48
AC
263#error "Non multi-arch definition of TARGET_READ_PC"
264#endif
bceabdd8 265#if !defined (TARGET_READ_PC_P)
cde9ea48
AC
266#define TARGET_READ_PC_P() (gdbarch_read_pc_p (current_gdbarch))
267#endif
268
39f77062
KB
269typedef CORE_ADDR (gdbarch_read_pc_ftype) (ptid_t ptid);
270extern CORE_ADDR gdbarch_read_pc (struct gdbarch *gdbarch, ptid_t ptid);
104c1213 271extern void set_gdbarch_read_pc (struct gdbarch *gdbarch, gdbarch_read_pc_ftype *read_pc);
5010d38b 272#if !defined (GDB_TM_FILE) && defined (TARGET_READ_PC)
83905903
AC
273#error "Non multi-arch definition of TARGET_READ_PC"
274#endif
c25083af 275#if !defined (TARGET_READ_PC)
39f77062 276#define TARGET_READ_PC(ptid) (gdbarch_read_pc (current_gdbarch, ptid))
0f71a2f6 277#endif
0f71a2f6 278
39f77062
KB
279typedef void (gdbarch_write_pc_ftype) (CORE_ADDR val, ptid_t ptid);
280extern void gdbarch_write_pc (struct gdbarch *gdbarch, CORE_ADDR val, ptid_t ptid);
104c1213 281extern void set_gdbarch_write_pc (struct gdbarch *gdbarch, gdbarch_write_pc_ftype *write_pc);
5010d38b 282#if !defined (GDB_TM_FILE) && defined (TARGET_WRITE_PC)
83905903
AC
283#error "Non multi-arch definition of TARGET_WRITE_PC"
284#endif
c25083af 285#if !defined (TARGET_WRITE_PC)
39f77062 286#define TARGET_WRITE_PC(val, ptid) (gdbarch_write_pc (current_gdbarch, val, ptid))
0f71a2f6 287#endif
0f71a2f6 288
a9e5fdc2
AC
289/* UNWIND_SP is a direct replacement for TARGET_READ_SP. */
290
bd1ce8ba
AC
291#if defined (TARGET_READ_SP)
292/* Legacy for systems yet to multi-arch TARGET_READ_SP */
293#if !defined (TARGET_READ_SP_P)
294#define TARGET_READ_SP_P() (1)
295#endif
296#endif
297
bd1ce8ba 298extern int gdbarch_read_sp_p (struct gdbarch *gdbarch);
5010d38b 299#if !defined (GDB_TM_FILE) && defined (TARGET_READ_SP_P)
bd1ce8ba
AC
300#error "Non multi-arch definition of TARGET_READ_SP"
301#endif
bceabdd8 302#if !defined (TARGET_READ_SP_P)
bd1ce8ba
AC
303#define TARGET_READ_SP_P() (gdbarch_read_sp_p (current_gdbarch))
304#endif
305
104c1213
JM
306typedef CORE_ADDR (gdbarch_read_sp_ftype) (void);
307extern CORE_ADDR gdbarch_read_sp (struct gdbarch *gdbarch);
308extern void set_gdbarch_read_sp (struct gdbarch *gdbarch, gdbarch_read_sp_ftype *read_sp);
5010d38b 309#if !defined (GDB_TM_FILE) && defined (TARGET_READ_SP)
83905903
AC
310#error "Non multi-arch definition of TARGET_READ_SP"
311#endif
c25083af 312#if !defined (TARGET_READ_SP)
0f71a2f6
JM
313#define TARGET_READ_SP() (gdbarch_read_sp (current_gdbarch))
314#endif
0f71a2f6 315
39d4ef09
AC
316/* Function for getting target's idea of a frame pointer. FIXME: GDB's
317 whole scheme for dealing with "frames" and "frame pointers" needs a
318 serious shakedown. */
319
39d4ef09
AC
320typedef void (gdbarch_virtual_frame_pointer_ftype) (CORE_ADDR pc, int *frame_regnum, LONGEST *frame_offset);
321extern void gdbarch_virtual_frame_pointer (struct gdbarch *gdbarch, CORE_ADDR pc, int *frame_regnum, LONGEST *frame_offset);
322extern void set_gdbarch_virtual_frame_pointer (struct gdbarch *gdbarch, gdbarch_virtual_frame_pointer_ftype *virtual_frame_pointer);
5010d38b 323#if !defined (GDB_TM_FILE) && defined (TARGET_VIRTUAL_FRAME_POINTER)
39d4ef09
AC
324#error "Non multi-arch definition of TARGET_VIRTUAL_FRAME_POINTER"
325#endif
c25083af 326#if !defined (TARGET_VIRTUAL_FRAME_POINTER)
39d4ef09
AC
327#define TARGET_VIRTUAL_FRAME_POINTER(pc, frame_regnum, frame_offset) (gdbarch_virtual_frame_pointer (current_gdbarch, pc, frame_regnum, frame_offset))
328#endif
39d4ef09 329
d8124050 330extern int gdbarch_pseudo_register_read_p (struct gdbarch *gdbarch);
61a0eb5b 331
b60c417a
AC
332typedef void (gdbarch_pseudo_register_read_ftype) (struct gdbarch *gdbarch, struct regcache *regcache, int cookednum, gdb_byte *buf);
333extern void gdbarch_pseudo_register_read (struct gdbarch *gdbarch, struct regcache *regcache, int cookednum, gdb_byte *buf);
d8124050 334extern void set_gdbarch_pseudo_register_read (struct gdbarch *gdbarch, gdbarch_pseudo_register_read_ftype *pseudo_register_read);
61a0eb5b 335
d8124050 336extern int gdbarch_pseudo_register_write_p (struct gdbarch *gdbarch);
61a0eb5b 337
b60c417a
AC
338typedef void (gdbarch_pseudo_register_write_ftype) (struct gdbarch *gdbarch, struct regcache *regcache, int cookednum, const gdb_byte *buf);
339extern void gdbarch_pseudo_register_write (struct gdbarch *gdbarch, struct regcache *regcache, int cookednum, const gdb_byte *buf);
d8124050 340extern void set_gdbarch_pseudo_register_write (struct gdbarch *gdbarch, gdbarch_pseudo_register_write_ftype *pseudo_register_write);
61a0eb5b 341
104c1213
JM
342extern int gdbarch_num_regs (struct gdbarch *gdbarch);
343extern void set_gdbarch_num_regs (struct gdbarch *gdbarch, int num_regs);
5010d38b 344#if !defined (GDB_TM_FILE) && defined (NUM_REGS)
83905903
AC
345#error "Non multi-arch definition of NUM_REGS"
346#endif
c25083af 347#if !defined (NUM_REGS)
0f71a2f6
JM
348#define NUM_REGS (gdbarch_num_regs (current_gdbarch))
349#endif
0f71a2f6 350
34620563
AC
351/* This macro gives the number of pseudo-registers that live in the
352 register namespace but do not get fetched or stored on the target.
353 These pseudo-registers may be aliases for other registers,
354 combinations of other registers, or they may be computed by GDB. */
355
0aba1244
EZ
356extern int gdbarch_num_pseudo_regs (struct gdbarch *gdbarch);
357extern void set_gdbarch_num_pseudo_regs (struct gdbarch *gdbarch, int num_pseudo_regs);
5010d38b 358#if !defined (GDB_TM_FILE) && defined (NUM_PSEUDO_REGS)
83905903
AC
359#error "Non multi-arch definition of NUM_PSEUDO_REGS"
360#endif
c25083af 361#if !defined (NUM_PSEUDO_REGS)
0aba1244
EZ
362#define NUM_PSEUDO_REGS (gdbarch_num_pseudo_regs (current_gdbarch))
363#endif
0aba1244 364
c2169756
AC
365/* GDB's standard (or well known) register numbers. These can map onto
366 a real register or a pseudo (computed) register or not be defined at
a9e5fdc2
AC
367 all (-1).
368 SP_REGNUM will hopefully be replaced by UNWIND_SP. */
1200cd6e 369
104c1213
JM
370extern int gdbarch_sp_regnum (struct gdbarch *gdbarch);
371extern void set_gdbarch_sp_regnum (struct gdbarch *gdbarch, int sp_regnum);
5010d38b 372#if !defined (GDB_TM_FILE) && defined (SP_REGNUM)
83905903
AC
373#error "Non multi-arch definition of SP_REGNUM"
374#endif
c25083af 375#if !defined (SP_REGNUM)
0f71a2f6
JM
376#define SP_REGNUM (gdbarch_sp_regnum (current_gdbarch))
377#endif
0f71a2f6 378
104c1213
JM
379extern int gdbarch_pc_regnum (struct gdbarch *gdbarch);
380extern void set_gdbarch_pc_regnum (struct gdbarch *gdbarch, int pc_regnum);
5010d38b 381#if !defined (GDB_TM_FILE) && defined (PC_REGNUM)
83905903
AC
382#error "Non multi-arch definition of PC_REGNUM"
383#endif
c25083af 384#if !defined (PC_REGNUM)
0f71a2f6
JM
385#define PC_REGNUM (gdbarch_pc_regnum (current_gdbarch))
386#endif
0f71a2f6 387
c2169756
AC
388extern int gdbarch_ps_regnum (struct gdbarch *gdbarch);
389extern void set_gdbarch_ps_regnum (struct gdbarch *gdbarch, int ps_regnum);
5010d38b 390#if !defined (GDB_TM_FILE) && defined (PS_REGNUM)
c2169756
AC
391#error "Non multi-arch definition of PS_REGNUM"
392#endif
c25083af 393#if !defined (PS_REGNUM)
c2169756
AC
394#define PS_REGNUM (gdbarch_ps_regnum (current_gdbarch))
395#endif
c2169756 396
60054393
MS
397extern int gdbarch_fp0_regnum (struct gdbarch *gdbarch);
398extern void set_gdbarch_fp0_regnum (struct gdbarch *gdbarch, int fp0_regnum);
5010d38b 399#if !defined (GDB_TM_FILE) && defined (FP0_REGNUM)
83905903
AC
400#error "Non multi-arch definition of FP0_REGNUM"
401#endif
c25083af 402#if !defined (FP0_REGNUM)
60054393
MS
403#define FP0_REGNUM (gdbarch_fp0_regnum (current_gdbarch))
404#endif
60054393 405
88c72b7d
AC
406/* Convert stab register number (from `r' declaration) to a gdb REGNUM. */
407
88c72b7d
AC
408typedef int (gdbarch_stab_reg_to_regnum_ftype) (int stab_regnr);
409extern int gdbarch_stab_reg_to_regnum (struct gdbarch *gdbarch, int stab_regnr);
410extern void set_gdbarch_stab_reg_to_regnum (struct gdbarch *gdbarch, gdbarch_stab_reg_to_regnum_ftype *stab_reg_to_regnum);
5010d38b 411#if !defined (GDB_TM_FILE) && defined (STAB_REG_TO_REGNUM)
83905903
AC
412#error "Non multi-arch definition of STAB_REG_TO_REGNUM"
413#endif
c25083af 414#if !defined (STAB_REG_TO_REGNUM)
88c72b7d
AC
415#define STAB_REG_TO_REGNUM(stab_regnr) (gdbarch_stab_reg_to_regnum (current_gdbarch, stab_regnr))
416#endif
88c72b7d
AC
417
418/* Provide a default mapping from a ecoff register number to a gdb REGNUM. */
419
88c72b7d
AC
420typedef int (gdbarch_ecoff_reg_to_regnum_ftype) (int ecoff_regnr);
421extern int gdbarch_ecoff_reg_to_regnum (struct gdbarch *gdbarch, int ecoff_regnr);
422extern void set_gdbarch_ecoff_reg_to_regnum (struct gdbarch *gdbarch, gdbarch_ecoff_reg_to_regnum_ftype *ecoff_reg_to_regnum);
5010d38b 423#if !defined (GDB_TM_FILE) && defined (ECOFF_REG_TO_REGNUM)
83905903
AC
424#error "Non multi-arch definition of ECOFF_REG_TO_REGNUM"
425#endif
c25083af 426#if !defined (ECOFF_REG_TO_REGNUM)
88c72b7d
AC
427#define ECOFF_REG_TO_REGNUM(ecoff_regnr) (gdbarch_ecoff_reg_to_regnum (current_gdbarch, ecoff_regnr))
428#endif
88c72b7d
AC
429
430/* Provide a default mapping from a DWARF register number to a gdb REGNUM. */
431
88c72b7d
AC
432typedef int (gdbarch_dwarf_reg_to_regnum_ftype) (int dwarf_regnr);
433extern int gdbarch_dwarf_reg_to_regnum (struct gdbarch *gdbarch, int dwarf_regnr);
434extern void set_gdbarch_dwarf_reg_to_regnum (struct gdbarch *gdbarch, gdbarch_dwarf_reg_to_regnum_ftype *dwarf_reg_to_regnum);
5010d38b 435#if !defined (GDB_TM_FILE) && defined (DWARF_REG_TO_REGNUM)
83905903
AC
436#error "Non multi-arch definition of DWARF_REG_TO_REGNUM"
437#endif
c25083af 438#if !defined (DWARF_REG_TO_REGNUM)
88c72b7d
AC
439#define DWARF_REG_TO_REGNUM(dwarf_regnr) (gdbarch_dwarf_reg_to_regnum (current_gdbarch, dwarf_regnr))
440#endif
88c72b7d 441
77949794 442/* Convert from an sdb register number to an internal gdb register number. */
88c72b7d 443
88c72b7d
AC
444typedef int (gdbarch_sdb_reg_to_regnum_ftype) (int sdb_regnr);
445extern int gdbarch_sdb_reg_to_regnum (struct gdbarch *gdbarch, int sdb_regnr);
446extern void set_gdbarch_sdb_reg_to_regnum (struct gdbarch *gdbarch, gdbarch_sdb_reg_to_regnum_ftype *sdb_reg_to_regnum);
5010d38b 447#if !defined (GDB_TM_FILE) && defined (SDB_REG_TO_REGNUM)
83905903
AC
448#error "Non multi-arch definition of SDB_REG_TO_REGNUM"
449#endif
c25083af 450#if !defined (SDB_REG_TO_REGNUM)
88c72b7d
AC
451#define SDB_REG_TO_REGNUM(sdb_regnr) (gdbarch_sdb_reg_to_regnum (current_gdbarch, sdb_regnr))
452#endif
88c72b7d 453
88c72b7d
AC
454typedef int (gdbarch_dwarf2_reg_to_regnum_ftype) (int dwarf2_regnr);
455extern int gdbarch_dwarf2_reg_to_regnum (struct gdbarch *gdbarch, int dwarf2_regnr);
456extern void set_gdbarch_dwarf2_reg_to_regnum (struct gdbarch *gdbarch, gdbarch_dwarf2_reg_to_regnum_ftype *dwarf2_reg_to_regnum);
5010d38b 457#if !defined (GDB_TM_FILE) && defined (DWARF2_REG_TO_REGNUM)
83905903
AC
458#error "Non multi-arch definition of DWARF2_REG_TO_REGNUM"
459#endif
c25083af 460#if !defined (DWARF2_REG_TO_REGNUM)
88c72b7d
AC
461#define DWARF2_REG_TO_REGNUM(dwarf2_regnr) (gdbarch_dwarf2_reg_to_regnum (current_gdbarch, dwarf2_regnr))
462#endif
88c72b7d 463
fa88f677
AC
464typedef const char * (gdbarch_register_name_ftype) (int regnr);
465extern const char * gdbarch_register_name (struct gdbarch *gdbarch, int regnr);
104c1213 466extern void set_gdbarch_register_name (struct gdbarch *gdbarch, gdbarch_register_name_ftype *register_name);
5010d38b 467#if !defined (GDB_TM_FILE) && defined (REGISTER_NAME)
83905903
AC
468#error "Non multi-arch definition of REGISTER_NAME"
469#endif
c25083af 470#if !defined (REGISTER_NAME)
0f71a2f6
JM
471#define REGISTER_NAME(regnr) (gdbarch_register_name (current_gdbarch, regnr))
472#endif
0f71a2f6 473
7b9ee6a8
DJ
474/* Return the type of a register specified by the architecture. Only
475 the register cache should call this function directly; others should
476 use "register_type". */
9c04cab7
AC
477
478extern int gdbarch_register_type_p (struct gdbarch *gdbarch);
479
480typedef struct type * (gdbarch_register_type_ftype) (struct gdbarch *gdbarch, int reg_nr);
481extern struct type * gdbarch_register_type (struct gdbarch *gdbarch, int reg_nr);
482extern void set_gdbarch_register_type (struct gdbarch *gdbarch, gdbarch_register_type_ftype *register_type);
483
f3be58bc
AC
484/* If the value returned by DEPRECATED_REGISTER_BYTE agrees with the
485 register offsets computed using just REGISTER_TYPE, this can be
486 deleted. See: maint print registers. NOTE: cagney/2002-05-02: This
487 function with predicate has a valid (callable) initial value. As a
488 consequence, even when the predicate is false, the corresponding
489 function works. This simplifies the migration process - old code,
490 calling DEPRECATED_REGISTER_BYTE, doesn't need to be modified. */
46654a5b 491
62700349
AC
492#if defined (DEPRECATED_REGISTER_BYTE)
493/* Legacy for systems yet to multi-arch DEPRECATED_REGISTER_BYTE */
494#if !defined (DEPRECATED_REGISTER_BYTE_P)
495#define DEPRECATED_REGISTER_BYTE_P() (1)
46654a5b
AC
496#endif
497#endif
498
9c04cab7 499extern int gdbarch_deprecated_register_byte_p (struct gdbarch *gdbarch);
5010d38b 500#if !defined (GDB_TM_FILE) && defined (DEPRECATED_REGISTER_BYTE_P)
62700349 501#error "Non multi-arch definition of DEPRECATED_REGISTER_BYTE"
46654a5b 502#endif
bceabdd8 503#if !defined (DEPRECATED_REGISTER_BYTE_P)
62700349 504#define DEPRECATED_REGISTER_BYTE_P() (gdbarch_deprecated_register_byte_p (current_gdbarch))
46654a5b
AC
505#endif
506
9c04cab7
AC
507typedef int (gdbarch_deprecated_register_byte_ftype) (int reg_nr);
508extern int gdbarch_deprecated_register_byte (struct gdbarch *gdbarch, int reg_nr);
509extern void set_gdbarch_deprecated_register_byte (struct gdbarch *gdbarch, gdbarch_deprecated_register_byte_ftype *deprecated_register_byte);
5010d38b 510#if !defined (GDB_TM_FILE) && defined (DEPRECATED_REGISTER_BYTE)
62700349 511#error "Non multi-arch definition of DEPRECATED_REGISTER_BYTE"
83905903 512#endif
62700349
AC
513#if !defined (DEPRECATED_REGISTER_BYTE)
514#define DEPRECATED_REGISTER_BYTE(reg_nr) (gdbarch_deprecated_register_byte (current_gdbarch, reg_nr))
0f71a2f6 515#endif
0f71a2f6 516
f3be58bc
AC
517/* See gdbint.texinfo, and PUSH_DUMMY_CALL. */
518
519extern int gdbarch_unwind_dummy_id_p (struct gdbarch *gdbarch);
520
521typedef struct frame_id (gdbarch_unwind_dummy_id_ftype) (struct gdbarch *gdbarch, struct frame_info *info);
522extern struct frame_id gdbarch_unwind_dummy_id (struct gdbarch *gdbarch, struct frame_info *info);
523extern void set_gdbarch_unwind_dummy_id (struct gdbarch *gdbarch, gdbarch_unwind_dummy_id_ftype *unwind_dummy_id);
524
f3be58bc
AC
525/* Implement UNWIND_DUMMY_ID and PUSH_DUMMY_CALL, then delete
526 DEPRECATED_FP_REGNUM. */
527
f3be58bc
AC
528extern int gdbarch_deprecated_fp_regnum (struct gdbarch *gdbarch);
529extern void set_gdbarch_deprecated_fp_regnum (struct gdbarch *gdbarch, int deprecated_fp_regnum);
5010d38b 530#if !defined (GDB_TM_FILE) && defined (DEPRECATED_FP_REGNUM)
f3be58bc
AC
531#error "Non multi-arch definition of DEPRECATED_FP_REGNUM"
532#endif
533#if !defined (DEPRECATED_FP_REGNUM)
534#define DEPRECATED_FP_REGNUM (gdbarch_deprecated_fp_regnum (current_gdbarch))
535#endif
536
a86c5fc9 537/* See gdbint.texinfo. See infcall.c. */
b8de8283
AC
538
539extern int gdbarch_push_dummy_call_p (struct gdbarch *gdbarch);
540
7d9b040b
RC
541typedef CORE_ADDR (gdbarch_push_dummy_call_ftype) (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);
542extern 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);
b8de8283
AC
543extern void set_gdbarch_push_dummy_call (struct gdbarch *gdbarch, gdbarch_push_dummy_call_ftype *push_dummy_call);
544
b8de8283
AC
545/* DEPRECATED_REGISTER_SIZE can be deleted. */
546
547extern int gdbarch_deprecated_register_size (struct gdbarch *gdbarch);
548extern void set_gdbarch_deprecated_register_size (struct gdbarch *gdbarch, int deprecated_register_size);
5010d38b 549#if !defined (GDB_TM_FILE) && defined (DEPRECATED_REGISTER_SIZE)
b8de8283
AC
550#error "Non multi-arch definition of DEPRECATED_REGISTER_SIZE"
551#endif
552#if !defined (DEPRECATED_REGISTER_SIZE)
553#define DEPRECATED_REGISTER_SIZE (gdbarch_deprecated_register_size (current_gdbarch))
554#endif
555
b8de8283
AC
556extern int gdbarch_call_dummy_location (struct gdbarch *gdbarch);
557extern void set_gdbarch_call_dummy_location (struct gdbarch *gdbarch, int call_dummy_location);
5010d38b 558#if !defined (GDB_TM_FILE) && defined (CALL_DUMMY_LOCATION)
b8de8283
AC
559#error "Non multi-arch definition of CALL_DUMMY_LOCATION"
560#endif
561#if !defined (CALL_DUMMY_LOCATION)
562#define CALL_DUMMY_LOCATION (gdbarch_call_dummy_location (current_gdbarch))
563#endif
564
b8de8283
AC
565extern int gdbarch_push_dummy_code_p (struct gdbarch *gdbarch);
566
567typedef CORE_ADDR (gdbarch_push_dummy_code_ftype) (struct gdbarch *gdbarch, CORE_ADDR sp, CORE_ADDR funaddr, int using_gcc, struct value **args, int nargs, struct type *value_type, CORE_ADDR *real_pc, CORE_ADDR *bp_addr);
568extern CORE_ADDR gdbarch_push_dummy_code (struct gdbarch *gdbarch, CORE_ADDR sp, CORE_ADDR funaddr, int using_gcc, struct value **args, int nargs, struct type *value_type, CORE_ADDR *real_pc, CORE_ADDR *bp_addr);
569extern void set_gdbarch_push_dummy_code (struct gdbarch *gdbarch, gdbarch_push_dummy_code_ftype *push_dummy_code);
570
0ab7a791
AC
571typedef void (gdbarch_print_registers_info_ftype) (struct gdbarch *gdbarch, struct ui_file *file, struct frame_info *frame, int regnum, int all);
572extern void gdbarch_print_registers_info (struct gdbarch *gdbarch, struct ui_file *file, struct frame_info *frame, int regnum, int all);
573extern void set_gdbarch_print_registers_info (struct gdbarch *gdbarch, gdbarch_print_registers_info_ftype *print_registers_info);
574
23e3a7ac
AC
575extern int gdbarch_print_float_info_p (struct gdbarch *gdbarch);
576
577typedef void (gdbarch_print_float_info_ftype) (struct gdbarch *gdbarch, struct ui_file *file, struct frame_info *frame, const char *args);
578extern void gdbarch_print_float_info (struct gdbarch *gdbarch, struct ui_file *file, struct frame_info *frame, const char *args);
5e74b15c 579extern void set_gdbarch_print_float_info (struct gdbarch *gdbarch, gdbarch_print_float_info_ftype *print_float_info);
5e74b15c 580
e76f1f2e
AC
581extern int gdbarch_print_vector_info_p (struct gdbarch *gdbarch);
582
583typedef void (gdbarch_print_vector_info_ftype) (struct gdbarch *gdbarch, struct ui_file *file, struct frame_info *frame, const char *args);
584extern void gdbarch_print_vector_info (struct gdbarch *gdbarch, struct ui_file *file, struct frame_info *frame, const char *args);
585extern void set_gdbarch_print_vector_info (struct gdbarch *gdbarch, gdbarch_print_vector_info_ftype *print_vector_info);
586
7c7651b2
AC
587/* MAP a GDB RAW register number onto a simulator register number. See
588 also include/...-sim.h. */
589
7c7651b2
AC
590typedef int (gdbarch_register_sim_regno_ftype) (int reg_nr);
591extern int gdbarch_register_sim_regno (struct gdbarch *gdbarch, int reg_nr);
592extern void set_gdbarch_register_sim_regno (struct gdbarch *gdbarch, gdbarch_register_sim_regno_ftype *register_sim_regno);
5010d38b 593#if !defined (GDB_TM_FILE) && defined (REGISTER_SIM_REGNO)
83905903
AC
594#error "Non multi-arch definition of REGISTER_SIM_REGNO"
595#endif
c25083af 596#if !defined (REGISTER_SIM_REGNO)
7c7651b2
AC
597#define REGISTER_SIM_REGNO(reg_nr) (gdbarch_register_sim_regno (current_gdbarch, reg_nr))
598#endif
7c7651b2 599
2649061d
AC
600#if defined (REGISTER_BYTES_OK)
601/* Legacy for systems yet to multi-arch REGISTER_BYTES_OK */
eee30e78 602#if !defined (REGISTER_BYTES_OK_P)
2649061d
AC
603#define REGISTER_BYTES_OK_P() (1)
604#endif
eee30e78 605#endif
2649061d 606
2649061d 607extern int gdbarch_register_bytes_ok_p (struct gdbarch *gdbarch);
5010d38b 608#if !defined (GDB_TM_FILE) && defined (REGISTER_BYTES_OK_P)
83905903
AC
609#error "Non multi-arch definition of REGISTER_BYTES_OK"
610#endif
bceabdd8 611#if !defined (REGISTER_BYTES_OK_P)
2649061d
AC
612#define REGISTER_BYTES_OK_P() (gdbarch_register_bytes_ok_p (current_gdbarch))
613#endif
614
2649061d
AC
615typedef int (gdbarch_register_bytes_ok_ftype) (long nr_bytes);
616extern int gdbarch_register_bytes_ok (struct gdbarch *gdbarch, long nr_bytes);
617extern void set_gdbarch_register_bytes_ok (struct gdbarch *gdbarch, gdbarch_register_bytes_ok_ftype *register_bytes_ok);
5010d38b 618#if !defined (GDB_TM_FILE) && defined (REGISTER_BYTES_OK)
83905903
AC
619#error "Non multi-arch definition of REGISTER_BYTES_OK"
620#endif
c25083af 621#if !defined (REGISTER_BYTES_OK)
2649061d
AC
622#define REGISTER_BYTES_OK(nr_bytes) (gdbarch_register_bytes_ok (current_gdbarch, nr_bytes))
623#endif
2649061d 624
01fb7433
AC
625typedef int (gdbarch_cannot_fetch_register_ftype) (int regnum);
626extern int gdbarch_cannot_fetch_register (struct gdbarch *gdbarch, int regnum);
627extern void set_gdbarch_cannot_fetch_register (struct gdbarch *gdbarch, gdbarch_cannot_fetch_register_ftype *cannot_fetch_register);
5010d38b 628#if !defined (GDB_TM_FILE) && defined (CANNOT_FETCH_REGISTER)
83905903
AC
629#error "Non multi-arch definition of CANNOT_FETCH_REGISTER"
630#endif
c25083af 631#if !defined (CANNOT_FETCH_REGISTER)
01fb7433
AC
632#define CANNOT_FETCH_REGISTER(regnum) (gdbarch_cannot_fetch_register (current_gdbarch, regnum))
633#endif
01fb7433 634
01fb7433
AC
635typedef int (gdbarch_cannot_store_register_ftype) (int regnum);
636extern int gdbarch_cannot_store_register (struct gdbarch *gdbarch, int regnum);
637extern void set_gdbarch_cannot_store_register (struct gdbarch *gdbarch, gdbarch_cannot_store_register_ftype *cannot_store_register);
5010d38b 638#if !defined (GDB_TM_FILE) && defined (CANNOT_STORE_REGISTER)
83905903
AC
639#error "Non multi-arch definition of CANNOT_STORE_REGISTER"
640#endif
c25083af 641#if !defined (CANNOT_STORE_REGISTER)
01fb7433
AC
642#define CANNOT_STORE_REGISTER(regnum) (gdbarch_cannot_store_register (current_gdbarch, regnum))
643#endif
01fb7433 644
9df628e0
RE
645/* setjmp/longjmp support. */
646
647#if defined (GET_LONGJMP_TARGET)
648/* Legacy for systems yet to multi-arch GET_LONGJMP_TARGET */
649#if !defined (GET_LONGJMP_TARGET_P)
650#define GET_LONGJMP_TARGET_P() (1)
651#endif
652#endif
653
9df628e0 654extern int gdbarch_get_longjmp_target_p (struct gdbarch *gdbarch);
5010d38b 655#if !defined (GDB_TM_FILE) && defined (GET_LONGJMP_TARGET_P)
9df628e0
RE
656#error "Non multi-arch definition of GET_LONGJMP_TARGET"
657#endif
bceabdd8 658#if !defined (GET_LONGJMP_TARGET_P)
b8de8283 659#define GET_LONGJMP_TARGET_P() (gdbarch_get_longjmp_target_p (current_gdbarch))
0f71a2f6 660#endif
0f71a2f6 661
b8de8283
AC
662typedef int (gdbarch_get_longjmp_target_ftype) (CORE_ADDR *pc);
663extern int gdbarch_get_longjmp_target (struct gdbarch *gdbarch, CORE_ADDR *pc);
664extern void set_gdbarch_get_longjmp_target (struct gdbarch *gdbarch, gdbarch_get_longjmp_target_ftype *get_longjmp_target);
5010d38b 665#if !defined (GDB_TM_FILE) && defined (GET_LONGJMP_TARGET)
b8de8283 666#error "Non multi-arch definition of GET_LONGJMP_TARGET"
83905903 667#endif
b8de8283
AC
668#if !defined (GET_LONGJMP_TARGET)
669#define GET_LONGJMP_TARGET(pc) (gdbarch_get_longjmp_target (current_gdbarch, pc))
0f71a2f6 670#endif
0f71a2f6 671
104c1213
JM
672extern int gdbarch_believe_pcc_promotion (struct gdbarch *gdbarch);
673extern void set_gdbarch_believe_pcc_promotion (struct gdbarch *gdbarch, int believe_pcc_promotion);
5010d38b 674#if !defined (GDB_TM_FILE) && defined (BELIEVE_PCC_PROMOTION)
83905903
AC
675#error "Non multi-arch definition of BELIEVE_PCC_PROMOTION"
676#endif
c25083af 677#if !defined (BELIEVE_PCC_PROMOTION)
0f71a2f6
JM
678#define BELIEVE_PCC_PROMOTION (gdbarch_believe_pcc_promotion (current_gdbarch))
679#endif
0f71a2f6 680
ff2e87ac
AC
681typedef int (gdbarch_convert_register_p_ftype) (int regnum, struct type *type);
682extern int gdbarch_convert_register_p (struct gdbarch *gdbarch, int regnum, struct type *type);
13d01224 683extern void set_gdbarch_convert_register_p (struct gdbarch *gdbarch, gdbarch_convert_register_p_ftype *convert_register_p);
5010d38b 684#if !defined (GDB_TM_FILE) && defined (CONVERT_REGISTER_P)
13d01224
AC
685#error "Non multi-arch definition of CONVERT_REGISTER_P"
686#endif
c25083af 687#if !defined (CONVERT_REGISTER_P)
ff2e87ac 688#define CONVERT_REGISTER_P(regnum, type) (gdbarch_convert_register_p (current_gdbarch, regnum, type))
13d01224 689#endif
13d01224 690
b60c417a
AC
691typedef void (gdbarch_register_to_value_ftype) (struct frame_info *frame, int regnum, struct type *type, gdb_byte *buf);
692extern void gdbarch_register_to_value (struct gdbarch *gdbarch, struct frame_info *frame, int regnum, struct type *type, gdb_byte *buf);
13d01224 693extern void set_gdbarch_register_to_value (struct gdbarch *gdbarch, gdbarch_register_to_value_ftype *register_to_value);
5010d38b 694#if !defined (GDB_TM_FILE) && defined (REGISTER_TO_VALUE)
13d01224
AC
695#error "Non multi-arch definition of REGISTER_TO_VALUE"
696#endif
c25083af 697#if !defined (REGISTER_TO_VALUE)
ff2e87ac 698#define REGISTER_TO_VALUE(frame, regnum, type, buf) (gdbarch_register_to_value (current_gdbarch, frame, regnum, type, buf))
13d01224 699#endif
13d01224 700
b60c417a
AC
701typedef void (gdbarch_value_to_register_ftype) (struct frame_info *frame, int regnum, struct type *type, const gdb_byte *buf);
702extern void gdbarch_value_to_register (struct gdbarch *gdbarch, struct frame_info *frame, int regnum, struct type *type, const gdb_byte *buf);
13d01224 703extern void set_gdbarch_value_to_register (struct gdbarch *gdbarch, gdbarch_value_to_register_ftype *value_to_register);
5010d38b 704#if !defined (GDB_TM_FILE) && defined (VALUE_TO_REGISTER)
13d01224
AC
705#error "Non multi-arch definition of VALUE_TO_REGISTER"
706#endif
c25083af 707#if !defined (VALUE_TO_REGISTER)
ff2e87ac 708#define VALUE_TO_REGISTER(frame, regnum, type, buf) (gdbarch_value_to_register (current_gdbarch, frame, regnum, type, buf))
13d01224 709#endif
13d01224 710
9acbedc0
UW
711/* Construct a value representing the contents of register REGNUM in
712 frame FRAME, interpreted as type TYPE. The routine needs to
713 allocate and return a struct value with all value attributes
714 (but not the value contents) filled in. */
715
716typedef struct value * (gdbarch_value_from_register_ftype) (struct type *type, int regnum, struct frame_info *frame);
717extern struct value * gdbarch_value_from_register (struct gdbarch *gdbarch, struct type *type, int regnum, struct frame_info *frame);
718extern void set_gdbarch_value_from_register (struct gdbarch *gdbarch, gdbarch_value_from_register_ftype *value_from_register);
719
b60c417a
AC
720typedef CORE_ADDR (gdbarch_pointer_to_address_ftype) (struct type *type, const gdb_byte *buf);
721extern CORE_ADDR gdbarch_pointer_to_address (struct gdbarch *gdbarch, struct type *type, const gdb_byte *buf);
4478b372 722extern void set_gdbarch_pointer_to_address (struct gdbarch *gdbarch, gdbarch_pointer_to_address_ftype *pointer_to_address);
5010d38b 723#if !defined (GDB_TM_FILE) && defined (POINTER_TO_ADDRESS)
83905903
AC
724#error "Non multi-arch definition of POINTER_TO_ADDRESS"
725#endif
c25083af 726#if !defined (POINTER_TO_ADDRESS)
4478b372
JB
727#define POINTER_TO_ADDRESS(type, buf) (gdbarch_pointer_to_address (current_gdbarch, type, buf))
728#endif
33489c5b 729
b60c417a
AC
730typedef void (gdbarch_address_to_pointer_ftype) (struct type *type, gdb_byte *buf, CORE_ADDR addr);
731extern void gdbarch_address_to_pointer (struct gdbarch *gdbarch, struct type *type, gdb_byte *buf, CORE_ADDR addr);
4478b372 732extern void set_gdbarch_address_to_pointer (struct gdbarch *gdbarch, gdbarch_address_to_pointer_ftype *address_to_pointer);
5010d38b 733#if !defined (GDB_TM_FILE) && defined (ADDRESS_TO_POINTER)
83905903
AC
734#error "Non multi-arch definition of ADDRESS_TO_POINTER"
735#endif
c25083af 736#if !defined (ADDRESS_TO_POINTER)
4478b372
JB
737#define ADDRESS_TO_POINTER(type, buf, addr) (gdbarch_address_to_pointer (current_gdbarch, type, buf, addr))
738#endif
33489c5b 739
fc0c74b1 740extern int gdbarch_integer_to_address_p (struct gdbarch *gdbarch);
fc0c74b1 741
fc1a4b47
AC
742typedef CORE_ADDR (gdbarch_integer_to_address_ftype) (struct gdbarch *gdbarch, struct type *type, const gdb_byte *buf);
743extern CORE_ADDR gdbarch_integer_to_address (struct gdbarch *gdbarch, struct type *type, const gdb_byte *buf);
fc0c74b1 744extern void set_gdbarch_integer_to_address (struct gdbarch *gdbarch, gdbarch_integer_to_address_ftype *integer_to_address);
fc0c74b1 745
a86c5fc9 746/* NOTE: kettenis/2005-09-01: Replaced by PUSH_DUMMY_CALL. */
4183d812
AC
747
748#if defined (DEPRECATED_STORE_STRUCT_RETURN)
749/* Legacy for systems yet to multi-arch DEPRECATED_STORE_STRUCT_RETURN */
750#if !defined (DEPRECATED_STORE_STRUCT_RETURN_P)
751#define DEPRECATED_STORE_STRUCT_RETURN_P() (1)
752#endif
753#endif
754
4183d812 755extern int gdbarch_deprecated_store_struct_return_p (struct gdbarch *gdbarch);
5010d38b 756#if !defined (GDB_TM_FILE) && defined (DEPRECATED_STORE_STRUCT_RETURN_P)
4183d812
AC
757#error "Non multi-arch definition of DEPRECATED_STORE_STRUCT_RETURN"
758#endif
bceabdd8 759#if !defined (DEPRECATED_STORE_STRUCT_RETURN_P)
4183d812
AC
760#define DEPRECATED_STORE_STRUCT_RETURN_P() (gdbarch_deprecated_store_struct_return_p (current_gdbarch))
761#endif
762
4183d812
AC
763typedef void (gdbarch_deprecated_store_struct_return_ftype) (CORE_ADDR addr, CORE_ADDR sp);
764extern void gdbarch_deprecated_store_struct_return (struct gdbarch *gdbarch, CORE_ADDR addr, CORE_ADDR sp);
765extern void set_gdbarch_deprecated_store_struct_return (struct gdbarch *gdbarch, gdbarch_deprecated_store_struct_return_ftype *deprecated_store_struct_return);
5010d38b 766#if !defined (GDB_TM_FILE) && defined (DEPRECATED_STORE_STRUCT_RETURN)
4183d812 767#error "Non multi-arch definition of DEPRECATED_STORE_STRUCT_RETURN"
83905903 768#endif
c25083af 769#if !defined (DEPRECATED_STORE_STRUCT_RETURN)
4183d812 770#define DEPRECATED_STORE_STRUCT_RETURN(addr, sp) (gdbarch_deprecated_store_struct_return (current_gdbarch, addr, sp))
0f71a2f6 771#endif
0f71a2f6 772
92ad9cd9
AC
773/* It has been suggested that this, well actually its predecessor,
774 should take the type/value of the function to be called and not the
750eb019
AC
775 return type. This is left as an exercise for the reader.
776 NOTE: cagney/2004-06-13: The function stack.c:return_command uses
777 the predicate with default hack to avoid calling STORE_RETURN_VALUE
778 (via legacy_return_value), when a small struct is involved. */
92ad9cd9
AC
779
780extern int gdbarch_return_value_p (struct gdbarch *gdbarch);
781
b60c417a
AC
782typedef enum return_value_convention (gdbarch_return_value_ftype) (struct gdbarch *gdbarch, struct type *valtype, struct regcache *regcache, gdb_byte *readbuf, const gdb_byte *writebuf);
783extern enum return_value_convention gdbarch_return_value (struct gdbarch *gdbarch, struct type *valtype, struct regcache *regcache, gdb_byte *readbuf, const gdb_byte *writebuf);
92ad9cd9
AC
784extern void set_gdbarch_return_value (struct gdbarch *gdbarch, gdbarch_return_value_ftype *return_value);
785
b5622e8d
AC
786/* The deprecated methods EXTRACT_RETURN_VALUE, STORE_RETURN_VALUE,
787 DEPRECATED_EXTRACT_STRUCT_VALUE_ADDRESS and
788 DEPRECATED_USE_STRUCT_CONVENTION have all been folded into
789 RETURN_VALUE. */
92ad9cd9 790
b60c417a
AC
791typedef void (gdbarch_extract_return_value_ftype) (struct type *type, struct regcache *regcache, gdb_byte *valbuf);
792extern void gdbarch_extract_return_value (struct gdbarch *gdbarch, struct type *type, struct regcache *regcache, gdb_byte *valbuf);
ebba8386 793extern void set_gdbarch_extract_return_value (struct gdbarch *gdbarch, gdbarch_extract_return_value_ftype *extract_return_value);
5010d38b 794#if !defined (GDB_TM_FILE) && defined (EXTRACT_RETURN_VALUE)
ebba8386
AC
795#error "Non multi-arch definition of EXTRACT_RETURN_VALUE"
796#endif
c25083af 797#if !defined (EXTRACT_RETURN_VALUE)
ebba8386
AC
798#define EXTRACT_RETURN_VALUE(type, regcache, valbuf) (gdbarch_extract_return_value (current_gdbarch, type, regcache, valbuf))
799#endif
ebba8386 800
b60c417a
AC
801typedef void (gdbarch_store_return_value_ftype) (struct type *type, struct regcache *regcache, const gdb_byte *valbuf);
802extern void gdbarch_store_return_value (struct gdbarch *gdbarch, struct type *type, struct regcache *regcache, const gdb_byte *valbuf);
104c1213 803extern void set_gdbarch_store_return_value (struct gdbarch *gdbarch, gdbarch_store_return_value_ftype *store_return_value);
5010d38b 804#if !defined (GDB_TM_FILE) && defined (STORE_RETURN_VALUE)
83905903
AC
805#error "Non multi-arch definition of STORE_RETURN_VALUE"
806#endif
c25083af 807#if !defined (STORE_RETURN_VALUE)
ebba8386
AC
808#define STORE_RETURN_VALUE(type, regcache, valbuf) (gdbarch_store_return_value (current_gdbarch, type, regcache, valbuf))
809#endif
ebba8386 810
b5622e8d
AC
811typedef int (gdbarch_deprecated_use_struct_convention_ftype) (int gcc_p, struct type *value_type);
812extern int gdbarch_deprecated_use_struct_convention (struct gdbarch *gdbarch, int gcc_p, struct type *value_type);
813extern void set_gdbarch_deprecated_use_struct_convention (struct gdbarch *gdbarch, gdbarch_deprecated_use_struct_convention_ftype *deprecated_use_struct_convention);
5010d38b 814#if !defined (GDB_TM_FILE) && defined (DEPRECATED_USE_STRUCT_CONVENTION)
b5622e8d 815#error "Non multi-arch definition of DEPRECATED_USE_STRUCT_CONVENTION"
92ad9cd9 816#endif
b5622e8d
AC
817#if !defined (DEPRECATED_USE_STRUCT_CONVENTION)
818#define DEPRECATED_USE_STRUCT_CONVENTION(gcc_p, value_type) (gdbarch_deprecated_use_struct_convention (current_gdbarch, gcc_p, value_type))
92ad9cd9
AC
819#endif
820
74055713
AC
821/* As of 2004-01-17 only the 32-bit SPARC ABI has been identified as an
822 ABI suitable for the implementation of a robust extract
823 struct-convention return-value address method (the sparc saves the
824 address in the callers frame). All the other cases so far examined,
825 the DEPRECATED_EXTRACT_STRUCT_VALUE implementation has been
826 erreneous - the code was incorrectly assuming that the return-value
827 address, stored in a register, was preserved across the entire
828 function call.
829 For the moment retain DEPRECATED_EXTRACT_STRUCT_VALUE as a marker of
830 the ABIs that are still to be analyzed - perhaps this should simply
831 be deleted. The commented out extract_returned_value_address method
832 is provided as a starting point for the 32-bit SPARC. It, or
833 something like it, along with changes to both infcmd.c and stack.c
834 will be needed for that case to work. NB: It is passed the callers
835 frame since it is only after the callee has returned that this
836 function is used.
57010b1c 837 M::CORE_ADDR:extract_returned_value_address:struct frame_info *caller_frame:caller_frame */
74055713
AC
838
839#if defined (DEPRECATED_EXTRACT_STRUCT_VALUE_ADDRESS)
840/* Legacy for systems yet to multi-arch DEPRECATED_EXTRACT_STRUCT_VALUE_ADDRESS */
841#if !defined (DEPRECATED_EXTRACT_STRUCT_VALUE_ADDRESS_P)
842#define DEPRECATED_EXTRACT_STRUCT_VALUE_ADDRESS_P() (1)
049ee0e4
AC
843#endif
844#endif
845
74055713 846extern int gdbarch_deprecated_extract_struct_value_address_p (struct gdbarch *gdbarch);
5010d38b 847#if !defined (GDB_TM_FILE) && defined (DEPRECATED_EXTRACT_STRUCT_VALUE_ADDRESS_P)
74055713 848#error "Non multi-arch definition of DEPRECATED_EXTRACT_STRUCT_VALUE_ADDRESS"
049ee0e4 849#endif
bceabdd8 850#if !defined (DEPRECATED_EXTRACT_STRUCT_VALUE_ADDRESS_P)
74055713 851#define DEPRECATED_EXTRACT_STRUCT_VALUE_ADDRESS_P() (gdbarch_deprecated_extract_struct_value_address_p (current_gdbarch))
049ee0e4
AC
852#endif
853
74055713
AC
854typedef CORE_ADDR (gdbarch_deprecated_extract_struct_value_address_ftype) (struct regcache *regcache);
855extern CORE_ADDR gdbarch_deprecated_extract_struct_value_address (struct gdbarch *gdbarch, struct regcache *regcache);
856extern void set_gdbarch_deprecated_extract_struct_value_address (struct gdbarch *gdbarch, gdbarch_deprecated_extract_struct_value_address_ftype *deprecated_extract_struct_value_address);
5010d38b 857#if !defined (GDB_TM_FILE) && defined (DEPRECATED_EXTRACT_STRUCT_VALUE_ADDRESS)
74055713 858#error "Non multi-arch definition of DEPRECATED_EXTRACT_STRUCT_VALUE_ADDRESS"
049ee0e4 859#endif
74055713
AC
860#if !defined (DEPRECATED_EXTRACT_STRUCT_VALUE_ADDRESS)
861#define DEPRECATED_EXTRACT_STRUCT_VALUE_ADDRESS(regcache) (gdbarch_deprecated_extract_struct_value_address (current_gdbarch, regcache))
049ee0e4 862#endif
049ee0e4 863
104c1213
JM
864typedef CORE_ADDR (gdbarch_skip_prologue_ftype) (CORE_ADDR ip);
865extern CORE_ADDR gdbarch_skip_prologue (struct gdbarch *gdbarch, CORE_ADDR ip);
866extern void set_gdbarch_skip_prologue (struct gdbarch *gdbarch, gdbarch_skip_prologue_ftype *skip_prologue);
5010d38b 867#if !defined (GDB_TM_FILE) && defined (SKIP_PROLOGUE)
83905903
AC
868#error "Non multi-arch definition of SKIP_PROLOGUE"
869#endif
c25083af 870#if !defined (SKIP_PROLOGUE)
0f71a2f6
JM
871#define SKIP_PROLOGUE(ip) (gdbarch_skip_prologue (current_gdbarch, ip))
872#endif
0f71a2f6 873
104c1213
JM
874typedef int (gdbarch_inner_than_ftype) (CORE_ADDR lhs, CORE_ADDR rhs);
875extern int gdbarch_inner_than (struct gdbarch *gdbarch, CORE_ADDR lhs, CORE_ADDR rhs);
876extern void set_gdbarch_inner_than (struct gdbarch *gdbarch, gdbarch_inner_than_ftype *inner_than);
5010d38b 877#if !defined (GDB_TM_FILE) && defined (INNER_THAN)
83905903
AC
878#error "Non multi-arch definition of INNER_THAN"
879#endif
c25083af 880#if !defined (INNER_THAN)
0f71a2f6
JM
881#define INNER_THAN(lhs, rhs) (gdbarch_inner_than (current_gdbarch, lhs, rhs))
882#endif
0f71a2f6 883
fc1a4b47
AC
884typedef const gdb_byte * (gdbarch_breakpoint_from_pc_ftype) (CORE_ADDR *pcptr, int *lenptr);
885extern const gdb_byte * gdbarch_breakpoint_from_pc (struct gdbarch *gdbarch, CORE_ADDR *pcptr, int *lenptr);
104c1213 886extern void set_gdbarch_breakpoint_from_pc (struct gdbarch *gdbarch, gdbarch_breakpoint_from_pc_ftype *breakpoint_from_pc);
5010d38b 887#if !defined (GDB_TM_FILE) && defined (BREAKPOINT_FROM_PC)
83905903
AC
888#error "Non multi-arch definition of BREAKPOINT_FROM_PC"
889#endif
c25083af 890#if !defined (BREAKPOINT_FROM_PC)
0f71a2f6
JM
891#define BREAKPOINT_FROM_PC(pcptr, lenptr) (gdbarch_breakpoint_from_pc (current_gdbarch, pcptr, lenptr))
892#endif
33489c5b 893
a1131521
KB
894extern int gdbarch_adjust_breakpoint_address_p (struct gdbarch *gdbarch);
895
896typedef CORE_ADDR (gdbarch_adjust_breakpoint_address_ftype) (struct gdbarch *gdbarch, CORE_ADDR bpaddr);
897extern CORE_ADDR gdbarch_adjust_breakpoint_address (struct gdbarch *gdbarch, CORE_ADDR bpaddr);
898extern void set_gdbarch_adjust_breakpoint_address (struct gdbarch *gdbarch, gdbarch_adjust_breakpoint_address_ftype *adjust_breakpoint_address);
899
8181d85f
DJ
900typedef int (gdbarch_memory_insert_breakpoint_ftype) (struct bp_target_info *bp_tgt);
901extern int gdbarch_memory_insert_breakpoint (struct gdbarch *gdbarch, struct bp_target_info *bp_tgt);
917317f4 902extern void set_gdbarch_memory_insert_breakpoint (struct gdbarch *gdbarch, gdbarch_memory_insert_breakpoint_ftype *memory_insert_breakpoint);
5010d38b 903#if !defined (GDB_TM_FILE) && defined (MEMORY_INSERT_BREAKPOINT)
83905903
AC
904#error "Non multi-arch definition of MEMORY_INSERT_BREAKPOINT"
905#endif
c25083af 906#if !defined (MEMORY_INSERT_BREAKPOINT)
8181d85f 907#define MEMORY_INSERT_BREAKPOINT(bp_tgt) (gdbarch_memory_insert_breakpoint (current_gdbarch, bp_tgt))
917317f4 908#endif
33489c5b 909
8181d85f
DJ
910typedef int (gdbarch_memory_remove_breakpoint_ftype) (struct bp_target_info *bp_tgt);
911extern int gdbarch_memory_remove_breakpoint (struct gdbarch *gdbarch, struct bp_target_info *bp_tgt);
917317f4 912extern void set_gdbarch_memory_remove_breakpoint (struct gdbarch *gdbarch, gdbarch_memory_remove_breakpoint_ftype *memory_remove_breakpoint);
5010d38b 913#if !defined (GDB_TM_FILE) && defined (MEMORY_REMOVE_BREAKPOINT)
83905903
AC
914#error "Non multi-arch definition of MEMORY_REMOVE_BREAKPOINT"
915#endif
c25083af 916#if !defined (MEMORY_REMOVE_BREAKPOINT)
8181d85f 917#define MEMORY_REMOVE_BREAKPOINT(bp_tgt) (gdbarch_memory_remove_breakpoint (current_gdbarch, bp_tgt))
917317f4 918#endif
917317f4 919
104c1213
JM
920extern CORE_ADDR gdbarch_decr_pc_after_break (struct gdbarch *gdbarch);
921extern void set_gdbarch_decr_pc_after_break (struct gdbarch *gdbarch, CORE_ADDR decr_pc_after_break);
5010d38b 922#if !defined (GDB_TM_FILE) && defined (DECR_PC_AFTER_BREAK)
83905903
AC
923#error "Non multi-arch definition of DECR_PC_AFTER_BREAK"
924#endif
c25083af 925#if !defined (DECR_PC_AFTER_BREAK)
0f71a2f6
JM
926#define DECR_PC_AFTER_BREAK (gdbarch_decr_pc_after_break (current_gdbarch))
927#endif
0f71a2f6 928
782263ab
AC
929/* A function can be addressed by either it's "pointer" (possibly a
930 descriptor address) or "entry point" (first executable instruction).
931 The method "convert_from_func_ptr_addr" converting the former to the
932 latter. DEPRECATED_FUNCTION_START_OFFSET is being used to implement
933 a simplified subset of that functionality - the function's address
934 corresponds to the "function pointer" and the function's start
935 corresponds to the "function entry point" - and hence is redundant. */
936
937extern CORE_ADDR gdbarch_deprecated_function_start_offset (struct gdbarch *gdbarch);
938extern void set_gdbarch_deprecated_function_start_offset (struct gdbarch *gdbarch, CORE_ADDR deprecated_function_start_offset);
5010d38b 939#if !defined (GDB_TM_FILE) && defined (DEPRECATED_FUNCTION_START_OFFSET)
782263ab
AC
940#error "Non multi-arch definition of DEPRECATED_FUNCTION_START_OFFSET"
941#endif
942#if !defined (DEPRECATED_FUNCTION_START_OFFSET)
943#define DEPRECATED_FUNCTION_START_OFFSET (gdbarch_deprecated_function_start_offset (current_gdbarch))
0f71a2f6 944#endif
0f71a2f6 945
f6684c31
AC
946typedef void (gdbarch_remote_translate_xfer_address_ftype) (struct gdbarch *gdbarch, struct regcache *regcache, CORE_ADDR gdb_addr, int gdb_len, CORE_ADDR *rem_addr, int *rem_len);
947extern void gdbarch_remote_translate_xfer_address (struct gdbarch *gdbarch, struct regcache *regcache, CORE_ADDR gdb_addr, int gdb_len, CORE_ADDR *rem_addr, int *rem_len);
104c1213 948extern void set_gdbarch_remote_translate_xfer_address (struct gdbarch *gdbarch, gdbarch_remote_translate_xfer_address_ftype *remote_translate_xfer_address);
0f71a2f6 949
b2756930
KB
950/* Fetch the target specific address used to represent a load module. */
951
952#if defined (FETCH_TLS_LOAD_MODULE_ADDRESS)
953/* Legacy for systems yet to multi-arch FETCH_TLS_LOAD_MODULE_ADDRESS */
954#if !defined (FETCH_TLS_LOAD_MODULE_ADDRESS_P)
955#define FETCH_TLS_LOAD_MODULE_ADDRESS_P() (1)
956#endif
957#endif
958
959extern int gdbarch_fetch_tls_load_module_address_p (struct gdbarch *gdbarch);
960#if !defined (GDB_TM_FILE) && defined (FETCH_TLS_LOAD_MODULE_ADDRESS_P)
961#error "Non multi-arch definition of FETCH_TLS_LOAD_MODULE_ADDRESS"
962#endif
963#if !defined (FETCH_TLS_LOAD_MODULE_ADDRESS_P)
964#define FETCH_TLS_LOAD_MODULE_ADDRESS_P() (gdbarch_fetch_tls_load_module_address_p (current_gdbarch))
965#endif
966
967typedef CORE_ADDR (gdbarch_fetch_tls_load_module_address_ftype) (struct objfile *objfile);
968extern CORE_ADDR gdbarch_fetch_tls_load_module_address (struct gdbarch *gdbarch, struct objfile *objfile);
969extern void set_gdbarch_fetch_tls_load_module_address (struct gdbarch *gdbarch, gdbarch_fetch_tls_load_module_address_ftype *fetch_tls_load_module_address);
970#if !defined (GDB_TM_FILE) && defined (FETCH_TLS_LOAD_MODULE_ADDRESS)
971#error "Non multi-arch definition of FETCH_TLS_LOAD_MODULE_ADDRESS"
972#endif
973#if !defined (FETCH_TLS_LOAD_MODULE_ADDRESS)
974#define FETCH_TLS_LOAD_MODULE_ADDRESS(objfile) (gdbarch_fetch_tls_load_module_address (current_gdbarch, objfile))
975#endif
976
104c1213
JM
977extern CORE_ADDR gdbarch_frame_args_skip (struct gdbarch *gdbarch);
978extern void set_gdbarch_frame_args_skip (struct gdbarch *gdbarch, CORE_ADDR frame_args_skip);
5010d38b 979#if !defined (GDB_TM_FILE) && defined (FRAME_ARGS_SKIP)
83905903
AC
980#error "Non multi-arch definition of FRAME_ARGS_SKIP"
981#endif
c25083af 982#if !defined (FRAME_ARGS_SKIP)
0f71a2f6
JM
983#define FRAME_ARGS_SKIP (gdbarch_frame_args_skip (current_gdbarch))
984#endif
0f71a2f6 985
12cc2063
AC
986extern int gdbarch_unwind_pc_p (struct gdbarch *gdbarch);
987
988typedef CORE_ADDR (gdbarch_unwind_pc_ftype) (struct gdbarch *gdbarch, struct frame_info *next_frame);
989extern CORE_ADDR gdbarch_unwind_pc (struct gdbarch *gdbarch, struct frame_info *next_frame);
990extern void set_gdbarch_unwind_pc (struct gdbarch *gdbarch, gdbarch_unwind_pc_ftype *unwind_pc);
991
a9e5fdc2
AC
992extern int gdbarch_unwind_sp_p (struct gdbarch *gdbarch);
993
994typedef CORE_ADDR (gdbarch_unwind_sp_ftype) (struct gdbarch *gdbarch, struct frame_info *next_frame);
995extern CORE_ADDR gdbarch_unwind_sp (struct gdbarch *gdbarch, struct frame_info *next_frame);
996extern void set_gdbarch_unwind_sp (struct gdbarch *gdbarch, gdbarch_unwind_sp_ftype *unwind_sp);
997
42efa47a
AC
998/* DEPRECATED_FRAME_LOCALS_ADDRESS as been replaced by the per-frame
999 frame-base. Enable frame-base before frame-unwind. */
1000
983a287a
AC
1001#if defined (FRAME_NUM_ARGS)
1002/* Legacy for systems yet to multi-arch FRAME_NUM_ARGS */
1003#if !defined (FRAME_NUM_ARGS_P)
1004#define FRAME_NUM_ARGS_P() (1)
1005#endif
1006#endif
1007
983a287a 1008extern int gdbarch_frame_num_args_p (struct gdbarch *gdbarch);
5010d38b 1009#if !defined (GDB_TM_FILE) && defined (FRAME_NUM_ARGS_P)
983a287a
AC
1010#error "Non multi-arch definition of FRAME_NUM_ARGS"
1011#endif
bceabdd8 1012#if !defined (FRAME_NUM_ARGS_P)
983a287a
AC
1013#define FRAME_NUM_ARGS_P() (gdbarch_frame_num_args_p (current_gdbarch))
1014#endif
1015
104c1213
JM
1016typedef int (gdbarch_frame_num_args_ftype) (struct frame_info *frame);
1017extern int gdbarch_frame_num_args (struct gdbarch *gdbarch, struct frame_info *frame);
1018extern void set_gdbarch_frame_num_args (struct gdbarch *gdbarch, gdbarch_frame_num_args_ftype *frame_num_args);
5010d38b 1019#if !defined (GDB_TM_FILE) && defined (FRAME_NUM_ARGS)
83905903
AC
1020#error "Non multi-arch definition of FRAME_NUM_ARGS"
1021#endif
c25083af 1022#if !defined (FRAME_NUM_ARGS)
0f71a2f6
JM
1023#define FRAME_NUM_ARGS(frame) (gdbarch_frame_num_args (current_gdbarch, frame))
1024#endif
0f71a2f6 1025
f27dd7fd
AC
1026/* DEPRECATED_STACK_ALIGN has been replaced by an initial aligning call
1027 to frame_align and the requirement that methods such as
1028 push_dummy_call and frame_red_zone_size maintain correct stack/frame
1029 alignment. */
1030
1031#if defined (DEPRECATED_STACK_ALIGN)
1032/* Legacy for systems yet to multi-arch DEPRECATED_STACK_ALIGN */
1033#if !defined (DEPRECATED_STACK_ALIGN_P)
1034#define DEPRECATED_STACK_ALIGN_P() (1)
2ada493a 1035#endif
eee30e78 1036#endif
2ada493a 1037
f27dd7fd 1038extern int gdbarch_deprecated_stack_align_p (struct gdbarch *gdbarch);
5010d38b 1039#if !defined (GDB_TM_FILE) && defined (DEPRECATED_STACK_ALIGN_P)
f27dd7fd 1040#error "Non multi-arch definition of DEPRECATED_STACK_ALIGN"
83905903 1041#endif
bceabdd8 1042#if !defined (DEPRECATED_STACK_ALIGN_P)
f27dd7fd 1043#define DEPRECATED_STACK_ALIGN_P() (gdbarch_deprecated_stack_align_p (current_gdbarch))
2ada493a
AC
1044#endif
1045
f27dd7fd
AC
1046typedef CORE_ADDR (gdbarch_deprecated_stack_align_ftype) (CORE_ADDR sp);
1047extern CORE_ADDR gdbarch_deprecated_stack_align (struct gdbarch *gdbarch, CORE_ADDR sp);
1048extern void set_gdbarch_deprecated_stack_align (struct gdbarch *gdbarch, gdbarch_deprecated_stack_align_ftype *deprecated_stack_align);
5010d38b 1049#if !defined (GDB_TM_FILE) && defined (DEPRECATED_STACK_ALIGN)
f27dd7fd 1050#error "Non multi-arch definition of DEPRECATED_STACK_ALIGN"
83905903 1051#endif
f27dd7fd
AC
1052#if !defined (DEPRECATED_STACK_ALIGN)
1053#define DEPRECATED_STACK_ALIGN(sp) (gdbarch_deprecated_stack_align (current_gdbarch, sp))
2ada493a
AC
1054#endif
1055
dc604539
AC
1056extern int gdbarch_frame_align_p (struct gdbarch *gdbarch);
1057
1058typedef CORE_ADDR (gdbarch_frame_align_ftype) (struct gdbarch *gdbarch, CORE_ADDR address);
1059extern CORE_ADDR gdbarch_frame_align (struct gdbarch *gdbarch, CORE_ADDR address);
1060extern void set_gdbarch_frame_align (struct gdbarch *gdbarch, gdbarch_frame_align_ftype *frame_align);
1061
192cb3d4
MK
1062/* DEPRECATED_REG_STRUCT_HAS_ADDR has been replaced by
1063 stabs_argument_has_addr. */
1064
88d89dbb
MK
1065#if defined (DEPRECATED_REG_STRUCT_HAS_ADDR)
1066/* Legacy for systems yet to multi-arch DEPRECATED_REG_STRUCT_HAS_ADDR */
1067#if !defined (DEPRECATED_REG_STRUCT_HAS_ADDR_P)
1068#define DEPRECATED_REG_STRUCT_HAS_ADDR_P() (1)
d03e67c9 1069#endif
eee30e78 1070#endif
d03e67c9 1071
88d89dbb 1072extern int gdbarch_deprecated_reg_struct_has_addr_p (struct gdbarch *gdbarch);
5010d38b 1073#if !defined (GDB_TM_FILE) && defined (DEPRECATED_REG_STRUCT_HAS_ADDR_P)
88d89dbb 1074#error "Non multi-arch definition of DEPRECATED_REG_STRUCT_HAS_ADDR"
83905903 1075#endif
bceabdd8 1076#if !defined (DEPRECATED_REG_STRUCT_HAS_ADDR_P)
88d89dbb 1077#define DEPRECATED_REG_STRUCT_HAS_ADDR_P() (gdbarch_deprecated_reg_struct_has_addr_p (current_gdbarch))
d03e67c9
AC
1078#endif
1079
88d89dbb
MK
1080typedef int (gdbarch_deprecated_reg_struct_has_addr_ftype) (int gcc_p, struct type *type);
1081extern int gdbarch_deprecated_reg_struct_has_addr (struct gdbarch *gdbarch, int gcc_p, struct type *type);
1082extern void set_gdbarch_deprecated_reg_struct_has_addr (struct gdbarch *gdbarch, gdbarch_deprecated_reg_struct_has_addr_ftype *deprecated_reg_struct_has_addr);
5010d38b 1083#if !defined (GDB_TM_FILE) && defined (DEPRECATED_REG_STRUCT_HAS_ADDR)
88d89dbb 1084#error "Non multi-arch definition of DEPRECATED_REG_STRUCT_HAS_ADDR"
83905903 1085#endif
88d89dbb
MK
1086#if !defined (DEPRECATED_REG_STRUCT_HAS_ADDR)
1087#define DEPRECATED_REG_STRUCT_HAS_ADDR(gcc_p, type) (gdbarch_deprecated_reg_struct_has_addr (current_gdbarch, gcc_p, type))
d03e67c9
AC
1088#endif
1089
192cb3d4
MK
1090typedef int (gdbarch_stabs_argument_has_addr_ftype) (struct gdbarch *gdbarch, struct type *type);
1091extern int gdbarch_stabs_argument_has_addr (struct gdbarch *gdbarch, struct type *type);
1092extern void set_gdbarch_stabs_argument_has_addr (struct gdbarch *gdbarch, gdbarch_stabs_argument_has_addr_ftype *stabs_argument_has_addr);
1093
8b148df9
AC
1094extern int gdbarch_frame_red_zone_size (struct gdbarch *gdbarch);
1095extern void set_gdbarch_frame_red_zone_size (struct gdbarch *gdbarch, int frame_red_zone_size);
5010d38b 1096#if !defined (GDB_TM_FILE) && defined (FRAME_RED_ZONE_SIZE)
8b148df9
AC
1097#error "Non multi-arch definition of FRAME_RED_ZONE_SIZE"
1098#endif
1099#if !defined (FRAME_RED_ZONE_SIZE)
1100#define FRAME_RED_ZONE_SIZE (gdbarch_frame_red_zone_size (current_gdbarch))
1101#endif
1102
e2d0e7eb
AC
1103typedef CORE_ADDR (gdbarch_convert_from_func_ptr_addr_ftype) (struct gdbarch *gdbarch, CORE_ADDR addr, struct target_ops *targ);
1104extern CORE_ADDR gdbarch_convert_from_func_ptr_addr (struct gdbarch *gdbarch, CORE_ADDR addr, struct target_ops *targ);
f517ea4e 1105extern void set_gdbarch_convert_from_func_ptr_addr (struct gdbarch *gdbarch, gdbarch_convert_from_func_ptr_addr_ftype *convert_from_func_ptr_addr);
f517ea4e 1106
875e1767
AC
1107/* On some machines there are bits in addresses which are not really
1108 part of the address, but are used by the kernel, the hardware, etc.
1109 for special purposes. ADDR_BITS_REMOVE takes out any such bits so
1110 we get a "real" address such as one would find in a symbol table.
1111 This is used only for addresses of instructions, and even then I'm
1112 not sure it's used in all contexts. It exists to deal with there
1113 being a few stray bits in the PC which would mislead us, not as some
1114 sort of generic thing to handle alignment or segmentation (it's
1115 possible it should be in TARGET_READ_PC instead). */
1116
875e1767
AC
1117typedef CORE_ADDR (gdbarch_addr_bits_remove_ftype) (CORE_ADDR addr);
1118extern CORE_ADDR gdbarch_addr_bits_remove (struct gdbarch *gdbarch, CORE_ADDR addr);
1119extern void set_gdbarch_addr_bits_remove (struct gdbarch *gdbarch, gdbarch_addr_bits_remove_ftype *addr_bits_remove);
5010d38b 1120#if !defined (GDB_TM_FILE) && defined (ADDR_BITS_REMOVE)
83905903
AC
1121#error "Non multi-arch definition of ADDR_BITS_REMOVE"
1122#endif
c25083af 1123#if !defined (ADDR_BITS_REMOVE)
875e1767
AC
1124#define ADDR_BITS_REMOVE(addr) (gdbarch_addr_bits_remove (current_gdbarch, addr))
1125#endif
875e1767 1126
2e092625 1127/* It is not at all clear why SMASH_TEXT_ADDRESS is not folded into
181c1381
RE
1128 ADDR_BITS_REMOVE. */
1129
181c1381
RE
1130typedef CORE_ADDR (gdbarch_smash_text_address_ftype) (CORE_ADDR addr);
1131extern CORE_ADDR gdbarch_smash_text_address (struct gdbarch *gdbarch, CORE_ADDR addr);
1132extern void set_gdbarch_smash_text_address (struct gdbarch *gdbarch, gdbarch_smash_text_address_ftype *smash_text_address);
5010d38b 1133#if !defined (GDB_TM_FILE) && defined (SMASH_TEXT_ADDRESS)
181c1381
RE
1134#error "Non multi-arch definition of SMASH_TEXT_ADDRESS"
1135#endif
c25083af 1136#if !defined (SMASH_TEXT_ADDRESS)
181c1381
RE
1137#define SMASH_TEXT_ADDRESS(addr) (gdbarch_smash_text_address (current_gdbarch, addr))
1138#endif
181c1381 1139
64c4637f
AC
1140/* FIXME/cagney/2001-01-18: This should be split in two. A target method that indicates if
1141 the target needs software single step. An ISA method to implement it.
1142
1143 FIXME/cagney/2001-01-18: This should be replaced with something that inserts breakpoints
1144 using the breakpoint system instead of blatting memory directly (as with rs6000).
1145
1146 FIXME/cagney/2001-01-18: The logic is backwards. It should be asking if the target can
1147 single step. If not, then implement single step using breakpoints. */
1148
1149#if defined (SOFTWARE_SINGLE_STEP)
1150/* Legacy for systems yet to multi-arch SOFTWARE_SINGLE_STEP */
1151#if !defined (SOFTWARE_SINGLE_STEP_P)
1152#define SOFTWARE_SINGLE_STEP_P() (1)
1153#endif
1154#endif
1155
64c4637f 1156extern int gdbarch_software_single_step_p (struct gdbarch *gdbarch);
5010d38b 1157#if !defined (GDB_TM_FILE) && defined (SOFTWARE_SINGLE_STEP_P)
83905903
AC
1158#error "Non multi-arch definition of SOFTWARE_SINGLE_STEP"
1159#endif
bceabdd8 1160#if !defined (SOFTWARE_SINGLE_STEP_P)
64c4637f
AC
1161#define SOFTWARE_SINGLE_STEP_P() (gdbarch_software_single_step_p (current_gdbarch))
1162#endif
1163
64c4637f
AC
1164typedef void (gdbarch_software_single_step_ftype) (enum target_signal sig, int insert_breakpoints_p);
1165extern void gdbarch_software_single_step (struct gdbarch *gdbarch, enum target_signal sig, int insert_breakpoints_p);
1166extern void set_gdbarch_software_single_step (struct gdbarch *gdbarch, gdbarch_software_single_step_ftype *software_single_step);
5010d38b 1167#if !defined (GDB_TM_FILE) && defined (SOFTWARE_SINGLE_STEP)
83905903
AC
1168#error "Non multi-arch definition of SOFTWARE_SINGLE_STEP"
1169#endif
c25083af 1170#if !defined (SOFTWARE_SINGLE_STEP)
64c4637f
AC
1171#define SOFTWARE_SINGLE_STEP(sig, insert_breakpoints_p) (gdbarch_software_single_step (current_gdbarch, sig, insert_breakpoints_p))
1172#endif
64c4637f 1173
3352ef37
AC
1174/* Return non-zero if the processor is executing a delay slot and a
1175 further single-step is needed before the instruction finishes. */
1176
1177extern int gdbarch_single_step_through_delay_p (struct gdbarch *gdbarch);
1178
1179typedef int (gdbarch_single_step_through_delay_ftype) (struct gdbarch *gdbarch, struct frame_info *frame);
1180extern int gdbarch_single_step_through_delay (struct gdbarch *gdbarch, struct frame_info *frame);
1181extern void set_gdbarch_single_step_through_delay (struct gdbarch *gdbarch, gdbarch_single_step_through_delay_ftype *single_step_through_delay);
1182
f6c40618 1183/* FIXME: cagney/2003-08-28: Need to find a better way of selecting the
b2fa5097 1184 disassembler. Perhaps objdump can handle it? */
f6c40618 1185
a89aa300
AC
1186typedef int (gdbarch_print_insn_ftype) (bfd_vma vma, struct disassemble_info *info);
1187extern int gdbarch_print_insn (struct gdbarch *gdbarch, bfd_vma vma, struct disassemble_info *info);
2bf0cb65 1188extern void set_gdbarch_print_insn (struct gdbarch *gdbarch, gdbarch_print_insn_ftype *print_insn);
5010d38b 1189#if !defined (GDB_TM_FILE) && defined (TARGET_PRINT_INSN)
2bf0cb65
EZ
1190#error "Non multi-arch definition of TARGET_PRINT_INSN"
1191#endif
c25083af 1192#if !defined (TARGET_PRINT_INSN)
2bf0cb65
EZ
1193#define TARGET_PRINT_INSN(vma, info) (gdbarch_print_insn (current_gdbarch, vma, info))
1194#endif
2bf0cb65 1195
bdcd319a
CV
1196typedef CORE_ADDR (gdbarch_skip_trampoline_code_ftype) (CORE_ADDR pc);
1197extern CORE_ADDR gdbarch_skip_trampoline_code (struct gdbarch *gdbarch, CORE_ADDR pc);
1198extern void set_gdbarch_skip_trampoline_code (struct gdbarch *gdbarch, gdbarch_skip_trampoline_code_ftype *skip_trampoline_code);
5010d38b 1199#if !defined (GDB_TM_FILE) && defined (SKIP_TRAMPOLINE_CODE)
bdcd319a
CV
1200#error "Non multi-arch definition of SKIP_TRAMPOLINE_CODE"
1201#endif
c25083af 1202#if !defined (SKIP_TRAMPOLINE_CODE)
bdcd319a
CV
1203#define SKIP_TRAMPOLINE_CODE(pc) (gdbarch_skip_trampoline_code (current_gdbarch, pc))
1204#endif
bdcd319a 1205
dea0c52f
MK
1206/* If IN_SOLIB_DYNSYM_RESOLVE_CODE returns true, and SKIP_SOLIB_RESOLVER
1207 evaluates non-zero, this is the address where the debugger will place
1208 a step-resume breakpoint to get us past the dynamic linker. */
1209
4c8c40e6 1210typedef CORE_ADDR (gdbarch_skip_solib_resolver_ftype) (struct gdbarch *gdbarch, CORE_ADDR pc);
dea0c52f
MK
1211extern CORE_ADDR gdbarch_skip_solib_resolver (struct gdbarch *gdbarch, CORE_ADDR pc);
1212extern void set_gdbarch_skip_solib_resolver (struct gdbarch *gdbarch, gdbarch_skip_solib_resolver_ftype *skip_solib_resolver);
dea0c52f 1213
d50355b6
MS
1214/* Some systems also have trampoline code for returning from shared libs. */
1215
d50355b6
MS
1216typedef int (gdbarch_in_solib_return_trampoline_ftype) (CORE_ADDR pc, char *name);
1217extern int gdbarch_in_solib_return_trampoline (struct gdbarch *gdbarch, CORE_ADDR pc, char *name);
1218extern void set_gdbarch_in_solib_return_trampoline (struct gdbarch *gdbarch, gdbarch_in_solib_return_trampoline_ftype *in_solib_return_trampoline);
5010d38b 1219#if !defined (GDB_TM_FILE) && defined (IN_SOLIB_RETURN_TRAMPOLINE)
d50355b6
MS
1220#error "Non multi-arch definition of IN_SOLIB_RETURN_TRAMPOLINE"
1221#endif
c25083af 1222#if !defined (IN_SOLIB_RETURN_TRAMPOLINE)
d50355b6
MS
1223#define IN_SOLIB_RETURN_TRAMPOLINE(pc, name) (gdbarch_in_solib_return_trampoline (current_gdbarch, pc, name))
1224#endif
d50355b6 1225
c12260ac
CV
1226/* A target might have problems with watchpoints as soon as the stack
1227 frame of the current function has been destroyed. This mostly happens
1228 as the first action in a funtion's epilogue. in_function_epilogue_p()
1229 is defined to return a non-zero value if either the given addr is one
1230 instruction after the stack destroying instruction up to the trailing
1231 return instruction or if we can figure out that the stack frame has
1232 already been invalidated regardless of the value of addr. Targets
1233 which don't suffer from that problem could just let this functionality
1234 untouched. */
1235
1236typedef int (gdbarch_in_function_epilogue_p_ftype) (struct gdbarch *gdbarch, CORE_ADDR addr);
1237extern int gdbarch_in_function_epilogue_p (struct gdbarch *gdbarch, CORE_ADDR addr);
1238extern void set_gdbarch_in_function_epilogue_p (struct gdbarch *gdbarch, gdbarch_in_function_epilogue_p_ftype *in_function_epilogue_p);
1239
552c04a7
TT
1240/* Given a vector of command-line arguments, return a newly allocated
1241 string which, when passed to the create_inferior function, will be
1242 parsed (on Unix systems, by the shell) to yield the same vector.
1243 This function should call error() if the argument vector is not
1244 representable for this target or if this target does not support
1245 command-line arguments.
1246 ARGC is the number of elements in the vector.
1247 ARGV is an array of strings, one per argument. */
1248
1249typedef char * (gdbarch_construct_inferior_arguments_ftype) (struct gdbarch *gdbarch, int argc, char **argv);
1250extern char * gdbarch_construct_inferior_arguments (struct gdbarch *gdbarch, int argc, char **argv);
1251extern void set_gdbarch_construct_inferior_arguments (struct gdbarch *gdbarch, gdbarch_construct_inferior_arguments_ftype *construct_inferior_arguments);
1252
a2cf933a
EZ
1253typedef void (gdbarch_elf_make_msymbol_special_ftype) (asymbol *sym, struct minimal_symbol *msym);
1254extern void gdbarch_elf_make_msymbol_special (struct gdbarch *gdbarch, asymbol *sym, struct minimal_symbol *msym);
1255extern void set_gdbarch_elf_make_msymbol_special (struct gdbarch *gdbarch, gdbarch_elf_make_msymbol_special_ftype *elf_make_msymbol_special);
5010d38b 1256#if !defined (GDB_TM_FILE) && defined (ELF_MAKE_MSYMBOL_SPECIAL)
a2cf933a
EZ
1257#error "Non multi-arch definition of ELF_MAKE_MSYMBOL_SPECIAL"
1258#endif
c25083af 1259#if !defined (ELF_MAKE_MSYMBOL_SPECIAL)
a2cf933a
EZ
1260#define ELF_MAKE_MSYMBOL_SPECIAL(sym, msym) (gdbarch_elf_make_msymbol_special (current_gdbarch, sym, msym))
1261#endif
a2cf933a 1262
a2cf933a
EZ
1263typedef void (gdbarch_coff_make_msymbol_special_ftype) (int val, struct minimal_symbol *msym);
1264extern void gdbarch_coff_make_msymbol_special (struct gdbarch *gdbarch, int val, struct minimal_symbol *msym);
1265extern void set_gdbarch_coff_make_msymbol_special (struct gdbarch *gdbarch, gdbarch_coff_make_msymbol_special_ftype *coff_make_msymbol_special);
5010d38b 1266#if !defined (GDB_TM_FILE) && defined (COFF_MAKE_MSYMBOL_SPECIAL)
a2cf933a
EZ
1267#error "Non multi-arch definition of COFF_MAKE_MSYMBOL_SPECIAL"
1268#endif
c25083af 1269#if !defined (COFF_MAKE_MSYMBOL_SPECIAL)
a2cf933a
EZ
1270#define COFF_MAKE_MSYMBOL_SPECIAL(val, msym) (gdbarch_coff_make_msymbol_special (current_gdbarch, val, msym))
1271#endif
a2cf933a 1272
5720643c
JB
1273extern const char * gdbarch_name_of_malloc (struct gdbarch *gdbarch);
1274extern void set_gdbarch_name_of_malloc (struct gdbarch *gdbarch, const char * name_of_malloc);
5010d38b 1275#if !defined (GDB_TM_FILE) && defined (NAME_OF_MALLOC)
5720643c
JB
1276#error "Non multi-arch definition of NAME_OF_MALLOC"
1277#endif
c25083af 1278#if !defined (NAME_OF_MALLOC)
5720643c
JB
1279#define NAME_OF_MALLOC (gdbarch_name_of_malloc (current_gdbarch))
1280#endif
5720643c 1281
c4ed33b9
AC
1282extern int gdbarch_cannot_step_breakpoint (struct gdbarch *gdbarch);
1283extern void set_gdbarch_cannot_step_breakpoint (struct gdbarch *gdbarch, int cannot_step_breakpoint);
5010d38b 1284#if !defined (GDB_TM_FILE) && defined (CANNOT_STEP_BREAKPOINT)
c4ed33b9
AC
1285#error "Non multi-arch definition of CANNOT_STEP_BREAKPOINT"
1286#endif
c25083af 1287#if !defined (CANNOT_STEP_BREAKPOINT)
c4ed33b9
AC
1288#define CANNOT_STEP_BREAKPOINT (gdbarch_cannot_step_breakpoint (current_gdbarch))
1289#endif
c4ed33b9 1290
f74fa174
MM
1291extern int gdbarch_have_nonsteppable_watchpoint (struct gdbarch *gdbarch);
1292extern void set_gdbarch_have_nonsteppable_watchpoint (struct gdbarch *gdbarch, int have_nonsteppable_watchpoint);
5010d38b 1293#if !defined (GDB_TM_FILE) && defined (HAVE_NONSTEPPABLE_WATCHPOINT)
f74fa174
MM
1294#error "Non multi-arch definition of HAVE_NONSTEPPABLE_WATCHPOINT"
1295#endif
c25083af 1296#if !defined (HAVE_NONSTEPPABLE_WATCHPOINT)
f74fa174
MM
1297#define HAVE_NONSTEPPABLE_WATCHPOINT (gdbarch_have_nonsteppable_watchpoint (current_gdbarch))
1298#endif
f74fa174 1299
8b2dbe47
KB
1300#if defined (ADDRESS_CLASS_TYPE_FLAGS)
1301/* Legacy for systems yet to multi-arch ADDRESS_CLASS_TYPE_FLAGS */
1302#if !defined (ADDRESS_CLASS_TYPE_FLAGS_P)
1303#define ADDRESS_CLASS_TYPE_FLAGS_P() (1)
1304#endif
1305#endif
1306
8b2dbe47 1307extern int gdbarch_address_class_type_flags_p (struct gdbarch *gdbarch);
5010d38b 1308#if !defined (GDB_TM_FILE) && defined (ADDRESS_CLASS_TYPE_FLAGS_P)
8b2dbe47
KB
1309#error "Non multi-arch definition of ADDRESS_CLASS_TYPE_FLAGS"
1310#endif
bceabdd8 1311#if !defined (ADDRESS_CLASS_TYPE_FLAGS_P)
8b2dbe47
KB
1312#define ADDRESS_CLASS_TYPE_FLAGS_P() (gdbarch_address_class_type_flags_p (current_gdbarch))
1313#endif
1314
8b2dbe47
KB
1315typedef int (gdbarch_address_class_type_flags_ftype) (int byte_size, int dwarf2_addr_class);
1316extern int gdbarch_address_class_type_flags (struct gdbarch *gdbarch, int byte_size, int dwarf2_addr_class);
1317extern void set_gdbarch_address_class_type_flags (struct gdbarch *gdbarch, gdbarch_address_class_type_flags_ftype *address_class_type_flags);
5010d38b 1318#if !defined (GDB_TM_FILE) && defined (ADDRESS_CLASS_TYPE_FLAGS)
8b2dbe47
KB
1319#error "Non multi-arch definition of ADDRESS_CLASS_TYPE_FLAGS"
1320#endif
c25083af 1321#if !defined (ADDRESS_CLASS_TYPE_FLAGS)
8b2dbe47
KB
1322#define ADDRESS_CLASS_TYPE_FLAGS(byte_size, dwarf2_addr_class) (gdbarch_address_class_type_flags (current_gdbarch, byte_size, dwarf2_addr_class))
1323#endif
8b2dbe47 1324
8b2dbe47 1325extern int gdbarch_address_class_type_flags_to_name_p (struct gdbarch *gdbarch);
8b2dbe47 1326
321432c0
KB
1327typedef const char * (gdbarch_address_class_type_flags_to_name_ftype) (struct gdbarch *gdbarch, int type_flags);
1328extern const char * gdbarch_address_class_type_flags_to_name (struct gdbarch *gdbarch, int type_flags);
8b2dbe47 1329extern 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);
8b2dbe47
KB
1330
1331extern int gdbarch_address_class_name_to_type_flags_p (struct gdbarch *gdbarch);
8b2dbe47 1332
321432c0
KB
1333typedef int (gdbarch_address_class_name_to_type_flags_ftype) (struct gdbarch *gdbarch, const char *name, int *type_flags_ptr);
1334extern int gdbarch_address_class_name_to_type_flags (struct gdbarch *gdbarch, const char *name, int *type_flags_ptr);
8b2dbe47 1335extern 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);
8b2dbe47 1336
b59ff9d5
AC
1337/* Is a register in a group */
1338
1339typedef int (gdbarch_register_reggroup_p_ftype) (struct gdbarch *gdbarch, int regnum, struct reggroup *reggroup);
1340extern int gdbarch_register_reggroup_p (struct gdbarch *gdbarch, int regnum, struct reggroup *reggroup);
1341extern void set_gdbarch_register_reggroup_p (struct gdbarch *gdbarch, gdbarch_register_reggroup_p_ftype *register_reggroup_p);
1342
2e092625 1343/* Fetch the pointer to the ith function argument. */
143985b7
AF
1344
1345#if defined (FETCH_POINTER_ARGUMENT)
1346/* Legacy for systems yet to multi-arch FETCH_POINTER_ARGUMENT */
1347#if !defined (FETCH_POINTER_ARGUMENT_P)
1348#define FETCH_POINTER_ARGUMENT_P() (1)
1349#endif
1350#endif
1351
143985b7 1352extern int gdbarch_fetch_pointer_argument_p (struct gdbarch *gdbarch);
5010d38b 1353#if !defined (GDB_TM_FILE) && defined (FETCH_POINTER_ARGUMENT_P)
143985b7
AF
1354#error "Non multi-arch definition of FETCH_POINTER_ARGUMENT"
1355#endif
bceabdd8 1356#if !defined (FETCH_POINTER_ARGUMENT_P)
143985b7
AF
1357#define FETCH_POINTER_ARGUMENT_P() (gdbarch_fetch_pointer_argument_p (current_gdbarch))
1358#endif
1359
143985b7
AF
1360typedef CORE_ADDR (gdbarch_fetch_pointer_argument_ftype) (struct frame_info *frame, int argi, struct type *type);
1361extern CORE_ADDR gdbarch_fetch_pointer_argument (struct gdbarch *gdbarch, struct frame_info *frame, int argi, struct type *type);
1362extern void set_gdbarch_fetch_pointer_argument (struct gdbarch *gdbarch, gdbarch_fetch_pointer_argument_ftype *fetch_pointer_argument);
5010d38b 1363#if !defined (GDB_TM_FILE) && defined (FETCH_POINTER_ARGUMENT)
143985b7
AF
1364#error "Non multi-arch definition of FETCH_POINTER_ARGUMENT"
1365#endif
1366#if !defined (FETCH_POINTER_ARGUMENT)
1367#define FETCH_POINTER_ARGUMENT(frame, argi, type) (gdbarch_fetch_pointer_argument (current_gdbarch, frame, argi, type))
1368#endif
1369
6ce6d90f
MK
1370/* Return the appropriate register set for a core file section with
1371 name SECT_NAME and size SECT_SIZE. */
1372
1373extern int gdbarch_regset_from_core_section_p (struct gdbarch *gdbarch);
1374
1375typedef const struct regset * (gdbarch_regset_from_core_section_ftype) (struct gdbarch *gdbarch, const char *sect_name, size_t sect_size);
1376extern const struct regset * gdbarch_regset_from_core_section (struct gdbarch *gdbarch, const char *sect_name, size_t sect_size);
1377extern void set_gdbarch_regset_from_core_section (struct gdbarch *gdbarch, gdbarch_regset_from_core_section_ftype *regset_from_core_section);
1378
0d5de010
DJ
1379/* If the elements of C++ vtables are in-place function descriptors rather
1380 than normal function pointers (which may point to code or a descriptor),
1381 set this to one. */
1382
1383extern int gdbarch_vtable_function_descriptors (struct gdbarch *gdbarch);
1384extern void set_gdbarch_vtable_function_descriptors (struct gdbarch *gdbarch, int vtable_function_descriptors);
1385
1386/* Set if the least significant bit of the delta is used instead of the least
1387 significant bit of the pfn for pointers to virtual member functions. */
1388
1389extern int gdbarch_vbit_in_delta (struct gdbarch *gdbarch);
1390extern void set_gdbarch_vbit_in_delta (struct gdbarch *gdbarch, int vbit_in_delta);
1391
104c1213 1392extern struct gdbarch_tdep *gdbarch_tdep (struct gdbarch *gdbarch);
0f71a2f6
JM
1393
1394
1395/* Mechanism for co-ordinating the selection of a specific
1396 architecture.
1397
1398 GDB targets (*-tdep.c) can register an interest in a specific
1399 architecture. Other GDB components can register a need to maintain
1400 per-architecture data.
1401
1402 The mechanisms below ensures that there is only a loose connection
1403 between the set-architecture command and the various GDB
99e7bb18 1404 components. Each component can independently register their need
0f71a2f6
JM
1405 to maintain architecture specific data with gdbarch.
1406
1407 Pragmatics:
1408
1409 Previously, a single TARGET_ARCHITECTURE_HOOK was provided. It
1410 didn't scale.
1411
1412 The more traditional mega-struct containing architecture specific
1413 data for all the various GDB components was also considered. Since
99e7bb18 1414 GDB is built from a variable number of (fairly independent)
0f71a2f6
JM
1415 components it was determined that the global aproach was not
1416 applicable. */
1417
1418
1419/* Register a new architectural family with GDB.
1420
1421 Register support for the specified ARCHITECTURE with GDB. When
1422 gdbarch determines that the specified architecture has been
1423 selected, the corresponding INIT function is called.
1424
1425 --
1426
1427 The INIT function takes two parameters: INFO which contains the
1428 information available to gdbarch about the (possibly new)
1429 architecture; ARCHES which is a list of the previously created
1430 ``struct gdbarch'' for this architecture.
1431
0f79675b 1432 The INFO parameter is, as far as possible, be pre-initialized with
7a107747 1433 information obtained from INFO.ABFD or the global defaults.
0f79675b
AC
1434
1435 The ARCHES parameter is a linked list (sorted most recently used)
1436 of all the previously created architures for this architecture
1437 family. The (possibly NULL) ARCHES->gdbarch can used to access
1438 values from the previously selected architecture for this
1439 architecture family. The global ``current_gdbarch'' shall not be
1440 used.
0f71a2f6
JM
1441
1442 The INIT function shall return any of: NULL - indicating that it
ec3d358c 1443 doesn't recognize the selected architecture; an existing ``struct
0f71a2f6
JM
1444 gdbarch'' from the ARCHES list - indicating that the new
1445 architecture is just a synonym for an earlier architecture (see
1446 gdbarch_list_lookup_by_info()); a newly created ``struct gdbarch''
4b9b3959
AC
1447 - that describes the selected architecture (see gdbarch_alloc()).
1448
1449 The DUMP_TDEP function shall print out all target specific values.
1450 Care should be taken to ensure that the function works in both the
1451 multi-arch and non- multi-arch cases. */
0f71a2f6 1452
adf40b2e
JM
1453struct gdbarch_list
1454{
1455 struct gdbarch *gdbarch;
1456 struct gdbarch_list *next;
1457};
0f71a2f6 1458
adf40b2e
JM
1459struct gdbarch_info
1460{
adf40b2e
JM
1461 /* Use default: NULL (ZERO). */
1462 const struct bfd_arch_info *bfd_arch_info;
0f71a2f6 1463
428721aa 1464 /* Use default: BFD_ENDIAN_UNKNOWN (NB: is not ZERO). */
adf40b2e 1465 int byte_order;
0f71a2f6 1466
adf40b2e
JM
1467 /* Use default: NULL (ZERO). */
1468 bfd *abfd;
0f71a2f6 1469
adf40b2e
JM
1470 /* Use default: NULL (ZERO). */
1471 struct gdbarch_tdep_info *tdep_info;
4be87837
DJ
1472
1473 /* Use default: GDB_OSABI_UNINITIALIZED (-1). */
1474 enum gdb_osabi osabi;
424163ea
DJ
1475
1476 /* Use default: NULL (ZERO). */
1477 const struct target_desc *target_desc;
adf40b2e 1478};
0f71a2f6 1479
104c1213 1480typedef struct gdbarch *(gdbarch_init_ftype) (struct gdbarch_info info, struct gdbarch_list *arches);
4b9b3959 1481typedef void (gdbarch_dump_tdep_ftype) (struct gdbarch *gdbarch, struct ui_file *file);
0f71a2f6 1482
4b9b3959 1483/* DEPRECATED - use gdbarch_register() */
104c1213 1484extern void register_gdbarch_init (enum bfd_architecture architecture, gdbarch_init_ftype *);
0f71a2f6 1485
4b9b3959
AC
1486extern void gdbarch_register (enum bfd_architecture architecture,
1487 gdbarch_init_ftype *,
1488 gdbarch_dump_tdep_ftype *);
1489
0f71a2f6 1490
b4a20239
AC
1491/* Return a freshly allocated, NULL terminated, array of the valid
1492 architecture names. Since architectures are registered during the
1493 _initialize phase this function only returns useful information
1494 once initialization has been completed. */
1495
1496extern const char **gdbarch_printable_names (void);
1497
1498
0f71a2f6
JM
1499/* Helper function. Search the list of ARCHES for a GDBARCH that
1500 matches the information provided by INFO. */
1501
424163ea 1502extern struct gdbarch_list *gdbarch_list_lookup_by_info (struct gdbarch_list *arches, const struct gdbarch_info *info);
0f71a2f6
JM
1503
1504
1505/* Helper function. Create a preliminary ``struct gdbarch''. Perform
424163ea 1506 basic initialization using values obtained from the INFO and TDEP
0f71a2f6
JM
1507 parameters. set_gdbarch_*() functions are called to complete the
1508 initialization of the object. */
1509
104c1213 1510extern struct gdbarch *gdbarch_alloc (const struct gdbarch_info *info, struct gdbarch_tdep *tdep);
0f71a2f6
JM
1511
1512
4b9b3959
AC
1513/* Helper function. Free a partially-constructed ``struct gdbarch''.
1514 It is assumed that the caller freeds the ``struct
1515 gdbarch_tdep''. */
1516
058f20d5
JB
1517extern void gdbarch_free (struct gdbarch *);
1518
1519
aebd7893
AC
1520/* Helper function. Allocate memory from the ``struct gdbarch''
1521 obstack. The memory is freed when the corresponding architecture
1522 is also freed. */
1523
1524extern void *gdbarch_obstack_zalloc (struct gdbarch *gdbarch, long size);
1525#define GDBARCH_OBSTACK_CALLOC(GDBARCH, NR, TYPE) ((TYPE *) gdbarch_obstack_zalloc ((GDBARCH), (NR) * sizeof (TYPE)))
1526#define GDBARCH_OBSTACK_ZALLOC(GDBARCH, TYPE) ((TYPE *) gdbarch_obstack_zalloc ((GDBARCH), sizeof (TYPE)))
1527
1528
b732d07d 1529/* Helper function. Force an update of the current architecture.
0f71a2f6 1530
b732d07d
AC
1531 The actual architecture selected is determined by INFO, ``(gdb) set
1532 architecture'' et.al., the existing architecture and BFD's default
1533 architecture. INFO should be initialized to zero and then selected
1534 fields should be updated.
0f71a2f6 1535
16f33e29
AC
1536 Returns non-zero if the update succeeds */
1537
1538extern int gdbarch_update_p (struct gdbarch_info info);
0f71a2f6
JM
1539
1540
ebdba546
AC
1541/* Helper function. Find an architecture matching info.
1542
1543 INFO should be initialized using gdbarch_info_init, relevant fields
1544 set, and then finished using gdbarch_info_fill.
1545
1546 Returns the corresponding architecture, or NULL if no matching
1547 architecture was found. "current_gdbarch" is not updated. */
1548
1549extern struct gdbarch *gdbarch_find_by_info (struct gdbarch_info info);
1550
1551
1552/* Helper function. Set the global "current_gdbarch" to "gdbarch".
1553
1554 FIXME: kettenis/20031124: Of the functions that follow, only
1555 gdbarch_from_bfd is supposed to survive. The others will
1556 dissappear since in the future GDB will (hopefully) be truly
1557 multi-arch. However, for now we're still stuck with the concept of
1558 a single active architecture. */
1559
1560extern void deprecated_current_gdbarch_select_hack (struct gdbarch *gdbarch);
1561
0f71a2f6
JM
1562
1563/* Register per-architecture data-pointer.
1564
1565 Reserve space for a per-architecture data-pointer. An identifier
1566 for the reserved data-pointer is returned. That identifer should
95160752 1567 be saved in a local static variable.
0f71a2f6 1568
fcc1c85c
AC
1569 Memory for the per-architecture data shall be allocated using
1570 gdbarch_obstack_zalloc. That memory will be deleted when the
1571 corresponding architecture object is deleted.
0f71a2f6 1572
95160752
AC
1573 When a previously created architecture is re-selected, the
1574 per-architecture data-pointer for that previous architecture is
76860b5f 1575 restored. INIT() is not re-called.
0f71a2f6
JM
1576
1577 Multiple registrarants for any architecture are allowed (and
1578 strongly encouraged). */
1579
95160752 1580struct gdbarch_data;
0f71a2f6 1581
030f20e1
AC
1582typedef void *(gdbarch_data_pre_init_ftype) (struct obstack *obstack);
1583extern struct gdbarch_data *gdbarch_data_register_pre_init (gdbarch_data_pre_init_ftype *init);
1584typedef void *(gdbarch_data_post_init_ftype) (struct gdbarch *gdbarch);
1585extern struct gdbarch_data *gdbarch_data_register_post_init (gdbarch_data_post_init_ftype *init);
1586extern void deprecated_set_gdbarch_data (struct gdbarch *gdbarch,
1587 struct gdbarch_data *data,
1588 void *pointer);
0f71a2f6 1589
451fbdda 1590extern void *gdbarch_data (struct gdbarch *gdbarch, struct gdbarch_data *);
0f71a2f6
JM
1591
1592
a8cf2722 1593
0f71a2f6
JM
1594/* Register per-architecture memory region.
1595
1596 Provide a memory-region swap mechanism. Per-architecture memory
1597 region are created. These memory regions are swapped whenever the
1598 architecture is changed. For a new architecture, the memory region
1599 is initialized with zero (0) and the INIT function is called.
1600
1601 Memory regions are swapped / initialized in the order that they are
1602 registered. NULL DATA and/or INIT values can be specified.
1603
030f20e1 1604 New code should use gdbarch_data_register_*(). */
0f71a2f6 1605
104c1213 1606typedef void (gdbarch_swap_ftype) (void);
046a4708
AC
1607extern void deprecated_register_gdbarch_swap (void *data, unsigned long size, gdbarch_swap_ftype *init);
1608#define DEPRECATED_REGISTER_GDBARCH_SWAP(VAR) deprecated_register_gdbarch_swap (&(VAR), sizeof ((VAR)), NULL)
0f71a2f6
JM
1609
1610
1611
99e7bb18 1612/* Set the dynamic target-system-dependent parameters (architecture,
c906108c
SS
1613 byte-order, ...) using information found in the BFD */
1614
104c1213 1615extern void set_gdbarch_from_file (bfd *);
c906108c
SS
1616
1617
e514a9d6
JM
1618/* Initialize the current architecture to the "first" one we find on
1619 our list. */
1620
1621extern void initialize_current_architecture (void);
1622
c906108c 1623/* gdbarch trace variable */
adf40b2e 1624extern int gdbarch_debug;
c906108c 1625
4b9b3959 1626extern void gdbarch_dump (struct gdbarch *gdbarch, struct ui_file *file);
0f71a2f6 1627
c906108c 1628#endif