gas/
[deliverable/binutils-gdb.git] / gdb / arm-tdep.c
CommitLineData
ed9a39eb 1/* Common target dependent code for GDB on ARM systems.
0fd88904 2
6aba47ca 3 Copyright (C) 1988, 1989, 1991, 1992, 1993, 1995, 1996, 1998, 1999, 2000,
9b254dd1
DJ
4 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008
5 Free Software Foundation, Inc.
c906108c 6
c5aa993b 7 This file is part of GDB.
c906108c 8
c5aa993b
JM
9 This program is free software; you can redistribute it and/or modify
10 it under the terms of the GNU General Public License as published by
a9762ec7 11 the Free Software Foundation; either version 3 of the License, or
c5aa993b 12 (at your option) any later version.
c906108c 13
c5aa993b
JM
14 This program is distributed in the hope that it will be useful,
15 but WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 GNU General Public License for more details.
c906108c 18
c5aa993b 19 You should have received a copy of the GNU General Public License
a9762ec7 20 along with this program. If not, see <http://www.gnu.org/licenses/>. */
c906108c 21
34e8f22d
RE
22#include <ctype.h> /* XXX for isupper () */
23
c906108c
SS
24#include "defs.h"
25#include "frame.h"
26#include "inferior.h"
27#include "gdbcmd.h"
28#include "gdbcore.h"
c906108c 29#include "gdb_string.h"
afd7eef0 30#include "dis-asm.h" /* For register styles. */
4e052eda 31#include "regcache.h"
d16aafd8 32#include "doublest.h"
fd0407d6 33#include "value.h"
34e8f22d 34#include "arch-utils.h"
4be87837 35#include "osabi.h"
eb5492fa
DJ
36#include "frame-unwind.h"
37#include "frame-base.h"
38#include "trad-frame.h"
842e1f1e
DJ
39#include "objfiles.h"
40#include "dwarf2-frame.h"
e4c16157 41#include "gdbtypes.h"
29d73ae4 42#include "prologue-value.h"
123dc839
DJ
43#include "target-descriptions.h"
44#include "user-regs.h"
34e8f22d
RE
45
46#include "arm-tdep.h"
26216b98 47#include "gdb/sim-arm.h"
34e8f22d 48
082fc60d
RE
49#include "elf-bfd.h"
50#include "coff/internal.h"
97e03143 51#include "elf/arm.h"
c906108c 52
26216b98
AC
53#include "gdb_assert.h"
54
6529d2dd
AC
55static int arm_debug;
56
082fc60d
RE
57/* Macros for setting and testing a bit in a minimal symbol that marks
58 it as Thumb function. The MSB of the minimal symbol's "info" field
f594e5e9 59 is used for this purpose.
082fc60d
RE
60
61 MSYMBOL_SET_SPECIAL Actually sets the "special" bit.
f594e5e9 62 MSYMBOL_IS_SPECIAL Tests the "special" bit in a minimal symbol. */
082fc60d
RE
63
64#define MSYMBOL_SET_SPECIAL(msym) \
65 MSYMBOL_INFO (msym) = (char *) (((long) MSYMBOL_INFO (msym)) \
66 | 0x80000000)
67
68#define MSYMBOL_IS_SPECIAL(msym) \
69 (((long) MSYMBOL_INFO (msym) & 0x80000000) != 0)
70
afd7eef0
RE
71/* The list of available "set arm ..." and "show arm ..." commands. */
72static struct cmd_list_element *setarmcmdlist = NULL;
73static struct cmd_list_element *showarmcmdlist = NULL;
74
fd50bc42
RE
75/* The type of floating-point to use. Keep this in sync with enum
76 arm_float_model, and the help string in _initialize_arm_tdep. */
77static const char *fp_model_strings[] =
78{
79 "auto",
80 "softfpa",
81 "fpa",
82 "softvfp",
28e97307
DJ
83 "vfp",
84 NULL
fd50bc42
RE
85};
86
87/* A variable that can be configured by the user. */
88static enum arm_float_model arm_fp_model = ARM_FLOAT_AUTO;
89static const char *current_fp_model = "auto";
90
28e97307
DJ
91/* The ABI to use. Keep this in sync with arm_abi_kind. */
92static const char *arm_abi_strings[] =
93{
94 "auto",
95 "APCS",
96 "AAPCS",
97 NULL
98};
99
100/* A variable that can be configured by the user. */
101static enum arm_abi_kind arm_abi_global = ARM_ABI_AUTO;
102static const char *arm_abi_string = "auto";
103
0428b8f5
DJ
104/* The execution mode to assume. */
105static const char *arm_mode_strings[] =
106 {
107 "auto",
108 "arm",
109 "thumb"
110 };
111
112static const char *arm_fallback_mode_string = "auto";
113static const char *arm_force_mode_string = "auto";
114
94c30b78 115/* Number of different reg name sets (options). */
afd7eef0 116static int num_disassembly_options;
bc90b915 117
123dc839
DJ
118/* The standard register names, and all the valid aliases for them. */
119static const struct
120{
121 const char *name;
122 int regnum;
123} arm_register_aliases[] = {
124 /* Basic register numbers. */
125 { "r0", 0 },
126 { "r1", 1 },
127 { "r2", 2 },
128 { "r3", 3 },
129 { "r4", 4 },
130 { "r5", 5 },
131 { "r6", 6 },
132 { "r7", 7 },
133 { "r8", 8 },
134 { "r9", 9 },
135 { "r10", 10 },
136 { "r11", 11 },
137 { "r12", 12 },
138 { "r13", 13 },
139 { "r14", 14 },
140 { "r15", 15 },
141 /* Synonyms (argument and variable registers). */
142 { "a1", 0 },
143 { "a2", 1 },
144 { "a3", 2 },
145 { "a4", 3 },
146 { "v1", 4 },
147 { "v2", 5 },
148 { "v3", 6 },
149 { "v4", 7 },
150 { "v5", 8 },
151 { "v6", 9 },
152 { "v7", 10 },
153 { "v8", 11 },
154 /* Other platform-specific names for r9. */
155 { "sb", 9 },
156 { "tr", 9 },
157 /* Special names. */
158 { "ip", 12 },
159 { "sp", 13 },
160 { "lr", 14 },
161 { "pc", 15 },
162 /* Names used by GCC (not listed in the ARM EABI). */
163 { "sl", 10 },
164 { "fp", 11 },
165 /* A special name from the older ATPCS. */
166 { "wr", 7 },
167};
bc90b915 168
123dc839 169static const char *const arm_register_names[] =
da59e081
JM
170{"r0", "r1", "r2", "r3", /* 0 1 2 3 */
171 "r4", "r5", "r6", "r7", /* 4 5 6 7 */
172 "r8", "r9", "r10", "r11", /* 8 9 10 11 */
173 "r12", "sp", "lr", "pc", /* 12 13 14 15 */
174 "f0", "f1", "f2", "f3", /* 16 17 18 19 */
175 "f4", "f5", "f6", "f7", /* 20 21 22 23 */
94c30b78 176 "fps", "cpsr" }; /* 24 25 */
ed9a39eb 177
afd7eef0
RE
178/* Valid register name styles. */
179static const char **valid_disassembly_styles;
ed9a39eb 180
afd7eef0
RE
181/* Disassembly style to use. Default to "std" register names. */
182static const char *disassembly_style;
96baa820 183
ed9a39eb 184/* This is used to keep the bfd arch_info in sync with the disassembly
afd7eef0
RE
185 style. */
186static void set_disassembly_style_sfunc(char *, int,
ed9a39eb 187 struct cmd_list_element *);
afd7eef0 188static void set_disassembly_style (void);
ed9a39eb 189
b508a996 190static void convert_from_extended (const struct floatformat *, const void *,
be8626e0 191 void *, int);
b508a996 192static void convert_to_extended (const struct floatformat *, void *,
be8626e0 193 const void *, int);
ed9a39eb 194
9b8d791a 195struct arm_prologue_cache
c3b4394c 196{
eb5492fa
DJ
197 /* The stack pointer at the time this frame was created; i.e. the
198 caller's stack pointer when this function was called. It is used
199 to identify this frame. */
200 CORE_ADDR prev_sp;
201
4be43953
DJ
202 /* The frame base for this frame is just prev_sp - frame size.
203 FRAMESIZE is the distance from the frame pointer to the
204 initial stack pointer. */
eb5492fa 205
c3b4394c 206 int framesize;
eb5492fa
DJ
207
208 /* The register used to hold the frame pointer for this frame. */
c3b4394c 209 int framereg;
eb5492fa
DJ
210
211 /* Saved register offsets. */
212 struct trad_frame_saved_reg *saved_regs;
c3b4394c 213};
ed9a39eb 214
bc90b915
FN
215/* Addresses for calling Thumb functions have the bit 0 set.
216 Here are some macros to test, set, or clear bit 0 of addresses. */
217#define IS_THUMB_ADDR(addr) ((addr) & 1)
218#define MAKE_THUMB_ADDR(addr) ((addr) | 1)
219#define UNMAKE_THUMB_ADDR(addr) ((addr) & ~1)
220
94c30b78 221/* Set to true if the 32-bit mode is in use. */
c906108c
SS
222
223int arm_apcs_32 = 1;
224
b39cc962
DJ
225/* Determine if FRAME is executing in Thumb mode. */
226
227static int
228arm_frame_is_thumb (struct frame_info *frame)
229{
230 CORE_ADDR cpsr;
231
232 /* Every ARM frame unwinder can unwind the T bit of the CPSR, either
233 directly (from a signal frame or dummy frame) or by interpreting
234 the saved LR (from a prologue or DWARF frame). So consult it and
235 trust the unwinders. */
236 cpsr = get_frame_register_unsigned (frame, ARM_PS_REGNUM);
237
238 return (cpsr & CPSR_T) != 0;
239}
240
ed9a39eb 241/* Determine if the program counter specified in MEMADDR is in a Thumb
b39cc962
DJ
242 function. This function should be called for addresses unrelated to
243 any executing frame; otherwise, prefer arm_frame_is_thumb. */
c906108c 244
ad527d2e 245static int
2a451106 246arm_pc_is_thumb (CORE_ADDR memaddr)
c906108c 247{
c5aa993b 248 struct minimal_symbol *sym;
c906108c 249
ed9a39eb 250 /* If bit 0 of the address is set, assume this is a Thumb address. */
c906108c
SS
251 if (IS_THUMB_ADDR (memaddr))
252 return 1;
253
0428b8f5
DJ
254 /* If the user wants to override the symbol table, let him. */
255 if (strcmp (arm_force_mode_string, "arm") == 0)
256 return 0;
257 if (strcmp (arm_force_mode_string, "thumb") == 0)
258 return 1;
259
ed9a39eb 260 /* Thumb functions have a "special" bit set in minimal symbols. */
c906108c
SS
261 sym = lookup_minimal_symbol_by_pc (memaddr);
262 if (sym)
0428b8f5
DJ
263 return (MSYMBOL_IS_SPECIAL (sym));
264
265 /* If the user wants to override the fallback mode, let them. */
266 if (strcmp (arm_fallback_mode_string, "arm") == 0)
267 return 0;
268 if (strcmp (arm_fallback_mode_string, "thumb") == 0)
269 return 1;
270
271 /* If we couldn't find any symbol, but we're talking to a running
272 target, then trust the current value of $cpsr. This lets
273 "display/i $pc" always show the correct mode (though if there is
274 a symbol table we will not reach here, so it still may not be
275 displayed in the mode it will be executed). */
276 if (target_has_registers)
277 return arm_frame_is_thumb (get_current_frame ());
278
279 /* Otherwise we're out of luck; we assume ARM. */
280 return 0;
c906108c
SS
281}
282
181c1381 283/* Remove useless bits from addresses in a running program. */
34e8f22d 284static CORE_ADDR
ed9a39eb 285arm_addr_bits_remove (CORE_ADDR val)
c906108c 286{
a3a2ee65 287 if (arm_apcs_32)
dd6be234 288 return UNMAKE_THUMB_ADDR (val);
c906108c 289 else
a3a2ee65 290 return (val & 0x03fffffc);
c906108c
SS
291}
292
181c1381
RE
293/* When reading symbols, we need to zap the low bit of the address,
294 which may be set to 1 for Thumb functions. */
34e8f22d 295static CORE_ADDR
181c1381
RE
296arm_smash_text_address (CORE_ADDR val)
297{
298 return val & ~1;
299}
300
29d73ae4
DJ
301/* Analyze a Thumb prologue, looking for a recognizable stack frame
302 and frame pointer. Scan until we encounter a store that could
303 clobber the stack frame unexpectedly, or an unknown instruction. */
c906108c
SS
304
305static CORE_ADDR
29d73ae4
DJ
306thumb_analyze_prologue (struct gdbarch *gdbarch,
307 CORE_ADDR start, CORE_ADDR limit,
308 struct arm_prologue_cache *cache)
c906108c 309{
29d73ae4
DJ
310 int i;
311 pv_t regs[16];
312 struct pv_area *stack;
313 struct cleanup *back_to;
314 CORE_ADDR offset;
da3c6d4a 315
29d73ae4
DJ
316 for (i = 0; i < 16; i++)
317 regs[i] = pv_register (i, 0);
318 stack = make_pv_area (ARM_SP_REGNUM);
319 back_to = make_cleanup_free_pv_area (stack);
320
29d73ae4 321 while (start < limit)
c906108c 322 {
29d73ae4
DJ
323 unsigned short insn;
324
325 insn = read_memory_unsigned_integer (start, 2);
c906108c 326
94c30b78 327 if ((insn & 0xfe00) == 0xb400) /* push { rlist } */
da59e081 328 {
29d73ae4
DJ
329 int regno;
330 int mask;
4be43953
DJ
331
332 if (pv_area_store_would_trash (stack, regs[ARM_SP_REGNUM]))
333 break;
29d73ae4
DJ
334
335 /* Bits 0-7 contain a mask for registers R0-R7. Bit 8 says
336 whether to save LR (R14). */
337 mask = (insn & 0xff) | ((insn & 0x100) << 6);
338
339 /* Calculate offsets of saved R0-R7 and LR. */
340 for (regno = ARM_LR_REGNUM; regno >= 0; regno--)
341 if (mask & (1 << regno))
342 {
29d73ae4
DJ
343 regs[ARM_SP_REGNUM] = pv_add_constant (regs[ARM_SP_REGNUM],
344 -4);
345 pv_area_store (stack, regs[ARM_SP_REGNUM], 4, regs[regno]);
346 }
da59e081 347 }
da3c6d4a
MS
348 else if ((insn & 0xff00) == 0xb000) /* add sp, #simm OR
349 sub sp, #simm */
da59e081 350 {
29d73ae4
DJ
351 offset = (insn & 0x7f) << 2; /* get scaled offset */
352 if (insn & 0x80) /* Check for SUB. */
353 regs[ARM_SP_REGNUM] = pv_add_constant (regs[ARM_SP_REGNUM],
354 -offset);
da59e081 355 else
29d73ae4
DJ
356 regs[ARM_SP_REGNUM] = pv_add_constant (regs[ARM_SP_REGNUM],
357 offset);
da59e081
JM
358 }
359 else if ((insn & 0xff00) == 0xaf00) /* add r7, sp, #imm */
29d73ae4
DJ
360 regs[THUMB_FP_REGNUM] = pv_add_constant (regs[ARM_SP_REGNUM],
361 (insn & 0xff) << 2);
362 else if ((insn & 0xff00) == 0x4600) /* mov hi, lo or mov lo, hi */
da59e081 363 {
29d73ae4
DJ
364 int dst_reg = (insn & 0x7) + ((insn & 0x80) >> 4);
365 int src_reg = (insn & 0x78) >> 3;
366 regs[dst_reg] = regs[src_reg];
da59e081 367 }
29d73ae4 368 else if ((insn & 0xf800) == 0x9000) /* str rd, [sp, #off] */
da59e081 369 {
29d73ae4
DJ
370 /* Handle stores to the stack. Normally pushes are used,
371 but with GCC -mtpcs-frame, there may be other stores
372 in the prologue to create the frame. */
373 int regno = (insn >> 8) & 0x7;
374 pv_t addr;
375
376 offset = (insn & 0xff) << 2;
377 addr = pv_add_constant (regs[ARM_SP_REGNUM], offset);
378
379 if (pv_area_store_would_trash (stack, addr))
380 break;
381
382 pv_area_store (stack, addr, 4, regs[regno]);
da59e081 383 }
29d73ae4 384 else
3d74b771 385 {
29d73ae4
DJ
386 /* We don't know what this instruction is. We're finished
387 scanning. NOTE: Recognizing more safe-to-ignore
388 instructions here will improve support for optimized
389 code. */
da3c6d4a 390 break;
3d74b771 391 }
29d73ae4
DJ
392
393 start += 2;
c906108c
SS
394 }
395
29d73ae4
DJ
396 if (cache == NULL)
397 {
398 do_cleanups (back_to);
399 return start;
400 }
401
29d73ae4
DJ
402 if (pv_is_register (regs[ARM_FP_REGNUM], ARM_SP_REGNUM))
403 {
404 /* Frame pointer is fp. Frame size is constant. */
405 cache->framereg = ARM_FP_REGNUM;
406 cache->framesize = -regs[ARM_FP_REGNUM].k;
407 }
408 else if (pv_is_register (regs[THUMB_FP_REGNUM], ARM_SP_REGNUM))
409 {
410 /* Frame pointer is r7. Frame size is constant. */
411 cache->framereg = THUMB_FP_REGNUM;
412 cache->framesize = -regs[THUMB_FP_REGNUM].k;
413 }
414 else if (pv_is_register (regs[ARM_SP_REGNUM], ARM_SP_REGNUM))
415 {
416 /* Try the stack pointer... this is a bit desperate. */
417 cache->framereg = ARM_SP_REGNUM;
418 cache->framesize = -regs[ARM_SP_REGNUM].k;
419 }
420 else
421 {
422 /* We're just out of luck. We don't know where the frame is. */
423 cache->framereg = -1;
424 cache->framesize = 0;
425 }
426
427 for (i = 0; i < 16; i++)
428 if (pv_area_find_reg (stack, gdbarch, i, &offset))
429 cache->saved_regs[i].addr = offset;
430
431 do_cleanups (back_to);
432 return start;
c906108c
SS
433}
434
da3c6d4a
MS
435/* Advance the PC across any function entry prologue instructions to
436 reach some "real" code.
34e8f22d
RE
437
438 The APCS (ARM Procedure Call Standard) defines the following
ed9a39eb 439 prologue:
c906108c 440
c5aa993b
JM
441 mov ip, sp
442 [stmfd sp!, {a1,a2,a3,a4}]
443 stmfd sp!, {...,fp,ip,lr,pc}
ed9a39eb
JM
444 [stfe f7, [sp, #-12]!]
445 [stfe f6, [sp, #-12]!]
446 [stfe f5, [sp, #-12]!]
447 [stfe f4, [sp, #-12]!]
448 sub fp, ip, #nn @@ nn == 20 or 4 depending on second insn */
c906108c 449
34e8f22d 450static CORE_ADDR
6093d2eb 451arm_skip_prologue (struct gdbarch *gdbarch, CORE_ADDR pc)
c906108c
SS
452{
453 unsigned long inst;
454 CORE_ADDR skip_pc;
b8d5e71d 455 CORE_ADDR func_addr, func_end = 0;
50f6fb4b 456 char *func_name;
c906108c
SS
457 struct symtab_and_line sal;
458
848cfffb 459 /* If we're in a dummy frame, don't even try to skip the prologue. */
30a4a8e0 460 if (deprecated_pc_in_call_dummy (pc))
848cfffb
AC
461 return pc;
462
96baa820 463 /* See what the symbol table says. */
ed9a39eb 464
50f6fb4b 465 if (find_pc_partial_function (pc, &func_name, &func_addr, &func_end))
c906108c 466 {
50f6fb4b
CV
467 struct symbol *sym;
468
469 /* Found a function. */
176620f1 470 sym = lookup_symbol (func_name, NULL, VAR_DOMAIN, NULL, NULL);
50f6fb4b
CV
471 if (sym && SYMBOL_LANGUAGE (sym) != language_asm)
472 {
94c30b78 473 /* Don't use this trick for assembly source files. */
50f6fb4b
CV
474 sal = find_pc_line (func_addr, 0);
475 if ((sal.line != 0) && (sal.end < func_end))
476 return sal.end;
477 }
c906108c
SS
478 }
479
c906108c 480 /* Can't find the prologue end in the symbol table, try it the hard way
94c30b78 481 by disassembling the instructions. */
c906108c 482
b8d5e71d
MS
483 /* Like arm_scan_prologue, stop no later than pc + 64. */
484 if (func_end == 0 || func_end > pc + 64)
485 func_end = pc + 64;
c906108c 486
29d73ae4
DJ
487 /* Check if this is Thumb code. */
488 if (arm_pc_is_thumb (pc))
6093d2eb 489 return thumb_analyze_prologue (gdbarch, pc, func_end, NULL);
29d73ae4 490
b8d5e71d 491 for (skip_pc = pc; skip_pc < func_end; skip_pc += 4)
f43845b3 492 {
1c5bada0 493 inst = read_memory_unsigned_integer (skip_pc, 4);
f43845b3 494
b8d5e71d
MS
495 /* "mov ip, sp" is no longer a required part of the prologue. */
496 if (inst == 0xe1a0c00d) /* mov ip, sp */
497 continue;
c906108c 498
28cd8767
JG
499 if ((inst & 0xfffff000) == 0xe28dc000) /* add ip, sp #n */
500 continue;
501
502 if ((inst & 0xfffff000) == 0xe24dc000) /* sub ip, sp #n */
503 continue;
504
b8d5e71d
MS
505 /* Some prologues begin with "str lr, [sp, #-4]!". */
506 if (inst == 0xe52de004) /* str lr, [sp, #-4]! */
507 continue;
c906108c 508
b8d5e71d
MS
509 if ((inst & 0xfffffff0) == 0xe92d0000) /* stmfd sp!,{a1,a2,a3,a4} */
510 continue;
c906108c 511
b8d5e71d
MS
512 if ((inst & 0xfffff800) == 0xe92dd800) /* stmfd sp!,{fp,ip,lr,pc} */
513 continue;
11d3b27d 514
b8d5e71d
MS
515 /* Any insns after this point may float into the code, if it makes
516 for better instruction scheduling, so we skip them only if we
517 find them, but still consider the function to be frame-ful. */
f43845b3 518
b8d5e71d
MS
519 /* We may have either one sfmfd instruction here, or several stfe
520 insns, depending on the version of floating point code we
521 support. */
522 if ((inst & 0xffbf0fff) == 0xec2d0200) /* sfmfd fn, <cnt>, [sp]! */
523 continue;
524
525 if ((inst & 0xffff8fff) == 0xed6d0103) /* stfe fn, [sp, #-12]! */
526 continue;
527
528 if ((inst & 0xfffff000) == 0xe24cb000) /* sub fp, ip, #nn */
529 continue;
530
531 if ((inst & 0xfffff000) == 0xe24dd000) /* sub sp, sp, #nn */
532 continue;
533
534 if ((inst & 0xffffc000) == 0xe54b0000 || /* strb r(0123),[r11,#-nn] */
535 (inst & 0xffffc0f0) == 0xe14b00b0 || /* strh r(0123),[r11,#-nn] */
536 (inst & 0xffffc000) == 0xe50b0000) /* str r(0123),[r11,#-nn] */
537 continue;
538
539 if ((inst & 0xffffc000) == 0xe5cd0000 || /* strb r(0123),[sp,#nn] */
540 (inst & 0xffffc0f0) == 0xe1cd00b0 || /* strh r(0123),[sp,#nn] */
541 (inst & 0xffffc000) == 0xe58d0000) /* str r(0123),[sp,#nn] */
542 continue;
543
544 /* Un-recognized instruction; stop scanning. */
545 break;
f43845b3 546 }
c906108c 547
b8d5e71d 548 return skip_pc; /* End of prologue */
c906108c 549}
94c30b78 550
c5aa993b 551/* *INDENT-OFF* */
c906108c
SS
552/* Function: thumb_scan_prologue (helper function for arm_scan_prologue)
553 This function decodes a Thumb function prologue to determine:
554 1) the size of the stack frame
555 2) which registers are saved on it
556 3) the offsets of saved regs
557 4) the offset from the stack pointer to the frame pointer
c906108c 558
da59e081
JM
559 A typical Thumb function prologue would create this stack frame
560 (offsets relative to FP)
c906108c
SS
561 old SP -> 24 stack parameters
562 20 LR
563 16 R7
564 R7 -> 0 local variables (16 bytes)
565 SP -> -12 additional stack space (12 bytes)
566 The frame size would thus be 36 bytes, and the frame offset would be
da59e081
JM
567 12 bytes. The frame register is R7.
568
da3c6d4a
MS
569 The comments for thumb_skip_prolog() describe the algorithm we use
570 to detect the end of the prolog. */
c5aa993b
JM
571/* *INDENT-ON* */
572
c906108c 573static void
be8626e0 574thumb_scan_prologue (struct gdbarch *gdbarch, CORE_ADDR prev_pc,
b39cc962 575 CORE_ADDR block_addr, struct arm_prologue_cache *cache)
c906108c
SS
576{
577 CORE_ADDR prologue_start;
578 CORE_ADDR prologue_end;
579 CORE_ADDR current_pc;
c906108c 580
b39cc962
DJ
581 if (find_pc_partial_function (block_addr, NULL, &prologue_start,
582 &prologue_end))
c906108c
SS
583 {
584 struct symtab_and_line sal = find_pc_line (prologue_start, 0);
585
94c30b78 586 if (sal.line == 0) /* no line info, use current PC */
eb5492fa 587 prologue_end = prev_pc;
c906108c 588 else if (sal.end < prologue_end) /* next line begins after fn end */
94c30b78 589 prologue_end = sal.end; /* (probably means no prologue) */
c906108c
SS
590 }
591 else
f7060f85
DJ
592 /* We're in the boondocks: we have no idea where the start of the
593 function is. */
594 return;
c906108c 595
eb5492fa 596 prologue_end = min (prologue_end, prev_pc);
c906108c 597
be8626e0 598 thumb_analyze_prologue (gdbarch, prologue_start, prologue_end, cache);
c906108c
SS
599}
600
ed9a39eb 601/* This function decodes an ARM function prologue to determine:
c5aa993b
JM
602 1) the size of the stack frame
603 2) which registers are saved on it
604 3) the offsets of saved regs
605 4) the offset from the stack pointer to the frame pointer
c906108c
SS
606 This information is stored in the "extra" fields of the frame_info.
607
96baa820
JM
608 There are two basic forms for the ARM prologue. The fixed argument
609 function call will look like:
ed9a39eb
JM
610
611 mov ip, sp
612 stmfd sp!, {fp, ip, lr, pc}
613 sub fp, ip, #4
614 [sub sp, sp, #4]
96baa820 615
c906108c 616 Which would create this stack frame (offsets relative to FP):
ed9a39eb
JM
617 IP -> 4 (caller's stack)
618 FP -> 0 PC (points to address of stmfd instruction + 8 in callee)
619 -4 LR (return address in caller)
620 -8 IP (copy of caller's SP)
621 -12 FP (caller's FP)
622 SP -> -28 Local variables
623
c906108c 624 The frame size would thus be 32 bytes, and the frame offset would be
96baa820
JM
625 28 bytes. The stmfd call can also save any of the vN registers it
626 plans to use, which increases the frame size accordingly.
627
628 Note: The stored PC is 8 off of the STMFD instruction that stored it
629 because the ARM Store instructions always store PC + 8 when you read
630 the PC register.
ed9a39eb 631
96baa820
JM
632 A variable argument function call will look like:
633
ed9a39eb
JM
634 mov ip, sp
635 stmfd sp!, {a1, a2, a3, a4}
636 stmfd sp!, {fp, ip, lr, pc}
637 sub fp, ip, #20
638
96baa820 639 Which would create this stack frame (offsets relative to FP):
ed9a39eb
JM
640 IP -> 20 (caller's stack)
641 16 A4
642 12 A3
643 8 A2
644 4 A1
645 FP -> 0 PC (points to address of stmfd instruction + 8 in callee)
646 -4 LR (return address in caller)
647 -8 IP (copy of caller's SP)
648 -12 FP (caller's FP)
649 SP -> -28 Local variables
96baa820
JM
650
651 The frame size would thus be 48 bytes, and the frame offset would be
652 28 bytes.
653
654 There is another potential complication, which is that the optimizer
655 will try to separate the store of fp in the "stmfd" instruction from
656 the "sub fp, ip, #NN" instruction. Almost anything can be there, so
657 we just key on the stmfd, and then scan for the "sub fp, ip, #NN"...
658
659 Also, note, the original version of the ARM toolchain claimed that there
660 should be an
661
662 instruction at the end of the prologue. I have never seen GCC produce
663 this, and the ARM docs don't mention it. We still test for it below in
664 case it happens...
ed9a39eb
JM
665
666 */
c906108c
SS
667
668static void
a262aec2 669arm_scan_prologue (struct frame_info *this_frame,
2af46ca0 670 struct arm_prologue_cache *cache)
c906108c 671{
a262aec2 672 struct gdbarch *gdbarch = get_frame_arch (this_frame);
4be43953 673 int regno;
c906108c 674 CORE_ADDR prologue_start, prologue_end, current_pc;
a262aec2 675 CORE_ADDR prev_pc = get_frame_pc (this_frame);
b39cc962 676 CORE_ADDR block_addr = get_frame_address_in_block (this_frame);
4be43953
DJ
677 pv_t regs[ARM_FPS_REGNUM];
678 struct pv_area *stack;
679 struct cleanup *back_to;
680 CORE_ADDR offset;
c906108c 681
c906108c 682 /* Assume there is no frame until proven otherwise. */
9b8d791a
DJ
683 cache->framereg = ARM_SP_REGNUM;
684 cache->framesize = 0;
c906108c
SS
685
686 /* Check for Thumb prologue. */
b39cc962 687 if (arm_frame_is_thumb (this_frame))
c906108c 688 {
b39cc962 689 thumb_scan_prologue (gdbarch, prev_pc, block_addr, cache);
c906108c
SS
690 return;
691 }
692
693 /* Find the function prologue. If we can't find the function in
694 the symbol table, peek in the stack frame to find the PC. */
b39cc962
DJ
695 if (find_pc_partial_function (block_addr, NULL, &prologue_start,
696 &prologue_end))
c906108c 697 {
2a451106
KB
698 /* One way to find the end of the prologue (which works well
699 for unoptimized code) is to do the following:
700
701 struct symtab_and_line sal = find_pc_line (prologue_start, 0);
702
703 if (sal.line == 0)
eb5492fa 704 prologue_end = prev_pc;
2a451106
KB
705 else if (sal.end < prologue_end)
706 prologue_end = sal.end;
707
708 This mechanism is very accurate so long as the optimizer
709 doesn't move any instructions from the function body into the
710 prologue. If this happens, sal.end will be the last
711 instruction in the first hunk of prologue code just before
712 the first instruction that the scheduler has moved from
713 the body to the prologue.
714
715 In order to make sure that we scan all of the prologue
716 instructions, we use a slightly less accurate mechanism which
717 may scan more than necessary. To help compensate for this
718 lack of accuracy, the prologue scanning loop below contains
719 several clauses which'll cause the loop to terminate early if
720 an implausible prologue instruction is encountered.
721
722 The expression
723
724 prologue_start + 64
725
726 is a suitable endpoint since it accounts for the largest
727 possible prologue plus up to five instructions inserted by
94c30b78 728 the scheduler. */
2a451106
KB
729
730 if (prologue_end > prologue_start + 64)
731 {
94c30b78 732 prologue_end = prologue_start + 64; /* See above. */
2a451106 733 }
c906108c
SS
734 }
735 else
736 {
eb5492fa
DJ
737 /* We have no symbol information. Our only option is to assume this
738 function has a standard stack frame and the normal frame register.
739 Then, we can find the value of our frame pointer on entrance to
740 the callee (or at the present moment if this is the innermost frame).
741 The value stored there should be the address of the stmfd + 8. */
742 CORE_ADDR frame_loc;
743 LONGEST return_value;
744
a262aec2 745 frame_loc = get_frame_register_unsigned (this_frame, ARM_FP_REGNUM);
eb5492fa 746 if (!safe_read_memory_integer (frame_loc, 4, &return_value))
16a0f3e7
EZ
747 return;
748 else
749 {
bf6ae464 750 prologue_start = gdbarch_addr_bits_remove
2af46ca0 751 (gdbarch, return_value) - 8;
94c30b78 752 prologue_end = prologue_start + 64; /* See above. */
16a0f3e7 753 }
c906108c
SS
754 }
755
eb5492fa
DJ
756 if (prev_pc < prologue_end)
757 prologue_end = prev_pc;
758
c906108c 759 /* Now search the prologue looking for instructions that set up the
96baa820 760 frame pointer, adjust the stack pointer, and save registers.
ed9a39eb 761
96baa820
JM
762 Be careful, however, and if it doesn't look like a prologue,
763 don't try to scan it. If, for instance, a frameless function
764 begins with stmfd sp!, then we will tell ourselves there is
b8d5e71d 765 a frame, which will confuse stack traceback, as well as "finish"
96baa820
JM
766 and other operations that rely on a knowledge of the stack
767 traceback.
768
769 In the APCS, the prologue should start with "mov ip, sp" so
f43845b3 770 if we don't see this as the first insn, we will stop.
c906108c 771
f43845b3
MS
772 [Note: This doesn't seem to be true any longer, so it's now an
773 optional part of the prologue. - Kevin Buettner, 2001-11-20]
c906108c 774
f43845b3
MS
775 [Note further: The "mov ip,sp" only seems to be missing in
776 frameless functions at optimization level "-O2" or above,
777 in which case it is often (but not always) replaced by
b8d5e71d 778 "str lr, [sp, #-4]!". - Michael Snyder, 2002-04-23] */
d4473757 779
4be43953
DJ
780 for (regno = 0; regno < ARM_FPS_REGNUM; regno++)
781 regs[regno] = pv_register (regno, 0);
782 stack = make_pv_area (ARM_SP_REGNUM);
783 back_to = make_cleanup_free_pv_area (stack);
784
94c30b78
MS
785 for (current_pc = prologue_start;
786 current_pc < prologue_end;
f43845b3 787 current_pc += 4)
96baa820 788 {
d4473757
KB
789 unsigned int insn = read_memory_unsigned_integer (current_pc, 4);
790
94c30b78 791 if (insn == 0xe1a0c00d) /* mov ip, sp */
f43845b3 792 {
4be43953 793 regs[ARM_IP_REGNUM] = regs[ARM_SP_REGNUM];
28cd8767
JG
794 continue;
795 }
796 else if ((insn & 0xfffff000) == 0xe28dc000) /* add ip, sp #n */
797 {
798 unsigned imm = insn & 0xff; /* immediate value */
799 unsigned rot = (insn & 0xf00) >> 7; /* rotate amount */
800 imm = (imm >> rot) | (imm << (32 - rot));
4be43953 801 regs[ARM_IP_REGNUM] = pv_add_constant (regs[ARM_SP_REGNUM], imm);
28cd8767
JG
802 continue;
803 }
804 else if ((insn & 0xfffff000) == 0xe24dc000) /* sub ip, sp #n */
805 {
806 unsigned imm = insn & 0xff; /* immediate value */
807 unsigned rot = (insn & 0xf00) >> 7; /* rotate amount */
808 imm = (imm >> rot) | (imm << (32 - rot));
4be43953 809 regs[ARM_IP_REGNUM] = pv_add_constant (regs[ARM_SP_REGNUM], -imm);
f43845b3
MS
810 continue;
811 }
94c30b78 812 else if (insn == 0xe52de004) /* str lr, [sp, #-4]! */
f43845b3 813 {
4be43953
DJ
814 if (pv_area_store_would_trash (stack, regs[ARM_SP_REGNUM]))
815 break;
816 regs[ARM_SP_REGNUM] = pv_add_constant (regs[ARM_SP_REGNUM], -4);
817 pv_area_store (stack, regs[ARM_SP_REGNUM], 4, regs[ARM_LR_REGNUM]);
f43845b3
MS
818 continue;
819 }
820 else if ((insn & 0xffff0000) == 0xe92d0000)
d4473757
KB
821 /* stmfd sp!, {..., fp, ip, lr, pc}
822 or
823 stmfd sp!, {a1, a2, a3, a4} */
c906108c 824 {
d4473757 825 int mask = insn & 0xffff;
ed9a39eb 826
4be43953
DJ
827 if (pv_area_store_would_trash (stack, regs[ARM_SP_REGNUM]))
828 break;
829
94c30b78 830 /* Calculate offsets of saved registers. */
34e8f22d 831 for (regno = ARM_PC_REGNUM; regno >= 0; regno--)
d4473757
KB
832 if (mask & (1 << regno))
833 {
4be43953
DJ
834 regs[ARM_SP_REGNUM] = pv_add_constant (regs[ARM_SP_REGNUM], -4);
835 pv_area_store (stack, regs[ARM_SP_REGNUM], 4, regs[regno]);
d4473757
KB
836 }
837 }
b8d5e71d
MS
838 else if ((insn & 0xffffc000) == 0xe54b0000 || /* strb rx,[r11,#-n] */
839 (insn & 0xffffc0f0) == 0xe14b00b0 || /* strh rx,[r11,#-n] */
840 (insn & 0xffffc000) == 0xe50b0000) /* str rx,[r11,#-n] */
841 {
842 /* No need to add this to saved_regs -- it's just an arg reg. */
843 continue;
844 }
845 else if ((insn & 0xffffc000) == 0xe5cd0000 || /* strb rx,[sp,#n] */
846 (insn & 0xffffc0f0) == 0xe1cd00b0 || /* strh rx,[sp,#n] */
847 (insn & 0xffffc000) == 0xe58d0000) /* str rx,[sp,#n] */
f43845b3
MS
848 {
849 /* No need to add this to saved_regs -- it's just an arg reg. */
850 continue;
851 }
d4473757
KB
852 else if ((insn & 0xfffff000) == 0xe24cb000) /* sub fp, ip #n */
853 {
94c30b78
MS
854 unsigned imm = insn & 0xff; /* immediate value */
855 unsigned rot = (insn & 0xf00) >> 7; /* rotate amount */
d4473757 856 imm = (imm >> rot) | (imm << (32 - rot));
4be43953 857 regs[ARM_FP_REGNUM] = pv_add_constant (regs[ARM_IP_REGNUM], -imm);
d4473757
KB
858 }
859 else if ((insn & 0xfffff000) == 0xe24dd000) /* sub sp, sp #n */
860 {
94c30b78
MS
861 unsigned imm = insn & 0xff; /* immediate value */
862 unsigned rot = (insn & 0xf00) >> 7; /* rotate amount */
d4473757 863 imm = (imm >> rot) | (imm << (32 - rot));
4be43953 864 regs[ARM_SP_REGNUM] = pv_add_constant (regs[ARM_SP_REGNUM], -imm);
d4473757 865 }
ff6f572f 866 else if ((insn & 0xffff7fff) == 0xed6d0103 /* stfe f?, [sp, -#c]! */
2af46ca0 867 && gdbarch_tdep (gdbarch)->have_fpa_registers)
d4473757 868 {
4be43953
DJ
869 if (pv_area_store_would_trash (stack, regs[ARM_SP_REGNUM]))
870 break;
871
872 regs[ARM_SP_REGNUM] = pv_add_constant (regs[ARM_SP_REGNUM], -12);
34e8f22d 873 regno = ARM_F0_REGNUM + ((insn >> 12) & 0x07);
4be43953 874 pv_area_store (stack, regs[ARM_SP_REGNUM], 12, regs[regno]);
d4473757 875 }
ff6f572f 876 else if ((insn & 0xffbf0fff) == 0xec2d0200 /* sfmfd f0, 4, [sp!] */
2af46ca0 877 && gdbarch_tdep (gdbarch)->have_fpa_registers)
d4473757
KB
878 {
879 int n_saved_fp_regs;
880 unsigned int fp_start_reg, fp_bound_reg;
881
4be43953
DJ
882 if (pv_area_store_would_trash (stack, regs[ARM_SP_REGNUM]))
883 break;
884
94c30b78 885 if ((insn & 0x800) == 0x800) /* N0 is set */
96baa820 886 {
d4473757
KB
887 if ((insn & 0x40000) == 0x40000) /* N1 is set */
888 n_saved_fp_regs = 3;
889 else
890 n_saved_fp_regs = 1;
96baa820 891 }
d4473757 892 else
96baa820 893 {
d4473757
KB
894 if ((insn & 0x40000) == 0x40000) /* N1 is set */
895 n_saved_fp_regs = 2;
896 else
897 n_saved_fp_regs = 4;
96baa820 898 }
d4473757 899
34e8f22d 900 fp_start_reg = ARM_F0_REGNUM + ((insn >> 12) & 0x7);
d4473757
KB
901 fp_bound_reg = fp_start_reg + n_saved_fp_regs;
902 for (; fp_start_reg < fp_bound_reg; fp_start_reg++)
96baa820 903 {
4be43953
DJ
904 regs[ARM_SP_REGNUM] = pv_add_constant (regs[ARM_SP_REGNUM], -12);
905 pv_area_store (stack, regs[ARM_SP_REGNUM], 12,
906 regs[fp_start_reg++]);
96baa820 907 }
c906108c 908 }
d4473757 909 else if ((insn & 0xf0000000) != 0xe0000000)
94c30b78 910 break; /* Condition not true, exit early */
b8d5e71d 911 else if ((insn & 0xfe200000) == 0xe8200000) /* ldm? */
94c30b78 912 break; /* Don't scan past a block load */
d4473757
KB
913 else
914 /* The optimizer might shove anything into the prologue,
94c30b78 915 so we just skip what we don't recognize. */
d4473757 916 continue;
c906108c
SS
917 }
918
4be43953
DJ
919 /* The frame size is just the distance from the frame register
920 to the original stack pointer. */
921 if (pv_is_register (regs[ARM_FP_REGNUM], ARM_SP_REGNUM))
922 {
923 /* Frame pointer is fp. */
924 cache->framereg = ARM_FP_REGNUM;
925 cache->framesize = -regs[ARM_FP_REGNUM].k;
926 }
927 else if (pv_is_register (regs[ARM_SP_REGNUM], ARM_SP_REGNUM))
928 {
929 /* Try the stack pointer... this is a bit desperate. */
930 cache->framereg = ARM_SP_REGNUM;
931 cache->framesize = -regs[ARM_SP_REGNUM].k;
932 }
d4473757 933 else
4be43953
DJ
934 {
935 /* We're just out of luck. We don't know where the frame is. */
936 cache->framereg = -1;
937 cache->framesize = 0;
938 }
939
940 for (regno = 0; regno < ARM_FPS_REGNUM; regno++)
941 if (pv_area_find_reg (stack, gdbarch, regno, &offset))
942 cache->saved_regs[regno].addr = offset;
943
944 do_cleanups (back_to);
c906108c
SS
945}
946
eb5492fa 947static struct arm_prologue_cache *
a262aec2 948arm_make_prologue_cache (struct frame_info *this_frame)
c906108c 949{
eb5492fa
DJ
950 int reg;
951 struct arm_prologue_cache *cache;
952 CORE_ADDR unwound_fp;
c5aa993b 953
35d5d4ee 954 cache = FRAME_OBSTACK_ZALLOC (struct arm_prologue_cache);
a262aec2 955 cache->saved_regs = trad_frame_alloc_saved_regs (this_frame);
c906108c 956
a262aec2 957 arm_scan_prologue (this_frame, cache);
848cfffb 958
a262aec2 959 unwound_fp = get_frame_register_unsigned (this_frame, cache->framereg);
eb5492fa
DJ
960 if (unwound_fp == 0)
961 return cache;
c906108c 962
4be43953 963 cache->prev_sp = unwound_fp + cache->framesize;
c906108c 964
eb5492fa
DJ
965 /* Calculate actual addresses of saved registers using offsets
966 determined by arm_scan_prologue. */
a262aec2 967 for (reg = 0; reg < gdbarch_num_regs (get_frame_arch (this_frame)); reg++)
e28a332c 968 if (trad_frame_addr_p (cache->saved_regs, reg))
eb5492fa
DJ
969 cache->saved_regs[reg].addr += cache->prev_sp;
970
971 return cache;
c906108c
SS
972}
973
eb5492fa
DJ
974/* Our frame ID for a normal frame is the current function's starting PC
975 and the caller's SP when we were called. */
c906108c 976
148754e5 977static void
a262aec2 978arm_prologue_this_id (struct frame_info *this_frame,
eb5492fa
DJ
979 void **this_cache,
980 struct frame_id *this_id)
c906108c 981{
eb5492fa
DJ
982 struct arm_prologue_cache *cache;
983 struct frame_id id;
984 CORE_ADDR func;
f079148d 985
eb5492fa 986 if (*this_cache == NULL)
a262aec2 987 *this_cache = arm_make_prologue_cache (this_frame);
eb5492fa 988 cache = *this_cache;
2a451106 989
a262aec2 990 func = get_frame_func (this_frame);
2a451106 991
eb5492fa
DJ
992 /* This is meant to halt the backtrace at "_start". Make sure we
993 don't halt it at a generic dummy frame. */
a262aec2 994 if (func <= gdbarch_tdep (get_frame_arch (this_frame))->lowest_pc)
eb5492fa 995 return;
5a203e44 996
eb5492fa
DJ
997 /* If we've hit a wall, stop. */
998 if (cache->prev_sp == 0)
999 return;
24de872b 1000
eb5492fa 1001 id = frame_id_build (cache->prev_sp, func);
eb5492fa 1002 *this_id = id;
c906108c
SS
1003}
1004
a262aec2
DJ
1005static struct value *
1006arm_prologue_prev_register (struct frame_info *this_frame,
eb5492fa 1007 void **this_cache,
a262aec2 1008 int prev_regnum)
24de872b
DJ
1009{
1010 struct arm_prologue_cache *cache;
1011
eb5492fa 1012 if (*this_cache == NULL)
a262aec2 1013 *this_cache = arm_make_prologue_cache (this_frame);
eb5492fa 1014 cache = *this_cache;
24de872b 1015
eb5492fa 1016 /* If we are asked to unwind the PC, then we need to return the LR
b39cc962
DJ
1017 instead. The prologue may save PC, but it will point into this
1018 frame's prologue, not the next frame's resume location. Also
1019 strip the saved T bit. A valid LR may have the low bit set, but
1020 a valid PC never does. */
eb5492fa 1021 if (prev_regnum == ARM_PC_REGNUM)
b39cc962
DJ
1022 {
1023 CORE_ADDR lr;
1024
1025 lr = frame_unwind_register_unsigned (this_frame, ARM_LR_REGNUM);
1026 return frame_unwind_got_constant (this_frame, prev_regnum,
1027 arm_addr_bits_remove (lr));
1028 }
24de872b 1029
eb5492fa 1030 /* SP is generally not saved to the stack, but this frame is
a262aec2 1031 identified by the next frame's stack pointer at the time of the call.
eb5492fa
DJ
1032 The value was already reconstructed into PREV_SP. */
1033 if (prev_regnum == ARM_SP_REGNUM)
a262aec2 1034 return frame_unwind_got_constant (this_frame, prev_regnum, cache->prev_sp);
eb5492fa 1035
b39cc962
DJ
1036 /* The CPSR may have been changed by the call instruction and by the
1037 called function. The only bit we can reconstruct is the T bit,
1038 by checking the low bit of LR as of the call. This is a reliable
1039 indicator of Thumb-ness except for some ARM v4T pre-interworking
1040 Thumb code, which could get away with a clear low bit as long as
1041 the called function did not use bx. Guess that all other
1042 bits are unchanged; the condition flags are presumably lost,
1043 but the processor status is likely valid. */
1044 if (prev_regnum == ARM_PS_REGNUM)
1045 {
1046 CORE_ADDR lr, cpsr;
1047
1048 cpsr = get_frame_register_unsigned (this_frame, prev_regnum);
1049 lr = frame_unwind_register_unsigned (this_frame, ARM_LR_REGNUM);
1050 if (IS_THUMB_ADDR (lr))
1051 cpsr |= CPSR_T;
1052 else
1053 cpsr &= ~CPSR_T;
1054 return frame_unwind_got_constant (this_frame, prev_regnum, cpsr);
1055 }
1056
a262aec2
DJ
1057 return trad_frame_get_prev_register (this_frame, cache->saved_regs,
1058 prev_regnum);
eb5492fa
DJ
1059}
1060
1061struct frame_unwind arm_prologue_unwind = {
1062 NORMAL_FRAME,
1063 arm_prologue_this_id,
a262aec2
DJ
1064 arm_prologue_prev_register,
1065 NULL,
1066 default_frame_sniffer
eb5492fa
DJ
1067};
1068
909cf6ea 1069static struct arm_prologue_cache *
a262aec2 1070arm_make_stub_cache (struct frame_info *this_frame)
909cf6ea
DJ
1071{
1072 int reg;
1073 struct arm_prologue_cache *cache;
1074 CORE_ADDR unwound_fp;
1075
35d5d4ee 1076 cache = FRAME_OBSTACK_ZALLOC (struct arm_prologue_cache);
a262aec2 1077 cache->saved_regs = trad_frame_alloc_saved_regs (this_frame);
909cf6ea 1078
a262aec2 1079 cache->prev_sp = get_frame_register_unsigned (this_frame, ARM_SP_REGNUM);
909cf6ea
DJ
1080
1081 return cache;
1082}
1083
1084/* Our frame ID for a stub frame is the current SP and LR. */
1085
1086static void
a262aec2 1087arm_stub_this_id (struct frame_info *this_frame,
909cf6ea
DJ
1088 void **this_cache,
1089 struct frame_id *this_id)
1090{
1091 struct arm_prologue_cache *cache;
1092
1093 if (*this_cache == NULL)
a262aec2 1094 *this_cache = arm_make_stub_cache (this_frame);
909cf6ea
DJ
1095 cache = *this_cache;
1096
a262aec2 1097 *this_id = frame_id_build (cache->prev_sp, get_frame_pc (this_frame));
909cf6ea
DJ
1098}
1099
a262aec2
DJ
1100static int
1101arm_stub_unwind_sniffer (const struct frame_unwind *self,
1102 struct frame_info *this_frame,
1103 void **this_prologue_cache)
909cf6ea 1104{
93d42b30 1105 CORE_ADDR addr_in_block;
909cf6ea
DJ
1106 char dummy[4];
1107
a262aec2 1108 addr_in_block = get_frame_address_in_block (this_frame);
93d42b30 1109 if (in_plt_section (addr_in_block, NULL)
a262aec2
DJ
1110 || target_read_memory (get_frame_pc (this_frame), dummy, 4) != 0)
1111 return 1;
909cf6ea 1112
a262aec2 1113 return 0;
909cf6ea
DJ
1114}
1115
a262aec2
DJ
1116struct frame_unwind arm_stub_unwind = {
1117 NORMAL_FRAME,
1118 arm_stub_this_id,
1119 arm_prologue_prev_register,
1120 NULL,
1121 arm_stub_unwind_sniffer
1122};
1123
24de872b 1124static CORE_ADDR
a262aec2 1125arm_normal_frame_base (struct frame_info *this_frame, void **this_cache)
24de872b
DJ
1126{
1127 struct arm_prologue_cache *cache;
1128
eb5492fa 1129 if (*this_cache == NULL)
a262aec2 1130 *this_cache = arm_make_prologue_cache (this_frame);
eb5492fa
DJ
1131 cache = *this_cache;
1132
4be43953 1133 return cache->prev_sp - cache->framesize;
24de872b
DJ
1134}
1135
eb5492fa
DJ
1136struct frame_base arm_normal_base = {
1137 &arm_prologue_unwind,
1138 arm_normal_frame_base,
1139 arm_normal_frame_base,
1140 arm_normal_frame_base
1141};
1142
a262aec2 1143/* Assuming THIS_FRAME is a dummy, return the frame ID of that
eb5492fa
DJ
1144 dummy frame. The frame ID's base needs to match the TOS value
1145 saved by save_dummy_frame_tos() and returned from
1146 arm_push_dummy_call, and the PC needs to match the dummy frame's
1147 breakpoint. */
c906108c 1148
eb5492fa 1149static struct frame_id
a262aec2 1150arm_dummy_id (struct gdbarch *gdbarch, struct frame_info *this_frame)
c906108c 1151{
a262aec2
DJ
1152 return frame_id_build (get_frame_register_unsigned (this_frame, ARM_SP_REGNUM),
1153 get_frame_pc (this_frame));
eb5492fa 1154}
c3b4394c 1155
eb5492fa
DJ
1156/* Given THIS_FRAME, find the previous frame's resume PC (which will
1157 be used to construct the previous frame's ID, after looking up the
1158 containing function). */
c3b4394c 1159
eb5492fa
DJ
1160static CORE_ADDR
1161arm_unwind_pc (struct gdbarch *gdbarch, struct frame_info *this_frame)
1162{
1163 CORE_ADDR pc;
1164 pc = frame_unwind_register_unsigned (this_frame, ARM_PC_REGNUM);
59ea4f70 1165 return arm_addr_bits_remove (pc);
eb5492fa
DJ
1166}
1167
1168static CORE_ADDR
1169arm_unwind_sp (struct gdbarch *gdbarch, struct frame_info *this_frame)
1170{
1171 return frame_unwind_register_unsigned (this_frame, ARM_SP_REGNUM);
c906108c
SS
1172}
1173
b39cc962
DJ
1174static struct value *
1175arm_dwarf2_prev_register (struct frame_info *this_frame, void **this_cache,
1176 int regnum)
1177{
1178 CORE_ADDR lr, cpsr;
1179
1180 switch (regnum)
1181 {
1182 case ARM_PC_REGNUM:
1183 /* The PC is normally copied from the return column, which
1184 describes saves of LR. However, that version may have an
1185 extra bit set to indicate Thumb state. The bit is not
1186 part of the PC. */
1187 lr = frame_unwind_register_unsigned (this_frame, ARM_LR_REGNUM);
1188 return frame_unwind_got_constant (this_frame, regnum,
1189 arm_addr_bits_remove (lr));
1190
1191 case ARM_PS_REGNUM:
1192 /* Reconstruct the T bit; see arm_prologue_prev_register for details. */
ca38c58e 1193 cpsr = get_frame_register_unsigned (this_frame, regnum);
b39cc962
DJ
1194 lr = frame_unwind_register_unsigned (this_frame, ARM_LR_REGNUM);
1195 if (IS_THUMB_ADDR (lr))
1196 cpsr |= CPSR_T;
1197 else
1198 cpsr &= ~CPSR_T;
ca38c58e 1199 return frame_unwind_got_constant (this_frame, regnum, cpsr);
b39cc962
DJ
1200
1201 default:
1202 internal_error (__FILE__, __LINE__,
1203 _("Unexpected register %d"), regnum);
1204 }
1205}
1206
1207static void
1208arm_dwarf2_frame_init_reg (struct gdbarch *gdbarch, int regnum,
1209 struct dwarf2_frame_state_reg *reg,
1210 struct frame_info *this_frame)
1211{
1212 switch (regnum)
1213 {
1214 case ARM_PC_REGNUM:
1215 case ARM_PS_REGNUM:
1216 reg->how = DWARF2_FRAME_REG_FN;
1217 reg->loc.fn = arm_dwarf2_prev_register;
1218 break;
1219 case ARM_SP_REGNUM:
1220 reg->how = DWARF2_FRAME_REG_CFA;
1221 break;
1222 }
1223}
1224
2dd604e7
RE
1225/* When arguments must be pushed onto the stack, they go on in reverse
1226 order. The code below implements a FILO (stack) to do this. */
1227
1228struct stack_item
1229{
1230 int len;
1231 struct stack_item *prev;
1232 void *data;
1233};
1234
1235static struct stack_item *
1236push_stack_item (struct stack_item *prev, void *contents, int len)
1237{
1238 struct stack_item *si;
1239 si = xmalloc (sizeof (struct stack_item));
226c7fbc 1240 si->data = xmalloc (len);
2dd604e7
RE
1241 si->len = len;
1242 si->prev = prev;
1243 memcpy (si->data, contents, len);
1244 return si;
1245}
1246
1247static struct stack_item *
1248pop_stack_item (struct stack_item *si)
1249{
1250 struct stack_item *dead = si;
1251 si = si->prev;
1252 xfree (dead->data);
1253 xfree (dead);
1254 return si;
1255}
1256
2af48f68
PB
1257
1258/* Return the alignment (in bytes) of the given type. */
1259
1260static int
1261arm_type_align (struct type *t)
1262{
1263 int n;
1264 int align;
1265 int falign;
1266
1267 t = check_typedef (t);
1268 switch (TYPE_CODE (t))
1269 {
1270 default:
1271 /* Should never happen. */
1272 internal_error (__FILE__, __LINE__, _("unknown type alignment"));
1273 return 4;
1274
1275 case TYPE_CODE_PTR:
1276 case TYPE_CODE_ENUM:
1277 case TYPE_CODE_INT:
1278 case TYPE_CODE_FLT:
1279 case TYPE_CODE_SET:
1280 case TYPE_CODE_RANGE:
1281 case TYPE_CODE_BITSTRING:
1282 case TYPE_CODE_REF:
1283 case TYPE_CODE_CHAR:
1284 case TYPE_CODE_BOOL:
1285 return TYPE_LENGTH (t);
1286
1287 case TYPE_CODE_ARRAY:
1288 case TYPE_CODE_COMPLEX:
1289 /* TODO: What about vector types? */
1290 return arm_type_align (TYPE_TARGET_TYPE (t));
1291
1292 case TYPE_CODE_STRUCT:
1293 case TYPE_CODE_UNION:
1294 align = 1;
1295 for (n = 0; n < TYPE_NFIELDS (t); n++)
1296 {
1297 falign = arm_type_align (TYPE_FIELD_TYPE (t, n));
1298 if (falign > align)
1299 align = falign;
1300 }
1301 return align;
1302 }
1303}
1304
2dd604e7
RE
1305/* We currently only support passing parameters in integer registers. This
1306 conforms with GCC's default model. Several other variants exist and
1307 we should probably support some of them based on the selected ABI. */
1308
1309static CORE_ADDR
7d9b040b 1310arm_push_dummy_call (struct gdbarch *gdbarch, struct value *function,
6a65450a
AC
1311 struct regcache *regcache, CORE_ADDR bp_addr, int nargs,
1312 struct value **args, CORE_ADDR sp, int struct_return,
1313 CORE_ADDR struct_addr)
2dd604e7
RE
1314{
1315 int argnum;
1316 int argreg;
1317 int nstack;
1318 struct stack_item *si = NULL;
1319
6a65450a
AC
1320 /* Set the return address. For the ARM, the return breakpoint is
1321 always at BP_ADDR. */
2dd604e7 1322 /* XXX Fix for Thumb. */
6a65450a 1323 regcache_cooked_write_unsigned (regcache, ARM_LR_REGNUM, bp_addr);
2dd604e7
RE
1324
1325 /* Walk through the list of args and determine how large a temporary
1326 stack is required. Need to take care here as structs may be
1327 passed on the stack, and we have to to push them. */
1328 nstack = 0;
1329
1330 argreg = ARM_A1_REGNUM;
1331 nstack = 0;
1332
2dd604e7
RE
1333 /* The struct_return pointer occupies the first parameter
1334 passing register. */
1335 if (struct_return)
1336 {
1337 if (arm_debug)
1338 fprintf_unfiltered (gdb_stdlog, "struct return in %s = 0x%s\n",
2af46ca0 1339 gdbarch_register_name (gdbarch, argreg),
c9f4d572 1340 paddr (struct_addr));
2dd604e7
RE
1341 regcache_cooked_write_unsigned (regcache, argreg, struct_addr);
1342 argreg++;
1343 }
1344
1345 for (argnum = 0; argnum < nargs; argnum++)
1346 {
1347 int len;
1348 struct type *arg_type;
1349 struct type *target_type;
1350 enum type_code typecode;
0fd88904 1351 bfd_byte *val;
2af48f68 1352 int align;
2dd604e7 1353
df407dfe 1354 arg_type = check_typedef (value_type (args[argnum]));
2dd604e7
RE
1355 len = TYPE_LENGTH (arg_type);
1356 target_type = TYPE_TARGET_TYPE (arg_type);
1357 typecode = TYPE_CODE (arg_type);
0fd88904 1358 val = value_contents_writeable (args[argnum]);
2dd604e7 1359
2af48f68
PB
1360 align = arm_type_align (arg_type);
1361 /* Round alignment up to a whole number of words. */
1362 align = (align + INT_REGISTER_SIZE - 1) & ~(INT_REGISTER_SIZE - 1);
1363 /* Different ABIs have different maximum alignments. */
1364 if (gdbarch_tdep (gdbarch)->arm_abi == ARM_ABI_APCS)
1365 {
1366 /* The APCS ABI only requires word alignment. */
1367 align = INT_REGISTER_SIZE;
1368 }
1369 else
1370 {
1371 /* The AAPCS requires at most doubleword alignment. */
1372 if (align > INT_REGISTER_SIZE * 2)
1373 align = INT_REGISTER_SIZE * 2;
1374 }
1375
1376 /* Push stack padding for dowubleword alignment. */
1377 if (nstack & (align - 1))
1378 {
1379 si = push_stack_item (si, val, INT_REGISTER_SIZE);
1380 nstack += INT_REGISTER_SIZE;
1381 }
1382
1383 /* Doubleword aligned quantities must go in even register pairs. */
1384 if (argreg <= ARM_LAST_ARG_REGNUM
1385 && align > INT_REGISTER_SIZE
1386 && argreg & 1)
1387 argreg++;
1388
2dd604e7
RE
1389 /* If the argument is a pointer to a function, and it is a
1390 Thumb function, create a LOCAL copy of the value and set
1391 the THUMB bit in it. */
1392 if (TYPE_CODE_PTR == typecode
1393 && target_type != NULL
1394 && TYPE_CODE_FUNC == TYPE_CODE (target_type))
1395 {
7c0b4a20 1396 CORE_ADDR regval = extract_unsigned_integer (val, len);
2dd604e7
RE
1397 if (arm_pc_is_thumb (regval))
1398 {
1399 val = alloca (len);
fbd9dcd3 1400 store_unsigned_integer (val, len, MAKE_THUMB_ADDR (regval));
2dd604e7
RE
1401 }
1402 }
1403
1404 /* Copy the argument to general registers or the stack in
1405 register-sized pieces. Large arguments are split between
1406 registers and stack. */
1407 while (len > 0)
1408 {
f0c9063c 1409 int partial_len = len < INT_REGISTER_SIZE ? len : INT_REGISTER_SIZE;
2dd604e7
RE
1410
1411 if (argreg <= ARM_LAST_ARG_REGNUM)
1412 {
1413 /* The argument is being passed in a general purpose
1414 register. */
7c0b4a20 1415 CORE_ADDR regval = extract_unsigned_integer (val, partial_len);
2af46ca0 1416 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG)
8bf8793c 1417 regval <<= (INT_REGISTER_SIZE - partial_len) * 8;
2dd604e7
RE
1418 if (arm_debug)
1419 fprintf_unfiltered (gdb_stdlog, "arg %d in %s = 0x%s\n",
c9f4d572
UW
1420 argnum,
1421 gdbarch_register_name
2af46ca0 1422 (gdbarch, argreg),
f0c9063c 1423 phex (regval, INT_REGISTER_SIZE));
2dd604e7
RE
1424 regcache_cooked_write_unsigned (regcache, argreg, regval);
1425 argreg++;
1426 }
1427 else
1428 {
1429 /* Push the arguments onto the stack. */
1430 if (arm_debug)
1431 fprintf_unfiltered (gdb_stdlog, "arg %d @ sp + %d\n",
1432 argnum, nstack);
f0c9063c
UW
1433 si = push_stack_item (si, val, INT_REGISTER_SIZE);
1434 nstack += INT_REGISTER_SIZE;
2dd604e7
RE
1435 }
1436
1437 len -= partial_len;
1438 val += partial_len;
1439 }
1440 }
1441 /* If we have an odd number of words to push, then decrement the stack
1442 by one word now, so first stack argument will be dword aligned. */
1443 if (nstack & 4)
1444 sp -= 4;
1445
1446 while (si)
1447 {
1448 sp -= si->len;
1449 write_memory (sp, si->data, si->len);
1450 si = pop_stack_item (si);
1451 }
1452
1453 /* Finally, update teh SP register. */
1454 regcache_cooked_write_unsigned (regcache, ARM_SP_REGNUM, sp);
1455
1456 return sp;
1457}
1458
f53f0d0b
PB
1459
1460/* Always align the frame to an 8-byte boundary. This is required on
1461 some platforms and harmless on the rest. */
1462
1463static CORE_ADDR
1464arm_frame_align (struct gdbarch *gdbarch, CORE_ADDR sp)
1465{
1466 /* Align the stack to eight bytes. */
1467 return sp & ~ (CORE_ADDR) 7;
1468}
1469
c906108c 1470static void
ed9a39eb 1471print_fpu_flags (int flags)
c906108c 1472{
c5aa993b
JM
1473 if (flags & (1 << 0))
1474 fputs ("IVO ", stdout);
1475 if (flags & (1 << 1))
1476 fputs ("DVZ ", stdout);
1477 if (flags & (1 << 2))
1478 fputs ("OFL ", stdout);
1479 if (flags & (1 << 3))
1480 fputs ("UFL ", stdout);
1481 if (flags & (1 << 4))
1482 fputs ("INX ", stdout);
1483 putchar ('\n');
c906108c
SS
1484}
1485
5e74b15c
RE
1486/* Print interesting information about the floating point processor
1487 (if present) or emulator. */
34e8f22d 1488static void
d855c300 1489arm_print_float_info (struct gdbarch *gdbarch, struct ui_file *file,
23e3a7ac 1490 struct frame_info *frame, const char *args)
c906108c 1491{
9c9acae0 1492 unsigned long status = get_frame_register_unsigned (frame, ARM_FPS_REGNUM);
c5aa993b
JM
1493 int type;
1494
1495 type = (status >> 24) & 127;
edefbb7c
AC
1496 if (status & (1 << 31))
1497 printf (_("Hardware FPU type %d\n"), type);
1498 else
1499 printf (_("Software FPU type %d\n"), type);
1500 /* i18n: [floating point unit] mask */
1501 fputs (_("mask: "), stdout);
c5aa993b 1502 print_fpu_flags (status >> 16);
edefbb7c
AC
1503 /* i18n: [floating point unit] flags */
1504 fputs (_("flags: "), stdout);
c5aa993b 1505 print_fpu_flags (status);
c906108c
SS
1506}
1507
34e8f22d
RE
1508/* Return the GDB type object for the "standard" data type of data in
1509 register N. */
1510
1511static struct type *
7a5ea0d4 1512arm_register_type (struct gdbarch *gdbarch, int regnum)
032758dc 1513{
34e8f22d 1514 if (regnum >= ARM_F0_REGNUM && regnum < ARM_F0_REGNUM + NUM_FREGS)
8da61cc4 1515 return builtin_type_arm_ext;
e4c16157
DJ
1516 else if (regnum == ARM_SP_REGNUM)
1517 return builtin_type_void_data_ptr;
1518 else if (regnum == ARM_PC_REGNUM)
1519 return builtin_type_void_func_ptr;
ff6f572f
DJ
1520 else if (regnum >= ARRAY_SIZE (arm_register_names))
1521 /* These registers are only supported on targets which supply
1522 an XML description. */
1523 return builtin_type_int0;
032758dc 1524 else
e4c16157 1525 return builtin_type_uint32;
032758dc
AC
1526}
1527
ff6f572f
DJ
1528/* Map a DWARF register REGNUM onto the appropriate GDB register
1529 number. */
1530
1531static int
d3f73121 1532arm_dwarf_reg_to_regnum (struct gdbarch *gdbarch, int reg)
ff6f572f
DJ
1533{
1534 /* Core integer regs. */
1535 if (reg >= 0 && reg <= 15)
1536 return reg;
1537
1538 /* Legacy FPA encoding. These were once used in a way which
1539 overlapped with VFP register numbering, so their use is
1540 discouraged, but GDB doesn't support the ARM toolchain
1541 which used them for VFP. */
1542 if (reg >= 16 && reg <= 23)
1543 return ARM_F0_REGNUM + reg - 16;
1544
1545 /* New assignments for the FPA registers. */
1546 if (reg >= 96 && reg <= 103)
1547 return ARM_F0_REGNUM + reg - 96;
1548
1549 /* WMMX register assignments. */
1550 if (reg >= 104 && reg <= 111)
1551 return ARM_WCGR0_REGNUM + reg - 104;
1552
1553 if (reg >= 112 && reg <= 127)
1554 return ARM_WR0_REGNUM + reg - 112;
1555
1556 if (reg >= 192 && reg <= 199)
1557 return ARM_WC0_REGNUM + reg - 192;
1558
1559 return -1;
1560}
1561
26216b98
AC
1562/* Map GDB internal REGNUM onto the Arm simulator register numbers. */
1563static int
e7faf938 1564arm_register_sim_regno (struct gdbarch *gdbarch, int regnum)
26216b98
AC
1565{
1566 int reg = regnum;
e7faf938 1567 gdb_assert (reg >= 0 && reg < gdbarch_num_regs (gdbarch));
26216b98 1568
ff6f572f
DJ
1569 if (regnum >= ARM_WR0_REGNUM && regnum <= ARM_WR15_REGNUM)
1570 return regnum - ARM_WR0_REGNUM + SIM_ARM_IWMMXT_COP0R0_REGNUM;
1571
1572 if (regnum >= ARM_WC0_REGNUM && regnum <= ARM_WC7_REGNUM)
1573 return regnum - ARM_WC0_REGNUM + SIM_ARM_IWMMXT_COP1R0_REGNUM;
1574
1575 if (regnum >= ARM_WCGR0_REGNUM && regnum <= ARM_WCGR7_REGNUM)
1576 return regnum - ARM_WCGR0_REGNUM + SIM_ARM_IWMMXT_COP1R8_REGNUM;
1577
26216b98
AC
1578 if (reg < NUM_GREGS)
1579 return SIM_ARM_R0_REGNUM + reg;
1580 reg -= NUM_GREGS;
1581
1582 if (reg < NUM_FREGS)
1583 return SIM_ARM_FP0_REGNUM + reg;
1584 reg -= NUM_FREGS;
1585
1586 if (reg < NUM_SREGS)
1587 return SIM_ARM_FPS_REGNUM + reg;
1588 reg -= NUM_SREGS;
1589
edefbb7c 1590 internal_error (__FILE__, __LINE__, _("Bad REGNUM %d"), regnum);
26216b98 1591}
34e8f22d 1592
a37b3cc0
AC
1593/* NOTE: cagney/2001-08-20: Both convert_from_extended() and
1594 convert_to_extended() use floatformat_arm_ext_littlebyte_bigword.
1595 It is thought that this is is the floating-point register format on
1596 little-endian systems. */
c906108c 1597
ed9a39eb 1598static void
b508a996 1599convert_from_extended (const struct floatformat *fmt, const void *ptr,
be8626e0 1600 void *dbl, int endianess)
c906108c 1601{
a37b3cc0 1602 DOUBLEST d;
be8626e0
MD
1603
1604 if (endianess == BFD_ENDIAN_BIG)
a37b3cc0
AC
1605 floatformat_to_doublest (&floatformat_arm_ext_big, ptr, &d);
1606 else
1607 floatformat_to_doublest (&floatformat_arm_ext_littlebyte_bigword,
1608 ptr, &d);
b508a996 1609 floatformat_from_doublest (fmt, &d, dbl);
c906108c
SS
1610}
1611
34e8f22d 1612static void
be8626e0
MD
1613convert_to_extended (const struct floatformat *fmt, void *dbl, const void *ptr,
1614 int endianess)
c906108c 1615{
a37b3cc0 1616 DOUBLEST d;
be8626e0 1617
b508a996 1618 floatformat_to_doublest (fmt, ptr, &d);
be8626e0 1619 if (endianess == BFD_ENDIAN_BIG)
a37b3cc0
AC
1620 floatformat_from_doublest (&floatformat_arm_ext_big, &d, dbl);
1621 else
1622 floatformat_from_doublest (&floatformat_arm_ext_littlebyte_bigword,
1623 &d, dbl);
c906108c 1624}
ed9a39eb 1625
c906108c 1626static int
ed9a39eb 1627condition_true (unsigned long cond, unsigned long status_reg)
c906108c
SS
1628{
1629 if (cond == INST_AL || cond == INST_NV)
1630 return 1;
1631
1632 switch (cond)
1633 {
1634 case INST_EQ:
1635 return ((status_reg & FLAG_Z) != 0);
1636 case INST_NE:
1637 return ((status_reg & FLAG_Z) == 0);
1638 case INST_CS:
1639 return ((status_reg & FLAG_C) != 0);
1640 case INST_CC:
1641 return ((status_reg & FLAG_C) == 0);
1642 case INST_MI:
1643 return ((status_reg & FLAG_N) != 0);
1644 case INST_PL:
1645 return ((status_reg & FLAG_N) == 0);
1646 case INST_VS:
1647 return ((status_reg & FLAG_V) != 0);
1648 case INST_VC:
1649 return ((status_reg & FLAG_V) == 0);
1650 case INST_HI:
1651 return ((status_reg & (FLAG_C | FLAG_Z)) == FLAG_C);
1652 case INST_LS:
1653 return ((status_reg & (FLAG_C | FLAG_Z)) != FLAG_C);
1654 case INST_GE:
1655 return (((status_reg & FLAG_N) == 0) == ((status_reg & FLAG_V) == 0));
1656 case INST_LT:
1657 return (((status_reg & FLAG_N) == 0) != ((status_reg & FLAG_V) == 0));
1658 case INST_GT:
1659 return (((status_reg & FLAG_Z) == 0) &&
ed9a39eb 1660 (((status_reg & FLAG_N) == 0) == ((status_reg & FLAG_V) == 0)));
c906108c
SS
1661 case INST_LE:
1662 return (((status_reg & FLAG_Z) != 0) ||
ed9a39eb 1663 (((status_reg & FLAG_N) == 0) != ((status_reg & FLAG_V) == 0)));
c906108c
SS
1664 }
1665 return 1;
1666}
1667
9512d7fd 1668/* Support routines for single stepping. Calculate the next PC value. */
c906108c
SS
1669#define submask(x) ((1L << ((x) + 1)) - 1)
1670#define bit(obj,st) (((obj) >> (st)) & 1)
1671#define bits(obj,st,fn) (((obj) >> (st)) & submask ((fn) - (st)))
1672#define sbits(obj,st,fn) \
1673 ((long) (bits(obj,st,fn) | ((long) bit(obj,fn) * ~ submask (fn - st))))
1674#define BranchDest(addr,instr) \
1675 ((CORE_ADDR) (((long) (addr)) + 8 + (sbits (instr, 0, 23) << 2)))
1676#define ARM_PC_32 1
1677
1678static unsigned long
0b1b3e42
UW
1679shifted_reg_val (struct frame_info *frame, unsigned long inst, int carry,
1680 unsigned long pc_val, unsigned long status_reg)
c906108c
SS
1681{
1682 unsigned long res, shift;
1683 int rm = bits (inst, 0, 3);
1684 unsigned long shifttype = bits (inst, 5, 6);
c5aa993b
JM
1685
1686 if (bit (inst, 4))
c906108c
SS
1687 {
1688 int rs = bits (inst, 8, 11);
0b1b3e42
UW
1689 shift = (rs == 15 ? pc_val + 8
1690 : get_frame_register_unsigned (frame, rs)) & 0xFF;
c906108c
SS
1691 }
1692 else
1693 shift = bits (inst, 7, 11);
c5aa993b
JM
1694
1695 res = (rm == 15
c906108c 1696 ? ((pc_val | (ARM_PC_32 ? 0 : status_reg))
c5aa993b 1697 + (bit (inst, 4) ? 12 : 8))
0b1b3e42 1698 : get_frame_register_unsigned (frame, rm));
c906108c
SS
1699
1700 switch (shifttype)
1701 {
c5aa993b 1702 case 0: /* LSL */
c906108c
SS
1703 res = shift >= 32 ? 0 : res << shift;
1704 break;
c5aa993b
JM
1705
1706 case 1: /* LSR */
c906108c
SS
1707 res = shift >= 32 ? 0 : res >> shift;
1708 break;
1709
c5aa993b
JM
1710 case 2: /* ASR */
1711 if (shift >= 32)
1712 shift = 31;
c906108c
SS
1713 res = ((res & 0x80000000L)
1714 ? ~((~res) >> shift) : res >> shift);
1715 break;
1716
c5aa993b 1717 case 3: /* ROR/RRX */
c906108c
SS
1718 shift &= 31;
1719 if (shift == 0)
1720 res = (res >> 1) | (carry ? 0x80000000L : 0);
1721 else
c5aa993b 1722 res = (res >> shift) | (res << (32 - shift));
c906108c
SS
1723 break;
1724 }
1725
1726 return res & 0xffffffff;
1727}
1728
c906108c
SS
1729/* Return number of 1-bits in VAL. */
1730
1731static int
ed9a39eb 1732bitcount (unsigned long val)
c906108c
SS
1733{
1734 int nbits;
1735 for (nbits = 0; val != 0; nbits++)
c5aa993b 1736 val &= val - 1; /* delete rightmost 1-bit in val */
c906108c
SS
1737 return nbits;
1738}
1739
ad527d2e 1740static CORE_ADDR
0b1b3e42 1741thumb_get_next_pc (struct frame_info *frame, CORE_ADDR pc)
c906108c 1742{
2af46ca0 1743 struct gdbarch *gdbarch = get_frame_arch (frame);
c5aa993b 1744 unsigned long pc_val = ((unsigned long) pc) + 4; /* PC after prefetch */
1c5bada0 1745 unsigned short inst1 = read_memory_unsigned_integer (pc, 2);
94c30b78 1746 CORE_ADDR nextpc = pc + 2; /* default is next instruction */
c906108c
SS
1747 unsigned long offset;
1748
1749 if ((inst1 & 0xff00) == 0xbd00) /* pop {rlist, pc} */
1750 {
1751 CORE_ADDR sp;
1752
1753 /* Fetch the saved PC from the stack. It's stored above
1754 all of the other registers. */
f0c9063c 1755 offset = bitcount (bits (inst1, 0, 7)) * INT_REGISTER_SIZE;
0b1b3e42 1756 sp = get_frame_register_unsigned (frame, ARM_SP_REGNUM);
1c5bada0 1757 nextpc = (CORE_ADDR) read_memory_unsigned_integer (sp + offset, 4);
2af46ca0 1758 nextpc = gdbarch_addr_bits_remove (gdbarch, nextpc);
c906108c 1759 if (nextpc == pc)
edefbb7c 1760 error (_("Infinite loop detected"));
c906108c
SS
1761 }
1762 else if ((inst1 & 0xf000) == 0xd000) /* conditional branch */
1763 {
0b1b3e42 1764 unsigned long status = get_frame_register_unsigned (frame, ARM_PS_REGNUM);
c5aa993b 1765 unsigned long cond = bits (inst1, 8, 11);
94c30b78 1766 if (cond != 0x0f && condition_true (cond, status)) /* 0x0f = SWI */
c906108c
SS
1767 nextpc = pc_val + (sbits (inst1, 0, 7) << 1);
1768 }
1769 else if ((inst1 & 0xf800) == 0xe000) /* unconditional branch */
1770 {
1771 nextpc = pc_val + (sbits (inst1, 0, 10) << 1);
1772 }
aa17d93e 1773 else if ((inst1 & 0xf800) == 0xf000) /* long branch with link, and blx */
c906108c 1774 {
1c5bada0 1775 unsigned short inst2 = read_memory_unsigned_integer (pc + 2, 2);
c5aa993b 1776 offset = (sbits (inst1, 0, 10) << 12) + (bits (inst2, 0, 10) << 1);
c906108c 1777 nextpc = pc_val + offset;
aa17d93e
DJ
1778 /* For BLX make sure to clear the low bits. */
1779 if (bits (inst2, 11, 12) == 1)
1780 nextpc = nextpc & 0xfffffffc;
c906108c 1781 }
aa17d93e 1782 else if ((inst1 & 0xff00) == 0x4700) /* bx REG, blx REG */
9498281f
DJ
1783 {
1784 if (bits (inst1, 3, 6) == 0x0f)
1785 nextpc = pc_val;
1786 else
0b1b3e42 1787 nextpc = get_frame_register_unsigned (frame, bits (inst1, 3, 6));
9498281f 1788
2af46ca0 1789 nextpc = gdbarch_addr_bits_remove (gdbarch, nextpc);
9498281f 1790 if (nextpc == pc)
edefbb7c 1791 error (_("Infinite loop detected"));
9498281f 1792 }
c906108c
SS
1793
1794 return nextpc;
1795}
1796
daddc3c1 1797CORE_ADDR
0b1b3e42 1798arm_get_next_pc (struct frame_info *frame, CORE_ADDR pc)
c906108c 1799{
2af46ca0 1800 struct gdbarch *gdbarch = get_frame_arch (frame);
c906108c
SS
1801 unsigned long pc_val;
1802 unsigned long this_instr;
1803 unsigned long status;
1804 CORE_ADDR nextpc;
1805
b39cc962 1806 if (arm_frame_is_thumb (frame))
0b1b3e42 1807 return thumb_get_next_pc (frame, pc);
c906108c
SS
1808
1809 pc_val = (unsigned long) pc;
1c5bada0 1810 this_instr = read_memory_unsigned_integer (pc, 4);
0b1b3e42 1811 status = get_frame_register_unsigned (frame, ARM_PS_REGNUM);
c5aa993b 1812 nextpc = (CORE_ADDR) (pc_val + 4); /* Default case */
c906108c 1813
daddc3c1
DJ
1814 if (bits (this_instr, 28, 31) == INST_NV)
1815 switch (bits (this_instr, 24, 27))
1816 {
1817 case 0xa:
1818 case 0xb:
1819 {
1820 /* Branch with Link and change to Thumb. */
1821 nextpc = BranchDest (pc, this_instr);
1822 nextpc |= bit (this_instr, 24) << 1;
1823
e1e01acd 1824 nextpc = gdbarch_addr_bits_remove (gdbarch, nextpc);
daddc3c1
DJ
1825 if (nextpc == pc)
1826 error (_("Infinite loop detected"));
1827 break;
1828 }
1829 case 0xc:
1830 case 0xd:
1831 case 0xe:
1832 /* Coprocessor register transfer. */
1833 if (bits (this_instr, 12, 15) == 15)
1834 error (_("Invalid update to pc in instruction"));
1835 break;
1836 }
1837 else if (condition_true (bits (this_instr, 28, 31), status))
c906108c
SS
1838 {
1839 switch (bits (this_instr, 24, 27))
1840 {
c5aa993b 1841 case 0x0:
94c30b78 1842 case 0x1: /* data processing */
c5aa993b
JM
1843 case 0x2:
1844 case 0x3:
c906108c
SS
1845 {
1846 unsigned long operand1, operand2, result = 0;
1847 unsigned long rn;
1848 int c;
c5aa993b 1849
c906108c
SS
1850 if (bits (this_instr, 12, 15) != 15)
1851 break;
1852
1853 if (bits (this_instr, 22, 25) == 0
c5aa993b 1854 && bits (this_instr, 4, 7) == 9) /* multiply */
edefbb7c 1855 error (_("Invalid update to pc in instruction"));
c906108c 1856
9498281f 1857 /* BX <reg>, BLX <reg> */
e150acc7
PB
1858 if (bits (this_instr, 4, 27) == 0x12fff1
1859 || bits (this_instr, 4, 27) == 0x12fff3)
9498281f
DJ
1860 {
1861 rn = bits (this_instr, 0, 3);
0b1b3e42
UW
1862 result = (rn == 15) ? pc_val + 8
1863 : get_frame_register_unsigned (frame, rn);
bf6ae464 1864 nextpc = (CORE_ADDR) gdbarch_addr_bits_remove
2af46ca0 1865 (gdbarch, result);
9498281f
DJ
1866
1867 if (nextpc == pc)
edefbb7c 1868 error (_("Infinite loop detected"));
9498281f
DJ
1869
1870 return nextpc;
1871 }
1872
c906108c
SS
1873 /* Multiply into PC */
1874 c = (status & FLAG_C) ? 1 : 0;
1875 rn = bits (this_instr, 16, 19);
0b1b3e42
UW
1876 operand1 = (rn == 15) ? pc_val + 8
1877 : get_frame_register_unsigned (frame, rn);
c5aa993b 1878
c906108c
SS
1879 if (bit (this_instr, 25))
1880 {
1881 unsigned long immval = bits (this_instr, 0, 7);
1882 unsigned long rotate = 2 * bits (this_instr, 8, 11);
c5aa993b
JM
1883 operand2 = ((immval >> rotate) | (immval << (32 - rotate)))
1884 & 0xffffffff;
c906108c 1885 }
c5aa993b 1886 else /* operand 2 is a shifted register */
0b1b3e42 1887 operand2 = shifted_reg_val (frame, this_instr, c, pc_val, status);
c5aa993b 1888
c906108c
SS
1889 switch (bits (this_instr, 21, 24))
1890 {
c5aa993b 1891 case 0x0: /*and */
c906108c
SS
1892 result = operand1 & operand2;
1893 break;
1894
c5aa993b 1895 case 0x1: /*eor */
c906108c
SS
1896 result = operand1 ^ operand2;
1897 break;
1898
c5aa993b 1899 case 0x2: /*sub */
c906108c
SS
1900 result = operand1 - operand2;
1901 break;
1902
c5aa993b 1903 case 0x3: /*rsb */
c906108c
SS
1904 result = operand2 - operand1;
1905 break;
1906
c5aa993b 1907 case 0x4: /*add */
c906108c
SS
1908 result = operand1 + operand2;
1909 break;
1910
c5aa993b 1911 case 0x5: /*adc */
c906108c
SS
1912 result = operand1 + operand2 + c;
1913 break;
1914
c5aa993b 1915 case 0x6: /*sbc */
c906108c
SS
1916 result = operand1 - operand2 + c;
1917 break;
1918
c5aa993b 1919 case 0x7: /*rsc */
c906108c
SS
1920 result = operand2 - operand1 + c;
1921 break;
1922
c5aa993b
JM
1923 case 0x8:
1924 case 0x9:
1925 case 0xa:
1926 case 0xb: /* tst, teq, cmp, cmn */
c906108c
SS
1927 result = (unsigned long) nextpc;
1928 break;
1929
c5aa993b 1930 case 0xc: /*orr */
c906108c
SS
1931 result = operand1 | operand2;
1932 break;
1933
c5aa993b 1934 case 0xd: /*mov */
c906108c
SS
1935 /* Always step into a function. */
1936 result = operand2;
c5aa993b 1937 break;
c906108c 1938
c5aa993b 1939 case 0xe: /*bic */
c906108c
SS
1940 result = operand1 & ~operand2;
1941 break;
1942
c5aa993b 1943 case 0xf: /*mvn */
c906108c
SS
1944 result = ~operand2;
1945 break;
1946 }
bf6ae464 1947 nextpc = (CORE_ADDR) gdbarch_addr_bits_remove
2af46ca0 1948 (gdbarch, result);
c906108c
SS
1949
1950 if (nextpc == pc)
edefbb7c 1951 error (_("Infinite loop detected"));
c906108c
SS
1952 break;
1953 }
c5aa993b
JM
1954
1955 case 0x4:
1956 case 0x5: /* data transfer */
1957 case 0x6:
1958 case 0x7:
c906108c
SS
1959 if (bit (this_instr, 20))
1960 {
1961 /* load */
1962 if (bits (this_instr, 12, 15) == 15)
1963 {
1964 /* rd == pc */
c5aa993b 1965 unsigned long rn;
c906108c 1966 unsigned long base;
c5aa993b 1967
c906108c 1968 if (bit (this_instr, 22))
edefbb7c 1969 error (_("Invalid update to pc in instruction"));
c906108c
SS
1970
1971 /* byte write to PC */
1972 rn = bits (this_instr, 16, 19);
0b1b3e42
UW
1973 base = (rn == 15) ? pc_val + 8
1974 : get_frame_register_unsigned (frame, rn);
c906108c
SS
1975 if (bit (this_instr, 24))
1976 {
1977 /* pre-indexed */
1978 int c = (status & FLAG_C) ? 1 : 0;
1979 unsigned long offset =
c5aa993b 1980 (bit (this_instr, 25)
0b1b3e42 1981 ? shifted_reg_val (frame, this_instr, c, pc_val, status)
c5aa993b 1982 : bits (this_instr, 0, 11));
c906108c
SS
1983
1984 if (bit (this_instr, 23))
1985 base += offset;
1986 else
1987 base -= offset;
1988 }
c5aa993b 1989 nextpc = (CORE_ADDR) read_memory_integer ((CORE_ADDR) base,
c906108c 1990 4);
c5aa993b 1991
2af46ca0 1992 nextpc = gdbarch_addr_bits_remove (gdbarch, nextpc);
c906108c
SS
1993
1994 if (nextpc == pc)
edefbb7c 1995 error (_("Infinite loop detected"));
c906108c
SS
1996 }
1997 }
1998 break;
c5aa993b
JM
1999
2000 case 0x8:
2001 case 0x9: /* block transfer */
c906108c
SS
2002 if (bit (this_instr, 20))
2003 {
2004 /* LDM */
2005 if (bit (this_instr, 15))
2006 {
2007 /* loading pc */
2008 int offset = 0;
2009
2010 if (bit (this_instr, 23))
2011 {
2012 /* up */
2013 unsigned long reglist = bits (this_instr, 0, 14);
2014 offset = bitcount (reglist) * 4;
c5aa993b 2015 if (bit (this_instr, 24)) /* pre */
c906108c
SS
2016 offset += 4;
2017 }
2018 else if (bit (this_instr, 24))
2019 offset = -4;
c5aa993b 2020
c906108c 2021 {
c5aa993b 2022 unsigned long rn_val =
0b1b3e42
UW
2023 get_frame_register_unsigned (frame,
2024 bits (this_instr, 16, 19));
c906108c
SS
2025 nextpc =
2026 (CORE_ADDR) read_memory_integer ((CORE_ADDR) (rn_val
c5aa993b 2027 + offset),
c906108c
SS
2028 4);
2029 }
bf6ae464 2030 nextpc = gdbarch_addr_bits_remove
2af46ca0 2031 (gdbarch, nextpc);
c906108c 2032 if (nextpc == pc)
edefbb7c 2033 error (_("Infinite loop detected"));
c906108c
SS
2034 }
2035 }
2036 break;
c5aa993b
JM
2037
2038 case 0xb: /* branch & link */
2039 case 0xa: /* branch */
c906108c
SS
2040 {
2041 nextpc = BranchDest (pc, this_instr);
2042
2af46ca0 2043 nextpc = gdbarch_addr_bits_remove (gdbarch, nextpc);
c906108c 2044 if (nextpc == pc)
edefbb7c 2045 error (_("Infinite loop detected"));
c906108c
SS
2046 break;
2047 }
c5aa993b
JM
2048
2049 case 0xc:
2050 case 0xd:
2051 case 0xe: /* coproc ops */
2052 case 0xf: /* SWI */
c906108c
SS
2053 break;
2054
2055 default:
edefbb7c 2056 fprintf_filtered (gdb_stderr, _("Bad bit-field extraction\n"));
c906108c
SS
2057 return (pc);
2058 }
2059 }
2060
2061 return nextpc;
2062}
2063
9512d7fd
FN
2064/* single_step() is called just before we want to resume the inferior,
2065 if we want to single-step it but there is no hardware or kernel
2066 single-step support. We find the target of the coming instruction
e0cd558a 2067 and breakpoint it. */
9512d7fd 2068
190dce09 2069int
0b1b3e42 2070arm_software_single_step (struct frame_info *frame)
9512d7fd 2071{
8181d85f
DJ
2072 /* NOTE: This may insert the wrong breakpoint instruction when
2073 single-stepping over a mode-changing instruction, if the
2074 CPSR heuristics are used. */
9512d7fd 2075
0b1b3e42 2076 CORE_ADDR next_pc = arm_get_next_pc (frame, get_frame_pc (frame));
e0cd558a 2077 insert_single_step_breakpoint (next_pc);
e6590a1b
UW
2078
2079 return 1;
9512d7fd 2080}
9512d7fd 2081
c906108c
SS
2082#include "bfd-in2.h"
2083#include "libcoff.h"
2084
2085static int
ed9a39eb 2086gdb_print_insn_arm (bfd_vma memaddr, disassemble_info *info)
c906108c
SS
2087{
2088 if (arm_pc_is_thumb (memaddr))
2089 {
c5aa993b
JM
2090 static asymbol *asym;
2091 static combined_entry_type ce;
2092 static struct coff_symbol_struct csym;
27cddce2 2093 static struct bfd fake_bfd;
c5aa993b 2094 static bfd_target fake_target;
c906108c
SS
2095
2096 if (csym.native == NULL)
2097 {
da3c6d4a
MS
2098 /* Create a fake symbol vector containing a Thumb symbol.
2099 This is solely so that the code in print_insn_little_arm()
2100 and print_insn_big_arm() in opcodes/arm-dis.c will detect
2101 the presence of a Thumb symbol and switch to decoding
2102 Thumb instructions. */
c5aa993b
JM
2103
2104 fake_target.flavour = bfd_target_coff_flavour;
2105 fake_bfd.xvec = &fake_target;
c906108c 2106 ce.u.syment.n_sclass = C_THUMBEXTFUNC;
c5aa993b
JM
2107 csym.native = &ce;
2108 csym.symbol.the_bfd = &fake_bfd;
2109 csym.symbol.name = "fake";
2110 asym = (asymbol *) & csym;
c906108c 2111 }
c5aa993b 2112
c906108c 2113 memaddr = UNMAKE_THUMB_ADDR (memaddr);
c5aa993b 2114 info->symbols = &asym;
c906108c
SS
2115 }
2116 else
2117 info->symbols = NULL;
c5aa993b 2118
40887e1a 2119 if (info->endian == BFD_ENDIAN_BIG)
c906108c
SS
2120 return print_insn_big_arm (memaddr, info);
2121 else
2122 return print_insn_little_arm (memaddr, info);
2123}
2124
66e810cd
RE
2125/* The following define instruction sequences that will cause ARM
2126 cpu's to take an undefined instruction trap. These are used to
2127 signal a breakpoint to GDB.
2128
2129 The newer ARMv4T cpu's are capable of operating in ARM or Thumb
2130 modes. A different instruction is required for each mode. The ARM
2131 cpu's can also be big or little endian. Thus four different
2132 instructions are needed to support all cases.
2133
2134 Note: ARMv4 defines several new instructions that will take the
2135 undefined instruction trap. ARM7TDMI is nominally ARMv4T, but does
2136 not in fact add the new instructions. The new undefined
2137 instructions in ARMv4 are all instructions that had no defined
2138 behaviour in earlier chips. There is no guarantee that they will
2139 raise an exception, but may be treated as NOP's. In practice, it
2140 may only safe to rely on instructions matching:
2141
2142 3 3 2 2 2 2 2 2 2 2 2 2 1 1 1 1 1 1 1 1 1 1
2143 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0 9 8 7 6 5 4 3 2 1 0
2144 C C C C 0 1 1 x x x x x x x x x x x x x x x x x x x x 1 x x x x
2145
2146 Even this may only true if the condition predicate is true. The
2147 following use a condition predicate of ALWAYS so it is always TRUE.
2148
2149 There are other ways of forcing a breakpoint. GNU/Linux, RISC iX,
2150 and NetBSD all use a software interrupt rather than an undefined
2151 instruction to force a trap. This can be handled by by the
2152 abi-specific code during establishment of the gdbarch vector. */
2153
66e810cd 2154#define ARM_LE_BREAKPOINT {0xFE,0xDE,0xFF,0xE7}
66e810cd 2155#define ARM_BE_BREAKPOINT {0xE7,0xFF,0xDE,0xFE}
190dce09
UW
2156#define THUMB_LE_BREAKPOINT {0xbe,0xbe}
2157#define THUMB_BE_BREAKPOINT {0xbe,0xbe}
66e810cd
RE
2158
2159static const char arm_default_arm_le_breakpoint[] = ARM_LE_BREAKPOINT;
2160static const char arm_default_arm_be_breakpoint[] = ARM_BE_BREAKPOINT;
2161static const char arm_default_thumb_le_breakpoint[] = THUMB_LE_BREAKPOINT;
2162static const char arm_default_thumb_be_breakpoint[] = THUMB_BE_BREAKPOINT;
2163
34e8f22d
RE
2164/* Determine the type and size of breakpoint to insert at PCPTR. Uses
2165 the program counter value to determine whether a 16-bit or 32-bit
ed9a39eb
JM
2166 breakpoint should be used. It returns a pointer to a string of
2167 bytes that encode a breakpoint instruction, stores the length of
2168 the string to *lenptr, and adjusts the program counter (if
2169 necessary) to point to the actual memory location where the
c906108c
SS
2170 breakpoint should be inserted. */
2171
ab89facf 2172static const unsigned char *
67d57894 2173arm_breakpoint_from_pc (struct gdbarch *gdbarch, CORE_ADDR *pcptr, int *lenptr)
c906108c 2174{
67d57894 2175 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
66e810cd 2176
4bf7064c 2177 if (arm_pc_is_thumb (*pcptr))
c906108c 2178 {
66e810cd
RE
2179 *pcptr = UNMAKE_THUMB_ADDR (*pcptr);
2180 *lenptr = tdep->thumb_breakpoint_size;
2181 return tdep->thumb_breakpoint;
c906108c
SS
2182 }
2183 else
2184 {
66e810cd
RE
2185 *lenptr = tdep->arm_breakpoint_size;
2186 return tdep->arm_breakpoint;
c906108c
SS
2187 }
2188}
ed9a39eb
JM
2189
2190/* Extract from an array REGBUF containing the (raw) register state a
2191 function return value of type TYPE, and copy that, in virtual
2192 format, into VALBUF. */
2193
34e8f22d 2194static void
5238cf52
MK
2195arm_extract_return_value (struct type *type, struct regcache *regs,
2196 gdb_byte *valbuf)
ed9a39eb 2197{
be8626e0
MD
2198 struct gdbarch *gdbarch = get_regcache_arch (regs);
2199
ed9a39eb 2200 if (TYPE_CODE_FLT == TYPE_CODE (type))
08216dd7 2201 {
be8626e0 2202 switch (gdbarch_tdep (gdbarch)->fp_model)
08216dd7
RE
2203 {
2204 case ARM_FLOAT_FPA:
b508a996
RE
2205 {
2206 /* The value is in register F0 in internal format. We need to
2207 extract the raw value and then convert it to the desired
2208 internal type. */
7a5ea0d4 2209 bfd_byte tmpbuf[FP_REGISTER_SIZE];
b508a996
RE
2210
2211 regcache_cooked_read (regs, ARM_F0_REGNUM, tmpbuf);
2212 convert_from_extended (floatformat_from_type (type), tmpbuf,
be8626e0 2213 valbuf, gdbarch_byte_order (gdbarch));
b508a996 2214 }
08216dd7
RE
2215 break;
2216
fd50bc42 2217 case ARM_FLOAT_SOFT_FPA:
08216dd7 2218 case ARM_FLOAT_SOFT_VFP:
b508a996
RE
2219 regcache_cooked_read (regs, ARM_A1_REGNUM, valbuf);
2220 if (TYPE_LENGTH (type) > 4)
2221 regcache_cooked_read (regs, ARM_A1_REGNUM + 1,
7a5ea0d4 2222 valbuf + INT_REGISTER_SIZE);
08216dd7
RE
2223 break;
2224
2225 default:
2226 internal_error
2227 (__FILE__, __LINE__,
edefbb7c 2228 _("arm_extract_return_value: Floating point model not supported"));
08216dd7
RE
2229 break;
2230 }
2231 }
b508a996
RE
2232 else if (TYPE_CODE (type) == TYPE_CODE_INT
2233 || TYPE_CODE (type) == TYPE_CODE_CHAR
2234 || TYPE_CODE (type) == TYPE_CODE_BOOL
2235 || TYPE_CODE (type) == TYPE_CODE_PTR
2236 || TYPE_CODE (type) == TYPE_CODE_REF
2237 || TYPE_CODE (type) == TYPE_CODE_ENUM)
2238 {
2239 /* If the the type is a plain integer, then the access is
2240 straight-forward. Otherwise we have to play around a bit more. */
2241 int len = TYPE_LENGTH (type);
2242 int regno = ARM_A1_REGNUM;
2243 ULONGEST tmp;
2244
2245 while (len > 0)
2246 {
2247 /* By using store_unsigned_integer we avoid having to do
2248 anything special for small big-endian values. */
2249 regcache_cooked_read_unsigned (regs, regno++, &tmp);
2250 store_unsigned_integer (valbuf,
7a5ea0d4
DJ
2251 (len > INT_REGISTER_SIZE
2252 ? INT_REGISTER_SIZE : len),
b508a996 2253 tmp);
7a5ea0d4
DJ
2254 len -= INT_REGISTER_SIZE;
2255 valbuf += INT_REGISTER_SIZE;
b508a996
RE
2256 }
2257 }
ed9a39eb 2258 else
b508a996
RE
2259 {
2260 /* For a structure or union the behaviour is as if the value had
2261 been stored to word-aligned memory and then loaded into
2262 registers with 32-bit load instruction(s). */
2263 int len = TYPE_LENGTH (type);
2264 int regno = ARM_A1_REGNUM;
7a5ea0d4 2265 bfd_byte tmpbuf[INT_REGISTER_SIZE];
b508a996
RE
2266
2267 while (len > 0)
2268 {
2269 regcache_cooked_read (regs, regno++, tmpbuf);
2270 memcpy (valbuf, tmpbuf,
7a5ea0d4
DJ
2271 len > INT_REGISTER_SIZE ? INT_REGISTER_SIZE : len);
2272 len -= INT_REGISTER_SIZE;
2273 valbuf += INT_REGISTER_SIZE;
b508a996
RE
2274 }
2275 }
34e8f22d
RE
2276}
2277
67255d04
RE
2278
2279/* Will a function return an aggregate type in memory or in a
2280 register? Return 0 if an aggregate type can be returned in a
2281 register, 1 if it must be returned in memory. */
2282
2283static int
2af48f68 2284arm_return_in_memory (struct gdbarch *gdbarch, struct type *type)
67255d04
RE
2285{
2286 int nRc;
52f0bd74 2287 enum type_code code;
67255d04 2288
44e1a9eb
DJ
2289 CHECK_TYPEDEF (type);
2290
67255d04
RE
2291 /* In the ARM ABI, "integer" like aggregate types are returned in
2292 registers. For an aggregate type to be integer like, its size
f0c9063c 2293 must be less than or equal to INT_REGISTER_SIZE and the
b1e29e33
AC
2294 offset of each addressable subfield must be zero. Note that bit
2295 fields are not addressable, and all addressable subfields of
2296 unions always start at offset zero.
67255d04
RE
2297
2298 This function is based on the behaviour of GCC 2.95.1.
2299 See: gcc/arm.c: arm_return_in_memory() for details.
2300
2301 Note: All versions of GCC before GCC 2.95.2 do not set up the
2302 parameters correctly for a function returning the following
2303 structure: struct { float f;}; This should be returned in memory,
2304 not a register. Richard Earnshaw sent me a patch, but I do not
2305 know of any way to detect if a function like the above has been
2306 compiled with the correct calling convention. */
2307
2308 /* All aggregate types that won't fit in a register must be returned
2309 in memory. */
f0c9063c 2310 if (TYPE_LENGTH (type) > INT_REGISTER_SIZE)
67255d04
RE
2311 {
2312 return 1;
2313 }
2314
2af48f68
PB
2315 /* The AAPCS says all aggregates not larger than a word are returned
2316 in a register. */
2317 if (gdbarch_tdep (gdbarch)->arm_abi != ARM_ABI_APCS)
2318 return 0;
2319
67255d04
RE
2320 /* The only aggregate types that can be returned in a register are
2321 structs and unions. Arrays must be returned in memory. */
2322 code = TYPE_CODE (type);
2323 if ((TYPE_CODE_STRUCT != code) && (TYPE_CODE_UNION != code))
2324 {
2325 return 1;
2326 }
2327
2328 /* Assume all other aggregate types can be returned in a register.
2329 Run a check for structures, unions and arrays. */
2330 nRc = 0;
2331
2332 if ((TYPE_CODE_STRUCT == code) || (TYPE_CODE_UNION == code))
2333 {
2334 int i;
2335 /* Need to check if this struct/union is "integer" like. For
2336 this to be true, its size must be less than or equal to
f0c9063c 2337 INT_REGISTER_SIZE and the offset of each addressable
b1e29e33
AC
2338 subfield must be zero. Note that bit fields are not
2339 addressable, and unions always start at offset zero. If any
2340 of the subfields is a floating point type, the struct/union
2341 cannot be an integer type. */
67255d04
RE
2342
2343 /* For each field in the object, check:
2344 1) Is it FP? --> yes, nRc = 1;
2345 2) Is it addressable (bitpos != 0) and
2346 not packed (bitsize == 0)?
2347 --> yes, nRc = 1
2348 */
2349
2350 for (i = 0; i < TYPE_NFIELDS (type); i++)
2351 {
2352 enum type_code field_type_code;
44e1a9eb 2353 field_type_code = TYPE_CODE (check_typedef (TYPE_FIELD_TYPE (type, i)));
67255d04
RE
2354
2355 /* Is it a floating point type field? */
2356 if (field_type_code == TYPE_CODE_FLT)
2357 {
2358 nRc = 1;
2359 break;
2360 }
2361
2362 /* If bitpos != 0, then we have to care about it. */
2363 if (TYPE_FIELD_BITPOS (type, i) != 0)
2364 {
2365 /* Bitfields are not addressable. If the field bitsize is
2366 zero, then the field is not packed. Hence it cannot be
2367 a bitfield or any other packed type. */
2368 if (TYPE_FIELD_BITSIZE (type, i) == 0)
2369 {
2370 nRc = 1;
2371 break;
2372 }
2373 }
2374 }
2375 }
2376
2377 return nRc;
2378}
2379
34e8f22d
RE
2380/* Write into appropriate registers a function return value of type
2381 TYPE, given in virtual format. */
2382
2383static void
b508a996 2384arm_store_return_value (struct type *type, struct regcache *regs,
5238cf52 2385 const gdb_byte *valbuf)
34e8f22d 2386{
be8626e0
MD
2387 struct gdbarch *gdbarch = get_regcache_arch (regs);
2388
34e8f22d
RE
2389 if (TYPE_CODE (type) == TYPE_CODE_FLT)
2390 {
7a5ea0d4 2391 char buf[MAX_REGISTER_SIZE];
34e8f22d 2392
be8626e0 2393 switch (gdbarch_tdep (gdbarch)->fp_model)
08216dd7
RE
2394 {
2395 case ARM_FLOAT_FPA:
2396
be8626e0
MD
2397 convert_to_extended (floatformat_from_type (type), buf, valbuf,
2398 gdbarch_byte_order (gdbarch));
b508a996 2399 regcache_cooked_write (regs, ARM_F0_REGNUM, buf);
08216dd7
RE
2400 break;
2401
fd50bc42 2402 case ARM_FLOAT_SOFT_FPA:
08216dd7 2403 case ARM_FLOAT_SOFT_VFP:
b508a996
RE
2404 regcache_cooked_write (regs, ARM_A1_REGNUM, valbuf);
2405 if (TYPE_LENGTH (type) > 4)
2406 regcache_cooked_write (regs, ARM_A1_REGNUM + 1,
7a5ea0d4 2407 valbuf + INT_REGISTER_SIZE);
08216dd7
RE
2408 break;
2409
2410 default:
2411 internal_error
2412 (__FILE__, __LINE__,
edefbb7c 2413 _("arm_store_return_value: Floating point model not supported"));
08216dd7
RE
2414 break;
2415 }
34e8f22d 2416 }
b508a996
RE
2417 else if (TYPE_CODE (type) == TYPE_CODE_INT
2418 || TYPE_CODE (type) == TYPE_CODE_CHAR
2419 || TYPE_CODE (type) == TYPE_CODE_BOOL
2420 || TYPE_CODE (type) == TYPE_CODE_PTR
2421 || TYPE_CODE (type) == TYPE_CODE_REF
2422 || TYPE_CODE (type) == TYPE_CODE_ENUM)
2423 {
2424 if (TYPE_LENGTH (type) <= 4)
2425 {
2426 /* Values of one word or less are zero/sign-extended and
2427 returned in r0. */
7a5ea0d4 2428 bfd_byte tmpbuf[INT_REGISTER_SIZE];
b508a996
RE
2429 LONGEST val = unpack_long (type, valbuf);
2430
7a5ea0d4 2431 store_signed_integer (tmpbuf, INT_REGISTER_SIZE, val);
b508a996
RE
2432 regcache_cooked_write (regs, ARM_A1_REGNUM, tmpbuf);
2433 }
2434 else
2435 {
2436 /* Integral values greater than one word are stored in consecutive
2437 registers starting with r0. This will always be a multiple of
2438 the regiser size. */
2439 int len = TYPE_LENGTH (type);
2440 int regno = ARM_A1_REGNUM;
2441
2442 while (len > 0)
2443 {
2444 regcache_cooked_write (regs, regno++, valbuf);
7a5ea0d4
DJ
2445 len -= INT_REGISTER_SIZE;
2446 valbuf += INT_REGISTER_SIZE;
b508a996
RE
2447 }
2448 }
2449 }
34e8f22d 2450 else
b508a996
RE
2451 {
2452 /* For a structure or union the behaviour is as if the value had
2453 been stored to word-aligned memory and then loaded into
2454 registers with 32-bit load instruction(s). */
2455 int len = TYPE_LENGTH (type);
2456 int regno = ARM_A1_REGNUM;
7a5ea0d4 2457 bfd_byte tmpbuf[INT_REGISTER_SIZE];
b508a996
RE
2458
2459 while (len > 0)
2460 {
2461 memcpy (tmpbuf, valbuf,
7a5ea0d4 2462 len > INT_REGISTER_SIZE ? INT_REGISTER_SIZE : len);
b508a996 2463 regcache_cooked_write (regs, regno++, tmpbuf);
7a5ea0d4
DJ
2464 len -= INT_REGISTER_SIZE;
2465 valbuf += INT_REGISTER_SIZE;
b508a996
RE
2466 }
2467 }
34e8f22d
RE
2468}
2469
2af48f68
PB
2470
2471/* Handle function return values. */
2472
2473static enum return_value_convention
c055b101
CV
2474arm_return_value (struct gdbarch *gdbarch, struct type *func_type,
2475 struct type *valtype, struct regcache *regcache,
2476 gdb_byte *readbuf, const gdb_byte *writebuf)
2af48f68 2477{
7c00367c
MK
2478 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
2479
2af48f68
PB
2480 if (TYPE_CODE (valtype) == TYPE_CODE_STRUCT
2481 || TYPE_CODE (valtype) == TYPE_CODE_UNION
2482 || TYPE_CODE (valtype) == TYPE_CODE_ARRAY)
2483 {
7c00367c
MK
2484 if (tdep->struct_return == pcc_struct_return
2485 || arm_return_in_memory (gdbarch, valtype))
2af48f68
PB
2486 return RETURN_VALUE_STRUCT_CONVENTION;
2487 }
2488
2489 if (writebuf)
2490 arm_store_return_value (valtype, regcache, writebuf);
2491
2492 if (readbuf)
2493 arm_extract_return_value (valtype, regcache, readbuf);
2494
2495 return RETURN_VALUE_REGISTER_CONVENTION;
2496}
2497
2498
9df628e0 2499static int
60ade65d 2500arm_get_longjmp_target (struct frame_info *frame, CORE_ADDR *pc)
9df628e0
RE
2501{
2502 CORE_ADDR jb_addr;
7a5ea0d4 2503 char buf[INT_REGISTER_SIZE];
60ade65d 2504 struct gdbarch_tdep *tdep = gdbarch_tdep (get_frame_arch (frame));
9df628e0 2505
60ade65d 2506 jb_addr = get_frame_register_unsigned (frame, ARM_A1_REGNUM);
9df628e0
RE
2507
2508 if (target_read_memory (jb_addr + tdep->jb_pc * tdep->jb_elt_size, buf,
7a5ea0d4 2509 INT_REGISTER_SIZE))
9df628e0
RE
2510 return 0;
2511
7a5ea0d4 2512 *pc = extract_unsigned_integer (buf, INT_REGISTER_SIZE);
9df628e0
RE
2513 return 1;
2514}
2515
faa95490
DJ
2516/* Recognize GCC and GNU ld's trampolines. If we are in a trampoline,
2517 return the target PC. Otherwise return 0. */
c906108c
SS
2518
2519CORE_ADDR
52f729a7 2520arm_skip_stub (struct frame_info *frame, CORE_ADDR pc)
c906108c 2521{
c5aa993b 2522 char *name;
faa95490 2523 int namelen;
c906108c
SS
2524 CORE_ADDR start_addr;
2525
2526 /* Find the starting address and name of the function containing the PC. */
2527 if (find_pc_partial_function (pc, &name, &start_addr, NULL) == 0)
2528 return 0;
2529
faa95490
DJ
2530 /* If PC is in a Thumb call or return stub, return the address of the
2531 target PC, which is in a register. The thunk functions are called
2532 _call_via_xx, where x is the register name. The possible names
2533 are r0-r9, sl, fp, ip, sp, and lr. */
c906108c
SS
2534 if (strncmp (name, "_call_via_", 10) == 0)
2535 {
ed9a39eb
JM
2536 /* Use the name suffix to determine which register contains the
2537 target PC. */
c5aa993b
JM
2538 static char *table[15] =
2539 {"r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
2540 "r8", "r9", "sl", "fp", "ip", "sp", "lr"
2541 };
c906108c 2542 int regno;
faa95490 2543 int offset = strlen (name) - 2;
c906108c
SS
2544
2545 for (regno = 0; regno <= 14; regno++)
faa95490 2546 if (strcmp (&name[offset], table[regno]) == 0)
52f729a7 2547 return get_frame_register_unsigned (frame, regno);
c906108c 2548 }
ed9a39eb 2549
faa95490
DJ
2550 /* GNU ld generates __foo_from_arm or __foo_from_thumb for
2551 non-interworking calls to foo. We could decode the stubs
2552 to find the target but it's easier to use the symbol table. */
2553 namelen = strlen (name);
2554 if (name[0] == '_' && name[1] == '_'
2555 && ((namelen > 2 + strlen ("_from_thumb")
2556 && strncmp (name + namelen - strlen ("_from_thumb"), "_from_thumb",
2557 strlen ("_from_thumb")) == 0)
2558 || (namelen > 2 + strlen ("_from_arm")
2559 && strncmp (name + namelen - strlen ("_from_arm"), "_from_arm",
2560 strlen ("_from_arm")) == 0)))
2561 {
2562 char *target_name;
2563 int target_len = namelen - 2;
2564 struct minimal_symbol *minsym;
2565 struct objfile *objfile;
2566 struct obj_section *sec;
2567
2568 if (name[namelen - 1] == 'b')
2569 target_len -= strlen ("_from_thumb");
2570 else
2571 target_len -= strlen ("_from_arm");
2572
2573 target_name = alloca (target_len + 1);
2574 memcpy (target_name, name + 2, target_len);
2575 target_name[target_len] = '\0';
2576
2577 sec = find_pc_section (pc);
2578 objfile = (sec == NULL) ? NULL : sec->objfile;
2579 minsym = lookup_minimal_symbol (target_name, NULL, objfile);
2580 if (minsym != NULL)
2581 return SYMBOL_VALUE_ADDRESS (minsym);
2582 else
2583 return 0;
2584 }
2585
c5aa993b 2586 return 0; /* not a stub */
c906108c
SS
2587}
2588
afd7eef0
RE
2589static void
2590set_arm_command (char *args, int from_tty)
2591{
edefbb7c
AC
2592 printf_unfiltered (_("\
2593\"set arm\" must be followed by an apporpriate subcommand.\n"));
afd7eef0
RE
2594 help_list (setarmcmdlist, "set arm ", all_commands, gdb_stdout);
2595}
2596
2597static void
2598show_arm_command (char *args, int from_tty)
2599{
26304000 2600 cmd_show_list (showarmcmdlist, from_tty, "");
afd7eef0
RE
2601}
2602
28e97307
DJ
2603static void
2604arm_update_current_architecture (void)
fd50bc42 2605{
28e97307 2606 struct gdbarch_info info;
fd50bc42 2607
28e97307
DJ
2608 /* If the current architecture is not ARM, we have nothing to do. */
2609 if (gdbarch_bfd_arch_info (current_gdbarch)->arch != bfd_arch_arm)
2610 return;
fd50bc42 2611
28e97307
DJ
2612 /* Update the architecture. */
2613 gdbarch_info_init (&info);
fd50bc42 2614
28e97307
DJ
2615 if (!gdbarch_update_p (info))
2616 internal_error (__FILE__, __LINE__, "could not update architecture");
fd50bc42
RE
2617}
2618
2619static void
2620set_fp_model_sfunc (char *args, int from_tty,
2621 struct cmd_list_element *c)
2622{
2623 enum arm_float_model fp_model;
2624
2625 for (fp_model = ARM_FLOAT_AUTO; fp_model != ARM_FLOAT_LAST; fp_model++)
2626 if (strcmp (current_fp_model, fp_model_strings[fp_model]) == 0)
2627 {
2628 arm_fp_model = fp_model;
2629 break;
2630 }
2631
2632 if (fp_model == ARM_FLOAT_LAST)
edefbb7c 2633 internal_error (__FILE__, __LINE__, _("Invalid fp model accepted: %s."),
fd50bc42
RE
2634 current_fp_model);
2635
28e97307 2636 arm_update_current_architecture ();
fd50bc42
RE
2637}
2638
2639static void
08546159
AC
2640show_fp_model (struct ui_file *file, int from_tty,
2641 struct cmd_list_element *c, const char *value)
fd50bc42
RE
2642{
2643 struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
2644
28e97307 2645 if (arm_fp_model == ARM_FLOAT_AUTO
fd50bc42 2646 && gdbarch_bfd_arch_info (current_gdbarch)->arch == bfd_arch_arm)
28e97307
DJ
2647 fprintf_filtered (file, _("\
2648The current ARM floating point model is \"auto\" (currently \"%s\").\n"),
2649 fp_model_strings[tdep->fp_model]);
2650 else
2651 fprintf_filtered (file, _("\
2652The current ARM floating point model is \"%s\".\n"),
2653 fp_model_strings[arm_fp_model]);
2654}
2655
2656static void
2657arm_set_abi (char *args, int from_tty,
2658 struct cmd_list_element *c)
2659{
2660 enum arm_abi_kind arm_abi;
2661
2662 for (arm_abi = ARM_ABI_AUTO; arm_abi != ARM_ABI_LAST; arm_abi++)
2663 if (strcmp (arm_abi_string, arm_abi_strings[arm_abi]) == 0)
2664 {
2665 arm_abi_global = arm_abi;
2666 break;
2667 }
2668
2669 if (arm_abi == ARM_ABI_LAST)
2670 internal_error (__FILE__, __LINE__, _("Invalid ABI accepted: %s."),
2671 arm_abi_string);
2672
2673 arm_update_current_architecture ();
2674}
2675
2676static void
2677arm_show_abi (struct ui_file *file, int from_tty,
2678 struct cmd_list_element *c, const char *value)
2679{
2680 struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
2681
2682 if (arm_abi_global == ARM_ABI_AUTO
2683 && gdbarch_bfd_arch_info (current_gdbarch)->arch == bfd_arch_arm)
2684 fprintf_filtered (file, _("\
2685The current ARM ABI is \"auto\" (currently \"%s\").\n"),
2686 arm_abi_strings[tdep->arm_abi]);
2687 else
2688 fprintf_filtered (file, _("The current ARM ABI is \"%s\".\n"),
2689 arm_abi_string);
fd50bc42
RE
2690}
2691
0428b8f5
DJ
2692static void
2693arm_show_fallback_mode (struct ui_file *file, int from_tty,
2694 struct cmd_list_element *c, const char *value)
2695{
2696 struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
2697
2698 fprintf_filtered (file, _("\
2699The current execution mode assumed (when symbols are unavailable) is \"%s\".\n"),
2700 arm_fallback_mode_string);
2701}
2702
2703static void
2704arm_show_force_mode (struct ui_file *file, int from_tty,
2705 struct cmd_list_element *c, const char *value)
2706{
2707 struct gdbarch_tdep *tdep = gdbarch_tdep (current_gdbarch);
2708
2709 fprintf_filtered (file, _("\
2710The current execution mode assumed (even when symbols are available) is \"%s\".\n"),
2711 arm_force_mode_string);
2712}
2713
afd7eef0
RE
2714/* If the user changes the register disassembly style used for info
2715 register and other commands, we have to also switch the style used
2716 in opcodes for disassembly output. This function is run in the "set
2717 arm disassembly" command, and does that. */
bc90b915
FN
2718
2719static void
afd7eef0 2720set_disassembly_style_sfunc (char *args, int from_tty,
bc90b915
FN
2721 struct cmd_list_element *c)
2722{
afd7eef0 2723 set_disassembly_style ();
bc90b915
FN
2724}
2725\f
966fbf70 2726/* Return the ARM register name corresponding to register I. */
a208b0cb 2727static const char *
d93859e2 2728arm_register_name (struct gdbarch *gdbarch, int i)
966fbf70 2729{
ff6f572f
DJ
2730 if (i >= ARRAY_SIZE (arm_register_names))
2731 /* These registers are only supported on targets which supply
2732 an XML description. */
2733 return "";
2734
966fbf70
RE
2735 return arm_register_names[i];
2736}
2737
bc90b915 2738static void
afd7eef0 2739set_disassembly_style (void)
bc90b915 2740{
123dc839 2741 int current;
bc90b915 2742
123dc839
DJ
2743 /* Find the style that the user wants. */
2744 for (current = 0; current < num_disassembly_options; current++)
2745 if (disassembly_style == valid_disassembly_styles[current])
2746 break;
2747 gdb_assert (current < num_disassembly_options);
bc90b915 2748
94c30b78 2749 /* Synchronize the disassembler. */
bc90b915
FN
2750 set_arm_regname_option (current);
2751}
2752
082fc60d
RE
2753/* Test whether the coff symbol specific value corresponds to a Thumb
2754 function. */
2755
2756static int
2757coff_sym_is_thumb (int val)
2758{
2759 return (val == C_THUMBEXT ||
2760 val == C_THUMBSTAT ||
2761 val == C_THUMBEXTFUNC ||
2762 val == C_THUMBSTATFUNC ||
2763 val == C_THUMBLABEL);
2764}
2765
2766/* arm_coff_make_msymbol_special()
2767 arm_elf_make_msymbol_special()
2768
2769 These functions test whether the COFF or ELF symbol corresponds to
2770 an address in thumb code, and set a "special" bit in a minimal
2771 symbol to indicate that it does. */
2772
34e8f22d 2773static void
082fc60d
RE
2774arm_elf_make_msymbol_special(asymbol *sym, struct minimal_symbol *msym)
2775{
2776 /* Thumb symbols are of type STT_LOPROC, (synonymous with
2777 STT_ARM_TFUNC). */
2778 if (ELF_ST_TYPE (((elf_symbol_type *)sym)->internal_elf_sym.st_info)
2779 == STT_LOPROC)
2780 MSYMBOL_SET_SPECIAL (msym);
2781}
2782
34e8f22d 2783static void
082fc60d
RE
2784arm_coff_make_msymbol_special(int val, struct minimal_symbol *msym)
2785{
2786 if (coff_sym_is_thumb (val))
2787 MSYMBOL_SET_SPECIAL (msym);
2788}
2789
756fe439 2790static void
61a1198a 2791arm_write_pc (struct regcache *regcache, CORE_ADDR pc)
756fe439 2792{
61a1198a 2793 regcache_cooked_write_unsigned (regcache, ARM_PC_REGNUM, pc);
756fe439
DJ
2794
2795 /* If necessary, set the T bit. */
2796 if (arm_apcs_32)
2797 {
61a1198a
UW
2798 ULONGEST val;
2799 regcache_cooked_read_unsigned (regcache, ARM_PS_REGNUM, &val);
756fe439 2800 if (arm_pc_is_thumb (pc))
b39cc962 2801 regcache_cooked_write_unsigned (regcache, ARM_PS_REGNUM, val | CPSR_T);
756fe439 2802 else
61a1198a 2803 regcache_cooked_write_unsigned (regcache, ARM_PS_REGNUM,
b39cc962 2804 val & ~(ULONGEST) CPSR_T);
756fe439
DJ
2805 }
2806}
123dc839
DJ
2807
2808static struct value *
2809value_of_arm_user_reg (struct frame_info *frame, const void *baton)
2810{
2811 const int *reg_p = baton;
2812 return value_of_register (*reg_p, frame);
2813}
97e03143 2814\f
70f80edf
JT
2815static enum gdb_osabi
2816arm_elf_osabi_sniffer (bfd *abfd)
97e03143 2817{
2af48f68 2818 unsigned int elfosabi;
70f80edf 2819 enum gdb_osabi osabi = GDB_OSABI_UNKNOWN;
97e03143 2820
70f80edf 2821 elfosabi = elf_elfheader (abfd)->e_ident[EI_OSABI];
97e03143 2822
28e97307
DJ
2823 if (elfosabi == ELFOSABI_ARM)
2824 /* GNU tools use this value. Check note sections in this case,
2825 as well. */
2826 bfd_map_over_sections (abfd,
2827 generic_elf_osabi_sniff_abi_tag_sections,
2828 &osabi);
97e03143 2829
28e97307 2830 /* Anything else will be handled by the generic ELF sniffer. */
70f80edf 2831 return osabi;
97e03143
RE
2832}
2833
70f80edf 2834\f
da3c6d4a
MS
2835/* Initialize the current architecture based on INFO. If possible,
2836 re-use an architecture from ARCHES, which is a list of
2837 architectures already created during this debugging session.
97e03143 2838
da3c6d4a
MS
2839 Called e.g. at program startup, when reading a core file, and when
2840 reading a binary file. */
97e03143 2841
39bbf761
RE
2842static struct gdbarch *
2843arm_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches)
2844{
97e03143 2845 struct gdbarch_tdep *tdep;
39bbf761 2846 struct gdbarch *gdbarch;
28e97307
DJ
2847 struct gdbarch_list *best_arch;
2848 enum arm_abi_kind arm_abi = arm_abi_global;
2849 enum arm_float_model fp_model = arm_fp_model;
123dc839
DJ
2850 struct tdesc_arch_data *tdesc_data = NULL;
2851 int i;
ff6f572f 2852 int have_fpa_registers = 1;
123dc839
DJ
2853
2854 /* Check any target description for validity. */
2855 if (tdesc_has_registers (info.target_desc))
2856 {
2857 /* For most registers we require GDB's default names; but also allow
2858 the numeric names for sp / lr / pc, as a convenience. */
2859 static const char *const arm_sp_names[] = { "r13", "sp", NULL };
2860 static const char *const arm_lr_names[] = { "r14", "lr", NULL };
2861 static const char *const arm_pc_names[] = { "r15", "pc", NULL };
2862
2863 const struct tdesc_feature *feature;
2864 int i, valid_p;
2865
2866 feature = tdesc_find_feature (info.target_desc,
2867 "org.gnu.gdb.arm.core");
2868 if (feature == NULL)
2869 return NULL;
2870
2871 tdesc_data = tdesc_data_alloc ();
2872
2873 valid_p = 1;
2874 for (i = 0; i < ARM_SP_REGNUM; i++)
2875 valid_p &= tdesc_numbered_register (feature, tdesc_data, i,
2876 arm_register_names[i]);
2877 valid_p &= tdesc_numbered_register_choices (feature, tdesc_data,
2878 ARM_SP_REGNUM,
2879 arm_sp_names);
2880 valid_p &= tdesc_numbered_register_choices (feature, tdesc_data,
2881 ARM_LR_REGNUM,
2882 arm_lr_names);
2883 valid_p &= tdesc_numbered_register_choices (feature, tdesc_data,
2884 ARM_PC_REGNUM,
2885 arm_pc_names);
2886 valid_p &= tdesc_numbered_register (feature, tdesc_data,
2887 ARM_PS_REGNUM, "cpsr");
2888
2889 if (!valid_p)
2890 {
2891 tdesc_data_cleanup (tdesc_data);
2892 return NULL;
2893 }
2894
2895 feature = tdesc_find_feature (info.target_desc,
2896 "org.gnu.gdb.arm.fpa");
2897 if (feature != NULL)
2898 {
2899 valid_p = 1;
2900 for (i = ARM_F0_REGNUM; i <= ARM_FPS_REGNUM; i++)
2901 valid_p &= tdesc_numbered_register (feature, tdesc_data, i,
2902 arm_register_names[i]);
2903 if (!valid_p)
2904 {
2905 tdesc_data_cleanup (tdesc_data);
2906 return NULL;
2907 }
2908 }
ff6f572f
DJ
2909 else
2910 have_fpa_registers = 0;
2911
2912 feature = tdesc_find_feature (info.target_desc,
2913 "org.gnu.gdb.xscale.iwmmxt");
2914 if (feature != NULL)
2915 {
2916 static const char *const iwmmxt_names[] = {
2917 "wR0", "wR1", "wR2", "wR3", "wR4", "wR5", "wR6", "wR7",
2918 "wR8", "wR9", "wR10", "wR11", "wR12", "wR13", "wR14", "wR15",
2919 "wCID", "wCon", "wCSSF", "wCASF", "", "", "", "",
2920 "wCGR0", "wCGR1", "wCGR2", "wCGR3", "", "", "", "",
2921 };
2922
2923 valid_p = 1;
2924 for (i = ARM_WR0_REGNUM; i <= ARM_WR15_REGNUM; i++)
2925 valid_p
2926 &= tdesc_numbered_register (feature, tdesc_data, i,
2927 iwmmxt_names[i - ARM_WR0_REGNUM]);
2928
2929 /* Check for the control registers, but do not fail if they
2930 are missing. */
2931 for (i = ARM_WC0_REGNUM; i <= ARM_WCASF_REGNUM; i++)
2932 tdesc_numbered_register (feature, tdesc_data, i,
2933 iwmmxt_names[i - ARM_WR0_REGNUM]);
2934
2935 for (i = ARM_WCGR0_REGNUM; i <= ARM_WCGR3_REGNUM; i++)
2936 valid_p
2937 &= tdesc_numbered_register (feature, tdesc_data, i,
2938 iwmmxt_names[i - ARM_WR0_REGNUM]);
2939
2940 if (!valid_p)
2941 {
2942 tdesc_data_cleanup (tdesc_data);
2943 return NULL;
2944 }
2945 }
123dc839 2946 }
39bbf761 2947
28e97307
DJ
2948 /* If we have an object to base this architecture on, try to determine
2949 its ABI. */
39bbf761 2950
28e97307 2951 if (arm_abi == ARM_ABI_AUTO && info.abfd != NULL)
97e03143 2952 {
6b26d61a 2953 int ei_osabi, e_flags;
28e97307 2954
4be87837 2955 switch (bfd_get_flavour (info.abfd))
97e03143 2956 {
4be87837
DJ
2957 case bfd_target_aout_flavour:
2958 /* Assume it's an old APCS-style ABI. */
28e97307 2959 arm_abi = ARM_ABI_APCS;
4be87837 2960 break;
97e03143 2961
4be87837
DJ
2962 case bfd_target_coff_flavour:
2963 /* Assume it's an old APCS-style ABI. */
2964 /* XXX WinCE? */
28e97307
DJ
2965 arm_abi = ARM_ABI_APCS;
2966 break;
2967
2968 case bfd_target_elf_flavour:
2969 ei_osabi = elf_elfheader (info.abfd)->e_ident[EI_OSABI];
6b26d61a
MK
2970 e_flags = elf_elfheader (info.abfd)->e_flags;
2971
28e97307
DJ
2972 if (ei_osabi == ELFOSABI_ARM)
2973 {
2974 /* GNU tools used to use this value, but do not for EABI
6b26d61a
MK
2975 objects. There's nowhere to tag an EABI version
2976 anyway, so assume APCS. */
28e97307
DJ
2977 arm_abi = ARM_ABI_APCS;
2978 }
2979 else if (ei_osabi == ELFOSABI_NONE)
2980 {
6b26d61a 2981 int eabi_ver = EF_ARM_EABI_VERSION (e_flags);
28e97307
DJ
2982
2983 switch (eabi_ver)
2984 {
2985 case EF_ARM_EABI_UNKNOWN:
2986 /* Assume GNU tools. */
2987 arm_abi = ARM_ABI_APCS;
2988 break;
2989
2990 case EF_ARM_EABI_VER4:
625b5003 2991 case EF_ARM_EABI_VER5:
28e97307 2992 arm_abi = ARM_ABI_AAPCS;
2af48f68
PB
2993 /* EABI binaries default to VFP float ordering. */
2994 if (fp_model == ARM_FLOAT_AUTO)
2995 fp_model = ARM_FLOAT_SOFT_VFP;
28e97307
DJ
2996 break;
2997
2998 default:
6b26d61a 2999 /* Leave it as "auto". */
28e97307 3000 warning (_("unknown ARM EABI version 0x%x"), eabi_ver);
6b26d61a
MK
3001 break;
3002 }
3003 }
3004
3005 if (fp_model == ARM_FLOAT_AUTO)
3006 {
3007 int e_flags = elf_elfheader (info.abfd)->e_flags;
3008
3009 switch (e_flags & (EF_ARM_SOFT_FLOAT | EF_ARM_VFP_FLOAT))
3010 {
3011 case 0:
3012 /* Leave it as "auto". Strictly speaking this case
3013 means FPA, but almost nobody uses that now, and
3014 many toolchains fail to set the appropriate bits
3015 for the floating-point model they use. */
3016 break;
3017 case EF_ARM_SOFT_FLOAT:
3018 fp_model = ARM_FLOAT_SOFT_FPA;
3019 break;
3020 case EF_ARM_VFP_FLOAT:
3021 fp_model = ARM_FLOAT_VFP;
3022 break;
3023 case EF_ARM_SOFT_FLOAT | EF_ARM_VFP_FLOAT:
3024 fp_model = ARM_FLOAT_SOFT_VFP;
28e97307
DJ
3025 break;
3026 }
3027 }
4be87837 3028 break;
97e03143 3029
4be87837 3030 default:
28e97307 3031 /* Leave it as "auto". */
50ceaba5 3032 break;
97e03143
RE
3033 }
3034 }
3035
28e97307
DJ
3036 /* If there is already a candidate, use it. */
3037 for (best_arch = gdbarch_list_lookup_by_info (arches, &info);
3038 best_arch != NULL;
3039 best_arch = gdbarch_list_lookup_by_info (best_arch->next, &info))
3040 {
b8926edc
DJ
3041 if (arm_abi != ARM_ABI_AUTO
3042 && arm_abi != gdbarch_tdep (best_arch->gdbarch)->arm_abi)
28e97307
DJ
3043 continue;
3044
b8926edc
DJ
3045 if (fp_model != ARM_FLOAT_AUTO
3046 && fp_model != gdbarch_tdep (best_arch->gdbarch)->fp_model)
28e97307
DJ
3047 continue;
3048
3049 /* Found a match. */
3050 break;
3051 }
97e03143 3052
28e97307 3053 if (best_arch != NULL)
123dc839
DJ
3054 {
3055 if (tdesc_data != NULL)
3056 tdesc_data_cleanup (tdesc_data);
3057 return best_arch->gdbarch;
3058 }
28e97307
DJ
3059
3060 tdep = xcalloc (1, sizeof (struct gdbarch_tdep));
97e03143
RE
3061 gdbarch = gdbarch_alloc (&info, tdep);
3062
28e97307
DJ
3063 /* Record additional information about the architecture we are defining.
3064 These are gdbarch discriminators, like the OSABI. */
3065 tdep->arm_abi = arm_abi;
3066 tdep->fp_model = fp_model;
ff6f572f 3067 tdep->have_fpa_registers = have_fpa_registers;
08216dd7
RE
3068
3069 /* Breakpoints. */
67255d04
RE
3070 switch (info.byte_order)
3071 {
3072 case BFD_ENDIAN_BIG:
66e810cd
RE
3073 tdep->arm_breakpoint = arm_default_arm_be_breakpoint;
3074 tdep->arm_breakpoint_size = sizeof (arm_default_arm_be_breakpoint);
3075 tdep->thumb_breakpoint = arm_default_thumb_be_breakpoint;
3076 tdep->thumb_breakpoint_size = sizeof (arm_default_thumb_be_breakpoint);
3077
67255d04
RE
3078 break;
3079
3080 case BFD_ENDIAN_LITTLE:
66e810cd
RE
3081 tdep->arm_breakpoint = arm_default_arm_le_breakpoint;
3082 tdep->arm_breakpoint_size = sizeof (arm_default_arm_le_breakpoint);
3083 tdep->thumb_breakpoint = arm_default_thumb_le_breakpoint;
3084 tdep->thumb_breakpoint_size = sizeof (arm_default_thumb_le_breakpoint);
3085
67255d04
RE
3086 break;
3087
3088 default:
3089 internal_error (__FILE__, __LINE__,
edefbb7c 3090 _("arm_gdbarch_init: bad byte order for float format"));
67255d04
RE
3091 }
3092
d7b486e7
RE
3093 /* On ARM targets char defaults to unsigned. */
3094 set_gdbarch_char_signed (gdbarch, 0);
3095
9df628e0 3096 /* This should be low enough for everything. */
97e03143 3097 tdep->lowest_pc = 0x20;
94c30b78 3098 tdep->jb_pc = -1; /* Longjump support not enabled by default. */
97e03143 3099
7c00367c
MK
3100 /* The default, for both APCS and AAPCS, is to return small
3101 structures in registers. */
3102 tdep->struct_return = reg_struct_return;
3103
2dd604e7 3104 set_gdbarch_push_dummy_call (gdbarch, arm_push_dummy_call);
f53f0d0b 3105 set_gdbarch_frame_align (gdbarch, arm_frame_align);
39bbf761 3106
756fe439
DJ
3107 set_gdbarch_write_pc (gdbarch, arm_write_pc);
3108
148754e5 3109 /* Frame handling. */
a262aec2 3110 set_gdbarch_dummy_id (gdbarch, arm_dummy_id);
eb5492fa
DJ
3111 set_gdbarch_unwind_pc (gdbarch, arm_unwind_pc);
3112 set_gdbarch_unwind_sp (gdbarch, arm_unwind_sp);
3113
eb5492fa 3114 frame_base_set_default (gdbarch, &arm_normal_base);
148754e5 3115
34e8f22d
RE
3116 /* Address manipulation. */
3117 set_gdbarch_smash_text_address (gdbarch, arm_smash_text_address);
3118 set_gdbarch_addr_bits_remove (gdbarch, arm_addr_bits_remove);
3119
34e8f22d
RE
3120 /* Advance PC across function entry code. */
3121 set_gdbarch_skip_prologue (gdbarch, arm_skip_prologue);
3122
190dce09
UW
3123 /* Skip trampolines. */
3124 set_gdbarch_skip_trampoline_code (gdbarch, arm_skip_stub);
3125
34e8f22d
RE
3126 /* The stack grows downward. */
3127 set_gdbarch_inner_than (gdbarch, core_addr_lessthan);
3128
3129 /* Breakpoint manipulation. */
3130 set_gdbarch_breakpoint_from_pc (gdbarch, arm_breakpoint_from_pc);
34e8f22d
RE
3131
3132 /* Information about registers, etc. */
0ba6dca9 3133 set_gdbarch_deprecated_fp_regnum (gdbarch, ARM_FP_REGNUM); /* ??? */
34e8f22d
RE
3134 set_gdbarch_sp_regnum (gdbarch, ARM_SP_REGNUM);
3135 set_gdbarch_pc_regnum (gdbarch, ARM_PC_REGNUM);
ff6f572f 3136 set_gdbarch_num_regs (gdbarch, ARM_NUM_REGS);
7a5ea0d4 3137 set_gdbarch_register_type (gdbarch, arm_register_type);
34e8f22d 3138
ff6f572f
DJ
3139 /* This "info float" is FPA-specific. Use the generic version if we
3140 do not have FPA. */
3141 if (gdbarch_tdep (gdbarch)->have_fpa_registers)
3142 set_gdbarch_print_float_info (gdbarch, arm_print_float_info);
3143
26216b98 3144 /* Internal <-> external register number maps. */
ff6f572f
DJ
3145 set_gdbarch_dwarf_reg_to_regnum (gdbarch, arm_dwarf_reg_to_regnum);
3146 set_gdbarch_dwarf2_reg_to_regnum (gdbarch, arm_dwarf_reg_to_regnum);
26216b98
AC
3147 set_gdbarch_register_sim_regno (gdbarch, arm_register_sim_regno);
3148
34e8f22d
RE
3149 set_gdbarch_register_name (gdbarch, arm_register_name);
3150
3151 /* Returning results. */
2af48f68 3152 set_gdbarch_return_value (gdbarch, arm_return_value);
34e8f22d 3153
03d48a7d
RE
3154 /* Disassembly. */
3155 set_gdbarch_print_insn (gdbarch, gdb_print_insn_arm);
3156
34e8f22d
RE
3157 /* Minsymbol frobbing. */
3158 set_gdbarch_elf_make_msymbol_special (gdbarch, arm_elf_make_msymbol_special);
3159 set_gdbarch_coff_make_msymbol_special (gdbarch,
3160 arm_coff_make_msymbol_special);
3161
0d5de010
DJ
3162 /* Virtual tables. */
3163 set_gdbarch_vbit_in_delta (gdbarch, 1);
3164
97e03143 3165 /* Hook in the ABI-specific overrides, if they have been registered. */
4be87837 3166 gdbarch_init_osabi (info, gdbarch);
97e03143 3167
b39cc962
DJ
3168 dwarf2_frame_set_init_reg (gdbarch, arm_dwarf2_frame_init_reg);
3169
eb5492fa 3170 /* Add some default predicates. */
a262aec2
DJ
3171 frame_unwind_append_unwinder (gdbarch, &arm_stub_unwind);
3172 dwarf2_append_unwinders (gdbarch);
3173 frame_unwind_append_unwinder (gdbarch, &arm_prologue_unwind);
eb5492fa 3174
97e03143
RE
3175 /* Now we have tuned the configuration, set a few final things,
3176 based on what the OS ABI has told us. */
3177
b8926edc
DJ
3178 /* If the ABI is not otherwise marked, assume the old GNU APCS. EABI
3179 binaries are always marked. */
3180 if (tdep->arm_abi == ARM_ABI_AUTO)
3181 tdep->arm_abi = ARM_ABI_APCS;
3182
3183 /* We used to default to FPA for generic ARM, but almost nobody
3184 uses that now, and we now provide a way for the user to force
3185 the model. So default to the most useful variant. */
3186 if (tdep->fp_model == ARM_FLOAT_AUTO)
3187 tdep->fp_model = ARM_FLOAT_SOFT_FPA;
3188
9df628e0
RE
3189 if (tdep->jb_pc >= 0)
3190 set_gdbarch_get_longjmp_target (gdbarch, arm_get_longjmp_target);
3191
08216dd7 3192 /* Floating point sizes and format. */
8da61cc4 3193 set_gdbarch_float_format (gdbarch, floatformats_ieee_single);
b8926edc 3194 if (tdep->fp_model == ARM_FLOAT_SOFT_FPA || tdep->fp_model == ARM_FLOAT_FPA)
08216dd7 3195 {
8da61cc4
DJ
3196 set_gdbarch_double_format
3197 (gdbarch, floatformats_ieee_double_littlebyte_bigword);
3198 set_gdbarch_long_double_format
3199 (gdbarch, floatformats_ieee_double_littlebyte_bigword);
3200 }
3201 else
3202 {
3203 set_gdbarch_double_format (gdbarch, floatformats_ieee_double);
3204 set_gdbarch_long_double_format (gdbarch, floatformats_ieee_double);
08216dd7
RE
3205 }
3206
123dc839 3207 if (tdesc_data)
7cc46491 3208 tdesc_use_registers (gdbarch, info.target_desc, tdesc_data);
123dc839
DJ
3209
3210 /* Add standard register aliases. We add aliases even for those
3211 nanes which are used by the current architecture - it's simpler,
3212 and does no harm, since nothing ever lists user registers. */
3213 for (i = 0; i < ARRAY_SIZE (arm_register_aliases); i++)
3214 user_reg_add (gdbarch, arm_register_aliases[i].name,
3215 value_of_arm_user_reg, &arm_register_aliases[i].regnum);
3216
39bbf761
RE
3217 return gdbarch;
3218}
3219
97e03143 3220static void
2af46ca0 3221arm_dump_tdep (struct gdbarch *gdbarch, struct ui_file *file)
97e03143 3222{
2af46ca0 3223 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
97e03143
RE
3224
3225 if (tdep == NULL)
3226 return;
3227
edefbb7c 3228 fprintf_unfiltered (file, _("arm_dump_tdep: Lowest pc = 0x%lx"),
97e03143
RE
3229 (unsigned long) tdep->lowest_pc);
3230}
3231
a78f21af
AC
3232extern initialize_file_ftype _initialize_arm_tdep; /* -Wmissing-prototypes */
3233
c906108c 3234void
ed9a39eb 3235_initialize_arm_tdep (void)
c906108c 3236{
bc90b915
FN
3237 struct ui_file *stb;
3238 long length;
26304000 3239 struct cmd_list_element *new_set, *new_show;
53904c9e
AC
3240 const char *setname;
3241 const char *setdesc;
4bd7b427 3242 const char *const *regnames;
bc90b915
FN
3243 int numregs, i, j;
3244 static char *helptext;
edefbb7c
AC
3245 char regdesc[1024], *rdptr = regdesc;
3246 size_t rest = sizeof (regdesc);
085dd6e6 3247
42cf1509 3248 gdbarch_register (bfd_arch_arm, arm_gdbarch_init, arm_dump_tdep);
97e03143 3249
70f80edf
JT
3250 /* Register an ELF OS ABI sniffer for ARM binaries. */
3251 gdbarch_register_osabi_sniffer (bfd_arch_arm,
3252 bfd_target_elf_flavour,
3253 arm_elf_osabi_sniffer);
3254
94c30b78 3255 /* Get the number of possible sets of register names defined in opcodes. */
afd7eef0
RE
3256 num_disassembly_options = get_arm_regname_num_options ();
3257
3258 /* Add root prefix command for all "set arm"/"show arm" commands. */
3259 add_prefix_cmd ("arm", no_class, set_arm_command,
edefbb7c 3260 _("Various ARM-specific commands."),
afd7eef0
RE
3261 &setarmcmdlist, "set arm ", 0, &setlist);
3262
3263 add_prefix_cmd ("arm", no_class, show_arm_command,
edefbb7c 3264 _("Various ARM-specific commands."),
afd7eef0 3265 &showarmcmdlist, "show arm ", 0, &showlist);
bc90b915 3266
94c30b78 3267 /* Sync the opcode insn printer with our register viewer. */
bc90b915 3268 parse_arm_disassembler_option ("reg-names-std");
c5aa993b 3269
eefe576e
AC
3270 /* Initialize the array that will be passed to
3271 add_setshow_enum_cmd(). */
afd7eef0
RE
3272 valid_disassembly_styles
3273 = xmalloc ((num_disassembly_options + 1) * sizeof (char *));
3274 for (i = 0; i < num_disassembly_options; i++)
bc90b915
FN
3275 {
3276 numregs = get_arm_regnames (i, &setname, &setdesc, &regnames);
afd7eef0 3277 valid_disassembly_styles[i] = setname;
edefbb7c
AC
3278 length = snprintf (rdptr, rest, "%s - %s\n", setname, setdesc);
3279 rdptr += length;
3280 rest -= length;
123dc839
DJ
3281 /* When we find the default names, tell the disassembler to use
3282 them. */
bc90b915
FN
3283 if (!strcmp (setname, "std"))
3284 {
afd7eef0 3285 disassembly_style = setname;
bc90b915
FN
3286 set_arm_regname_option (i);
3287 }
3288 }
94c30b78 3289 /* Mark the end of valid options. */
afd7eef0 3290 valid_disassembly_styles[num_disassembly_options] = NULL;
c906108c 3291
edefbb7c
AC
3292 /* Create the help text. */
3293 stb = mem_fileopen ();
3294 fprintf_unfiltered (stb, "%s%s%s",
3295 _("The valid values are:\n"),
3296 regdesc,
3297 _("The default is \"std\"."));
bc90b915
FN
3298 helptext = ui_file_xstrdup (stb, &length);
3299 ui_file_delete (stb);
ed9a39eb 3300
edefbb7c
AC
3301 add_setshow_enum_cmd("disassembler", no_class,
3302 valid_disassembly_styles, &disassembly_style,
3303 _("Set the disassembly style."),
3304 _("Show the disassembly style."),
3305 helptext,
2c5b56ce 3306 set_disassembly_style_sfunc,
7915a72c 3307 NULL, /* FIXME: i18n: The disassembly style is \"%s\". */
7376b4c2 3308 &setarmcmdlist, &showarmcmdlist);
edefbb7c
AC
3309
3310 add_setshow_boolean_cmd ("apcs32", no_class, &arm_apcs_32,
3311 _("Set usage of ARM 32-bit mode."),
3312 _("Show usage of ARM 32-bit mode."),
3313 _("When off, a 26-bit PC will be used."),
2c5b56ce 3314 NULL,
7915a72c 3315 NULL, /* FIXME: i18n: Usage of ARM 32-bit mode is %s. */
26304000 3316 &setarmcmdlist, &showarmcmdlist);
c906108c 3317
fd50bc42 3318 /* Add a command to allow the user to force the FPU model. */
edefbb7c
AC
3319 add_setshow_enum_cmd ("fpu", no_class, fp_model_strings, &current_fp_model,
3320 _("Set the floating point type."),
3321 _("Show the floating point type."),
3322 _("auto - Determine the FP typefrom the OS-ABI.\n\
3323softfpa - Software FP, mixed-endian doubles on little-endian ARMs.\n\
3324fpa - FPA co-processor (GCC compiled).\n\
3325softvfp - Software FP with pure-endian doubles.\n\
3326vfp - VFP co-processor."),
edefbb7c 3327 set_fp_model_sfunc, show_fp_model,
7376b4c2 3328 &setarmcmdlist, &showarmcmdlist);
fd50bc42 3329
28e97307
DJ
3330 /* Add a command to allow the user to force the ABI. */
3331 add_setshow_enum_cmd ("abi", class_support, arm_abi_strings, &arm_abi_string,
3332 _("Set the ABI."),
3333 _("Show the ABI."),
3334 NULL, arm_set_abi, arm_show_abi,
3335 &setarmcmdlist, &showarmcmdlist);
3336
0428b8f5
DJ
3337 /* Add two commands to allow the user to force the assumed
3338 execution mode. */
3339 add_setshow_enum_cmd ("fallback-mode", class_support,
3340 arm_mode_strings, &arm_fallback_mode_string,
3341 _("Set the mode assumed when symbols are unavailable."),
3342 _("Show the mode assumed when symbols are unavailable."),
3343 NULL, NULL, arm_show_fallback_mode,
3344 &setarmcmdlist, &showarmcmdlist);
3345 add_setshow_enum_cmd ("force-mode", class_support,
3346 arm_mode_strings, &arm_force_mode_string,
3347 _("Set the mode assumed even when symbols are available."),
3348 _("Show the mode assumed even when symbols are available."),
3349 NULL, NULL, arm_show_force_mode,
3350 &setarmcmdlist, &showarmcmdlist);
3351
6529d2dd 3352 /* Debugging flag. */
edefbb7c
AC
3353 add_setshow_boolean_cmd ("arm", class_maintenance, &arm_debug,
3354 _("Set ARM debugging."),
3355 _("Show ARM debugging."),
3356 _("When on, arm-specific debugging is enabled."),
2c5b56ce 3357 NULL,
7915a72c 3358 NULL, /* FIXME: i18n: "ARM debugging is %s. */
26304000 3359 &setdebuglist, &showdebuglist);
c906108c 3360}
This page took 0.770203 seconds and 4 git commands to generate.