include/elf/
[deliverable/binutils-gdb.git] / gdb / mips-tdep.c
CommitLineData
c906108c 1/* Target-dependent code for the MIPS architecture, for GDB, the GNU Debugger.
bf64bfd6 2
6aba47ca 3 Copyright (C) 1988, 1989, 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997,
4c38e0a4 4 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009,
7b6bb8da 5 2010, 2011 Free Software Foundation, Inc.
bf64bfd6 6
c906108c
SS
7 Contributed by Alessandro Forin(af@cs.cmu.edu) at CMU
8 and by Per Bothner(bothner@cs.wisc.edu) at U.Wisconsin.
9
c5aa993b 10 This file is part of GDB.
c906108c 11
c5aa993b
JM
12 This program is free software; you can redistribute it and/or modify
13 it under the terms of the GNU General Public License as published by
a9762ec7 14 the Free Software Foundation; either version 3 of the License, or
c5aa993b 15 (at your option) any later version.
c906108c 16
c5aa993b
JM
17 This program is distributed in the hope that it will be useful,
18 but WITHOUT ANY WARRANTY; without even the implied warranty of
19 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
20 GNU General Public License for more details.
c906108c 21
c5aa993b 22 You should have received a copy of the GNU General Public License
a9762ec7 23 along with this program. If not, see <http://www.gnu.org/licenses/>. */
c906108c
SS
24
25#include "defs.h"
26#include "gdb_string.h"
5e2e9765 27#include "gdb_assert.h"
c906108c
SS
28#include "frame.h"
29#include "inferior.h"
30#include "symtab.h"
31#include "value.h"
32#include "gdbcmd.h"
33#include "language.h"
34#include "gdbcore.h"
35#include "symfile.h"
36#include "objfiles.h"
37#include "gdbtypes.h"
38#include "target.h"
28d069e6 39#include "arch-utils.h"
4e052eda 40#include "regcache.h"
70f80edf 41#include "osabi.h"
d1973055 42#include "mips-tdep.h"
fe898f56 43#include "block.h"
a4b8ebc8 44#include "reggroups.h"
c906108c 45#include "opcode/mips.h"
c2d11a7d
JM
46#include "elf/mips.h"
47#include "elf-bfd.h"
2475bac3 48#include "symcat.h"
a4b8ebc8 49#include "sim-regno.h"
a89aa300 50#include "dis-asm.h"
edfae063
AC
51#include "frame-unwind.h"
52#include "frame-base.h"
53#include "trad-frame.h"
7d9b040b 54#include "infcall.h"
fed7ba43 55#include "floatformat.h"
29709017
DJ
56#include "remote.h"
57#include "target-descriptions.h"
2bd0c3d7 58#include "dwarf2-frame.h"
f8b73d13 59#include "user-regs.h"
79a45b7d 60#include "valprint.h"
175ff332 61#include "ax.h"
c906108c 62
8d5f9dcb
DJ
63static const struct objfile_data *mips_pdr_data;
64
5bbcb741 65static struct type *mips_register_type (struct gdbarch *gdbarch, int regnum);
e0f7ec59 66
24e05951 67/* A useful bit in the CP0 status register (MIPS_PS_REGNUM). */
dd824b04
DJ
68/* This bit is set if we are emulating 32-bit FPRs on a 64-bit chip. */
69#define ST0_FR (1 << 26)
70
b0069a17
AC
71/* The sizes of floating point registers. */
72
73enum
74{
75 MIPS_FPU_SINGLE_REGSIZE = 4,
76 MIPS_FPU_DOUBLE_REGSIZE = 8
77};
78
1a69e1e4
DJ
79enum
80{
81 MIPS32_REGSIZE = 4,
82 MIPS64_REGSIZE = 8
83};
0dadbba0 84
2e4ebe70
DJ
85static const char *mips_abi_string;
86
87static const char *mips_abi_strings[] = {
88 "auto",
89 "n32",
90 "o32",
28d169de 91 "n64",
2e4ebe70
DJ
92 "o64",
93 "eabi32",
94 "eabi64",
95 NULL
96};
97
f8b73d13
DJ
98/* The standard register names, and all the valid aliases for them. */
99struct register_alias
100{
101 const char *name;
102 int regnum;
103};
104
105/* Aliases for o32 and most other ABIs. */
106const struct register_alias mips_o32_aliases[] = {
107 { "ta0", 12 },
108 { "ta1", 13 },
109 { "ta2", 14 },
110 { "ta3", 15 }
111};
112
113/* Aliases for n32 and n64. */
114const struct register_alias mips_n32_n64_aliases[] = {
115 { "ta0", 8 },
116 { "ta1", 9 },
117 { "ta2", 10 },
118 { "ta3", 11 }
119};
120
121/* Aliases for ABI-independent registers. */
122const struct register_alias mips_register_aliases[] = {
123 /* The architecture manuals specify these ABI-independent names for
124 the GPRs. */
125#define R(n) { "r" #n, n }
126 R(0), R(1), R(2), R(3), R(4), R(5), R(6), R(7),
127 R(8), R(9), R(10), R(11), R(12), R(13), R(14), R(15),
128 R(16), R(17), R(18), R(19), R(20), R(21), R(22), R(23),
129 R(24), R(25), R(26), R(27), R(28), R(29), R(30), R(31),
130#undef R
131
132 /* k0 and k1 are sometimes called these instead (for "kernel
133 temp"). */
134 { "kt0", 26 },
135 { "kt1", 27 },
136
137 /* This is the traditional GDB name for the CP0 status register. */
138 { "sr", MIPS_PS_REGNUM },
139
140 /* This is the traditional GDB name for the CP0 BadVAddr register. */
141 { "bad", MIPS_EMBED_BADVADDR_REGNUM },
142
143 /* This is the traditional GDB name for the FCSR. */
144 { "fsr", MIPS_EMBED_FP0_REGNUM + 32 }
145};
146
865093a3
AR
147const struct register_alias mips_numeric_register_aliases[] = {
148#define R(n) { #n, n }
149 R(0), R(1), R(2), R(3), R(4), R(5), R(6), R(7),
150 R(8), R(9), R(10), R(11), R(12), R(13), R(14), R(15),
151 R(16), R(17), R(18), R(19), R(20), R(21), R(22), R(23),
152 R(24), R(25), R(26), R(27), R(28), R(29), R(30), R(31),
153#undef R
154};
155
c906108c
SS
156#ifndef MIPS_DEFAULT_FPU_TYPE
157#define MIPS_DEFAULT_FPU_TYPE MIPS_FPU_DOUBLE
158#endif
159static int mips_fpu_type_auto = 1;
160static enum mips_fpu_type mips_fpu_type = MIPS_DEFAULT_FPU_TYPE;
7a292a7a 161
9ace0497 162static int mips_debug = 0;
7a292a7a 163
29709017
DJ
164/* Properties (for struct target_desc) describing the g/G packet
165 layout. */
166#define PROPERTY_GP32 "internal: transfers-32bit-registers"
167#define PROPERTY_GP64 "internal: transfers-64bit-registers"
168
4eb0ad19
DJ
169struct target_desc *mips_tdesc_gp32;
170struct target_desc *mips_tdesc_gp64;
171
56cea623
AC
172const struct mips_regnum *
173mips_regnum (struct gdbarch *gdbarch)
174{
175 return gdbarch_tdep (gdbarch)->regnum;
176}
177
178static int
179mips_fpa0_regnum (struct gdbarch *gdbarch)
180{
181 return mips_regnum (gdbarch)->fp0 + 12;
182}
183
74ed0bb4
MD
184#define MIPS_EABI(gdbarch) (gdbarch_tdep (gdbarch)->mips_abi \
185 == MIPS_ABI_EABI32 \
186 || gdbarch_tdep (gdbarch)->mips_abi == MIPS_ABI_EABI64)
c2d11a7d 187
025bb325
MS
188#define MIPS_LAST_FP_ARG_REGNUM(gdbarch) \
189 (gdbarch_tdep (gdbarch)->mips_last_fp_arg_regnum)
c2d11a7d 190
025bb325
MS
191#define MIPS_LAST_ARG_REGNUM(gdbarch) \
192 (gdbarch_tdep (gdbarch)->mips_last_arg_regnum)
c2d11a7d 193
74ed0bb4 194#define MIPS_FPU_TYPE(gdbarch) (gdbarch_tdep (gdbarch)->mips_fpu_type)
c2d11a7d 195
95404a3e
AC
196/* MIPS16 function addresses are odd (bit 0 is set). Here are some
197 functions to test, set, or clear bit 0 of addresses. */
198
199static CORE_ADDR
200is_mips16_addr (CORE_ADDR addr)
201{
202 return ((addr) & 1);
203}
204
95404a3e
AC
205static CORE_ADDR
206unmake_mips16_addr (CORE_ADDR addr)
207{
5b652102 208 return ((addr) & ~(CORE_ADDR) 1);
95404a3e
AC
209}
210
930bd0e0
KB
211static CORE_ADDR
212make_mips16_addr (CORE_ADDR addr)
213{
214 return ((addr) | (CORE_ADDR) 1);
215}
216
d1973055
KB
217/* Return the MIPS ABI associated with GDBARCH. */
218enum mips_abi
219mips_abi (struct gdbarch *gdbarch)
220{
221 return gdbarch_tdep (gdbarch)->mips_abi;
222}
223
4246e332 224int
1b13c4f6 225mips_isa_regsize (struct gdbarch *gdbarch)
4246e332 226{
29709017
DJ
227 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
228
229 /* If we know how big the registers are, use that size. */
230 if (tdep->register_size_valid_p)
231 return tdep->register_size;
232
233 /* Fall back to the previous behavior. */
4246e332
AC
234 return (gdbarch_bfd_arch_info (gdbarch)->bits_per_word
235 / gdbarch_bfd_arch_info (gdbarch)->bits_per_byte);
236}
237
025bb325 238/* Return the currently configured (or set) saved register size. */
480d3dd2 239
e6bc2e8a 240unsigned int
13326b4e 241mips_abi_regsize (struct gdbarch *gdbarch)
d929b26f 242{
1a69e1e4
DJ
243 switch (mips_abi (gdbarch))
244 {
245 case MIPS_ABI_EABI32:
246 case MIPS_ABI_O32:
247 return 4;
248 case MIPS_ABI_N32:
249 case MIPS_ABI_N64:
250 case MIPS_ABI_O64:
251 case MIPS_ABI_EABI64:
252 return 8;
253 case MIPS_ABI_UNKNOWN:
254 case MIPS_ABI_LAST:
255 default:
256 internal_error (__FILE__, __LINE__, _("bad switch"));
257 }
d929b26f
AC
258}
259
71b8ef93 260/* Functions for setting and testing a bit in a minimal symbol that
5a89d8aa 261 marks it as 16-bit function. The MSB of the minimal symbol's
f594e5e9 262 "info" field is used for this purpose.
5a89d8aa 263
95f1da47 264 gdbarch_elf_make_msymbol_special tests whether an ELF symbol is "special",
5a89d8aa
MS
265 i.e. refers to a 16-bit function, and sets a "special" bit in a
266 minimal symbol to mark it as a 16-bit function
267
f594e5e9 268 MSYMBOL_IS_SPECIAL tests the "special" bit in a minimal symbol */
5a89d8aa 269
5a89d8aa 270static void
6d82d43b
AC
271mips_elf_make_msymbol_special (asymbol * sym, struct minimal_symbol *msym)
272{
273 if (((elf_symbol_type *) (sym))->internal_elf_sym.st_other == STO_MIPS16)
274 {
b887350f 275 MSYMBOL_TARGET_FLAG_1 (msym) = 1;
6d82d43b 276 }
5a89d8aa
MS
277}
278
71b8ef93
MS
279static int
280msymbol_is_special (struct minimal_symbol *msym)
281{
b887350f 282 return MSYMBOL_TARGET_FLAG_1 (msym);
71b8ef93
MS
283}
284
88658117
AC
285/* XFER a value from the big/little/left end of the register.
286 Depending on the size of the value it might occupy the entire
287 register or just part of it. Make an allowance for this, aligning
288 things accordingly. */
289
290static void
ba32f989
DJ
291mips_xfer_register (struct gdbarch *gdbarch, struct regcache *regcache,
292 int reg_num, int length,
870cd05e
MK
293 enum bfd_endian endian, gdb_byte *in,
294 const gdb_byte *out, int buf_offset)
88658117 295{
88658117 296 int reg_offset = 0;
72a155b4
UW
297
298 gdb_assert (reg_num >= gdbarch_num_regs (gdbarch));
cb1d2653
AC
299 /* Need to transfer the left or right part of the register, based on
300 the targets byte order. */
88658117
AC
301 switch (endian)
302 {
303 case BFD_ENDIAN_BIG:
72a155b4 304 reg_offset = register_size (gdbarch, reg_num) - length;
88658117
AC
305 break;
306 case BFD_ENDIAN_LITTLE:
307 reg_offset = 0;
308 break;
6d82d43b 309 case BFD_ENDIAN_UNKNOWN: /* Indicates no alignment. */
88658117
AC
310 reg_offset = 0;
311 break;
312 default:
e2e0b3e5 313 internal_error (__FILE__, __LINE__, _("bad switch"));
88658117
AC
314 }
315 if (mips_debug)
cb1d2653
AC
316 fprintf_unfiltered (gdb_stderr,
317 "xfer $%d, reg offset %d, buf offset %d, length %d, ",
318 reg_num, reg_offset, buf_offset, length);
88658117
AC
319 if (mips_debug && out != NULL)
320 {
321 int i;
cb1d2653 322 fprintf_unfiltered (gdb_stdlog, "out ");
88658117 323 for (i = 0; i < length; i++)
cb1d2653 324 fprintf_unfiltered (gdb_stdlog, "%02x", out[buf_offset + i]);
88658117
AC
325 }
326 if (in != NULL)
6d82d43b
AC
327 regcache_cooked_read_part (regcache, reg_num, reg_offset, length,
328 in + buf_offset);
88658117 329 if (out != NULL)
6d82d43b
AC
330 regcache_cooked_write_part (regcache, reg_num, reg_offset, length,
331 out + buf_offset);
88658117
AC
332 if (mips_debug && in != NULL)
333 {
334 int i;
cb1d2653 335 fprintf_unfiltered (gdb_stdlog, "in ");
88658117 336 for (i = 0; i < length; i++)
cb1d2653 337 fprintf_unfiltered (gdb_stdlog, "%02x", in[buf_offset + i]);
88658117
AC
338 }
339 if (mips_debug)
340 fprintf_unfiltered (gdb_stdlog, "\n");
341}
342
dd824b04
DJ
343/* Determine if a MIPS3 or later cpu is operating in MIPS{1,2} FPU
344 compatiblity mode. A return value of 1 means that we have
345 physical 64-bit registers, but should treat them as 32-bit registers. */
346
347static int
9c9acae0 348mips2_fp_compat (struct frame_info *frame)
dd824b04 349{
72a155b4 350 struct gdbarch *gdbarch = get_frame_arch (frame);
dd824b04
DJ
351 /* MIPS1 and MIPS2 have only 32 bit FPRs, and the FR bit is not
352 meaningful. */
72a155b4 353 if (register_size (gdbarch, mips_regnum (gdbarch)->fp0) == 4)
dd824b04
DJ
354 return 0;
355
356#if 0
357 /* FIXME drow 2002-03-10: This is disabled until we can do it consistently,
358 in all the places we deal with FP registers. PR gdb/413. */
359 /* Otherwise check the FR bit in the status register - it controls
360 the FP compatiblity mode. If it is clear we are in compatibility
361 mode. */
9c9acae0 362 if ((get_frame_register_unsigned (frame, MIPS_PS_REGNUM) & ST0_FR) == 0)
dd824b04
DJ
363 return 1;
364#endif
361d1df0 365
dd824b04
DJ
366 return 0;
367}
368
7a292a7a 369#define VM_MIN_ADDRESS (CORE_ADDR)0x400000
c906108c 370
74ed0bb4 371static CORE_ADDR heuristic_proc_start (struct gdbarch *, CORE_ADDR);
c906108c 372
a14ed312 373static void reinit_frame_cache_sfunc (char *, int, struct cmd_list_element *);
c906108c 374
025bb325 375/* The list of available "set mips " and "show mips " commands. */
acdb74a0
AC
376
377static struct cmd_list_element *setmipscmdlist = NULL;
378static struct cmd_list_element *showmipscmdlist = NULL;
379
5e2e9765
KB
380/* Integer registers 0 thru 31 are handled explicitly by
381 mips_register_name(). Processor specific registers 32 and above
8a9fc081 382 are listed in the following tables. */
691c0433 383
6d82d43b
AC
384enum
385{ NUM_MIPS_PROCESSOR_REGS = (90 - 32) };
691c0433
AC
386
387/* Generic MIPS. */
388
389static const char *mips_generic_reg_names[NUM_MIPS_PROCESSOR_REGS] = {
6d82d43b
AC
390 "sr", "lo", "hi", "bad", "cause", "pc",
391 "f0", "f1", "f2", "f3", "f4", "f5", "f6", "f7",
392 "f8", "f9", "f10", "f11", "f12", "f13", "f14", "f15",
393 "f16", "f17", "f18", "f19", "f20", "f21", "f22", "f23",
394 "f24", "f25", "f26", "f27", "f28", "f29", "f30", "f31",
395 "fsr", "fir", "" /*"fp" */ , "",
396 "", "", "", "", "", "", "", "",
397 "", "", "", "", "", "", "", "",
691c0433
AC
398};
399
400/* Names of IDT R3041 registers. */
401
402static const char *mips_r3041_reg_names[] = {
6d82d43b
AC
403 "sr", "lo", "hi", "bad", "cause", "pc",
404 "f0", "f1", "f2", "f3", "f4", "f5", "f6", "f7",
405 "f8", "f9", "f10", "f11", "f12", "f13", "f14", "f15",
406 "f16", "f17", "f18", "f19", "f20", "f21", "f22", "f23",
407 "f24", "f25", "f26", "f27", "f28", "f29", "f30", "f31",
408 "fsr", "fir", "", /*"fp" */ "",
409 "", "", "bus", "ccfg", "", "", "", "",
410 "", "", "port", "cmp", "", "", "epc", "prid",
691c0433
AC
411};
412
413/* Names of tx39 registers. */
414
415static const char *mips_tx39_reg_names[NUM_MIPS_PROCESSOR_REGS] = {
6d82d43b
AC
416 "sr", "lo", "hi", "bad", "cause", "pc",
417 "", "", "", "", "", "", "", "",
418 "", "", "", "", "", "", "", "",
419 "", "", "", "", "", "", "", "",
420 "", "", "", "", "", "", "", "",
421 "", "", "", "",
422 "", "", "", "", "", "", "", "",
423 "", "", "config", "cache", "debug", "depc", "epc", ""
691c0433
AC
424};
425
426/* Names of IRIX registers. */
427static const char *mips_irix_reg_names[NUM_MIPS_PROCESSOR_REGS] = {
6d82d43b
AC
428 "f0", "f1", "f2", "f3", "f4", "f5", "f6", "f7",
429 "f8", "f9", "f10", "f11", "f12", "f13", "f14", "f15",
430 "f16", "f17", "f18", "f19", "f20", "f21", "f22", "f23",
431 "f24", "f25", "f26", "f27", "f28", "f29", "f30", "f31",
432 "pc", "cause", "bad", "hi", "lo", "fsr", "fir"
691c0433
AC
433};
434
cce74817 435
5e2e9765 436/* Return the name of the register corresponding to REGNO. */
5a89d8aa 437static const char *
d93859e2 438mips_register_name (struct gdbarch *gdbarch, int regno)
cce74817 439{
d93859e2 440 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
5e2e9765
KB
441 /* GPR names for all ABIs other than n32/n64. */
442 static char *mips_gpr_names[] = {
6d82d43b
AC
443 "zero", "at", "v0", "v1", "a0", "a1", "a2", "a3",
444 "t0", "t1", "t2", "t3", "t4", "t5", "t6", "t7",
445 "s0", "s1", "s2", "s3", "s4", "s5", "s6", "s7",
446 "t8", "t9", "k0", "k1", "gp", "sp", "s8", "ra",
5e2e9765
KB
447 };
448
449 /* GPR names for n32 and n64 ABIs. */
450 static char *mips_n32_n64_gpr_names[] = {
6d82d43b
AC
451 "zero", "at", "v0", "v1", "a0", "a1", "a2", "a3",
452 "a4", "a5", "a6", "a7", "t0", "t1", "t2", "t3",
453 "s0", "s1", "s2", "s3", "s4", "s5", "s6", "s7",
454 "t8", "t9", "k0", "k1", "gp", "sp", "s8", "ra"
5e2e9765
KB
455 };
456
d93859e2 457 enum mips_abi abi = mips_abi (gdbarch);
5e2e9765 458
f57d151a 459 /* Map [gdbarch_num_regs .. 2*gdbarch_num_regs) onto the raw registers,
6229fbea
HZ
460 but then don't make the raw register names visible. This (upper)
461 range of user visible register numbers are the pseudo-registers.
462
463 This approach was adopted accommodate the following scenario:
464 It is possible to debug a 64-bit device using a 32-bit
465 programming model. In such instances, the raw registers are
466 configured to be 64-bits wide, while the pseudo registers are
467 configured to be 32-bits wide. The registers that the user
468 sees - the pseudo registers - match the users expectations
469 given the programming model being used. */
d93859e2
UW
470 int rawnum = regno % gdbarch_num_regs (gdbarch);
471 if (regno < gdbarch_num_regs (gdbarch))
a4b8ebc8
AC
472 return "";
473
5e2e9765
KB
474 /* The MIPS integer registers are always mapped from 0 to 31. The
475 names of the registers (which reflects the conventions regarding
476 register use) vary depending on the ABI. */
a4b8ebc8 477 if (0 <= rawnum && rawnum < 32)
5e2e9765
KB
478 {
479 if (abi == MIPS_ABI_N32 || abi == MIPS_ABI_N64)
a4b8ebc8 480 return mips_n32_n64_gpr_names[rawnum];
5e2e9765 481 else
a4b8ebc8 482 return mips_gpr_names[rawnum];
5e2e9765 483 }
d93859e2
UW
484 else if (tdesc_has_registers (gdbarch_target_desc (gdbarch)))
485 return tdesc_register_name (gdbarch, rawnum);
486 else if (32 <= rawnum && rawnum < gdbarch_num_regs (gdbarch))
691c0433
AC
487 {
488 gdb_assert (rawnum - 32 < NUM_MIPS_PROCESSOR_REGS);
489 return tdep->mips_processor_reg_names[rawnum - 32];
490 }
5e2e9765
KB
491 else
492 internal_error (__FILE__, __LINE__,
e2e0b3e5 493 _("mips_register_name: bad register number %d"), rawnum);
cce74817 494}
5e2e9765 495
a4b8ebc8 496/* Return the groups that a MIPS register can be categorised into. */
c5aa993b 497
a4b8ebc8
AC
498static int
499mips_register_reggroup_p (struct gdbarch *gdbarch, int regnum,
500 struct reggroup *reggroup)
501{
502 int vector_p;
503 int float_p;
504 int raw_p;
72a155b4
UW
505 int rawnum = regnum % gdbarch_num_regs (gdbarch);
506 int pseudo = regnum / gdbarch_num_regs (gdbarch);
a4b8ebc8
AC
507 if (reggroup == all_reggroup)
508 return pseudo;
509 vector_p = TYPE_VECTOR (register_type (gdbarch, regnum));
510 float_p = TYPE_CODE (register_type (gdbarch, regnum)) == TYPE_CODE_FLT;
511 /* FIXME: cagney/2003-04-13: Can't yet use gdbarch_num_regs
512 (gdbarch), as not all architectures are multi-arch. */
72a155b4
UW
513 raw_p = rawnum < gdbarch_num_regs (gdbarch);
514 if (gdbarch_register_name (gdbarch, regnum) == NULL
515 || gdbarch_register_name (gdbarch, regnum)[0] == '\0')
a4b8ebc8
AC
516 return 0;
517 if (reggroup == float_reggroup)
518 return float_p && pseudo;
519 if (reggroup == vector_reggroup)
520 return vector_p && pseudo;
521 if (reggroup == general_reggroup)
522 return (!vector_p && !float_p) && pseudo;
523 /* Save the pseudo registers. Need to make certain that any code
524 extracting register values from a saved register cache also uses
525 pseudo registers. */
526 if (reggroup == save_reggroup)
527 return raw_p && pseudo;
528 /* Restore the same pseudo register. */
529 if (reggroup == restore_reggroup)
530 return raw_p && pseudo;
6d82d43b 531 return 0;
a4b8ebc8
AC
532}
533
f8b73d13
DJ
534/* Return the groups that a MIPS register can be categorised into.
535 This version is only used if we have a target description which
536 describes real registers (and their groups). */
537
538static int
539mips_tdesc_register_reggroup_p (struct gdbarch *gdbarch, int regnum,
540 struct reggroup *reggroup)
541{
542 int rawnum = regnum % gdbarch_num_regs (gdbarch);
543 int pseudo = regnum / gdbarch_num_regs (gdbarch);
544 int ret;
545
546 /* Only save, restore, and display the pseudo registers. Need to
547 make certain that any code extracting register values from a
548 saved register cache also uses pseudo registers.
549
550 Note: saving and restoring the pseudo registers is slightly
551 strange; if we have 64 bits, we should save and restore all
552 64 bits. But this is hard and has little benefit. */
553 if (!pseudo)
554 return 0;
555
556 ret = tdesc_register_in_reggroup_p (gdbarch, rawnum, reggroup);
557 if (ret != -1)
558 return ret;
559
560 return mips_register_reggroup_p (gdbarch, regnum, reggroup);
561}
562
a4b8ebc8 563/* Map the symbol table registers which live in the range [1 *
f57d151a 564 gdbarch_num_regs .. 2 * gdbarch_num_regs) back onto the corresponding raw
47ebcfbe 565 registers. Take care of alignment and size problems. */
c5aa993b 566
a4b8ebc8
AC
567static void
568mips_pseudo_register_read (struct gdbarch *gdbarch, struct regcache *regcache,
47a35522 569 int cookednum, gdb_byte *buf)
a4b8ebc8 570{
72a155b4
UW
571 int rawnum = cookednum % gdbarch_num_regs (gdbarch);
572 gdb_assert (cookednum >= gdbarch_num_regs (gdbarch)
573 && cookednum < 2 * gdbarch_num_regs (gdbarch));
47ebcfbe 574 if (register_size (gdbarch, rawnum) == register_size (gdbarch, cookednum))
de38af99 575 regcache_raw_read (regcache, rawnum, buf);
6d82d43b
AC
576 else if (register_size (gdbarch, rawnum) >
577 register_size (gdbarch, cookednum))
47ebcfbe 578 {
8bdf35dc 579 if (gdbarch_tdep (gdbarch)->mips64_transfers_32bit_regs_p)
47ebcfbe
AC
580 regcache_raw_read_part (regcache, rawnum, 0, 4, buf);
581 else
8bdf35dc
KB
582 {
583 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
584 LONGEST regval;
585 regcache_raw_read_signed (regcache, rawnum, &regval);
586 store_signed_integer (buf, 4, byte_order, regval);
587 }
47ebcfbe
AC
588 }
589 else
e2e0b3e5 590 internal_error (__FILE__, __LINE__, _("bad register size"));
a4b8ebc8
AC
591}
592
593static void
6d82d43b
AC
594mips_pseudo_register_write (struct gdbarch *gdbarch,
595 struct regcache *regcache, int cookednum,
47a35522 596 const gdb_byte *buf)
a4b8ebc8 597{
72a155b4
UW
598 int rawnum = cookednum % gdbarch_num_regs (gdbarch);
599 gdb_assert (cookednum >= gdbarch_num_regs (gdbarch)
600 && cookednum < 2 * gdbarch_num_regs (gdbarch));
47ebcfbe 601 if (register_size (gdbarch, rawnum) == register_size (gdbarch, cookednum))
de38af99 602 regcache_raw_write (regcache, rawnum, buf);
6d82d43b
AC
603 else if (register_size (gdbarch, rawnum) >
604 register_size (gdbarch, cookednum))
47ebcfbe 605 {
8bdf35dc 606 if (gdbarch_tdep (gdbarch)->mips64_transfers_32bit_regs_p)
47ebcfbe
AC
607 regcache_raw_write_part (regcache, rawnum, 0, 4, buf);
608 else
8bdf35dc
KB
609 {
610 /* Sign extend the shortened version of the register prior
611 to placing it in the raw register. This is required for
612 some mips64 parts in order to avoid unpredictable behavior. */
613 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
614 LONGEST regval = extract_signed_integer (buf, 4, byte_order);
615 regcache_raw_write_signed (regcache, rawnum, regval);
616 }
47ebcfbe
AC
617 }
618 else
e2e0b3e5 619 internal_error (__FILE__, __LINE__, _("bad register size"));
a4b8ebc8 620}
c5aa993b 621
175ff332
HZ
622static int
623mips_ax_pseudo_register_collect (struct gdbarch *gdbarch,
624 struct agent_expr *ax, int reg)
625{
626 int rawnum = reg % gdbarch_num_regs (gdbarch);
627 gdb_assert (reg >= gdbarch_num_regs (gdbarch)
628 && reg < 2 * gdbarch_num_regs (gdbarch));
629
630 ax_reg_mask (ax, rawnum);
631
632 return 0;
633}
634
635static int
636mips_ax_pseudo_register_push_stack (struct gdbarch *gdbarch,
637 struct agent_expr *ax, int reg)
638{
639 int rawnum = reg % gdbarch_num_regs (gdbarch);
640 gdb_assert (reg >= gdbarch_num_regs (gdbarch)
641 && reg < 2 * gdbarch_num_regs (gdbarch));
642 if (register_size (gdbarch, rawnum) >= register_size (gdbarch, reg))
643 {
644 ax_reg (ax, rawnum);
645
646 if (register_size (gdbarch, rawnum) > register_size (gdbarch, reg))
647 {
648 if (!gdbarch_tdep (gdbarch)->mips64_transfers_32bit_regs_p
649 || gdbarch_byte_order (gdbarch) != BFD_ENDIAN_BIG)
650 {
651 ax_const_l (ax, 32);
652 ax_simple (ax, aop_lsh);
653 }
654 ax_const_l (ax, 32);
655 ax_simple (ax, aop_rsh_signed);
656 }
657 }
658 else
659 internal_error (__FILE__, __LINE__, _("bad register size"));
660
661 return 0;
662}
663
c906108c 664/* Table to translate MIPS16 register field to actual register number. */
6d82d43b 665static int mips16_to_32_reg[8] = { 16, 17, 2, 3, 4, 5, 6, 7 };
c906108c
SS
666
667/* Heuristic_proc_start may hunt through the text section for a long
668 time across a 2400 baud serial line. Allows the user to limit this
669 search. */
670
671static unsigned int heuristic_fence_post = 0;
672
46cd78fb 673/* Number of bytes of storage in the actual machine representation for
719ec221
AC
674 register N. NOTE: This defines the pseudo register type so need to
675 rebuild the architecture vector. */
43e526b9
JM
676
677static int mips64_transfers_32bit_regs_p = 0;
678
719ec221
AC
679static void
680set_mips64_transfers_32bit_regs (char *args, int from_tty,
681 struct cmd_list_element *c)
43e526b9 682{
719ec221
AC
683 struct gdbarch_info info;
684 gdbarch_info_init (&info);
685 /* FIXME: cagney/2003-11-15: Should be setting a field in "info"
686 instead of relying on globals. Doing that would let generic code
687 handle the search for this specific architecture. */
688 if (!gdbarch_update_p (info))
a4b8ebc8 689 {
719ec221 690 mips64_transfers_32bit_regs_p = 0;
8a3fe4f8 691 error (_("32-bit compatibility mode not supported"));
a4b8ebc8 692 }
a4b8ebc8
AC
693}
694
47ebcfbe 695/* Convert to/from a register and the corresponding memory value. */
43e526b9 696
ee51a8c7
KB
697/* This predicate tests for the case of an 8 byte floating point
698 value that is being transferred to or from a pair of floating point
699 registers each of which are (or are considered to be) only 4 bytes
700 wide. */
ff2e87ac 701static int
ee51a8c7
KB
702mips_convert_register_float_case_p (struct gdbarch *gdbarch, int regnum,
703 struct type *type)
ff2e87ac 704{
0abe36f5
MD
705 return (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG
706 && register_size (gdbarch, regnum) == 4
707 && (regnum % gdbarch_num_regs (gdbarch))
708 >= mips_regnum (gdbarch)->fp0
709 && (regnum % gdbarch_num_regs (gdbarch))
710 < mips_regnum (gdbarch)->fp0 + 32
6d82d43b 711 && TYPE_CODE (type) == TYPE_CODE_FLT && TYPE_LENGTH (type) == 8);
ff2e87ac
AC
712}
713
ee51a8c7
KB
714/* This predicate tests for the case of a value of less than 8
715 bytes in width that is being transfered to or from an 8 byte
716 general purpose register. */
717static int
718mips_convert_register_gpreg_case_p (struct gdbarch *gdbarch, int regnum,
719 struct type *type)
720{
721 int num_regs = gdbarch_num_regs (gdbarch);
722
723 return (register_size (gdbarch, regnum) == 8
724 && regnum % num_regs > 0 && regnum % num_regs < 32
725 && TYPE_LENGTH (type) < 8);
726}
727
728static int
025bb325
MS
729mips_convert_register_p (struct gdbarch *gdbarch,
730 int regnum, struct type *type)
ee51a8c7
KB
731{
732 return mips_convert_register_float_case_p (gdbarch, regnum, type)
733 || mips_convert_register_gpreg_case_p (gdbarch, regnum, type);
734}
735
42c466d7 736static void
ff2e87ac 737mips_register_to_value (struct frame_info *frame, int regnum,
47a35522 738 struct type *type, gdb_byte *to)
102182a9 739{
ee51a8c7
KB
740 struct gdbarch *gdbarch = get_frame_arch (frame);
741
742 if (mips_convert_register_float_case_p (gdbarch, regnum, type))
743 {
744 get_frame_register (frame, regnum + 0, to + 4);
745 get_frame_register (frame, regnum + 1, to + 0);
746 }
747 else if (mips_convert_register_gpreg_case_p (gdbarch, regnum, type))
748 {
749 int len = TYPE_LENGTH (type);
750 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG)
751 get_frame_register_bytes (frame, regnum, 8 - len, len, to);
752 else
753 get_frame_register_bytes (frame, regnum, 0, len, to);
754 }
755 else
756 {
757 internal_error (__FILE__, __LINE__,
758 _("mips_register_to_value: unrecognized case"));
759 }
102182a9
MS
760}
761
42c466d7 762static void
ff2e87ac 763mips_value_to_register (struct frame_info *frame, int regnum,
47a35522 764 struct type *type, const gdb_byte *from)
102182a9 765{
ee51a8c7
KB
766 struct gdbarch *gdbarch = get_frame_arch (frame);
767
768 if (mips_convert_register_float_case_p (gdbarch, regnum, type))
769 {
770 put_frame_register (frame, regnum + 0, from + 4);
771 put_frame_register (frame, regnum + 1, from + 0);
772 }
773 else if (mips_convert_register_gpreg_case_p (gdbarch, regnum, type))
774 {
775 gdb_byte fill[8];
776 int len = TYPE_LENGTH (type);
777
778 /* Sign extend values, irrespective of type, that are stored to
779 a 64-bit general purpose register. (32-bit unsigned values
780 are stored as signed quantities within a 64-bit register.
781 When performing an operation, in compiled code, that combines
782 a 32-bit unsigned value with a signed 64-bit value, a type
783 conversion is first performed that zeroes out the high 32 bits.) */
784 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG)
785 {
786 if (from[0] & 0x80)
787 store_signed_integer (fill, 8, BFD_ENDIAN_BIG, -1);
788 else
789 store_signed_integer (fill, 8, BFD_ENDIAN_BIG, 0);
790 put_frame_register_bytes (frame, regnum, 0, 8 - len, fill);
791 put_frame_register_bytes (frame, regnum, 8 - len, len, from);
792 }
793 else
794 {
795 if (from[len-1] & 0x80)
796 store_signed_integer (fill, 8, BFD_ENDIAN_LITTLE, -1);
797 else
798 store_signed_integer (fill, 8, BFD_ENDIAN_LITTLE, 0);
799 put_frame_register_bytes (frame, regnum, 0, len, from);
800 put_frame_register_bytes (frame, regnum, len, 8 - len, fill);
801 }
802 }
803 else
804 {
805 internal_error (__FILE__, __LINE__,
806 _("mips_value_to_register: unrecognized case"));
807 }
102182a9
MS
808}
809
a4b8ebc8
AC
810/* Return the GDB type object for the "standard" data type of data in
811 register REG. */
78fde5f8
KB
812
813static struct type *
a4b8ebc8
AC
814mips_register_type (struct gdbarch *gdbarch, int regnum)
815{
72a155b4
UW
816 gdb_assert (regnum >= 0 && regnum < 2 * gdbarch_num_regs (gdbarch));
817 if ((regnum % gdbarch_num_regs (gdbarch)) >= mips_regnum (gdbarch)->fp0
818 && (regnum % gdbarch_num_regs (gdbarch))
819 < mips_regnum (gdbarch)->fp0 + 32)
a6425924 820 {
5ef80fb0 821 /* The floating-point registers raw, or cooked, always match
1b13c4f6 822 mips_isa_regsize(), and also map 1:1, byte for byte. */
8da61cc4 823 if (mips_isa_regsize (gdbarch) == 4)
27067745 824 return builtin_type (gdbarch)->builtin_float;
8da61cc4 825 else
27067745 826 return builtin_type (gdbarch)->builtin_double;
a6425924 827 }
72a155b4 828 else if (regnum < gdbarch_num_regs (gdbarch))
d5ac5a39
AC
829 {
830 /* The raw or ISA registers. These are all sized according to
831 the ISA regsize. */
832 if (mips_isa_regsize (gdbarch) == 4)
df4df182 833 return builtin_type (gdbarch)->builtin_int32;
d5ac5a39 834 else
df4df182 835 return builtin_type (gdbarch)->builtin_int64;
d5ac5a39 836 }
78fde5f8 837 else
d5ac5a39
AC
838 {
839 /* The cooked or ABI registers. These are sized according to
840 the ABI (with a few complications). */
72a155b4
UW
841 if (regnum >= (gdbarch_num_regs (gdbarch)
842 + mips_regnum (gdbarch)->fp_control_status)
843 && regnum <= gdbarch_num_regs (gdbarch) + MIPS_LAST_EMBED_REGNUM)
d5ac5a39
AC
844 /* The pseudo/cooked view of the embedded registers is always
845 32-bit. The raw view is handled below. */
df4df182 846 return builtin_type (gdbarch)->builtin_int32;
d5ac5a39
AC
847 else if (gdbarch_tdep (gdbarch)->mips64_transfers_32bit_regs_p)
848 /* The target, while possibly using a 64-bit register buffer,
849 is only transfering 32-bits of each integer register.
850 Reflect this in the cooked/pseudo (ABI) register value. */
df4df182 851 return builtin_type (gdbarch)->builtin_int32;
d5ac5a39
AC
852 else if (mips_abi_regsize (gdbarch) == 4)
853 /* The ABI is restricted to 32-bit registers (the ISA could be
854 32- or 64-bit). */
df4df182 855 return builtin_type (gdbarch)->builtin_int32;
d5ac5a39
AC
856 else
857 /* 64-bit ABI. */
df4df182 858 return builtin_type (gdbarch)->builtin_int64;
d5ac5a39 859 }
78fde5f8
KB
860}
861
f8b73d13
DJ
862/* Return the GDB type for the pseudo register REGNUM, which is the
863 ABI-level view. This function is only called if there is a target
864 description which includes registers, so we know precisely the
865 types of hardware registers. */
866
867static struct type *
868mips_pseudo_register_type (struct gdbarch *gdbarch, int regnum)
869{
870 const int num_regs = gdbarch_num_regs (gdbarch);
871 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
872 int rawnum = regnum % num_regs;
873 struct type *rawtype;
874
875 gdb_assert (regnum >= num_regs && regnum < 2 * num_regs);
876
877 /* Absent registers are still absent. */
878 rawtype = gdbarch_register_type (gdbarch, rawnum);
879 if (TYPE_LENGTH (rawtype) == 0)
880 return rawtype;
881
882 if (rawnum >= MIPS_EMBED_FP0_REGNUM && rawnum < MIPS_EMBED_FP0_REGNUM + 32)
883 /* Present the floating point registers however the hardware did;
884 do not try to convert between FPU layouts. */
885 return rawtype;
886
887 if (rawnum >= MIPS_EMBED_FP0_REGNUM + 32 && rawnum <= MIPS_LAST_EMBED_REGNUM)
888 {
889 /* The pseudo/cooked view of embedded registers is always
890 32-bit, even if the target transfers 64-bit values for them.
891 New targets relying on XML descriptions should only transfer
892 the necessary 32 bits, but older versions of GDB expected 64,
893 so allow the target to provide 64 bits without interfering
894 with the displayed type. */
df4df182 895 return builtin_type (gdbarch)->builtin_int32;
f8b73d13
DJ
896 }
897
898 /* Use pointer types for registers if we can. For n32 we can not,
899 since we do not have a 64-bit pointer type. */
0dfff4cb
UW
900 if (mips_abi_regsize (gdbarch)
901 == TYPE_LENGTH (builtin_type (gdbarch)->builtin_data_ptr))
f8b73d13
DJ
902 {
903 if (rawnum == MIPS_SP_REGNUM || rawnum == MIPS_EMBED_BADVADDR_REGNUM)
0dfff4cb 904 return builtin_type (gdbarch)->builtin_data_ptr;
f8b73d13 905 else if (rawnum == MIPS_EMBED_PC_REGNUM)
0dfff4cb 906 return builtin_type (gdbarch)->builtin_func_ptr;
f8b73d13
DJ
907 }
908
909 if (mips_abi_regsize (gdbarch) == 4 && TYPE_LENGTH (rawtype) == 8
910 && rawnum >= MIPS_ZERO_REGNUM && rawnum <= MIPS_EMBED_PC_REGNUM)
df4df182 911 return builtin_type (gdbarch)->builtin_int32;
f8b73d13
DJ
912
913 /* For all other registers, pass through the hardware type. */
914 return rawtype;
915}
bcb0cc15 916
025bb325 917/* Should the upper word of 64-bit addresses be zeroed? */
7f19b9a2 918enum auto_boolean mask_address_var = AUTO_BOOLEAN_AUTO;
4014092b
AC
919
920static int
480d3dd2 921mips_mask_address_p (struct gdbarch_tdep *tdep)
4014092b
AC
922{
923 switch (mask_address_var)
924 {
7f19b9a2 925 case AUTO_BOOLEAN_TRUE:
4014092b 926 return 1;
7f19b9a2 927 case AUTO_BOOLEAN_FALSE:
4014092b
AC
928 return 0;
929 break;
7f19b9a2 930 case AUTO_BOOLEAN_AUTO:
480d3dd2 931 return tdep->default_mask_address_p;
4014092b 932 default:
025bb325
MS
933 internal_error (__FILE__, __LINE__,
934 _("mips_mask_address_p: bad switch"));
4014092b 935 return -1;
361d1df0 936 }
4014092b
AC
937}
938
939static void
08546159
AC
940show_mask_address (struct ui_file *file, int from_tty,
941 struct cmd_list_element *c, const char *value)
4014092b 942{
1cf3db46 943 struct gdbarch_tdep *tdep = gdbarch_tdep (target_gdbarch);
08546159
AC
944
945 deprecated_show_value_hack (file, from_tty, c, value);
4014092b
AC
946 switch (mask_address_var)
947 {
7f19b9a2 948 case AUTO_BOOLEAN_TRUE:
4014092b
AC
949 printf_filtered ("The 32 bit mips address mask is enabled\n");
950 break;
7f19b9a2 951 case AUTO_BOOLEAN_FALSE:
4014092b
AC
952 printf_filtered ("The 32 bit mips address mask is disabled\n");
953 break;
7f19b9a2 954 case AUTO_BOOLEAN_AUTO:
6d82d43b
AC
955 printf_filtered
956 ("The 32 bit address mask is set automatically. Currently %s\n",
957 mips_mask_address_p (tdep) ? "enabled" : "disabled");
4014092b
AC
958 break;
959 default:
e2e0b3e5 960 internal_error (__FILE__, __LINE__, _("show_mask_address: bad switch"));
4014092b 961 break;
361d1df0 962 }
4014092b 963}
c906108c 964
c906108c
SS
965/* Tell if the program counter value in MEMADDR is in a MIPS16 function. */
966
0fe7e7c8
AC
967int
968mips_pc_is_mips16 (CORE_ADDR memaddr)
c906108c
SS
969{
970 struct minimal_symbol *sym;
971
025bb325 972 /* If bit 0 of the address is set, assume this is a MIPS16 address. */
95404a3e 973 if (is_mips16_addr (memaddr))
c906108c
SS
974 return 1;
975
976 /* A flag indicating that this is a MIPS16 function is stored by elfread.c in
977 the high bit of the info field. Use this to decide if the function is
978 MIPS16 or normal MIPS. */
979 sym = lookup_minimal_symbol_by_pc (memaddr);
980 if (sym)
71b8ef93 981 return msymbol_is_special (sym);
c906108c
SS
982 else
983 return 0;
984}
985
b2fa5097 986/* MIPS believes that the PC has a sign extended value. Perhaps the
025bb325 987 all registers should be sign extended for simplicity? */
6c997a34
AC
988
989static CORE_ADDR
61a1198a 990mips_read_pc (struct regcache *regcache)
6c997a34 991{
61a1198a
UW
992 ULONGEST pc;
993 int regnum = mips_regnum (get_regcache_arch (regcache))->pc;
994 regcache_cooked_read_signed (regcache, regnum, &pc);
930bd0e0
KB
995 if (is_mips16_addr (pc))
996 pc = unmake_mips16_addr (pc);
61a1198a 997 return pc;
b6cb9035
AC
998}
999
58dfe9ff
AC
1000static CORE_ADDR
1001mips_unwind_pc (struct gdbarch *gdbarch, struct frame_info *next_frame)
1002{
930bd0e0
KB
1003 ULONGEST pc;
1004
1005 pc = frame_unwind_register_signed
1006 (next_frame, gdbarch_num_regs (gdbarch) + mips_regnum (gdbarch)->pc);
1007 if (is_mips16_addr (pc))
1008 pc = unmake_mips16_addr (pc);
1009 return pc;
edfae063
AC
1010}
1011
30244cd8
UW
1012static CORE_ADDR
1013mips_unwind_sp (struct gdbarch *gdbarch, struct frame_info *next_frame)
1014{
72a155b4
UW
1015 return frame_unwind_register_signed
1016 (next_frame, gdbarch_num_regs (gdbarch) + MIPS_SP_REGNUM);
30244cd8
UW
1017}
1018
b8a22b94 1019/* Assuming THIS_FRAME is a dummy, return the frame ID of that
edfae063
AC
1020 dummy frame. The frame ID's base needs to match the TOS value
1021 saved by save_dummy_frame_tos(), and the PC match the dummy frame's
1022 breakpoint. */
1023
1024static struct frame_id
b8a22b94 1025mips_dummy_id (struct gdbarch *gdbarch, struct frame_info *this_frame)
edfae063 1026{
f57d151a 1027 return frame_id_build
b8a22b94
DJ
1028 (get_frame_register_signed (this_frame,
1029 gdbarch_num_regs (gdbarch)
1030 + MIPS_SP_REGNUM),
1031 get_frame_pc (this_frame));
58dfe9ff
AC
1032}
1033
b6cb9035 1034static void
61a1198a 1035mips_write_pc (struct regcache *regcache, CORE_ADDR pc)
b6cb9035 1036{
61a1198a 1037 int regnum = mips_regnum (get_regcache_arch (regcache))->pc;
930bd0e0
KB
1038 if (mips_pc_is_mips16 (pc))
1039 regcache_cooked_write_unsigned (regcache, regnum, make_mips16_addr (pc));
1040 else
1041 regcache_cooked_write_unsigned (regcache, regnum, pc);
6c997a34 1042}
c906108c 1043
c906108c
SS
1044/* Fetch and return instruction from the specified location. If the PC
1045 is odd, assume it's a MIPS16 instruction; otherwise MIPS32. */
1046
d37cca3d 1047static ULONGEST
e17a4113 1048mips_fetch_instruction (struct gdbarch *gdbarch, CORE_ADDR addr)
c906108c 1049{
e17a4113 1050 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
47a35522 1051 gdb_byte buf[MIPS_INSN32_SIZE];
c906108c
SS
1052 int instlen;
1053 int status;
1054
0fe7e7c8 1055 if (mips_pc_is_mips16 (addr))
c906108c 1056 {
95ac2dcf 1057 instlen = MIPS_INSN16_SIZE;
95404a3e 1058 addr = unmake_mips16_addr (addr);
c906108c
SS
1059 }
1060 else
95ac2dcf 1061 instlen = MIPS_INSN32_SIZE;
8defab1a 1062 status = target_read_memory (addr, buf, instlen);
c906108c
SS
1063 if (status)
1064 memory_error (status, addr);
e17a4113 1065 return extract_unsigned_integer (buf, instlen, byte_order);
c906108c
SS
1066}
1067
025bb325 1068/* These are the fields of 32 bit mips instructions. */
e135b889
DJ
1069#define mips32_op(x) (x >> 26)
1070#define itype_op(x) (x >> 26)
1071#define itype_rs(x) ((x >> 21) & 0x1f)
c906108c 1072#define itype_rt(x) ((x >> 16) & 0x1f)
e135b889 1073#define itype_immediate(x) (x & 0xffff)
c906108c 1074
e135b889
DJ
1075#define jtype_op(x) (x >> 26)
1076#define jtype_target(x) (x & 0x03ffffff)
c906108c 1077
e135b889
DJ
1078#define rtype_op(x) (x >> 26)
1079#define rtype_rs(x) ((x >> 21) & 0x1f)
1080#define rtype_rt(x) ((x >> 16) & 0x1f)
1081#define rtype_rd(x) ((x >> 11) & 0x1f)
1082#define rtype_shamt(x) ((x >> 6) & 0x1f)
1083#define rtype_funct(x) (x & 0x3f)
c906108c 1084
06987e64
MK
1085static LONGEST
1086mips32_relative_offset (ULONGEST inst)
c5aa993b 1087{
06987e64 1088 return ((itype_immediate (inst) ^ 0x8000) - 0x8000) << 2;
c906108c
SS
1089}
1090
f49e4e6d
MS
1091/* Determine where to set a single step breakpoint while considering
1092 branch prediction. */
5a89d8aa 1093static CORE_ADDR
0b1b3e42 1094mips32_next_pc (struct frame_info *frame, CORE_ADDR pc)
c5aa993b 1095{
e17a4113 1096 struct gdbarch *gdbarch = get_frame_arch (frame);
c5aa993b
JM
1097 unsigned long inst;
1098 int op;
e17a4113 1099 inst = mips_fetch_instruction (gdbarch, pc);
025bb325
MS
1100 if ((inst & 0xe0000000) != 0) /* Not a special, jump or branch
1101 instruction. */
c5aa993b 1102 {
e135b889 1103 if (itype_op (inst) >> 2 == 5)
6d82d43b 1104 /* BEQL, BNEL, BLEZL, BGTZL: bits 0101xx */
c5aa993b 1105 {
e135b889 1106 op = (itype_op (inst) & 0x03);
c906108c
SS
1107 switch (op)
1108 {
e135b889
DJ
1109 case 0: /* BEQL */
1110 goto equal_branch;
1111 case 1: /* BNEL */
1112 goto neq_branch;
1113 case 2: /* BLEZL */
1114 goto less_branch;
313628cc 1115 case 3: /* BGTZL */
e135b889 1116 goto greater_branch;
c5aa993b
JM
1117 default:
1118 pc += 4;
c906108c
SS
1119 }
1120 }
e135b889 1121 else if (itype_op (inst) == 17 && itype_rs (inst) == 8)
6d82d43b 1122 /* BC1F, BC1FL, BC1T, BC1TL: 010001 01000 */
e135b889
DJ
1123 {
1124 int tf = itype_rt (inst) & 0x01;
1125 int cnum = itype_rt (inst) >> 2;
6d82d43b 1126 int fcrcs =
72a155b4
UW
1127 get_frame_register_signed (frame,
1128 mips_regnum (get_frame_arch (frame))->
0b1b3e42 1129 fp_control_status);
e135b889
DJ
1130 int cond = ((fcrcs >> 24) & 0x0e) | ((fcrcs >> 23) & 0x01);
1131
1132 if (((cond >> cnum) & 0x01) == tf)
1133 pc += mips32_relative_offset (inst) + 4;
1134 else
1135 pc += 8;
1136 }
c5aa993b 1137 else
025bb325 1138 pc += 4; /* Not a branch, next instruction is easy. */
c906108c
SS
1139 }
1140 else
025bb325 1141 { /* This gets way messy. */
c5aa993b 1142
025bb325
MS
1143 /* Further subdivide into SPECIAL, REGIMM and other. */
1144 switch (op = itype_op (inst) & 0x07) /* Extract bits 28,27,26. */
c906108c 1145 {
c5aa993b
JM
1146 case 0: /* SPECIAL */
1147 op = rtype_funct (inst);
1148 switch (op)
1149 {
1150 case 8: /* JR */
1151 case 9: /* JALR */
025bb325 1152 /* Set PC to that address. */
0b1b3e42 1153 pc = get_frame_register_signed (frame, rtype_rs (inst));
c5aa993b 1154 break;
e38d4e1a
DJ
1155 case 12: /* SYSCALL */
1156 {
1157 struct gdbarch_tdep *tdep;
1158
1159 tdep = gdbarch_tdep (get_frame_arch (frame));
1160 if (tdep->syscall_next_pc != NULL)
1161 pc = tdep->syscall_next_pc (frame);
1162 else
1163 pc += 4;
1164 }
1165 break;
c5aa993b
JM
1166 default:
1167 pc += 4;
1168 }
1169
6d82d43b 1170 break; /* end SPECIAL */
025bb325 1171 case 1: /* REGIMM */
c906108c 1172 {
e135b889
DJ
1173 op = itype_rt (inst); /* branch condition */
1174 switch (op)
c906108c 1175 {
c5aa993b 1176 case 0: /* BLTZ */
e135b889
DJ
1177 case 2: /* BLTZL */
1178 case 16: /* BLTZAL */
c5aa993b 1179 case 18: /* BLTZALL */
c906108c 1180 less_branch:
0b1b3e42 1181 if (get_frame_register_signed (frame, itype_rs (inst)) < 0)
c5aa993b
JM
1182 pc += mips32_relative_offset (inst) + 4;
1183 else
1184 pc += 8; /* after the delay slot */
1185 break;
e135b889 1186 case 1: /* BGEZ */
c5aa993b
JM
1187 case 3: /* BGEZL */
1188 case 17: /* BGEZAL */
1189 case 19: /* BGEZALL */
0b1b3e42 1190 if (get_frame_register_signed (frame, itype_rs (inst)) >= 0)
c5aa993b
JM
1191 pc += mips32_relative_offset (inst) + 4;
1192 else
1193 pc += 8; /* after the delay slot */
1194 break;
e135b889 1195 /* All of the other instructions in the REGIMM category */
c5aa993b
JM
1196 default:
1197 pc += 4;
c906108c
SS
1198 }
1199 }
6d82d43b 1200 break; /* end REGIMM */
c5aa993b
JM
1201 case 2: /* J */
1202 case 3: /* JAL */
1203 {
1204 unsigned long reg;
1205 reg = jtype_target (inst) << 2;
025bb325 1206 /* Upper four bits get never changed... */
5b652102 1207 pc = reg + ((pc + 4) & ~(CORE_ADDR) 0x0fffffff);
c906108c 1208 }
c5aa993b
JM
1209 break;
1210 /* FIXME case JALX : */
1211 {
1212 unsigned long reg;
1213 reg = jtype_target (inst) << 2;
025bb325 1214 pc = reg + ((pc + 4) & ~(CORE_ADDR) 0x0fffffff) + 1; /* yes, +1 */
c906108c
SS
1215 /* Add 1 to indicate 16 bit mode - Invert ISA mode */
1216 }
c5aa993b 1217 break; /* The new PC will be alternate mode */
e135b889 1218 case 4: /* BEQ, BEQL */
c5aa993b 1219 equal_branch:
0b1b3e42
UW
1220 if (get_frame_register_signed (frame, itype_rs (inst)) ==
1221 get_frame_register_signed (frame, itype_rt (inst)))
c5aa993b
JM
1222 pc += mips32_relative_offset (inst) + 4;
1223 else
1224 pc += 8;
1225 break;
e135b889 1226 case 5: /* BNE, BNEL */
c5aa993b 1227 neq_branch:
0b1b3e42
UW
1228 if (get_frame_register_signed (frame, itype_rs (inst)) !=
1229 get_frame_register_signed (frame, itype_rt (inst)))
c5aa993b
JM
1230 pc += mips32_relative_offset (inst) + 4;
1231 else
1232 pc += 8;
1233 break;
e135b889 1234 case 6: /* BLEZ, BLEZL */
0b1b3e42 1235 if (get_frame_register_signed (frame, itype_rs (inst)) <= 0)
c5aa993b
JM
1236 pc += mips32_relative_offset (inst) + 4;
1237 else
1238 pc += 8;
1239 break;
1240 case 7:
e135b889
DJ
1241 default:
1242 greater_branch: /* BGTZ, BGTZL */
0b1b3e42 1243 if (get_frame_register_signed (frame, itype_rs (inst)) > 0)
c5aa993b
JM
1244 pc += mips32_relative_offset (inst) + 4;
1245 else
1246 pc += 8;
1247 break;
c5aa993b
JM
1248 } /* switch */
1249 } /* else */
1250 return pc;
1251} /* mips32_next_pc */
c906108c
SS
1252
1253/* Decoding the next place to set a breakpoint is irregular for the
025bb325
MS
1254 mips 16 variant, but fortunately, there fewer instructions. We have
1255 to cope ith extensions for 16 bit instructions and a pair of actual
1256 32 bit instructions. We dont want to set a single step instruction
1257 on the extend instruction either. */
c906108c
SS
1258
1259/* Lots of mips16 instruction formats */
1260/* Predicting jumps requires itype,ritype,i8type
025bb325 1261 and their extensions extItype,extritype,extI8type. */
c906108c
SS
1262enum mips16_inst_fmts
1263{
c5aa993b
JM
1264 itype, /* 0 immediate 5,10 */
1265 ritype, /* 1 5,3,8 */
1266 rrtype, /* 2 5,3,3,5 */
1267 rritype, /* 3 5,3,3,5 */
1268 rrrtype, /* 4 5,3,3,3,2 */
1269 rriatype, /* 5 5,3,3,1,4 */
1270 shifttype, /* 6 5,3,3,3,2 */
1271 i8type, /* 7 5,3,8 */
1272 i8movtype, /* 8 5,3,3,5 */
1273 i8mov32rtype, /* 9 5,3,5,3 */
1274 i64type, /* 10 5,3,8 */
1275 ri64type, /* 11 5,3,3,5 */
1276 jalxtype, /* 12 5,1,5,5,16 - a 32 bit instruction */
1277 exiItype, /* 13 5,6,5,5,1,1,1,1,1,1,5 */
1278 extRitype, /* 14 5,6,5,5,3,1,1,1,5 */
1279 extRRItype, /* 15 5,5,5,5,3,3,5 */
1280 extRRIAtype, /* 16 5,7,4,5,3,3,1,4 */
1281 EXTshifttype, /* 17 5,5,1,1,1,1,1,1,5,3,3,1,1,1,2 */
1282 extI8type, /* 18 5,6,5,5,3,1,1,1,5 */
1283 extI64type, /* 19 5,6,5,5,3,1,1,1,5 */
1284 extRi64type, /* 20 5,6,5,5,3,3,5 */
1285 extshift64type /* 21 5,5,1,1,1,1,1,1,5,1,1,1,3,5 */
1286};
12f02c2a 1287/* I am heaping all the fields of the formats into one structure and
025bb325 1288 then, only the fields which are involved in instruction extension. */
c906108c 1289struct upk_mips16
6d82d43b
AC
1290{
1291 CORE_ADDR offset;
025bb325 1292 unsigned int regx; /* Function in i8 type. */
6d82d43b
AC
1293 unsigned int regy;
1294};
c906108c
SS
1295
1296
12f02c2a 1297/* The EXT-I, EXT-ri nad EXT-I8 instructions all have the same format
c68cf8ad 1298 for the bits which make up the immediate extension. */
c906108c 1299
12f02c2a
AC
1300static CORE_ADDR
1301extended_offset (unsigned int extension)
c906108c 1302{
12f02c2a 1303 CORE_ADDR value;
c5aa993b
JM
1304 value = (extension >> 21) & 0x3f; /* * extract 15:11 */
1305 value = value << 6;
025bb325 1306 value |= (extension >> 16) & 0x1f; /* extract 10:5 */
c5aa993b
JM
1307 value = value << 5;
1308 value |= extension & 0x01f; /* extract 4:0 */
1309 return value;
c906108c
SS
1310}
1311
1312/* Only call this function if you know that this is an extendable
bcf1ea1e
MR
1313 instruction. It won't malfunction, but why make excess remote memory
1314 references? If the immediate operands get sign extended or something,
1315 do it after the extension is performed. */
c906108c 1316/* FIXME: Every one of these cases needs to worry about sign extension
bcf1ea1e 1317 when the offset is to be used in relative addressing. */
c906108c 1318
12f02c2a 1319static unsigned int
e17a4113 1320fetch_mips_16 (struct gdbarch *gdbarch, CORE_ADDR pc)
c906108c 1321{
e17a4113 1322 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
47a35522 1323 gdb_byte buf[8];
025bb325 1324 pc &= 0xfffffffe; /* Clear the low order bit. */
c5aa993b 1325 target_read_memory (pc, buf, 2);
e17a4113 1326 return extract_unsigned_integer (buf, 2, byte_order);
c906108c
SS
1327}
1328
1329static void
e17a4113 1330unpack_mips16 (struct gdbarch *gdbarch, CORE_ADDR pc,
12f02c2a
AC
1331 unsigned int extension,
1332 unsigned int inst,
6d82d43b 1333 enum mips16_inst_fmts insn_format, struct upk_mips16 *upk)
c906108c 1334{
12f02c2a
AC
1335 CORE_ADDR offset;
1336 int regx;
1337 int regy;
1338 switch (insn_format)
c906108c 1339 {
c5aa993b 1340 case itype:
c906108c 1341 {
12f02c2a
AC
1342 CORE_ADDR value;
1343 if (extension)
c5aa993b
JM
1344 {
1345 value = extended_offset (extension);
1346 value = value << 11; /* rom for the original value */
6d82d43b 1347 value |= inst & 0x7ff; /* eleven bits from instruction */
c906108c
SS
1348 }
1349 else
c5aa993b 1350 {
12f02c2a 1351 value = inst & 0x7ff;
025bb325 1352 /* FIXME : Consider sign extension. */
c906108c 1353 }
12f02c2a
AC
1354 offset = value;
1355 regx = -1;
1356 regy = -1;
c906108c 1357 }
c5aa993b
JM
1358 break;
1359 case ritype:
1360 case i8type:
025bb325 1361 { /* A register identifier and an offset. */
c906108c 1362 /* Most of the fields are the same as I type but the
025bb325 1363 immediate value is of a different length. */
12f02c2a
AC
1364 CORE_ADDR value;
1365 if (extension)
c906108c 1366 {
c5aa993b 1367 value = extended_offset (extension);
025bb325 1368 value = value << 8; /* from the original instruction */
12f02c2a
AC
1369 value |= inst & 0xff; /* eleven bits from instruction */
1370 regx = (extension >> 8) & 0x07; /* or i8 funct */
025bb325 1371 if (value & 0x4000) /* Test the sign bit, bit 26. */
c5aa993b 1372 {
025bb325 1373 value &= ~0x3fff; /* Remove the sign bit. */
c5aa993b 1374 value = -value;
c906108c
SS
1375 }
1376 }
c5aa993b
JM
1377 else
1378 {
12f02c2a
AC
1379 value = inst & 0xff; /* 8 bits */
1380 regx = (inst >> 8) & 0x07; /* or i8 funct */
025bb325
MS
1381 /* FIXME: Do sign extension, this format needs it. */
1382 if (value & 0x80) /* THIS CONFUSES ME. */
c5aa993b 1383 {
025bb325 1384 value &= 0xef; /* Remove the sign bit. */
c5aa993b
JM
1385 value = -value;
1386 }
c5aa993b 1387 }
12f02c2a
AC
1388 offset = value;
1389 regy = -1;
c5aa993b 1390 break;
c906108c 1391 }
c5aa993b 1392 case jalxtype:
c906108c 1393 {
c5aa993b 1394 unsigned long value;
12f02c2a
AC
1395 unsigned int nexthalf;
1396 value = ((inst & 0x1f) << 5) | ((inst >> 5) & 0x1f);
c5aa993b 1397 value = value << 16;
025bb325
MS
1398 nexthalf = mips_fetch_instruction (gdbarch, pc + 2); /* low bit
1399 still set. */
c5aa993b 1400 value |= nexthalf;
12f02c2a
AC
1401 offset = value;
1402 regx = -1;
1403 regy = -1;
c5aa993b 1404 break;
c906108c
SS
1405 }
1406 default:
e2e0b3e5 1407 internal_error (__FILE__, __LINE__, _("bad switch"));
c906108c 1408 }
12f02c2a
AC
1409 upk->offset = offset;
1410 upk->regx = regx;
1411 upk->regy = regy;
c906108c
SS
1412}
1413
1414
c5aa993b
JM
1415static CORE_ADDR
1416add_offset_16 (CORE_ADDR pc, int offset)
c906108c 1417{
5b652102 1418 return ((offset << 2) | ((pc + 2) & (~(CORE_ADDR) 0x0fffffff)));
c906108c
SS
1419}
1420
12f02c2a 1421static CORE_ADDR
0b1b3e42 1422extended_mips16_next_pc (struct frame_info *frame, CORE_ADDR pc,
6d82d43b 1423 unsigned int extension, unsigned int insn)
c906108c 1424{
e17a4113 1425 struct gdbarch *gdbarch = get_frame_arch (frame);
12f02c2a
AC
1426 int op = (insn >> 11);
1427 switch (op)
c906108c 1428 {
6d82d43b 1429 case 2: /* Branch */
12f02c2a
AC
1430 {
1431 CORE_ADDR offset;
1432 struct upk_mips16 upk;
e17a4113 1433 unpack_mips16 (gdbarch, pc, extension, insn, itype, &upk);
12f02c2a
AC
1434 offset = upk.offset;
1435 if (offset & 0x800)
1436 {
1437 offset &= 0xeff;
1438 offset = -offset;
1439 }
1440 pc += (offset << 1) + 2;
1441 break;
1442 }
025bb325
MS
1443 case 3: /* JAL , JALX - Watch out, these are 32 bit
1444 instructions. */
12f02c2a
AC
1445 {
1446 struct upk_mips16 upk;
e17a4113 1447 unpack_mips16 (gdbarch, pc, extension, insn, jalxtype, &upk);
12f02c2a
AC
1448 pc = add_offset_16 (pc, upk.offset);
1449 if ((insn >> 10) & 0x01) /* Exchange mode */
025bb325 1450 pc = pc & ~0x01; /* Clear low bit, indicate 32 bit mode. */
12f02c2a
AC
1451 else
1452 pc |= 0x01;
1453 break;
1454 }
6d82d43b 1455 case 4: /* beqz */
12f02c2a
AC
1456 {
1457 struct upk_mips16 upk;
1458 int reg;
e17a4113 1459 unpack_mips16 (gdbarch, pc, extension, insn, ritype, &upk);
0b1b3e42 1460 reg = get_frame_register_signed (frame, upk.regx);
12f02c2a
AC
1461 if (reg == 0)
1462 pc += (upk.offset << 1) + 2;
1463 else
1464 pc += 2;
1465 break;
1466 }
6d82d43b 1467 case 5: /* bnez */
12f02c2a
AC
1468 {
1469 struct upk_mips16 upk;
1470 int reg;
e17a4113 1471 unpack_mips16 (gdbarch, pc, extension, insn, ritype, &upk);
0b1b3e42 1472 reg = get_frame_register_signed (frame, upk.regx);
12f02c2a
AC
1473 if (reg != 0)
1474 pc += (upk.offset << 1) + 2;
1475 else
1476 pc += 2;
1477 break;
1478 }
6d82d43b 1479 case 12: /* I8 Formats btez btnez */
12f02c2a
AC
1480 {
1481 struct upk_mips16 upk;
1482 int reg;
e17a4113 1483 unpack_mips16 (gdbarch, pc, extension, insn, i8type, &upk);
12f02c2a 1484 /* upk.regx contains the opcode */
0b1b3e42 1485 reg = get_frame_register_signed (frame, 24); /* Test register is 24 */
12f02c2a
AC
1486 if (((upk.regx == 0) && (reg == 0)) /* BTEZ */
1487 || ((upk.regx == 1) && (reg != 0))) /* BTNEZ */
1488 /* pc = add_offset_16(pc,upk.offset) ; */
1489 pc += (upk.offset << 1) + 2;
1490 else
1491 pc += 2;
1492 break;
1493 }
6d82d43b 1494 case 29: /* RR Formats JR, JALR, JALR-RA */
12f02c2a
AC
1495 {
1496 struct upk_mips16 upk;
1497 /* upk.fmt = rrtype; */
1498 op = insn & 0x1f;
1499 if (op == 0)
c5aa993b 1500 {
12f02c2a
AC
1501 int reg;
1502 upk.regx = (insn >> 8) & 0x07;
1503 upk.regy = (insn >> 5) & 0x07;
1504 switch (upk.regy)
c5aa993b 1505 {
12f02c2a
AC
1506 case 0:
1507 reg = upk.regx;
1508 break;
1509 case 1:
1510 reg = 31;
025bb325 1511 break; /* Function return instruction. */
12f02c2a
AC
1512 case 2:
1513 reg = upk.regx;
1514 break;
1515 default:
1516 reg = 31;
6d82d43b 1517 break; /* BOGUS Guess */
c906108c 1518 }
0b1b3e42 1519 pc = get_frame_register_signed (frame, reg);
c906108c 1520 }
12f02c2a 1521 else
c5aa993b 1522 pc += 2;
12f02c2a
AC
1523 break;
1524 }
1525 case 30:
1526 /* This is an instruction extension. Fetch the real instruction
1527 (which follows the extension) and decode things based on
025bb325 1528 that. */
12f02c2a
AC
1529 {
1530 pc += 2;
e17a4113
UW
1531 pc = extended_mips16_next_pc (frame, pc, insn,
1532 fetch_mips_16 (gdbarch, pc));
12f02c2a
AC
1533 break;
1534 }
1535 default:
1536 {
1537 pc += 2;
1538 break;
1539 }
c906108c 1540 }
c5aa993b 1541 return pc;
12f02c2a 1542}
c906108c 1543
5a89d8aa 1544static CORE_ADDR
0b1b3e42 1545mips16_next_pc (struct frame_info *frame, CORE_ADDR pc)
12f02c2a 1546{
e17a4113
UW
1547 struct gdbarch *gdbarch = get_frame_arch (frame);
1548 unsigned int insn = fetch_mips_16 (gdbarch, pc);
0b1b3e42 1549 return extended_mips16_next_pc (frame, pc, 0, insn);
12f02c2a
AC
1550}
1551
1552/* The mips_next_pc function supports single_step when the remote
7e73cedf 1553 target monitor or stub is not developed enough to do a single_step.
12f02c2a 1554 It works by decoding the current instruction and predicting where a
025bb325 1555 branch will go. This isnt hard because all the data is available.
ce1f96de 1556 The MIPS32 and MIPS16 variants are quite different. */
ad527d2e 1557static CORE_ADDR
0b1b3e42 1558mips_next_pc (struct frame_info *frame, CORE_ADDR pc)
c906108c 1559{
ce1f96de 1560 if (is_mips16_addr (pc))
0b1b3e42 1561 return mips16_next_pc (frame, pc);
c5aa993b 1562 else
0b1b3e42 1563 return mips32_next_pc (frame, pc);
12f02c2a 1564}
c906108c 1565
edfae063
AC
1566struct mips_frame_cache
1567{
1568 CORE_ADDR base;
1569 struct trad_frame_saved_reg *saved_regs;
1570};
1571
29639122
JB
1572/* Set a register's saved stack address in temp_saved_regs. If an
1573 address has already been set for this register, do nothing; this
1574 way we will only recognize the first save of a given register in a
1575 function prologue.
eec63939 1576
f57d151a
UW
1577 For simplicity, save the address in both [0 .. gdbarch_num_regs) and
1578 [gdbarch_num_regs .. 2*gdbarch_num_regs).
1579 Strictly speaking, only the second range is used as it is only second
1580 range (the ABI instead of ISA registers) that comes into play when finding
1581 saved registers in a frame. */
eec63939
AC
1582
1583static void
74ed0bb4
MD
1584set_reg_offset (struct gdbarch *gdbarch, struct mips_frame_cache *this_cache,
1585 int regnum, CORE_ADDR offset)
eec63939 1586{
29639122
JB
1587 if (this_cache != NULL
1588 && this_cache->saved_regs[regnum].addr == -1)
1589 {
74ed0bb4
MD
1590 this_cache->saved_regs[regnum + 0 * gdbarch_num_regs (gdbarch)].addr
1591 = offset;
1592 this_cache->saved_regs[regnum + 1 * gdbarch_num_regs (gdbarch)].addr
1593 = offset;
29639122 1594 }
eec63939
AC
1595}
1596
eec63939 1597
29639122
JB
1598/* Fetch the immediate value from a MIPS16 instruction.
1599 If the previous instruction was an EXTEND, use it to extend
1600 the upper bits of the immediate value. This is a helper function
1601 for mips16_scan_prologue. */
eec63939 1602
29639122
JB
1603static int
1604mips16_get_imm (unsigned short prev_inst, /* previous instruction */
1605 unsigned short inst, /* current instruction */
1606 int nbits, /* number of bits in imm field */
1607 int scale, /* scale factor to be applied to imm */
025bb325 1608 int is_signed) /* is the imm field signed? */
eec63939 1609{
29639122 1610 int offset;
eec63939 1611
29639122
JB
1612 if ((prev_inst & 0xf800) == 0xf000) /* prev instruction was EXTEND? */
1613 {
1614 offset = ((prev_inst & 0x1f) << 11) | (prev_inst & 0x7e0);
1615 if (offset & 0x8000) /* check for negative extend */
1616 offset = 0 - (0x10000 - (offset & 0xffff));
1617 return offset | (inst & 0x1f);
1618 }
eec63939 1619 else
29639122
JB
1620 {
1621 int max_imm = 1 << nbits;
1622 int mask = max_imm - 1;
1623 int sign_bit = max_imm >> 1;
45c9dd44 1624
29639122
JB
1625 offset = inst & mask;
1626 if (is_signed && (offset & sign_bit))
1627 offset = 0 - (max_imm - offset);
1628 return offset * scale;
1629 }
1630}
eec63939 1631
65596487 1632
29639122
JB
1633/* Analyze the function prologue from START_PC to LIMIT_PC. Builds
1634 the associated FRAME_CACHE if not null.
1635 Return the address of the first instruction past the prologue. */
eec63939 1636
29639122 1637static CORE_ADDR
e17a4113
UW
1638mips16_scan_prologue (struct gdbarch *gdbarch,
1639 CORE_ADDR start_pc, CORE_ADDR limit_pc,
b8a22b94 1640 struct frame_info *this_frame,
29639122
JB
1641 struct mips_frame_cache *this_cache)
1642{
1643 CORE_ADDR cur_pc;
025bb325 1644 CORE_ADDR frame_addr = 0; /* Value of $r17, used as frame pointer. */
29639122
JB
1645 CORE_ADDR sp;
1646 long frame_offset = 0; /* Size of stack frame. */
1647 long frame_adjust = 0; /* Offset of FP from SP. */
1648 int frame_reg = MIPS_SP_REGNUM;
025bb325 1649 unsigned short prev_inst = 0; /* saved copy of previous instruction. */
29639122
JB
1650 unsigned inst = 0; /* current instruction */
1651 unsigned entry_inst = 0; /* the entry instruction */
2207132d 1652 unsigned save_inst = 0; /* the save instruction */
29639122 1653 int reg, offset;
a343eb3c 1654
29639122
JB
1655 int extend_bytes = 0;
1656 int prev_extend_bytes;
1657 CORE_ADDR end_prologue_addr = 0;
a343eb3c 1658
29639122 1659 /* Can be called when there's no process, and hence when there's no
b8a22b94
DJ
1660 THIS_FRAME. */
1661 if (this_frame != NULL)
1662 sp = get_frame_register_signed (this_frame,
1663 gdbarch_num_regs (gdbarch)
1664 + MIPS_SP_REGNUM);
29639122
JB
1665 else
1666 sp = 0;
eec63939 1667
29639122
JB
1668 if (limit_pc > start_pc + 200)
1669 limit_pc = start_pc + 200;
eec63939 1670
95ac2dcf 1671 for (cur_pc = start_pc; cur_pc < limit_pc; cur_pc += MIPS_INSN16_SIZE)
29639122
JB
1672 {
1673 /* Save the previous instruction. If it's an EXTEND, we'll extract
1674 the immediate offset extension from it in mips16_get_imm. */
1675 prev_inst = inst;
eec63939 1676
025bb325 1677 /* Fetch and decode the instruction. */
e17a4113 1678 inst = (unsigned short) mips_fetch_instruction (gdbarch, cur_pc);
eec63939 1679
29639122
JB
1680 /* Normally we ignore extend instructions. However, if it is
1681 not followed by a valid prologue instruction, then this
1682 instruction is not part of the prologue either. We must
1683 remember in this case to adjust the end_prologue_addr back
1684 over the extend. */
1685 if ((inst & 0xf800) == 0xf000) /* extend */
1686 {
95ac2dcf 1687 extend_bytes = MIPS_INSN16_SIZE;
29639122
JB
1688 continue;
1689 }
eec63939 1690
29639122
JB
1691 prev_extend_bytes = extend_bytes;
1692 extend_bytes = 0;
eec63939 1693
29639122
JB
1694 if ((inst & 0xff00) == 0x6300 /* addiu sp */
1695 || (inst & 0xff00) == 0xfb00) /* daddiu sp */
1696 {
1697 offset = mips16_get_imm (prev_inst, inst, 8, 8, 1);
025bb325 1698 if (offset < 0) /* Negative stack adjustment? */
29639122
JB
1699 frame_offset -= offset;
1700 else
1701 /* Exit loop if a positive stack adjustment is found, which
1702 usually means that the stack cleanup code in the function
1703 epilogue is reached. */
1704 break;
1705 }
1706 else if ((inst & 0xf800) == 0xd000) /* sw reg,n($sp) */
1707 {
1708 offset = mips16_get_imm (prev_inst, inst, 8, 4, 0);
1709 reg = mips16_to_32_reg[(inst & 0x700) >> 8];
74ed0bb4 1710 set_reg_offset (gdbarch, this_cache, reg, sp + offset);
29639122
JB
1711 }
1712 else if ((inst & 0xff00) == 0xf900) /* sd reg,n($sp) */
1713 {
1714 offset = mips16_get_imm (prev_inst, inst, 5, 8, 0);
1715 reg = mips16_to_32_reg[(inst & 0xe0) >> 5];
74ed0bb4 1716 set_reg_offset (gdbarch, this_cache, reg, sp + offset);
29639122
JB
1717 }
1718 else if ((inst & 0xff00) == 0x6200) /* sw $ra,n($sp) */
1719 {
1720 offset = mips16_get_imm (prev_inst, inst, 8, 4, 0);
74ed0bb4 1721 set_reg_offset (gdbarch, this_cache, MIPS_RA_REGNUM, sp + offset);
29639122
JB
1722 }
1723 else if ((inst & 0xff00) == 0xfa00) /* sd $ra,n($sp) */
1724 {
1725 offset = mips16_get_imm (prev_inst, inst, 8, 8, 0);
74ed0bb4 1726 set_reg_offset (gdbarch, this_cache, MIPS_RA_REGNUM, sp + offset);
29639122
JB
1727 }
1728 else if (inst == 0x673d) /* move $s1, $sp */
1729 {
1730 frame_addr = sp;
1731 frame_reg = 17;
1732 }
1733 else if ((inst & 0xff00) == 0x0100) /* addiu $s1,sp,n */
1734 {
1735 offset = mips16_get_imm (prev_inst, inst, 8, 4, 0);
1736 frame_addr = sp + offset;
1737 frame_reg = 17;
1738 frame_adjust = offset;
1739 }
1740 else if ((inst & 0xFF00) == 0xd900) /* sw reg,offset($s1) */
1741 {
1742 offset = mips16_get_imm (prev_inst, inst, 5, 4, 0);
1743 reg = mips16_to_32_reg[(inst & 0xe0) >> 5];
74ed0bb4 1744 set_reg_offset (gdbarch, this_cache, reg, frame_addr + offset);
29639122
JB
1745 }
1746 else if ((inst & 0xFF00) == 0x7900) /* sd reg,offset($s1) */
1747 {
1748 offset = mips16_get_imm (prev_inst, inst, 5, 8, 0);
1749 reg = mips16_to_32_reg[(inst & 0xe0) >> 5];
74ed0bb4 1750 set_reg_offset (gdbarch, this_cache, reg, frame_addr + offset);
29639122
JB
1751 }
1752 else if ((inst & 0xf81f) == 0xe809
1753 && (inst & 0x700) != 0x700) /* entry */
025bb325 1754 entry_inst = inst; /* Save for later processing. */
2207132d
MR
1755 else if ((inst & 0xff80) == 0x6480) /* save */
1756 {
025bb325 1757 save_inst = inst; /* Save for later processing. */
2207132d
MR
1758 if (prev_extend_bytes) /* extend */
1759 save_inst |= prev_inst << 16;
1760 }
29639122 1761 else if ((inst & 0xf800) == 0x1800) /* jal(x) */
95ac2dcf 1762 cur_pc += MIPS_INSN16_SIZE; /* 32-bit instruction */
29639122
JB
1763 else if ((inst & 0xff1c) == 0x6704) /* move reg,$a0-$a3 */
1764 {
1765 /* This instruction is part of the prologue, but we don't
1766 need to do anything special to handle it. */
1767 }
1768 else
1769 {
1770 /* This instruction is not an instruction typically found
1771 in a prologue, so we must have reached the end of the
1772 prologue. */
1773 if (end_prologue_addr == 0)
1774 end_prologue_addr = cur_pc - prev_extend_bytes;
1775 }
1776 }
eec63939 1777
29639122
JB
1778 /* The entry instruction is typically the first instruction in a function,
1779 and it stores registers at offsets relative to the value of the old SP
1780 (before the prologue). But the value of the sp parameter to this
1781 function is the new SP (after the prologue has been executed). So we
1782 can't calculate those offsets until we've seen the entire prologue,
025bb325 1783 and can calculate what the old SP must have been. */
29639122
JB
1784 if (entry_inst != 0)
1785 {
1786 int areg_count = (entry_inst >> 8) & 7;
1787 int sreg_count = (entry_inst >> 6) & 3;
eec63939 1788
29639122
JB
1789 /* The entry instruction always subtracts 32 from the SP. */
1790 frame_offset += 32;
1791
1792 /* Now we can calculate what the SP must have been at the
1793 start of the function prologue. */
1794 sp += frame_offset;
1795
1796 /* Check if a0-a3 were saved in the caller's argument save area. */
1797 for (reg = 4, offset = 0; reg < areg_count + 4; reg++)
1798 {
74ed0bb4 1799 set_reg_offset (gdbarch, this_cache, reg, sp + offset);
72a155b4 1800 offset += mips_abi_regsize (gdbarch);
29639122
JB
1801 }
1802
1803 /* Check if the ra register was pushed on the stack. */
1804 offset = -4;
1805 if (entry_inst & 0x20)
1806 {
74ed0bb4 1807 set_reg_offset (gdbarch, this_cache, MIPS_RA_REGNUM, sp + offset);
72a155b4 1808 offset -= mips_abi_regsize (gdbarch);
29639122
JB
1809 }
1810
1811 /* Check if the s0 and s1 registers were pushed on the stack. */
1812 for (reg = 16; reg < sreg_count + 16; reg++)
1813 {
74ed0bb4 1814 set_reg_offset (gdbarch, this_cache, reg, sp + offset);
72a155b4 1815 offset -= mips_abi_regsize (gdbarch);
29639122
JB
1816 }
1817 }
1818
2207132d
MR
1819 /* The SAVE instruction is similar to ENTRY, except that defined by the
1820 MIPS16e ASE of the MIPS Architecture. Unlike with ENTRY though, the
1821 size of the frame is specified as an immediate field of instruction
1822 and an extended variation exists which lets additional registers and
1823 frame space to be specified. The instruction always treats registers
1824 as 32-bit so its usefulness for 64-bit ABIs is questionable. */
1825 if (save_inst != 0 && mips_abi_regsize (gdbarch) == 4)
1826 {
1827 static int args_table[16] = {
1828 0, 0, 0, 0, 1, 1, 1, 1,
1829 2, 2, 2, 0, 3, 3, 4, -1,
1830 };
1831 static int astatic_table[16] = {
1832 0, 1, 2, 3, 0, 1, 2, 3,
1833 0, 1, 2, 4, 0, 1, 0, -1,
1834 };
1835 int aregs = (save_inst >> 16) & 0xf;
1836 int xsregs = (save_inst >> 24) & 0x7;
1837 int args = args_table[aregs];
1838 int astatic = astatic_table[aregs];
1839 long frame_size;
1840
1841 if (args < 0)
1842 {
1843 warning (_("Invalid number of argument registers encoded in SAVE."));
1844 args = 0;
1845 }
1846 if (astatic < 0)
1847 {
1848 warning (_("Invalid number of static registers encoded in SAVE."));
1849 astatic = 0;
1850 }
1851
1852 /* For standard SAVE the frame size of 0 means 128. */
1853 frame_size = ((save_inst >> 16) & 0xf0) | (save_inst & 0xf);
1854 if (frame_size == 0 && (save_inst >> 16) == 0)
1855 frame_size = 16;
1856 frame_size *= 8;
1857 frame_offset += frame_size;
1858
1859 /* Now we can calculate what the SP must have been at the
1860 start of the function prologue. */
1861 sp += frame_offset;
1862
1863 /* Check if A0-A3 were saved in the caller's argument save area. */
1864 for (reg = MIPS_A0_REGNUM, offset = 0; reg < args + 4; reg++)
1865 {
74ed0bb4 1866 set_reg_offset (gdbarch, this_cache, reg, sp + offset);
2207132d
MR
1867 offset += mips_abi_regsize (gdbarch);
1868 }
1869
1870 offset = -4;
1871
1872 /* Check if the RA register was pushed on the stack. */
1873 if (save_inst & 0x40)
1874 {
74ed0bb4 1875 set_reg_offset (gdbarch, this_cache, MIPS_RA_REGNUM, sp + offset);
2207132d
MR
1876 offset -= mips_abi_regsize (gdbarch);
1877 }
1878
1879 /* Check if the S8 register was pushed on the stack. */
1880 if (xsregs > 6)
1881 {
74ed0bb4 1882 set_reg_offset (gdbarch, this_cache, 30, sp + offset);
2207132d
MR
1883 offset -= mips_abi_regsize (gdbarch);
1884 xsregs--;
1885 }
1886 /* Check if S2-S7 were pushed on the stack. */
1887 for (reg = 18 + xsregs - 1; reg > 18 - 1; reg--)
1888 {
74ed0bb4 1889 set_reg_offset (gdbarch, this_cache, reg, sp + offset);
2207132d
MR
1890 offset -= mips_abi_regsize (gdbarch);
1891 }
1892
1893 /* Check if the S1 register was pushed on the stack. */
1894 if (save_inst & 0x10)
1895 {
74ed0bb4 1896 set_reg_offset (gdbarch, this_cache, 17, sp + offset);
2207132d
MR
1897 offset -= mips_abi_regsize (gdbarch);
1898 }
1899 /* Check if the S0 register was pushed on the stack. */
1900 if (save_inst & 0x20)
1901 {
74ed0bb4 1902 set_reg_offset (gdbarch, this_cache, 16, sp + offset);
2207132d
MR
1903 offset -= mips_abi_regsize (gdbarch);
1904 }
1905
1906 /* Check if A0-A3 were pushed on the stack. */
1907 for (reg = MIPS_A0_REGNUM + 3; reg > MIPS_A0_REGNUM + 3 - astatic; reg--)
1908 {
74ed0bb4 1909 set_reg_offset (gdbarch, this_cache, reg, sp + offset);
2207132d
MR
1910 offset -= mips_abi_regsize (gdbarch);
1911 }
1912 }
1913
29639122
JB
1914 if (this_cache != NULL)
1915 {
1916 this_cache->base =
b8a22b94
DJ
1917 (get_frame_register_signed (this_frame,
1918 gdbarch_num_regs (gdbarch) + frame_reg)
29639122
JB
1919 + frame_offset - frame_adjust);
1920 /* FIXME: brobecker/2004-10-10: Just as in the mips32 case, we should
025bb325 1921 be able to get rid of the assignment below, evetually. But it's
29639122 1922 still needed for now. */
72a155b4
UW
1923 this_cache->saved_regs[gdbarch_num_regs (gdbarch)
1924 + mips_regnum (gdbarch)->pc]
1925 = this_cache->saved_regs[gdbarch_num_regs (gdbarch) + MIPS_RA_REGNUM];
29639122
JB
1926 }
1927
1928 /* If we didn't reach the end of the prologue when scanning the function
1929 instructions, then set end_prologue_addr to the address of the
1930 instruction immediately after the last one we scanned. */
1931 if (end_prologue_addr == 0)
1932 end_prologue_addr = cur_pc;
1933
1934 return end_prologue_addr;
eec63939
AC
1935}
1936
29639122
JB
1937/* Heuristic unwinder for 16-bit MIPS instruction set (aka MIPS16).
1938 Procedures that use the 32-bit instruction set are handled by the
1939 mips_insn32 unwinder. */
1940
1941static struct mips_frame_cache *
b8a22b94 1942mips_insn16_frame_cache (struct frame_info *this_frame, void **this_cache)
eec63939 1943{
e17a4113 1944 struct gdbarch *gdbarch = get_frame_arch (this_frame);
29639122 1945 struct mips_frame_cache *cache;
eec63939
AC
1946
1947 if ((*this_cache) != NULL)
1948 return (*this_cache);
29639122
JB
1949 cache = FRAME_OBSTACK_ZALLOC (struct mips_frame_cache);
1950 (*this_cache) = cache;
b8a22b94 1951 cache->saved_regs = trad_frame_alloc_saved_regs (this_frame);
eec63939 1952
29639122
JB
1953 /* Analyze the function prologue. */
1954 {
b8a22b94 1955 const CORE_ADDR pc = get_frame_address_in_block (this_frame);
29639122 1956 CORE_ADDR start_addr;
eec63939 1957
29639122
JB
1958 find_pc_partial_function (pc, NULL, &start_addr, NULL);
1959 if (start_addr == 0)
e17a4113 1960 start_addr = heuristic_proc_start (gdbarch, pc);
29639122
JB
1961 /* We can't analyze the prologue if we couldn't find the begining
1962 of the function. */
1963 if (start_addr == 0)
1964 return cache;
eec63939 1965
e17a4113 1966 mips16_scan_prologue (gdbarch, start_addr, pc, this_frame, *this_cache);
29639122
JB
1967 }
1968
3e8c568d 1969 /* gdbarch_sp_regnum contains the value and not the address. */
72a155b4 1970 trad_frame_set_value (cache->saved_regs,
e17a4113 1971 gdbarch_num_regs (gdbarch) + MIPS_SP_REGNUM,
72a155b4 1972 cache->base);
eec63939 1973
29639122 1974 return (*this_cache);
eec63939
AC
1975}
1976
1977static void
b8a22b94 1978mips_insn16_frame_this_id (struct frame_info *this_frame, void **this_cache,
29639122 1979 struct frame_id *this_id)
eec63939 1980{
b8a22b94 1981 struct mips_frame_cache *info = mips_insn16_frame_cache (this_frame,
29639122 1982 this_cache);
21327321
DJ
1983 /* This marks the outermost frame. */
1984 if (info->base == 0)
1985 return;
b8a22b94 1986 (*this_id) = frame_id_build (info->base, get_frame_func (this_frame));
eec63939
AC
1987}
1988
b8a22b94
DJ
1989static struct value *
1990mips_insn16_frame_prev_register (struct frame_info *this_frame,
1991 void **this_cache, int regnum)
eec63939 1992{
b8a22b94 1993 struct mips_frame_cache *info = mips_insn16_frame_cache (this_frame,
29639122 1994 this_cache);
b8a22b94
DJ
1995 return trad_frame_get_prev_register (this_frame, info->saved_regs, regnum);
1996}
1997
1998static int
1999mips_insn16_frame_sniffer (const struct frame_unwind *self,
2000 struct frame_info *this_frame, void **this_cache)
2001{
2002 CORE_ADDR pc = get_frame_pc (this_frame);
2003 if (mips_pc_is_mips16 (pc))
2004 return 1;
2005 return 0;
eec63939
AC
2006}
2007
29639122 2008static const struct frame_unwind mips_insn16_frame_unwind =
eec63939
AC
2009{
2010 NORMAL_FRAME,
29639122 2011 mips_insn16_frame_this_id,
b8a22b94
DJ
2012 mips_insn16_frame_prev_register,
2013 NULL,
2014 mips_insn16_frame_sniffer
eec63939
AC
2015};
2016
eec63939 2017static CORE_ADDR
b8a22b94 2018mips_insn16_frame_base_address (struct frame_info *this_frame,
29639122 2019 void **this_cache)
eec63939 2020{
b8a22b94 2021 struct mips_frame_cache *info = mips_insn16_frame_cache (this_frame,
29639122
JB
2022 this_cache);
2023 return info->base;
eec63939
AC
2024}
2025
29639122 2026static const struct frame_base mips_insn16_frame_base =
eec63939 2027{
29639122
JB
2028 &mips_insn16_frame_unwind,
2029 mips_insn16_frame_base_address,
2030 mips_insn16_frame_base_address,
2031 mips_insn16_frame_base_address
eec63939
AC
2032};
2033
2034static const struct frame_base *
b8a22b94 2035mips_insn16_frame_base_sniffer (struct frame_info *this_frame)
eec63939 2036{
b8a22b94
DJ
2037 CORE_ADDR pc = get_frame_pc (this_frame);
2038 if (mips_pc_is_mips16 (pc))
29639122 2039 return &mips_insn16_frame_base;
eec63939
AC
2040 else
2041 return NULL;
edfae063
AC
2042}
2043
29639122
JB
2044/* Mark all the registers as unset in the saved_regs array
2045 of THIS_CACHE. Do nothing if THIS_CACHE is null. */
2046
74ed0bb4
MD
2047static void
2048reset_saved_regs (struct gdbarch *gdbarch, struct mips_frame_cache *this_cache)
c906108c 2049{
29639122
JB
2050 if (this_cache == NULL || this_cache->saved_regs == NULL)
2051 return;
2052
2053 {
74ed0bb4 2054 const int num_regs = gdbarch_num_regs (gdbarch);
29639122 2055 int i;
64159455 2056
29639122
JB
2057 for (i = 0; i < num_regs; i++)
2058 {
2059 this_cache->saved_regs[i].addr = -1;
2060 }
2061 }
c906108c
SS
2062}
2063
025bb325 2064/* Analyze the function prologue from START_PC to LIMIT_PC. Builds
29639122
JB
2065 the associated FRAME_CACHE if not null.
2066 Return the address of the first instruction past the prologue. */
c906108c 2067
875e1767 2068static CORE_ADDR
e17a4113
UW
2069mips32_scan_prologue (struct gdbarch *gdbarch,
2070 CORE_ADDR start_pc, CORE_ADDR limit_pc,
b8a22b94 2071 struct frame_info *this_frame,
29639122 2072 struct mips_frame_cache *this_cache)
c906108c 2073{
29639122 2074 CORE_ADDR cur_pc;
025bb325
MS
2075 CORE_ADDR frame_addr = 0; /* Value of $r30. Used by gcc for
2076 frame-pointer. */
29639122
JB
2077 CORE_ADDR sp;
2078 long frame_offset;
2079 int frame_reg = MIPS_SP_REGNUM;
8fa9cfa1 2080
29639122
JB
2081 CORE_ADDR end_prologue_addr = 0;
2082 int seen_sp_adjust = 0;
2083 int load_immediate_bytes = 0;
db5f024e 2084 int in_delay_slot = 0;
7d1e6fb8 2085 int regsize_is_64_bits = (mips_abi_regsize (gdbarch) == 8);
8fa9cfa1 2086
29639122 2087 /* Can be called when there's no process, and hence when there's no
b8a22b94
DJ
2088 THIS_FRAME. */
2089 if (this_frame != NULL)
2090 sp = get_frame_register_signed (this_frame,
2091 gdbarch_num_regs (gdbarch)
2092 + MIPS_SP_REGNUM);
8fa9cfa1 2093 else
29639122 2094 sp = 0;
9022177c 2095
29639122
JB
2096 if (limit_pc > start_pc + 200)
2097 limit_pc = start_pc + 200;
9022177c 2098
29639122 2099restart:
9022177c 2100
29639122 2101 frame_offset = 0;
95ac2dcf 2102 for (cur_pc = start_pc; cur_pc < limit_pc; cur_pc += MIPS_INSN32_SIZE)
9022177c 2103 {
29639122
JB
2104 unsigned long inst, high_word, low_word;
2105 int reg;
9022177c 2106
025bb325 2107 /* Fetch the instruction. */
e17a4113 2108 inst = (unsigned long) mips_fetch_instruction (gdbarch, cur_pc);
9022177c 2109
29639122
JB
2110 /* Save some code by pre-extracting some useful fields. */
2111 high_word = (inst >> 16) & 0xffff;
2112 low_word = inst & 0xffff;
2113 reg = high_word & 0x1f;
fe29b929 2114
025bb325 2115 if (high_word == 0x27bd /* addiu $sp,$sp,-i */
29639122
JB
2116 || high_word == 0x23bd /* addi $sp,$sp,-i */
2117 || high_word == 0x67bd) /* daddiu $sp,$sp,-i */
2118 {
025bb325 2119 if (low_word & 0x8000) /* Negative stack adjustment? */
29639122
JB
2120 frame_offset += 0x10000 - low_word;
2121 else
2122 /* Exit loop if a positive stack adjustment is found, which
2123 usually means that the stack cleanup code in the function
2124 epilogue is reached. */
2125 break;
2126 seen_sp_adjust = 1;
2127 }
7d1e6fb8
KB
2128 else if (((high_word & 0xFFE0) == 0xafa0) /* sw reg,offset($sp) */
2129 && !regsize_is_64_bits)
29639122 2130 {
74ed0bb4 2131 set_reg_offset (gdbarch, this_cache, reg, sp + low_word);
29639122 2132 }
7d1e6fb8
KB
2133 else if (((high_word & 0xFFE0) == 0xffa0) /* sd reg,offset($sp) */
2134 && regsize_is_64_bits)
29639122
JB
2135 {
2136 /* Irix 6.2 N32 ABI uses sd instructions for saving $gp and $ra. */
74ed0bb4 2137 set_reg_offset (gdbarch, this_cache, reg, sp + low_word);
29639122
JB
2138 }
2139 else if (high_word == 0x27be) /* addiu $30,$sp,size */
2140 {
2141 /* Old gcc frame, r30 is virtual frame pointer. */
2142 if ((long) low_word != frame_offset)
2143 frame_addr = sp + low_word;
b8a22b94 2144 else if (this_frame && frame_reg == MIPS_SP_REGNUM)
29639122
JB
2145 {
2146 unsigned alloca_adjust;
a4b8ebc8 2147
29639122 2148 frame_reg = 30;
b8a22b94
DJ
2149 frame_addr = get_frame_register_signed
2150 (this_frame, gdbarch_num_regs (gdbarch) + 30);
d2ca4222 2151
29639122
JB
2152 alloca_adjust = (unsigned) (frame_addr - (sp + low_word));
2153 if (alloca_adjust > 0)
2154 {
025bb325 2155 /* FP > SP + frame_size. This may be because of
29639122
JB
2156 an alloca or somethings similar. Fix sp to
2157 "pre-alloca" value, and try again. */
2158 sp += alloca_adjust;
2159 /* Need to reset the status of all registers. Otherwise,
2160 we will hit a guard that prevents the new address
2161 for each register to be recomputed during the second
2162 pass. */
74ed0bb4 2163 reset_saved_regs (gdbarch, this_cache);
29639122
JB
2164 goto restart;
2165 }
2166 }
2167 }
2168 /* move $30,$sp. With different versions of gas this will be either
2169 `addu $30,$sp,$zero' or `or $30,$sp,$zero' or `daddu 30,sp,$0'.
2170 Accept any one of these. */
2171 else if (inst == 0x03A0F021 || inst == 0x03a0f025 || inst == 0x03a0f02d)
2172 {
2173 /* New gcc frame, virtual frame pointer is at r30 + frame_size. */
b8a22b94 2174 if (this_frame && frame_reg == MIPS_SP_REGNUM)
29639122
JB
2175 {
2176 unsigned alloca_adjust;
c906108c 2177
29639122 2178 frame_reg = 30;
b8a22b94
DJ
2179 frame_addr = get_frame_register_signed
2180 (this_frame, gdbarch_num_regs (gdbarch) + 30);
d2ca4222 2181
29639122
JB
2182 alloca_adjust = (unsigned) (frame_addr - sp);
2183 if (alloca_adjust > 0)
2184 {
025bb325 2185 /* FP > SP + frame_size. This may be because of
29639122
JB
2186 an alloca or somethings similar. Fix sp to
2187 "pre-alloca" value, and try again. */
2188 sp = frame_addr;
2189 /* Need to reset the status of all registers. Otherwise,
2190 we will hit a guard that prevents the new address
2191 for each register to be recomputed during the second
2192 pass. */
74ed0bb4 2193 reset_saved_regs (gdbarch, this_cache);
29639122
JB
2194 goto restart;
2195 }
2196 }
2197 }
7d1e6fb8
KB
2198 else if ((high_word & 0xFFE0) == 0xafc0 /* sw reg,offset($30) */
2199 && !regsize_is_64_bits)
29639122 2200 {
74ed0bb4 2201 set_reg_offset (gdbarch, this_cache, reg, frame_addr + low_word);
29639122
JB
2202 }
2203 else if ((high_word & 0xFFE0) == 0xE7A0 /* swc1 freg,n($sp) */
2204 || (high_word & 0xF3E0) == 0xA3C0 /* sx reg,n($s8) */
2205 || (inst & 0xFF9F07FF) == 0x00800021 /* move reg,$a0-$a3 */
2206 || high_word == 0x3c1c /* lui $gp,n */
2207 || high_word == 0x279c /* addiu $gp,$gp,n */
2208 || inst == 0x0399e021 /* addu $gp,$gp,$t9 */
2209 || inst == 0x033ce021 /* addu $gp,$t9,$gp */
2210 )
2211 {
2212 /* These instructions are part of the prologue, but we don't
2213 need to do anything special to handle them. */
2214 }
2215 /* The instructions below load $at or $t0 with an immediate
2216 value in preparation for a stack adjustment via
025bb325 2217 subu $sp,$sp,[$at,$t0]. These instructions could also
29639122
JB
2218 initialize a local variable, so we accept them only before
2219 a stack adjustment instruction was seen. */
2220 else if (!seen_sp_adjust
2221 && (high_word == 0x3c01 /* lui $at,n */
2222 || high_word == 0x3c08 /* lui $t0,n */
2223 || high_word == 0x3421 /* ori $at,$at,n */
2224 || high_word == 0x3508 /* ori $t0,$t0,n */
2225 || high_word == 0x3401 /* ori $at,$zero,n */
2226 || high_word == 0x3408 /* ori $t0,$zero,n */
2227 ))
2228 {
95ac2dcf 2229 load_immediate_bytes += MIPS_INSN32_SIZE; /* FIXME! */
29639122
JB
2230 }
2231 else
2232 {
2233 /* This instruction is not an instruction typically found
2234 in a prologue, so we must have reached the end of the
2235 prologue. */
2236 /* FIXME: brobecker/2004-10-10: Can't we just break out of this
2237 loop now? Why would we need to continue scanning the function
2238 instructions? */
2239 if (end_prologue_addr == 0)
2240 end_prologue_addr = cur_pc;
db5f024e
DJ
2241
2242 /* Check for branches and jumps. For now, only jump to
2243 register are caught (i.e. returns). */
2244 if ((itype_op (inst) & 0x07) == 0 && rtype_funct (inst) == 8)
2245 in_delay_slot = 1;
29639122 2246 }
db5f024e
DJ
2247
2248 /* If the previous instruction was a jump, we must have reached
2249 the end of the prologue by now. Stop scanning so that we do
2250 not go past the function return. */
2251 if (in_delay_slot)
2252 break;
a4b8ebc8 2253 }
c906108c 2254
29639122
JB
2255 if (this_cache != NULL)
2256 {
2257 this_cache->base =
b8a22b94
DJ
2258 (get_frame_register_signed (this_frame,
2259 gdbarch_num_regs (gdbarch) + frame_reg)
29639122
JB
2260 + frame_offset);
2261 /* FIXME: brobecker/2004-09-15: We should be able to get rid of
2262 this assignment below, eventually. But it's still needed
2263 for now. */
72a155b4
UW
2264 this_cache->saved_regs[gdbarch_num_regs (gdbarch)
2265 + mips_regnum (gdbarch)->pc]
2266 = this_cache->saved_regs[gdbarch_num_regs (gdbarch)
f57d151a 2267 + MIPS_RA_REGNUM];
29639122 2268 }
c906108c 2269
29639122
JB
2270 /* If we didn't reach the end of the prologue when scanning the function
2271 instructions, then set end_prologue_addr to the address of the
2272 instruction immediately after the last one we scanned. */
2273 /* brobecker/2004-10-10: I don't think this would ever happen, but
2274 we may as well be careful and do our best if we have a null
2275 end_prologue_addr. */
2276 if (end_prologue_addr == 0)
2277 end_prologue_addr = cur_pc;
2278
2279 /* In a frameless function, we might have incorrectly
025bb325 2280 skipped some load immediate instructions. Undo the skipping
29639122
JB
2281 if the load immediate was not followed by a stack adjustment. */
2282 if (load_immediate_bytes && !seen_sp_adjust)
2283 end_prologue_addr -= load_immediate_bytes;
c906108c 2284
29639122 2285 return end_prologue_addr;
c906108c
SS
2286}
2287
29639122
JB
2288/* Heuristic unwinder for procedures using 32-bit instructions (covers
2289 both 32-bit and 64-bit MIPS ISAs). Procedures using 16-bit
2290 instructions (a.k.a. MIPS16) are handled by the mips_insn16
2291 unwinder. */
c906108c 2292
29639122 2293static struct mips_frame_cache *
b8a22b94 2294mips_insn32_frame_cache (struct frame_info *this_frame, void **this_cache)
c906108c 2295{
e17a4113 2296 struct gdbarch *gdbarch = get_frame_arch (this_frame);
29639122 2297 struct mips_frame_cache *cache;
c906108c 2298
29639122
JB
2299 if ((*this_cache) != NULL)
2300 return (*this_cache);
c5aa993b 2301
29639122
JB
2302 cache = FRAME_OBSTACK_ZALLOC (struct mips_frame_cache);
2303 (*this_cache) = cache;
b8a22b94 2304 cache->saved_regs = trad_frame_alloc_saved_regs (this_frame);
c5aa993b 2305
29639122
JB
2306 /* Analyze the function prologue. */
2307 {
b8a22b94 2308 const CORE_ADDR pc = get_frame_address_in_block (this_frame);
29639122 2309 CORE_ADDR start_addr;
c906108c 2310
29639122
JB
2311 find_pc_partial_function (pc, NULL, &start_addr, NULL);
2312 if (start_addr == 0)
e17a4113 2313 start_addr = heuristic_proc_start (gdbarch, pc);
29639122
JB
2314 /* We can't analyze the prologue if we couldn't find the begining
2315 of the function. */
2316 if (start_addr == 0)
2317 return cache;
c5aa993b 2318
e17a4113 2319 mips32_scan_prologue (gdbarch, start_addr, pc, this_frame, *this_cache);
29639122
JB
2320 }
2321
3e8c568d 2322 /* gdbarch_sp_regnum contains the value and not the address. */
f57d151a 2323 trad_frame_set_value (cache->saved_regs,
e17a4113 2324 gdbarch_num_regs (gdbarch) + MIPS_SP_REGNUM,
f57d151a 2325 cache->base);
c5aa993b 2326
29639122 2327 return (*this_cache);
c906108c
SS
2328}
2329
29639122 2330static void
b8a22b94 2331mips_insn32_frame_this_id (struct frame_info *this_frame, void **this_cache,
29639122 2332 struct frame_id *this_id)
c906108c 2333{
b8a22b94 2334 struct mips_frame_cache *info = mips_insn32_frame_cache (this_frame,
29639122 2335 this_cache);
21327321
DJ
2336 /* This marks the outermost frame. */
2337 if (info->base == 0)
2338 return;
b8a22b94 2339 (*this_id) = frame_id_build (info->base, get_frame_func (this_frame));
29639122 2340}
c906108c 2341
b8a22b94
DJ
2342static struct value *
2343mips_insn32_frame_prev_register (struct frame_info *this_frame,
2344 void **this_cache, int regnum)
29639122 2345{
b8a22b94 2346 struct mips_frame_cache *info = mips_insn32_frame_cache (this_frame,
29639122 2347 this_cache);
b8a22b94
DJ
2348 return trad_frame_get_prev_register (this_frame, info->saved_regs, regnum);
2349}
2350
2351static int
2352mips_insn32_frame_sniffer (const struct frame_unwind *self,
2353 struct frame_info *this_frame, void **this_cache)
2354{
2355 CORE_ADDR pc = get_frame_pc (this_frame);
2356 if (! mips_pc_is_mips16 (pc))
2357 return 1;
2358 return 0;
c906108c
SS
2359}
2360
29639122
JB
2361static const struct frame_unwind mips_insn32_frame_unwind =
2362{
2363 NORMAL_FRAME,
2364 mips_insn32_frame_this_id,
b8a22b94
DJ
2365 mips_insn32_frame_prev_register,
2366 NULL,
2367 mips_insn32_frame_sniffer
29639122 2368};
c906108c 2369
1c645fec 2370static CORE_ADDR
b8a22b94 2371mips_insn32_frame_base_address (struct frame_info *this_frame,
29639122 2372 void **this_cache)
c906108c 2373{
b8a22b94 2374 struct mips_frame_cache *info = mips_insn32_frame_cache (this_frame,
29639122
JB
2375 this_cache);
2376 return info->base;
2377}
c906108c 2378
29639122
JB
2379static const struct frame_base mips_insn32_frame_base =
2380{
2381 &mips_insn32_frame_unwind,
2382 mips_insn32_frame_base_address,
2383 mips_insn32_frame_base_address,
2384 mips_insn32_frame_base_address
2385};
1c645fec 2386
29639122 2387static const struct frame_base *
b8a22b94 2388mips_insn32_frame_base_sniffer (struct frame_info *this_frame)
29639122 2389{
b8a22b94
DJ
2390 CORE_ADDR pc = get_frame_pc (this_frame);
2391 if (! mips_pc_is_mips16 (pc))
29639122 2392 return &mips_insn32_frame_base;
a65bbe44 2393 else
29639122
JB
2394 return NULL;
2395}
a65bbe44 2396
29639122 2397static struct trad_frame_cache *
b8a22b94 2398mips_stub_frame_cache (struct frame_info *this_frame, void **this_cache)
29639122
JB
2399{
2400 CORE_ADDR pc;
2401 CORE_ADDR start_addr;
2402 CORE_ADDR stack_addr;
2403 struct trad_frame_cache *this_trad_cache;
b8a22b94
DJ
2404 struct gdbarch *gdbarch = get_frame_arch (this_frame);
2405 int num_regs = gdbarch_num_regs (gdbarch);
c906108c 2406
29639122
JB
2407 if ((*this_cache) != NULL)
2408 return (*this_cache);
b8a22b94 2409 this_trad_cache = trad_frame_cache_zalloc (this_frame);
29639122 2410 (*this_cache) = this_trad_cache;
1c645fec 2411
29639122 2412 /* The return address is in the link register. */
3e8c568d 2413 trad_frame_set_reg_realreg (this_trad_cache,
72a155b4 2414 gdbarch_pc_regnum (gdbarch),
b8a22b94 2415 num_regs + MIPS_RA_REGNUM);
1c645fec 2416
29639122
JB
2417 /* Frame ID, since it's a frameless / stackless function, no stack
2418 space is allocated and SP on entry is the current SP. */
b8a22b94 2419 pc = get_frame_pc (this_frame);
29639122 2420 find_pc_partial_function (pc, NULL, &start_addr, NULL);
b8a22b94
DJ
2421 stack_addr = get_frame_register_signed (this_frame,
2422 num_regs + MIPS_SP_REGNUM);
aa6c981f 2423 trad_frame_set_id (this_trad_cache, frame_id_build (stack_addr, start_addr));
1c645fec 2424
29639122
JB
2425 /* Assume that the frame's base is the same as the
2426 stack-pointer. */
2427 trad_frame_set_this_base (this_trad_cache, stack_addr);
c906108c 2428
29639122
JB
2429 return this_trad_cache;
2430}
c906108c 2431
29639122 2432static void
b8a22b94 2433mips_stub_frame_this_id (struct frame_info *this_frame, void **this_cache,
29639122
JB
2434 struct frame_id *this_id)
2435{
2436 struct trad_frame_cache *this_trad_cache
b8a22b94 2437 = mips_stub_frame_cache (this_frame, this_cache);
29639122
JB
2438 trad_frame_get_id (this_trad_cache, this_id);
2439}
c906108c 2440
b8a22b94
DJ
2441static struct value *
2442mips_stub_frame_prev_register (struct frame_info *this_frame,
2443 void **this_cache, int regnum)
29639122
JB
2444{
2445 struct trad_frame_cache *this_trad_cache
b8a22b94
DJ
2446 = mips_stub_frame_cache (this_frame, this_cache);
2447 return trad_frame_get_register (this_trad_cache, this_frame, regnum);
29639122 2448}
c906108c 2449
b8a22b94
DJ
2450static int
2451mips_stub_frame_sniffer (const struct frame_unwind *self,
2452 struct frame_info *this_frame, void **this_cache)
29639122 2453{
aa6c981f 2454 gdb_byte dummy[4];
979b38e0 2455 struct obj_section *s;
b8a22b94 2456 CORE_ADDR pc = get_frame_address_in_block (this_frame);
db5f024e 2457 struct minimal_symbol *msym;
979b38e0 2458
aa6c981f 2459 /* Use the stub unwinder for unreadable code. */
b8a22b94
DJ
2460 if (target_read_memory (get_frame_pc (this_frame), dummy, 4) != 0)
2461 return 1;
aa6c981f 2462
29639122 2463 if (in_plt_section (pc, NULL))
b8a22b94 2464 return 1;
979b38e0
DJ
2465
2466 /* Binutils for MIPS puts lazy resolution stubs into .MIPS.stubs. */
2467 s = find_pc_section (pc);
2468
2469 if (s != NULL
2470 && strcmp (bfd_get_section_name (s->objfile->obfd, s->the_bfd_section),
2471 ".MIPS.stubs") == 0)
b8a22b94 2472 return 1;
979b38e0 2473
db5f024e
DJ
2474 /* Calling a PIC function from a non-PIC function passes through a
2475 stub. The stub for foo is named ".pic.foo". */
2476 msym = lookup_minimal_symbol_by_pc (pc);
2477 if (msym != NULL
2478 && SYMBOL_LINKAGE_NAME (msym) != NULL
2479 && strncmp (SYMBOL_LINKAGE_NAME (msym), ".pic.", 5) == 0)
2480 return 1;
2481
b8a22b94 2482 return 0;
29639122 2483}
c906108c 2484
b8a22b94
DJ
2485static const struct frame_unwind mips_stub_frame_unwind =
2486{
2487 NORMAL_FRAME,
2488 mips_stub_frame_this_id,
2489 mips_stub_frame_prev_register,
2490 NULL,
2491 mips_stub_frame_sniffer
2492};
2493
29639122 2494static CORE_ADDR
b8a22b94 2495mips_stub_frame_base_address (struct frame_info *this_frame,
29639122
JB
2496 void **this_cache)
2497{
2498 struct trad_frame_cache *this_trad_cache
b8a22b94 2499 = mips_stub_frame_cache (this_frame, this_cache);
29639122
JB
2500 return trad_frame_get_this_base (this_trad_cache);
2501}
0fce0821 2502
29639122
JB
2503static const struct frame_base mips_stub_frame_base =
2504{
2505 &mips_stub_frame_unwind,
2506 mips_stub_frame_base_address,
2507 mips_stub_frame_base_address,
2508 mips_stub_frame_base_address
2509};
2510
2511static const struct frame_base *
b8a22b94 2512mips_stub_frame_base_sniffer (struct frame_info *this_frame)
29639122 2513{
b8a22b94 2514 if (mips_stub_frame_sniffer (&mips_stub_frame_unwind, this_frame, NULL))
29639122
JB
2515 return &mips_stub_frame_base;
2516 else
2517 return NULL;
2518}
2519
29639122 2520/* mips_addr_bits_remove - remove useless address bits */
65596487 2521
29639122 2522static CORE_ADDR
24568a2c 2523mips_addr_bits_remove (struct gdbarch *gdbarch, CORE_ADDR addr)
65596487 2524{
24568a2c 2525 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
930bd0e0
KB
2526
2527 if (is_mips16_addr (addr))
2528 addr = unmake_mips16_addr (addr);
2529
29639122
JB
2530 if (mips_mask_address_p (tdep) && (((ULONGEST) addr) >> 32 == 0xffffffffUL))
2531 /* This hack is a work-around for existing boards using PMON, the
2532 simulator, and any other 64-bit targets that doesn't have true
2533 64-bit addressing. On these targets, the upper 32 bits of
2534 addresses are ignored by the hardware. Thus, the PC or SP are
2535 likely to have been sign extended to all 1s by instruction
2536 sequences that load 32-bit addresses. For example, a typical
2537 piece of code that loads an address is this:
65596487 2538
29639122
JB
2539 lui $r2, <upper 16 bits>
2540 ori $r2, <lower 16 bits>
65596487 2541
29639122
JB
2542 But the lui sign-extends the value such that the upper 32 bits
2543 may be all 1s. The workaround is simply to mask off these
2544 bits. In the future, gcc may be changed to support true 64-bit
2545 addressing, and this masking will have to be disabled. */
2546 return addr &= 0xffffffffUL;
2547 else
2548 return addr;
65596487
JB
2549}
2550
3d5f6d12
DJ
2551/* Instructions used during single-stepping of atomic sequences. */
2552#define LL_OPCODE 0x30
2553#define LLD_OPCODE 0x34
2554#define SC_OPCODE 0x38
2555#define SCD_OPCODE 0x3c
2556
2557/* Checks for an atomic sequence of instructions beginning with a LL/LLD
2558 instruction and ending with a SC/SCD instruction. If such a sequence
2559 is found, attempt to step through it. A breakpoint is placed at the end of
2560 the sequence. */
2561
2562static int
6c95b8df
PA
2563deal_with_atomic_sequence (struct gdbarch *gdbarch,
2564 struct address_space *aspace, CORE_ADDR pc)
3d5f6d12
DJ
2565{
2566 CORE_ADDR breaks[2] = {-1, -1};
2567 CORE_ADDR loc = pc;
2568 CORE_ADDR branch_bp; /* Breakpoint at branch instruction's destination. */
2569 unsigned long insn;
2570 int insn_count;
2571 int index;
2572 int last_breakpoint = 0; /* Defaults to 0 (no breakpoints placed). */
2573 const int atomic_sequence_length = 16; /* Instruction sequence length. */
2574
2575 if (pc & 0x01)
2576 return 0;
2577
e17a4113 2578 insn = mips_fetch_instruction (gdbarch, loc);
3d5f6d12
DJ
2579 /* Assume all atomic sequences start with a ll/lld instruction. */
2580 if (itype_op (insn) != LL_OPCODE && itype_op (insn) != LLD_OPCODE)
2581 return 0;
2582
2583 /* Assume that no atomic sequence is longer than "atomic_sequence_length"
2584 instructions. */
2585 for (insn_count = 0; insn_count < atomic_sequence_length; ++insn_count)
2586 {
2587 int is_branch = 0;
2588 loc += MIPS_INSN32_SIZE;
e17a4113 2589 insn = mips_fetch_instruction (gdbarch, loc);
3d5f6d12
DJ
2590
2591 /* Assume that there is at most one branch in the atomic
2592 sequence. If a branch is found, put a breakpoint in its
2593 destination address. */
2594 switch (itype_op (insn))
2595 {
2596 case 0: /* SPECIAL */
2597 if (rtype_funct (insn) >> 1 == 4) /* JR, JALR */
025bb325 2598 return 0; /* fallback to the standard single-step code. */
3d5f6d12
DJ
2599 break;
2600 case 1: /* REGIMM */
2601 is_branch = ((itype_rt (insn) & 0xc0) == 0); /* B{LT,GE}Z* */
2602 break;
2603 case 2: /* J */
2604 case 3: /* JAL */
025bb325 2605 return 0; /* fallback to the standard single-step code. */
3d5f6d12
DJ
2606 case 4: /* BEQ */
2607 case 5: /* BNE */
2608 case 6: /* BLEZ */
2609 case 7: /* BGTZ */
2610 case 20: /* BEQL */
2611 case 21: /* BNEL */
2612 case 22: /* BLEZL */
2613 case 23: /* BGTTL */
2614 is_branch = 1;
2615 break;
2616 case 17: /* COP1 */
2617 case 18: /* COP2 */
2618 case 19: /* COP3 */
2619 is_branch = (itype_rs (insn) == 8); /* BCzF, BCzFL, BCzT, BCzTL */
2620 break;
2621 }
2622 if (is_branch)
2623 {
2624 branch_bp = loc + mips32_relative_offset (insn) + 4;
2625 if (last_breakpoint >= 1)
2626 return 0; /* More than one branch found, fallback to the
2627 standard single-step code. */
2628 breaks[1] = branch_bp;
2629 last_breakpoint++;
2630 }
2631
2632 if (itype_op (insn) == SC_OPCODE || itype_op (insn) == SCD_OPCODE)
2633 break;
2634 }
2635
2636 /* Assume that the atomic sequence ends with a sc/scd instruction. */
2637 if (itype_op (insn) != SC_OPCODE && itype_op (insn) != SCD_OPCODE)
2638 return 0;
2639
2640 loc += MIPS_INSN32_SIZE;
2641
2642 /* Insert a breakpoint right after the end of the atomic sequence. */
2643 breaks[0] = loc;
2644
2645 /* Check for duplicated breakpoints. Check also for a breakpoint
025bb325 2646 placed (branch instruction's destination) in the atomic sequence. */
3d5f6d12
DJ
2647 if (last_breakpoint && pc <= breaks[1] && breaks[1] <= breaks[0])
2648 last_breakpoint = 0;
2649
2650 /* Effectively inserts the breakpoints. */
2651 for (index = 0; index <= last_breakpoint; index++)
6c95b8df 2652 insert_single_step_breakpoint (gdbarch, aspace, breaks[index]);
3d5f6d12
DJ
2653
2654 return 1;
2655}
2656
29639122
JB
2657/* mips_software_single_step() is called just before we want to resume
2658 the inferior, if we want to single-step it but there is no hardware
2659 or kernel single-step support (MIPS on GNU/Linux for example). We find
e0cd558a 2660 the target of the coming instruction and breakpoint it. */
29639122 2661
e6590a1b 2662int
0b1b3e42 2663mips_software_single_step (struct frame_info *frame)
c906108c 2664{
a6d9a66e 2665 struct gdbarch *gdbarch = get_frame_arch (frame);
6c95b8df 2666 struct address_space *aspace = get_frame_address_space (frame);
8181d85f 2667 CORE_ADDR pc, next_pc;
65596487 2668
0b1b3e42 2669 pc = get_frame_pc (frame);
6c95b8df 2670 if (deal_with_atomic_sequence (gdbarch, aspace, pc))
3d5f6d12
DJ
2671 return 1;
2672
0b1b3e42 2673 next_pc = mips_next_pc (frame, pc);
e6590a1b 2674
6c95b8df 2675 insert_single_step_breakpoint (gdbarch, aspace, next_pc);
e6590a1b 2676 return 1;
29639122 2677}
a65bbe44 2678
29639122 2679/* Test whether the PC points to the return instruction at the
025bb325 2680 end of a function. */
65596487 2681
29639122 2682static int
e17a4113 2683mips_about_to_return (struct gdbarch *gdbarch, CORE_ADDR pc)
29639122 2684{
0fe7e7c8 2685 if (mips_pc_is_mips16 (pc))
29639122
JB
2686 /* This mips16 case isn't necessarily reliable. Sometimes the compiler
2687 generates a "jr $ra"; other times it generates code to load
2688 the return address from the stack to an accessible register (such
2689 as $a3), then a "jr" using that register. This second case
2690 is almost impossible to distinguish from an indirect jump
2691 used for switch statements, so we don't even try. */
e17a4113 2692 return mips_fetch_instruction (gdbarch, pc) == 0xe820; /* jr $ra */
29639122 2693 else
e17a4113 2694 return mips_fetch_instruction (gdbarch, pc) == 0x3e00008; /* jr $ra */
29639122 2695}
c906108c 2696
c906108c 2697
29639122
JB
2698/* This fencepost looks highly suspicious to me. Removing it also
2699 seems suspicious as it could affect remote debugging across serial
2700 lines. */
c906108c 2701
29639122 2702static CORE_ADDR
74ed0bb4 2703heuristic_proc_start (struct gdbarch *gdbarch, CORE_ADDR pc)
29639122
JB
2704{
2705 CORE_ADDR start_pc;
2706 CORE_ADDR fence;
2707 int instlen;
2708 int seen_adjsp = 0;
d6b48e9c 2709 struct inferior *inf;
65596487 2710
74ed0bb4 2711 pc = gdbarch_addr_bits_remove (gdbarch, pc);
29639122
JB
2712 start_pc = pc;
2713 fence = start_pc - heuristic_fence_post;
2714 if (start_pc == 0)
2715 return 0;
65596487 2716
29639122
JB
2717 if (heuristic_fence_post == UINT_MAX || fence < VM_MIN_ADDRESS)
2718 fence = VM_MIN_ADDRESS;
65596487 2719
95ac2dcf 2720 instlen = mips_pc_is_mips16 (pc) ? MIPS_INSN16_SIZE : MIPS_INSN32_SIZE;
98b4dd94 2721
d6b48e9c
PA
2722 inf = current_inferior ();
2723
025bb325 2724 /* Search back for previous return. */
29639122
JB
2725 for (start_pc -= instlen;; start_pc -= instlen)
2726 if (start_pc < fence)
2727 {
2728 /* It's not clear to me why we reach this point when
2729 stop_soon, but with this test, at least we
2730 don't print out warnings for every child forked (eg, on
2731 decstation). 22apr93 rich@cygnus.com. */
16c381f0 2732 if (inf->control.stop_soon == NO_STOP_QUIETLY)
29639122
JB
2733 {
2734 static int blurb_printed = 0;
98b4dd94 2735
5af949e3
UW
2736 warning (_("GDB can't find the start of the function at %s."),
2737 paddress (gdbarch, pc));
29639122
JB
2738
2739 if (!blurb_printed)
2740 {
2741 /* This actually happens frequently in embedded
2742 development, when you first connect to a board
2743 and your stack pointer and pc are nowhere in
2744 particular. This message needs to give people
2745 in that situation enough information to
2746 determine that it's no big deal. */
2747 printf_filtered ("\n\
5af949e3 2748 GDB is unable to find the start of the function at %s\n\
29639122
JB
2749and thus can't determine the size of that function's stack frame.\n\
2750This means that GDB may be unable to access that stack frame, or\n\
2751the frames below it.\n\
2752 This problem is most likely caused by an invalid program counter or\n\
2753stack pointer.\n\
2754 However, if you think GDB should simply search farther back\n\
5af949e3 2755from %s for code which looks like the beginning of a\n\
29639122 2756function, you can increase the range of the search using the `set\n\
5af949e3
UW
2757heuristic-fence-post' command.\n",
2758 paddress (gdbarch, pc), paddress (gdbarch, pc));
29639122
JB
2759 blurb_printed = 1;
2760 }
2761 }
2762
2763 return 0;
2764 }
0fe7e7c8 2765 else if (mips_pc_is_mips16 (start_pc))
29639122
JB
2766 {
2767 unsigned short inst;
2768
2769 /* On MIPS16, any one of the following is likely to be the
2770 start of a function:
193774b3
MR
2771 extend save
2772 save
29639122
JB
2773 entry
2774 addiu sp,-n
2775 daddiu sp,-n
025bb325 2776 extend -n followed by 'addiu sp,+n' or 'daddiu sp,+n'. */
e17a4113 2777 inst = mips_fetch_instruction (gdbarch, start_pc);
193774b3
MR
2778 if ((inst & 0xff80) == 0x6480) /* save */
2779 {
2780 if (start_pc - instlen >= fence)
2781 {
e17a4113 2782 inst = mips_fetch_instruction (gdbarch, start_pc - instlen);
193774b3
MR
2783 if ((inst & 0xf800) == 0xf000) /* extend */
2784 start_pc -= instlen;
2785 }
2786 break;
2787 }
2788 else if (((inst & 0xf81f) == 0xe809
2789 && (inst & 0x700) != 0x700) /* entry */
2790 || (inst & 0xff80) == 0x6380 /* addiu sp,-n */
2791 || (inst & 0xff80) == 0xfb80 /* daddiu sp,-n */
2792 || ((inst & 0xf810) == 0xf010 && seen_adjsp)) /* extend -n */
29639122
JB
2793 break;
2794 else if ((inst & 0xff00) == 0x6300 /* addiu sp */
2795 || (inst & 0xff00) == 0xfb00) /* daddiu sp */
2796 seen_adjsp = 1;
2797 else
2798 seen_adjsp = 0;
2799 }
e17a4113 2800 else if (mips_about_to_return (gdbarch, start_pc))
29639122 2801 {
4c7d22cb 2802 /* Skip return and its delay slot. */
95ac2dcf 2803 start_pc += 2 * MIPS_INSN32_SIZE;
29639122
JB
2804 break;
2805 }
2806
2807 return start_pc;
c906108c
SS
2808}
2809
6c0d6680
DJ
2810struct mips_objfile_private
2811{
2812 bfd_size_type size;
2813 char *contents;
2814};
2815
f09ded24
AC
2816/* According to the current ABI, should the type be passed in a
2817 floating-point register (assuming that there is space)? When there
a1f5b845 2818 is no FPU, FP are not even considered as possible candidates for
f09ded24 2819 FP registers and, consequently this returns false - forces FP
025bb325 2820 arguments into integer registers. */
f09ded24
AC
2821
2822static int
74ed0bb4
MD
2823fp_register_arg_p (struct gdbarch *gdbarch, enum type_code typecode,
2824 struct type *arg_type)
f09ded24
AC
2825{
2826 return ((typecode == TYPE_CODE_FLT
74ed0bb4 2827 || (MIPS_EABI (gdbarch)
6d82d43b
AC
2828 && (typecode == TYPE_CODE_STRUCT
2829 || typecode == TYPE_CODE_UNION)
f09ded24 2830 && TYPE_NFIELDS (arg_type) == 1
b2d6f210
MS
2831 && TYPE_CODE (check_typedef (TYPE_FIELD_TYPE (arg_type, 0)))
2832 == TYPE_CODE_FLT))
74ed0bb4 2833 && MIPS_FPU_TYPE(gdbarch) != MIPS_FPU_NONE);
f09ded24
AC
2834}
2835
49e790b0 2836/* On o32, argument passing in GPRs depends on the alignment of the type being
025bb325 2837 passed. Return 1 if this type must be aligned to a doubleword boundary. */
49e790b0
DJ
2838
2839static int
2840mips_type_needs_double_align (struct type *type)
2841{
2842 enum type_code typecode = TYPE_CODE (type);
361d1df0 2843
49e790b0
DJ
2844 if (typecode == TYPE_CODE_FLT && TYPE_LENGTH (type) == 8)
2845 return 1;
2846 else if (typecode == TYPE_CODE_STRUCT)
2847 {
2848 if (TYPE_NFIELDS (type) < 1)
2849 return 0;
2850 return mips_type_needs_double_align (TYPE_FIELD_TYPE (type, 0));
2851 }
2852 else if (typecode == TYPE_CODE_UNION)
2853 {
361d1df0 2854 int i, n;
49e790b0
DJ
2855
2856 n = TYPE_NFIELDS (type);
2857 for (i = 0; i < n; i++)
2858 if (mips_type_needs_double_align (TYPE_FIELD_TYPE (type, i)))
2859 return 1;
2860 return 0;
2861 }
2862 return 0;
2863}
2864
dc604539
AC
2865/* Adjust the address downward (direction of stack growth) so that it
2866 is correctly aligned for a new stack frame. */
2867static CORE_ADDR
2868mips_frame_align (struct gdbarch *gdbarch, CORE_ADDR addr)
2869{
5b03f266 2870 return align_down (addr, 16);
dc604539
AC
2871}
2872
f7ab6ec6 2873static CORE_ADDR
7d9b040b 2874mips_eabi_push_dummy_call (struct gdbarch *gdbarch, struct value *function,
6d82d43b
AC
2875 struct regcache *regcache, CORE_ADDR bp_addr,
2876 int nargs, struct value **args, CORE_ADDR sp,
2877 int struct_return, CORE_ADDR struct_addr)
c906108c
SS
2878{
2879 int argreg;
2880 int float_argreg;
2881 int argnum;
2882 int len = 0;
2883 int stack_offset = 0;
480d3dd2 2884 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
e17a4113 2885 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
7d9b040b 2886 CORE_ADDR func_addr = find_function_addr (function, NULL);
1a69e1e4 2887 int regsize = mips_abi_regsize (gdbarch);
c906108c 2888
25ab4790
AC
2889 /* For shared libraries, "t9" needs to point at the function
2890 address. */
4c7d22cb 2891 regcache_cooked_write_signed (regcache, MIPS_T9_REGNUM, func_addr);
25ab4790
AC
2892
2893 /* Set the return address register to point to the entry point of
2894 the program, where a breakpoint lies in wait. */
4c7d22cb 2895 regcache_cooked_write_signed (regcache, MIPS_RA_REGNUM, bp_addr);
25ab4790 2896
c906108c 2897 /* First ensure that the stack and structure return address (if any)
cb3d25d1
MS
2898 are properly aligned. The stack has to be at least 64-bit
2899 aligned even on 32-bit machines, because doubles must be 64-bit
2900 aligned. For n32 and n64, stack frames need to be 128-bit
2901 aligned, so we round to this widest known alignment. */
2902
5b03f266
AC
2903 sp = align_down (sp, 16);
2904 struct_addr = align_down (struct_addr, 16);
c5aa993b 2905
46e0f506 2906 /* Now make space on the stack for the args. We allocate more
c906108c 2907 than necessary for EABI, because the first few arguments are
46e0f506 2908 passed in registers, but that's OK. */
c906108c 2909 for (argnum = 0; argnum < nargs; argnum++)
1a69e1e4 2910 len += align_up (TYPE_LENGTH (value_type (args[argnum])), regsize);
5b03f266 2911 sp -= align_up (len, 16);
c906108c 2912
9ace0497 2913 if (mips_debug)
6d82d43b 2914 fprintf_unfiltered (gdb_stdlog,
5af949e3
UW
2915 "mips_eabi_push_dummy_call: sp=%s allocated %ld\n",
2916 paddress (gdbarch, sp), (long) align_up (len, 16));
9ace0497 2917
c906108c 2918 /* Initialize the integer and float register pointers. */
4c7d22cb 2919 argreg = MIPS_A0_REGNUM;
72a155b4 2920 float_argreg = mips_fpa0_regnum (gdbarch);
c906108c 2921
46e0f506 2922 /* The struct_return pointer occupies the first parameter-passing reg. */
c906108c 2923 if (struct_return)
9ace0497
AC
2924 {
2925 if (mips_debug)
2926 fprintf_unfiltered (gdb_stdlog,
025bb325
MS
2927 "mips_eabi_push_dummy_call: "
2928 "struct_return reg=%d %s\n",
5af949e3 2929 argreg, paddress (gdbarch, struct_addr));
9c9acae0 2930 regcache_cooked_write_unsigned (regcache, argreg++, struct_addr);
9ace0497 2931 }
c906108c
SS
2932
2933 /* Now load as many as possible of the first arguments into
2934 registers, and push the rest onto the stack. Loop thru args
2935 from first to last. */
2936 for (argnum = 0; argnum < nargs; argnum++)
2937 {
47a35522
MK
2938 const gdb_byte *val;
2939 gdb_byte valbuf[MAX_REGISTER_SIZE];
ea7c478f 2940 struct value *arg = args[argnum];
4991999e 2941 struct type *arg_type = check_typedef (value_type (arg));
c906108c
SS
2942 int len = TYPE_LENGTH (arg_type);
2943 enum type_code typecode = TYPE_CODE (arg_type);
2944
9ace0497
AC
2945 if (mips_debug)
2946 fprintf_unfiltered (gdb_stdlog,
25ab4790 2947 "mips_eabi_push_dummy_call: %d len=%d type=%d",
acdb74a0 2948 argnum + 1, len, (int) typecode);
9ace0497 2949
930bd0e0
KB
2950 /* Function pointer arguments to mips16 code need to be made into
2951 mips16 pointers. */
2952 if (typecode == TYPE_CODE_PTR
2953 && TYPE_CODE (TYPE_TARGET_TYPE (arg_type)) == TYPE_CODE_FUNC)
2954 {
2955 CORE_ADDR addr = extract_signed_integer (value_contents (arg),
2956 len, byte_order);
2957 if (mips_pc_is_mips16 (addr))
2958 {
2959 store_signed_integer (valbuf, len, byte_order,
2960 make_mips16_addr (addr));
2961 val = valbuf;
2962 }
2963 else
2964 val = value_contents (arg);
2965 }
c906108c 2966 /* The EABI passes structures that do not fit in a register by
46e0f506 2967 reference. */
930bd0e0 2968 else if (len > regsize
9ace0497 2969 && (typecode == TYPE_CODE_STRUCT || typecode == TYPE_CODE_UNION))
c906108c 2970 {
e17a4113
UW
2971 store_unsigned_integer (valbuf, regsize, byte_order,
2972 value_address (arg));
c906108c 2973 typecode = TYPE_CODE_PTR;
1a69e1e4 2974 len = regsize;
c906108c 2975 val = valbuf;
9ace0497
AC
2976 if (mips_debug)
2977 fprintf_unfiltered (gdb_stdlog, " push");
c906108c
SS
2978 }
2979 else
47a35522 2980 val = value_contents (arg);
c906108c
SS
2981
2982 /* 32-bit ABIs always start floating point arguments in an
acdb74a0
AC
2983 even-numbered floating point register. Round the FP register
2984 up before the check to see if there are any FP registers
46e0f506
MS
2985 left. Non MIPS_EABI targets also pass the FP in the integer
2986 registers so also round up normal registers. */
74ed0bb4 2987 if (regsize < 8 && fp_register_arg_p (gdbarch, typecode, arg_type))
acdb74a0
AC
2988 {
2989 if ((float_argreg & 1))
2990 float_argreg++;
2991 }
c906108c
SS
2992
2993 /* Floating point arguments passed in registers have to be
2994 treated specially. On 32-bit architectures, doubles
c5aa993b
JM
2995 are passed in register pairs; the even register gets
2996 the low word, and the odd register gets the high word.
2997 On non-EABI processors, the first two floating point arguments are
2998 also copied to general registers, because MIPS16 functions
2999 don't use float registers for arguments. This duplication of
3000 arguments in general registers can't hurt non-MIPS16 functions
3001 because those registers are normally skipped. */
1012bd0e
EZ
3002 /* MIPS_EABI squeezes a struct that contains a single floating
3003 point value into an FP register instead of pushing it onto the
46e0f506 3004 stack. */
74ed0bb4
MD
3005 if (fp_register_arg_p (gdbarch, typecode, arg_type)
3006 && float_argreg <= MIPS_LAST_FP_ARG_REGNUM (gdbarch))
c906108c 3007 {
6da397e0
KB
3008 /* EABI32 will pass doubles in consecutive registers, even on
3009 64-bit cores. At one time, we used to check the size of
3010 `float_argreg' to determine whether or not to pass doubles
3011 in consecutive registers, but this is not sufficient for
3012 making the ABI determination. */
3013 if (len == 8 && mips_abi (gdbarch) == MIPS_ABI_EABI32)
c906108c 3014 {
72a155b4 3015 int low_offset = gdbarch_byte_order (gdbarch)
4c6b5505 3016 == BFD_ENDIAN_BIG ? 4 : 0;
a8852dc5 3017 long regval;
c906108c
SS
3018
3019 /* Write the low word of the double to the even register(s). */
a8852dc5
KB
3020 regval = extract_signed_integer (val + low_offset,
3021 4, byte_order);
9ace0497 3022 if (mips_debug)
acdb74a0 3023 fprintf_unfiltered (gdb_stdlog, " - fpreg=%d val=%s",
9ace0497 3024 float_argreg, phex (regval, 4));
a8852dc5 3025 regcache_cooked_write_signed (regcache, float_argreg++, regval);
c906108c
SS
3026
3027 /* Write the high word of the double to the odd register(s). */
a8852dc5
KB
3028 regval = extract_signed_integer (val + 4 - low_offset,
3029 4, byte_order);
9ace0497 3030 if (mips_debug)
acdb74a0 3031 fprintf_unfiltered (gdb_stdlog, " - fpreg=%d val=%s",
9ace0497 3032 float_argreg, phex (regval, 4));
a8852dc5 3033 regcache_cooked_write_signed (regcache, float_argreg++, regval);
c906108c
SS
3034 }
3035 else
3036 {
3037 /* This is a floating point value that fits entirely
3038 in a single register. */
53a5351d 3039 /* On 32 bit ABI's the float_argreg is further adjusted
6d82d43b 3040 above to ensure that it is even register aligned. */
a8852dc5 3041 LONGEST regval = extract_signed_integer (val, len, byte_order);
9ace0497 3042 if (mips_debug)
acdb74a0 3043 fprintf_unfiltered (gdb_stdlog, " - fpreg=%d val=%s",
9ace0497 3044 float_argreg, phex (regval, len));
a8852dc5 3045 regcache_cooked_write_signed (regcache, float_argreg++, regval);
c906108c
SS
3046 }
3047 }
3048 else
3049 {
3050 /* Copy the argument to general registers or the stack in
3051 register-sized pieces. Large arguments are split between
3052 registers and stack. */
1a69e1e4
DJ
3053 /* Note: structs whose size is not a multiple of regsize
3054 are treated specially: Irix cc passes
d5ac5a39
AC
3055 them in registers where gcc sometimes puts them on the
3056 stack. For maximum compatibility, we will put them in
3057 both places. */
1a69e1e4 3058 int odd_sized_struct = (len > regsize && len % regsize != 0);
46e0f506 3059
f09ded24 3060 /* Note: Floating-point values that didn't fit into an FP
6d82d43b 3061 register are only written to memory. */
c906108c
SS
3062 while (len > 0)
3063 {
ebafbe83 3064 /* Remember if the argument was written to the stack. */
566f0f7a 3065 int stack_used_p = 0;
1a69e1e4 3066 int partial_len = (len < regsize ? len : regsize);
c906108c 3067
acdb74a0
AC
3068 if (mips_debug)
3069 fprintf_unfiltered (gdb_stdlog, " -- partial=%d",
3070 partial_len);
3071
566f0f7a 3072 /* Write this portion of the argument to the stack. */
74ed0bb4 3073 if (argreg > MIPS_LAST_ARG_REGNUM (gdbarch)
f09ded24 3074 || odd_sized_struct
74ed0bb4 3075 || fp_register_arg_p (gdbarch, typecode, arg_type))
c906108c 3076 {
c906108c 3077 /* Should shorter than int integer values be
025bb325 3078 promoted to int before being stored? */
c906108c 3079 int longword_offset = 0;
9ace0497 3080 CORE_ADDR addr;
566f0f7a 3081 stack_used_p = 1;
72a155b4 3082 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG)
7a292a7a 3083 {
1a69e1e4 3084 if (regsize == 8
480d3dd2
AC
3085 && (typecode == TYPE_CODE_INT
3086 || typecode == TYPE_CODE_PTR
6d82d43b 3087 || typecode == TYPE_CODE_FLT) && len <= 4)
1a69e1e4 3088 longword_offset = regsize - len;
480d3dd2
AC
3089 else if ((typecode == TYPE_CODE_STRUCT
3090 || typecode == TYPE_CODE_UNION)
1a69e1e4
DJ
3091 && TYPE_LENGTH (arg_type) < regsize)
3092 longword_offset = regsize - len;
7a292a7a 3093 }
c5aa993b 3094
9ace0497
AC
3095 if (mips_debug)
3096 {
5af949e3
UW
3097 fprintf_unfiltered (gdb_stdlog, " - stack_offset=%s",
3098 paddress (gdbarch, stack_offset));
3099 fprintf_unfiltered (gdb_stdlog, " longword_offset=%s",
3100 paddress (gdbarch, longword_offset));
9ace0497 3101 }
361d1df0 3102
9ace0497
AC
3103 addr = sp + stack_offset + longword_offset;
3104
3105 if (mips_debug)
3106 {
3107 int i;
5af949e3
UW
3108 fprintf_unfiltered (gdb_stdlog, " @%s ",
3109 paddress (gdbarch, addr));
9ace0497
AC
3110 for (i = 0; i < partial_len; i++)
3111 {
6d82d43b 3112 fprintf_unfiltered (gdb_stdlog, "%02x",
cb3d25d1 3113 val[i] & 0xff);
9ace0497
AC
3114 }
3115 }
3116 write_memory (addr, val, partial_len);
c906108c
SS
3117 }
3118
f09ded24
AC
3119 /* Note!!! This is NOT an else clause. Odd sized
3120 structs may go thru BOTH paths. Floating point
46e0f506 3121 arguments will not. */
566f0f7a 3122 /* Write this portion of the argument to a general
6d82d43b 3123 purpose register. */
74ed0bb4
MD
3124 if (argreg <= MIPS_LAST_ARG_REGNUM (gdbarch)
3125 && !fp_register_arg_p (gdbarch, typecode, arg_type))
c906108c 3126 {
6d82d43b 3127 LONGEST regval =
a8852dc5 3128 extract_signed_integer (val, partial_len, byte_order);
c906108c 3129
9ace0497 3130 if (mips_debug)
acdb74a0 3131 fprintf_filtered (gdb_stdlog, " - reg=%d val=%s",
9ace0497 3132 argreg,
1a69e1e4 3133 phex (regval, regsize));
a8852dc5 3134 regcache_cooked_write_signed (regcache, argreg, regval);
c906108c 3135 argreg++;
c906108c 3136 }
c5aa993b 3137
c906108c
SS
3138 len -= partial_len;
3139 val += partial_len;
3140
b021a221
MS
3141 /* Compute the offset into the stack at which we will
3142 copy the next parameter.
566f0f7a 3143
566f0f7a 3144 In the new EABI (and the NABI32), the stack_offset
46e0f506 3145 only needs to be adjusted when it has been used. */
c906108c 3146
46e0f506 3147 if (stack_used_p)
1a69e1e4 3148 stack_offset += align_up (partial_len, regsize);
c906108c
SS
3149 }
3150 }
9ace0497
AC
3151 if (mips_debug)
3152 fprintf_unfiltered (gdb_stdlog, "\n");
c906108c
SS
3153 }
3154
f10683bb 3155 regcache_cooked_write_signed (regcache, MIPS_SP_REGNUM, sp);
310e9b6a 3156
0f71a2f6
JM
3157 /* Return adjusted stack pointer. */
3158 return sp;
3159}
3160
a1f5b845 3161/* Determine the return value convention being used. */
6d82d43b 3162
9c8fdbfa 3163static enum return_value_convention
c055b101 3164mips_eabi_return_value (struct gdbarch *gdbarch, struct type *func_type,
9c8fdbfa 3165 struct type *type, struct regcache *regcache,
47a35522 3166 gdb_byte *readbuf, const gdb_byte *writebuf)
6d82d43b 3167{
609ba780
JM
3168 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
3169 int fp_return_type = 0;
3170 int offset, regnum, xfer;
3171
9c8fdbfa
AC
3172 if (TYPE_LENGTH (type) > 2 * mips_abi_regsize (gdbarch))
3173 return RETURN_VALUE_STRUCT_CONVENTION;
609ba780
JM
3174
3175 /* Floating point type? */
3176 if (tdep->mips_fpu_type != MIPS_FPU_NONE)
3177 {
3178 if (TYPE_CODE (type) == TYPE_CODE_FLT)
3179 fp_return_type = 1;
3180 /* Structs with a single field of float type
3181 are returned in a floating point register. */
3182 if ((TYPE_CODE (type) == TYPE_CODE_STRUCT
3183 || TYPE_CODE (type) == TYPE_CODE_UNION)
3184 && TYPE_NFIELDS (type) == 1)
3185 {
3186 struct type *fieldtype = TYPE_FIELD_TYPE (type, 0);
3187
3188 if (TYPE_CODE (check_typedef (fieldtype)) == TYPE_CODE_FLT)
3189 fp_return_type = 1;
3190 }
3191 }
3192
3193 if (fp_return_type)
3194 {
3195 /* A floating-point value belongs in the least significant part
3196 of FP0/FP1. */
3197 if (mips_debug)
3198 fprintf_unfiltered (gdb_stderr, "Return float in $fp0\n");
3199 regnum = mips_regnum (gdbarch)->fp0;
3200 }
3201 else
3202 {
3203 /* An integer value goes in V0/V1. */
3204 if (mips_debug)
3205 fprintf_unfiltered (gdb_stderr, "Return scalar in $v0\n");
3206 regnum = MIPS_V0_REGNUM;
3207 }
3208 for (offset = 0;
3209 offset < TYPE_LENGTH (type);
3210 offset += mips_abi_regsize (gdbarch), regnum++)
3211 {
3212 xfer = mips_abi_regsize (gdbarch);
3213 if (offset + xfer > TYPE_LENGTH (type))
3214 xfer = TYPE_LENGTH (type) - offset;
3215 mips_xfer_register (gdbarch, regcache,
3216 gdbarch_num_regs (gdbarch) + regnum, xfer,
3217 gdbarch_byte_order (gdbarch), readbuf, writebuf,
3218 offset);
3219 }
3220
9c8fdbfa 3221 return RETURN_VALUE_REGISTER_CONVENTION;
6d82d43b
AC
3222}
3223
6d82d43b
AC
3224
3225/* N32/N64 ABI stuff. */
ebafbe83 3226
8d26208a
DJ
3227/* Search for a naturally aligned double at OFFSET inside a struct
3228 ARG_TYPE. The N32 / N64 ABIs pass these in floating point
3229 registers. */
3230
3231static int
74ed0bb4
MD
3232mips_n32n64_fp_arg_chunk_p (struct gdbarch *gdbarch, struct type *arg_type,
3233 int offset)
8d26208a
DJ
3234{
3235 int i;
3236
3237 if (TYPE_CODE (arg_type) != TYPE_CODE_STRUCT)
3238 return 0;
3239
74ed0bb4 3240 if (MIPS_FPU_TYPE (gdbarch) != MIPS_FPU_DOUBLE)
8d26208a
DJ
3241 return 0;
3242
3243 if (TYPE_LENGTH (arg_type) < offset + MIPS64_REGSIZE)
3244 return 0;
3245
3246 for (i = 0; i < TYPE_NFIELDS (arg_type); i++)
3247 {
3248 int pos;
3249 struct type *field_type;
3250
3251 /* We're only looking at normal fields. */
5bc60cfb 3252 if (field_is_static (&TYPE_FIELD (arg_type, i))
8d26208a
DJ
3253 || (TYPE_FIELD_BITPOS (arg_type, i) % 8) != 0)
3254 continue;
3255
3256 /* If we have gone past the offset, there is no double to pass. */
3257 pos = TYPE_FIELD_BITPOS (arg_type, i) / 8;
3258 if (pos > offset)
3259 return 0;
3260
3261 field_type = check_typedef (TYPE_FIELD_TYPE (arg_type, i));
3262
3263 /* If this field is entirely before the requested offset, go
3264 on to the next one. */
3265 if (pos + TYPE_LENGTH (field_type) <= offset)
3266 continue;
3267
3268 /* If this is our special aligned double, we can stop. */
3269 if (TYPE_CODE (field_type) == TYPE_CODE_FLT
3270 && TYPE_LENGTH (field_type) == MIPS64_REGSIZE)
3271 return 1;
3272
3273 /* This field starts at or before the requested offset, and
3274 overlaps it. If it is a structure, recurse inwards. */
74ed0bb4 3275 return mips_n32n64_fp_arg_chunk_p (gdbarch, field_type, offset - pos);
8d26208a
DJ
3276 }
3277
3278 return 0;
3279}
3280
f7ab6ec6 3281static CORE_ADDR
7d9b040b 3282mips_n32n64_push_dummy_call (struct gdbarch *gdbarch, struct value *function,
6d82d43b
AC
3283 struct regcache *regcache, CORE_ADDR bp_addr,
3284 int nargs, struct value **args, CORE_ADDR sp,
3285 int struct_return, CORE_ADDR struct_addr)
cb3d25d1
MS
3286{
3287 int argreg;
3288 int float_argreg;
3289 int argnum;
3290 int len = 0;
3291 int stack_offset = 0;
480d3dd2 3292 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
e17a4113 3293 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
7d9b040b 3294 CORE_ADDR func_addr = find_function_addr (function, NULL);
cb3d25d1 3295
25ab4790
AC
3296 /* For shared libraries, "t9" needs to point at the function
3297 address. */
4c7d22cb 3298 regcache_cooked_write_signed (regcache, MIPS_T9_REGNUM, func_addr);
25ab4790
AC
3299
3300 /* Set the return address register to point to the entry point of
3301 the program, where a breakpoint lies in wait. */
4c7d22cb 3302 regcache_cooked_write_signed (regcache, MIPS_RA_REGNUM, bp_addr);
25ab4790 3303
cb3d25d1
MS
3304 /* First ensure that the stack and structure return address (if any)
3305 are properly aligned. The stack has to be at least 64-bit
3306 aligned even on 32-bit machines, because doubles must be 64-bit
3307 aligned. For n32 and n64, stack frames need to be 128-bit
3308 aligned, so we round to this widest known alignment. */
3309
5b03f266
AC
3310 sp = align_down (sp, 16);
3311 struct_addr = align_down (struct_addr, 16);
cb3d25d1
MS
3312
3313 /* Now make space on the stack for the args. */
3314 for (argnum = 0; argnum < nargs; argnum++)
1a69e1e4 3315 len += align_up (TYPE_LENGTH (value_type (args[argnum])), MIPS64_REGSIZE);
5b03f266 3316 sp -= align_up (len, 16);
cb3d25d1
MS
3317
3318 if (mips_debug)
6d82d43b 3319 fprintf_unfiltered (gdb_stdlog,
5af949e3
UW
3320 "mips_n32n64_push_dummy_call: sp=%s allocated %ld\n",
3321 paddress (gdbarch, sp), (long) align_up (len, 16));
cb3d25d1
MS
3322
3323 /* Initialize the integer and float register pointers. */
4c7d22cb 3324 argreg = MIPS_A0_REGNUM;
72a155b4 3325 float_argreg = mips_fpa0_regnum (gdbarch);
cb3d25d1 3326
46e0f506 3327 /* The struct_return pointer occupies the first parameter-passing reg. */
cb3d25d1
MS
3328 if (struct_return)
3329 {
3330 if (mips_debug)
3331 fprintf_unfiltered (gdb_stdlog,
025bb325
MS
3332 "mips_n32n64_push_dummy_call: "
3333 "struct_return reg=%d %s\n",
5af949e3 3334 argreg, paddress (gdbarch, struct_addr));
9c9acae0 3335 regcache_cooked_write_unsigned (regcache, argreg++, struct_addr);
cb3d25d1
MS
3336 }
3337
3338 /* Now load as many as possible of the first arguments into
3339 registers, and push the rest onto the stack. Loop thru args
3340 from first to last. */
3341 for (argnum = 0; argnum < nargs; argnum++)
3342 {
47a35522 3343 const gdb_byte *val;
cb3d25d1 3344 struct value *arg = args[argnum];
4991999e 3345 struct type *arg_type = check_typedef (value_type (arg));
cb3d25d1
MS
3346 int len = TYPE_LENGTH (arg_type);
3347 enum type_code typecode = TYPE_CODE (arg_type);
3348
3349 if (mips_debug)
3350 fprintf_unfiltered (gdb_stdlog,
25ab4790 3351 "mips_n32n64_push_dummy_call: %d len=%d type=%d",
cb3d25d1
MS
3352 argnum + 1, len, (int) typecode);
3353
47a35522 3354 val = value_contents (arg);
cb3d25d1 3355
5b68030f
JM
3356 /* A 128-bit long double value requires an even-odd pair of
3357 floating-point registers. */
3358 if (len == 16
3359 && fp_register_arg_p (gdbarch, typecode, arg_type)
3360 && (float_argreg & 1))
3361 {
3362 float_argreg++;
3363 argreg++;
3364 }
3365
74ed0bb4
MD
3366 if (fp_register_arg_p (gdbarch, typecode, arg_type)
3367 && argreg <= MIPS_LAST_ARG_REGNUM (gdbarch))
cb3d25d1
MS
3368 {
3369 /* This is a floating point value that fits entirely
5b68030f
JM
3370 in a single register or a pair of registers. */
3371 int reglen = (len <= MIPS64_REGSIZE ? len : MIPS64_REGSIZE);
e17a4113 3372 LONGEST regval = extract_unsigned_integer (val, reglen, byte_order);
cb3d25d1
MS
3373 if (mips_debug)
3374 fprintf_unfiltered (gdb_stdlog, " - fpreg=%d val=%s",
5b68030f 3375 float_argreg, phex (regval, reglen));
8d26208a 3376 regcache_cooked_write_unsigned (regcache, float_argreg, regval);
cb3d25d1
MS
3377
3378 if (mips_debug)
3379 fprintf_unfiltered (gdb_stdlog, " - reg=%d val=%s",
5b68030f 3380 argreg, phex (regval, reglen));
9c9acae0 3381 regcache_cooked_write_unsigned (regcache, argreg, regval);
8d26208a
DJ
3382 float_argreg++;
3383 argreg++;
5b68030f
JM
3384 if (len == 16)
3385 {
e17a4113
UW
3386 regval = extract_unsigned_integer (val + reglen,
3387 reglen, byte_order);
5b68030f
JM
3388 if (mips_debug)
3389 fprintf_unfiltered (gdb_stdlog, " - fpreg=%d val=%s",
3390 float_argreg, phex (regval, reglen));
3391 regcache_cooked_write_unsigned (regcache, float_argreg, regval);
3392
3393 if (mips_debug)
3394 fprintf_unfiltered (gdb_stdlog, " - reg=%d val=%s",
3395 argreg, phex (regval, reglen));
3396 regcache_cooked_write_unsigned (regcache, argreg, regval);
3397 float_argreg++;
3398 argreg++;
3399 }
cb3d25d1
MS
3400 }
3401 else
3402 {
3403 /* Copy the argument to general registers or the stack in
3404 register-sized pieces. Large arguments are split between
3405 registers and stack. */
ab2e1992
MR
3406 /* For N32/N64, structs, unions, or other composite types are
3407 treated as a sequence of doublewords, and are passed in integer
3408 or floating point registers as though they were simple scalar
3409 parameters to the extent that they fit, with any excess on the
3410 stack packed according to the normal memory layout of the
3411 object.
3412 The caller does not reserve space for the register arguments;
3413 the callee is responsible for reserving it if required. */
cb3d25d1 3414 /* Note: Floating-point values that didn't fit into an FP
6d82d43b 3415 register are only written to memory. */
cb3d25d1
MS
3416 while (len > 0)
3417 {
ad018eee 3418 /* Remember if the argument was written to the stack. */
cb3d25d1 3419 int stack_used_p = 0;
1a69e1e4 3420 int partial_len = (len < MIPS64_REGSIZE ? len : MIPS64_REGSIZE);
cb3d25d1
MS
3421
3422 if (mips_debug)
3423 fprintf_unfiltered (gdb_stdlog, " -- partial=%d",
3424 partial_len);
3425
74ed0bb4
MD
3426 if (fp_register_arg_p (gdbarch, typecode, arg_type))
3427 gdb_assert (argreg > MIPS_LAST_ARG_REGNUM (gdbarch));
8d26208a 3428
cb3d25d1 3429 /* Write this portion of the argument to the stack. */
74ed0bb4 3430 if (argreg > MIPS_LAST_ARG_REGNUM (gdbarch))
cb3d25d1
MS
3431 {
3432 /* Should shorter than int integer values be
025bb325 3433 promoted to int before being stored? */
cb3d25d1
MS
3434 int longword_offset = 0;
3435 CORE_ADDR addr;
3436 stack_used_p = 1;
72a155b4 3437 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG)
cb3d25d1 3438 {
1a69e1e4 3439 if ((typecode == TYPE_CODE_INT
5b68030f 3440 || typecode == TYPE_CODE_PTR)
1a69e1e4
DJ
3441 && len <= 4)
3442 longword_offset = MIPS64_REGSIZE - len;
cb3d25d1
MS
3443 }
3444
3445 if (mips_debug)
3446 {
5af949e3
UW
3447 fprintf_unfiltered (gdb_stdlog, " - stack_offset=%s",
3448 paddress (gdbarch, stack_offset));
3449 fprintf_unfiltered (gdb_stdlog, " longword_offset=%s",
3450 paddress (gdbarch, longword_offset));
cb3d25d1
MS
3451 }
3452
3453 addr = sp + stack_offset + longword_offset;
3454
3455 if (mips_debug)
3456 {
3457 int i;
5af949e3
UW
3458 fprintf_unfiltered (gdb_stdlog, " @%s ",
3459 paddress (gdbarch, addr));
cb3d25d1
MS
3460 for (i = 0; i < partial_len; i++)
3461 {
6d82d43b 3462 fprintf_unfiltered (gdb_stdlog, "%02x",
cb3d25d1
MS
3463 val[i] & 0xff);
3464 }
3465 }
3466 write_memory (addr, val, partial_len);
3467 }
3468
3469 /* Note!!! This is NOT an else clause. Odd sized
8d26208a 3470 structs may go thru BOTH paths. */
cb3d25d1 3471 /* Write this portion of the argument to a general
6d82d43b 3472 purpose register. */
74ed0bb4 3473 if (argreg <= MIPS_LAST_ARG_REGNUM (gdbarch))
cb3d25d1 3474 {
5863b5d5
MR
3475 LONGEST regval;
3476
3477 /* Sign extend pointers, 32-bit integers and signed
3478 16-bit and 8-bit integers; everything else is taken
3479 as is. */
3480
3481 if ((partial_len == 4
3482 && (typecode == TYPE_CODE_PTR
3483 || typecode == TYPE_CODE_INT))
3484 || (partial_len < 4
3485 && typecode == TYPE_CODE_INT
3486 && !TYPE_UNSIGNED (arg_type)))
e17a4113
UW
3487 regval = extract_signed_integer (val, partial_len,
3488 byte_order);
5863b5d5 3489 else
e17a4113
UW
3490 regval = extract_unsigned_integer (val, partial_len,
3491 byte_order);
cb3d25d1
MS
3492
3493 /* A non-floating-point argument being passed in a
3494 general register. If a struct or union, and if
3495 the remaining length is smaller than the register
3496 size, we have to adjust the register value on
3497 big endian targets.
3498
3499 It does not seem to be necessary to do the
1a69e1e4 3500 same for integral types. */
cb3d25d1 3501
72a155b4 3502 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG
1a69e1e4 3503 && partial_len < MIPS64_REGSIZE
06f9a1af
MR
3504 && (typecode == TYPE_CODE_STRUCT
3505 || typecode == TYPE_CODE_UNION))
1a69e1e4 3506 regval <<= ((MIPS64_REGSIZE - partial_len)
9ecf7166 3507 * TARGET_CHAR_BIT);
cb3d25d1
MS
3508
3509 if (mips_debug)
3510 fprintf_filtered (gdb_stdlog, " - reg=%d val=%s",
3511 argreg,
1a69e1e4 3512 phex (regval, MIPS64_REGSIZE));
9c9acae0 3513 regcache_cooked_write_unsigned (regcache, argreg, regval);
8d26208a 3514
74ed0bb4 3515 if (mips_n32n64_fp_arg_chunk_p (gdbarch, arg_type,
8d26208a
DJ
3516 TYPE_LENGTH (arg_type) - len))
3517 {
3518 if (mips_debug)
3519 fprintf_filtered (gdb_stdlog, " - fpreg=%d val=%s",
3520 float_argreg,
3521 phex (regval, MIPS64_REGSIZE));
3522 regcache_cooked_write_unsigned (regcache, float_argreg,
3523 regval);
3524 }
3525
3526 float_argreg++;
cb3d25d1
MS
3527 argreg++;
3528 }
3529
3530 len -= partial_len;
3531 val += partial_len;
3532
b021a221
MS
3533 /* Compute the offset into the stack at which we will
3534 copy the next parameter.
cb3d25d1
MS
3535
3536 In N32 (N64?), the stack_offset only needs to be
3537 adjusted when it has been used. */
3538
3539 if (stack_used_p)
1a69e1e4 3540 stack_offset += align_up (partial_len, MIPS64_REGSIZE);
cb3d25d1
MS
3541 }
3542 }
3543 if (mips_debug)
3544 fprintf_unfiltered (gdb_stdlog, "\n");
3545 }
3546
f10683bb 3547 regcache_cooked_write_signed (regcache, MIPS_SP_REGNUM, sp);
310e9b6a 3548
cb3d25d1
MS
3549 /* Return adjusted stack pointer. */
3550 return sp;
3551}
3552
6d82d43b 3553static enum return_value_convention
c055b101 3554mips_n32n64_return_value (struct gdbarch *gdbarch, struct type *func_type,
6d82d43b 3555 struct type *type, struct regcache *regcache,
47a35522 3556 gdb_byte *readbuf, const gdb_byte *writebuf)
ebafbe83 3557{
72a155b4 3558 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
b18bb924
MR
3559
3560 /* From MIPSpro N32 ABI Handbook, Document Number: 007-2816-004
3561
3562 Function results are returned in $2 (and $3 if needed), or $f0 (and $f2
3563 if needed), as appropriate for the type. Composite results (struct,
3564 union, or array) are returned in $2/$f0 and $3/$f2 according to the
3565 following rules:
3566
3567 * A struct with only one or two floating point fields is returned in $f0
3568 (and $f2 if necessary). This is a generalization of the Fortran COMPLEX
3569 case.
3570
f08877ba 3571 * Any other composite results of at most 128 bits are returned in
b18bb924
MR
3572 $2 (first 64 bits) and $3 (remainder, if necessary).
3573
3574 * Larger composite results are handled by converting the function to a
3575 procedure with an implicit first parameter, which is a pointer to an area
3576 reserved by the caller to receive the result. [The o32-bit ABI requires
3577 that all composite results be handled by conversion to implicit first
3578 parameters. The MIPS/SGI Fortran implementation has always made a
3579 specific exception to return COMPLEX results in the floating point
3580 registers.] */
3581
f08877ba 3582 if (TYPE_LENGTH (type) > 2 * MIPS64_REGSIZE)
6d82d43b 3583 return RETURN_VALUE_STRUCT_CONVENTION;
d05f6826
DJ
3584 else if (TYPE_CODE (type) == TYPE_CODE_FLT
3585 && TYPE_LENGTH (type) == 16
3586 && tdep->mips_fpu_type != MIPS_FPU_NONE)
3587 {
3588 /* A 128-bit floating-point value fills both $f0 and $f2. The
3589 two registers are used in the same as memory order, so the
3590 eight bytes with the lower memory address are in $f0. */
3591 if (mips_debug)
3592 fprintf_unfiltered (gdb_stderr, "Return float in $f0 and $f2\n");
ba32f989 3593 mips_xfer_register (gdbarch, regcache,
72a155b4
UW
3594 gdbarch_num_regs (gdbarch)
3595 + mips_regnum (gdbarch)->fp0,
3596 8, gdbarch_byte_order (gdbarch),
4c6b5505 3597 readbuf, writebuf, 0);
ba32f989 3598 mips_xfer_register (gdbarch, regcache,
72a155b4
UW
3599 gdbarch_num_regs (gdbarch)
3600 + mips_regnum (gdbarch)->fp0 + 2,
3601 8, gdbarch_byte_order (gdbarch),
4c6b5505 3602 readbuf ? readbuf + 8 : readbuf,
d05f6826
DJ
3603 writebuf ? writebuf + 8 : writebuf, 0);
3604 return RETURN_VALUE_REGISTER_CONVENTION;
3605 }
6d82d43b
AC
3606 else if (TYPE_CODE (type) == TYPE_CODE_FLT
3607 && tdep->mips_fpu_type != MIPS_FPU_NONE)
3608 {
59aa1faa 3609 /* A single or double floating-point value that fits in FP0. */
6d82d43b
AC
3610 if (mips_debug)
3611 fprintf_unfiltered (gdb_stderr, "Return float in $fp0\n");
ba32f989 3612 mips_xfer_register (gdbarch, regcache,
72a155b4
UW
3613 gdbarch_num_regs (gdbarch)
3614 + mips_regnum (gdbarch)->fp0,
6d82d43b 3615 TYPE_LENGTH (type),
72a155b4 3616 gdbarch_byte_order (gdbarch),
4c6b5505 3617 readbuf, writebuf, 0);
6d82d43b
AC
3618 return RETURN_VALUE_REGISTER_CONVENTION;
3619 }
3620 else if (TYPE_CODE (type) == TYPE_CODE_STRUCT
3621 && TYPE_NFIELDS (type) <= 2
3622 && TYPE_NFIELDS (type) >= 1
3623 && ((TYPE_NFIELDS (type) == 1
b18bb924 3624 && (TYPE_CODE (check_typedef (TYPE_FIELD_TYPE (type, 0)))
6d82d43b
AC
3625 == TYPE_CODE_FLT))
3626 || (TYPE_NFIELDS (type) == 2
b18bb924 3627 && (TYPE_CODE (check_typedef (TYPE_FIELD_TYPE (type, 0)))
6d82d43b 3628 == TYPE_CODE_FLT)
b18bb924 3629 && (TYPE_CODE (check_typedef (TYPE_FIELD_TYPE (type, 1)))
5b68030f 3630 == TYPE_CODE_FLT))))
6d82d43b
AC
3631 {
3632 /* A struct that contains one or two floats. Each value is part
3633 in the least significant part of their floating point
5b68030f 3634 register (or GPR, for soft float). */
6d82d43b
AC
3635 int regnum;
3636 int field;
5b68030f
JM
3637 for (field = 0, regnum = (tdep->mips_fpu_type != MIPS_FPU_NONE
3638 ? mips_regnum (gdbarch)->fp0
3639 : MIPS_V0_REGNUM);
6d82d43b
AC
3640 field < TYPE_NFIELDS (type); field++, regnum += 2)
3641 {
3642 int offset = (FIELD_BITPOS (TYPE_FIELDS (type)[field])
3643 / TARGET_CHAR_BIT);
3644 if (mips_debug)
3645 fprintf_unfiltered (gdb_stderr, "Return float struct+%d\n",
3646 offset);
5b68030f
JM
3647 if (TYPE_LENGTH (TYPE_FIELD_TYPE (type, field)) == 16)
3648 {
3649 /* A 16-byte long double field goes in two consecutive
3650 registers. */
3651 mips_xfer_register (gdbarch, regcache,
3652 gdbarch_num_regs (gdbarch) + regnum,
3653 8,
3654 gdbarch_byte_order (gdbarch),
3655 readbuf, writebuf, offset);
3656 mips_xfer_register (gdbarch, regcache,
3657 gdbarch_num_regs (gdbarch) + regnum + 1,
3658 8,
3659 gdbarch_byte_order (gdbarch),
3660 readbuf, writebuf, offset + 8);
3661 }
3662 else
3663 mips_xfer_register (gdbarch, regcache,
3664 gdbarch_num_regs (gdbarch) + regnum,
3665 TYPE_LENGTH (TYPE_FIELD_TYPE (type, field)),
3666 gdbarch_byte_order (gdbarch),
3667 readbuf, writebuf, offset);
6d82d43b
AC
3668 }
3669 return RETURN_VALUE_REGISTER_CONVENTION;
3670 }
3671 else if (TYPE_CODE (type) == TYPE_CODE_STRUCT
f08877ba
JB
3672 || TYPE_CODE (type) == TYPE_CODE_UNION
3673 || TYPE_CODE (type) == TYPE_CODE_ARRAY)
6d82d43b 3674 {
f08877ba 3675 /* A composite type. Extract the left justified value,
6d82d43b
AC
3676 regardless of the byte order. I.e. DO NOT USE
3677 mips_xfer_lower. */
3678 int offset;
3679 int regnum;
4c7d22cb 3680 for (offset = 0, regnum = MIPS_V0_REGNUM;
6d82d43b 3681 offset < TYPE_LENGTH (type);
72a155b4 3682 offset += register_size (gdbarch, regnum), regnum++)
6d82d43b 3683 {
72a155b4 3684 int xfer = register_size (gdbarch, regnum);
6d82d43b
AC
3685 if (offset + xfer > TYPE_LENGTH (type))
3686 xfer = TYPE_LENGTH (type) - offset;
3687 if (mips_debug)
3688 fprintf_unfiltered (gdb_stderr, "Return struct+%d:%d in $%d\n",
3689 offset, xfer, regnum);
ba32f989
DJ
3690 mips_xfer_register (gdbarch, regcache,
3691 gdbarch_num_regs (gdbarch) + regnum,
72a155b4
UW
3692 xfer, BFD_ENDIAN_UNKNOWN, readbuf, writebuf,
3693 offset);
6d82d43b
AC
3694 }
3695 return RETURN_VALUE_REGISTER_CONVENTION;
3696 }
3697 else
3698 {
3699 /* A scalar extract each part but least-significant-byte
3700 justified. */
3701 int offset;
3702 int regnum;
4c7d22cb 3703 for (offset = 0, regnum = MIPS_V0_REGNUM;
6d82d43b 3704 offset < TYPE_LENGTH (type);
72a155b4 3705 offset += register_size (gdbarch, regnum), regnum++)
6d82d43b 3706 {
72a155b4 3707 int xfer = register_size (gdbarch, regnum);
6d82d43b
AC
3708 if (offset + xfer > TYPE_LENGTH (type))
3709 xfer = TYPE_LENGTH (type) - offset;
3710 if (mips_debug)
3711 fprintf_unfiltered (gdb_stderr, "Return scalar+%d:%d in $%d\n",
3712 offset, xfer, regnum);
ba32f989
DJ
3713 mips_xfer_register (gdbarch, regcache,
3714 gdbarch_num_regs (gdbarch) + regnum,
72a155b4 3715 xfer, gdbarch_byte_order (gdbarch),
4c6b5505 3716 readbuf, writebuf, offset);
6d82d43b
AC
3717 }
3718 return RETURN_VALUE_REGISTER_CONVENTION;
3719 }
3720}
3721
3722/* O32 ABI stuff. */
3723
3724static CORE_ADDR
7d9b040b 3725mips_o32_push_dummy_call (struct gdbarch *gdbarch, struct value *function,
6d82d43b
AC
3726 struct regcache *regcache, CORE_ADDR bp_addr,
3727 int nargs, struct value **args, CORE_ADDR sp,
3728 int struct_return, CORE_ADDR struct_addr)
3729{
3730 int argreg;
3731 int float_argreg;
3732 int argnum;
3733 int len = 0;
3734 int stack_offset = 0;
3735 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
e17a4113 3736 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
7d9b040b 3737 CORE_ADDR func_addr = find_function_addr (function, NULL);
6d82d43b
AC
3738
3739 /* For shared libraries, "t9" needs to point at the function
3740 address. */
4c7d22cb 3741 regcache_cooked_write_signed (regcache, MIPS_T9_REGNUM, func_addr);
6d82d43b
AC
3742
3743 /* Set the return address register to point to the entry point of
3744 the program, where a breakpoint lies in wait. */
4c7d22cb 3745 regcache_cooked_write_signed (regcache, MIPS_RA_REGNUM, bp_addr);
6d82d43b
AC
3746
3747 /* First ensure that the stack and structure return address (if any)
3748 are properly aligned. The stack has to be at least 64-bit
3749 aligned even on 32-bit machines, because doubles must be 64-bit
ebafbe83
MS
3750 aligned. For n32 and n64, stack frames need to be 128-bit
3751 aligned, so we round to this widest known alignment. */
3752
5b03f266
AC
3753 sp = align_down (sp, 16);
3754 struct_addr = align_down (struct_addr, 16);
ebafbe83
MS
3755
3756 /* Now make space on the stack for the args. */
3757 for (argnum = 0; argnum < nargs; argnum++)
968b5391
MR
3758 {
3759 struct type *arg_type = check_typedef (value_type (args[argnum]));
3760 int arglen = TYPE_LENGTH (arg_type);
3761
3762 /* Align to double-word if necessary. */
2afd3f0a 3763 if (mips_type_needs_double_align (arg_type))
1a69e1e4 3764 len = align_up (len, MIPS32_REGSIZE * 2);
968b5391 3765 /* Allocate space on the stack. */
1a69e1e4 3766 len += align_up (arglen, MIPS32_REGSIZE);
968b5391 3767 }
5b03f266 3768 sp -= align_up (len, 16);
ebafbe83
MS
3769
3770 if (mips_debug)
6d82d43b 3771 fprintf_unfiltered (gdb_stdlog,
5af949e3
UW
3772 "mips_o32_push_dummy_call: sp=%s allocated %ld\n",
3773 paddress (gdbarch, sp), (long) align_up (len, 16));
ebafbe83
MS
3774
3775 /* Initialize the integer and float register pointers. */
4c7d22cb 3776 argreg = MIPS_A0_REGNUM;
72a155b4 3777 float_argreg = mips_fpa0_regnum (gdbarch);
ebafbe83 3778
bcb0cc15 3779 /* The struct_return pointer occupies the first parameter-passing reg. */
ebafbe83
MS
3780 if (struct_return)
3781 {
3782 if (mips_debug)
3783 fprintf_unfiltered (gdb_stdlog,
025bb325
MS
3784 "mips_o32_push_dummy_call: "
3785 "struct_return reg=%d %s\n",
5af949e3 3786 argreg, paddress (gdbarch, struct_addr));
9c9acae0 3787 regcache_cooked_write_unsigned (regcache, argreg++, struct_addr);
1a69e1e4 3788 stack_offset += MIPS32_REGSIZE;
ebafbe83
MS
3789 }
3790
3791 /* Now load as many as possible of the first arguments into
3792 registers, and push the rest onto the stack. Loop thru args
3793 from first to last. */
3794 for (argnum = 0; argnum < nargs; argnum++)
3795 {
47a35522 3796 const gdb_byte *val;
ebafbe83 3797 struct value *arg = args[argnum];
4991999e 3798 struct type *arg_type = check_typedef (value_type (arg));
ebafbe83
MS
3799 int len = TYPE_LENGTH (arg_type);
3800 enum type_code typecode = TYPE_CODE (arg_type);
3801
3802 if (mips_debug)
3803 fprintf_unfiltered (gdb_stdlog,
25ab4790 3804 "mips_o32_push_dummy_call: %d len=%d type=%d",
46cac009
AC
3805 argnum + 1, len, (int) typecode);
3806
47a35522 3807 val = value_contents (arg);
46cac009
AC
3808
3809 /* 32-bit ABIs always start floating point arguments in an
3810 even-numbered floating point register. Round the FP register
3811 up before the check to see if there are any FP registers
3812 left. O32/O64 targets also pass the FP in the integer
3813 registers so also round up normal registers. */
74ed0bb4 3814 if (fp_register_arg_p (gdbarch, typecode, arg_type))
46cac009
AC
3815 {
3816 if ((float_argreg & 1))
3817 float_argreg++;
3818 }
3819
3820 /* Floating point arguments passed in registers have to be
3821 treated specially. On 32-bit architectures, doubles
3822 are passed in register pairs; the even register gets
3823 the low word, and the odd register gets the high word.
3824 On O32/O64, the first two floating point arguments are
3825 also copied to general registers, because MIPS16 functions
3826 don't use float registers for arguments. This duplication of
3827 arguments in general registers can't hurt non-MIPS16 functions
3828 because those registers are normally skipped. */
3829
74ed0bb4
MD
3830 if (fp_register_arg_p (gdbarch, typecode, arg_type)
3831 && float_argreg <= MIPS_LAST_FP_ARG_REGNUM (gdbarch))
46cac009 3832 {
8b07f6d8 3833 if (register_size (gdbarch, float_argreg) < 8 && len == 8)
46cac009 3834 {
72a155b4 3835 int low_offset = gdbarch_byte_order (gdbarch)
4c6b5505 3836 == BFD_ENDIAN_BIG ? 4 : 0;
46cac009
AC
3837 unsigned long regval;
3838
3839 /* Write the low word of the double to the even register(s). */
e17a4113
UW
3840 regval = extract_unsigned_integer (val + low_offset,
3841 4, byte_order);
46cac009
AC
3842 if (mips_debug)
3843 fprintf_unfiltered (gdb_stdlog, " - fpreg=%d val=%s",
3844 float_argreg, phex (regval, 4));
025bb325
MS
3845 regcache_cooked_write_unsigned (regcache,
3846 float_argreg++, regval);
46cac009
AC
3847 if (mips_debug)
3848 fprintf_unfiltered (gdb_stdlog, " - reg=%d val=%s",
3849 argreg, phex (regval, 4));
9c9acae0 3850 regcache_cooked_write_unsigned (regcache, argreg++, regval);
46cac009
AC
3851
3852 /* Write the high word of the double to the odd register(s). */
e17a4113
UW
3853 regval = extract_unsigned_integer (val + 4 - low_offset,
3854 4, byte_order);
46cac009
AC
3855 if (mips_debug)
3856 fprintf_unfiltered (gdb_stdlog, " - fpreg=%d val=%s",
3857 float_argreg, phex (regval, 4));
025bb325
MS
3858 regcache_cooked_write_unsigned (regcache,
3859 float_argreg++, regval);
46cac009
AC
3860
3861 if (mips_debug)
3862 fprintf_unfiltered (gdb_stdlog, " - reg=%d val=%s",
3863 argreg, phex (regval, 4));
9c9acae0 3864 regcache_cooked_write_unsigned (regcache, argreg++, regval);
46cac009
AC
3865 }
3866 else
3867 {
3868 /* This is a floating point value that fits entirely
3869 in a single register. */
3870 /* On 32 bit ABI's the float_argreg is further adjusted
6d82d43b 3871 above to ensure that it is even register aligned. */
e17a4113 3872 LONGEST regval = extract_unsigned_integer (val, len, byte_order);
46cac009
AC
3873 if (mips_debug)
3874 fprintf_unfiltered (gdb_stdlog, " - fpreg=%d val=%s",
3875 float_argreg, phex (regval, len));
025bb325
MS
3876 regcache_cooked_write_unsigned (regcache,
3877 float_argreg++, regval);
5b68030f
JM
3878 /* Although two FP registers are reserved for each
3879 argument, only one corresponding integer register is
3880 reserved. */
46cac009
AC
3881 if (mips_debug)
3882 fprintf_unfiltered (gdb_stdlog, " - reg=%d val=%s",
3883 argreg, phex (regval, len));
5b68030f 3884 regcache_cooked_write_unsigned (regcache, argreg++, regval);
46cac009
AC
3885 }
3886 /* Reserve space for the FP register. */
1a69e1e4 3887 stack_offset += align_up (len, MIPS32_REGSIZE);
46cac009
AC
3888 }
3889 else
3890 {
3891 /* Copy the argument to general registers or the stack in
3892 register-sized pieces. Large arguments are split between
3893 registers and stack. */
1a69e1e4
DJ
3894 /* Note: structs whose size is not a multiple of MIPS32_REGSIZE
3895 are treated specially: Irix cc passes
d5ac5a39
AC
3896 them in registers where gcc sometimes puts them on the
3897 stack. For maximum compatibility, we will put them in
3898 both places. */
1a69e1e4
DJ
3899 int odd_sized_struct = (len > MIPS32_REGSIZE
3900 && len % MIPS32_REGSIZE != 0);
46cac009
AC
3901 /* Structures should be aligned to eight bytes (even arg registers)
3902 on MIPS_ABI_O32, if their first member has double precision. */
2afd3f0a 3903 if (mips_type_needs_double_align (arg_type))
46cac009
AC
3904 {
3905 if ((argreg & 1))
968b5391
MR
3906 {
3907 argreg++;
1a69e1e4 3908 stack_offset += MIPS32_REGSIZE;
968b5391 3909 }
46cac009 3910 }
46cac009
AC
3911 while (len > 0)
3912 {
3913 /* Remember if the argument was written to the stack. */
3914 int stack_used_p = 0;
1a69e1e4 3915 int partial_len = (len < MIPS32_REGSIZE ? len : MIPS32_REGSIZE);
46cac009
AC
3916
3917 if (mips_debug)
3918 fprintf_unfiltered (gdb_stdlog, " -- partial=%d",
3919 partial_len);
3920
3921 /* Write this portion of the argument to the stack. */
74ed0bb4 3922 if (argreg > MIPS_LAST_ARG_REGNUM (gdbarch)
968b5391 3923 || odd_sized_struct)
46cac009
AC
3924 {
3925 /* Should shorter than int integer values be
025bb325 3926 promoted to int before being stored? */
46cac009
AC
3927 int longword_offset = 0;
3928 CORE_ADDR addr;
3929 stack_used_p = 1;
46cac009
AC
3930
3931 if (mips_debug)
3932 {
5af949e3
UW
3933 fprintf_unfiltered (gdb_stdlog, " - stack_offset=%s",
3934 paddress (gdbarch, stack_offset));
3935 fprintf_unfiltered (gdb_stdlog, " longword_offset=%s",
3936 paddress (gdbarch, longword_offset));
46cac009
AC
3937 }
3938
3939 addr = sp + stack_offset + longword_offset;
3940
3941 if (mips_debug)
3942 {
3943 int i;
5af949e3
UW
3944 fprintf_unfiltered (gdb_stdlog, " @%s ",
3945 paddress (gdbarch, addr));
46cac009
AC
3946 for (i = 0; i < partial_len; i++)
3947 {
6d82d43b 3948 fprintf_unfiltered (gdb_stdlog, "%02x",
46cac009
AC
3949 val[i] & 0xff);
3950 }
3951 }
3952 write_memory (addr, val, partial_len);
3953 }
3954
3955 /* Note!!! This is NOT an else clause. Odd sized
968b5391 3956 structs may go thru BOTH paths. */
46cac009 3957 /* Write this portion of the argument to a general
6d82d43b 3958 purpose register. */
74ed0bb4 3959 if (argreg <= MIPS_LAST_ARG_REGNUM (gdbarch))
46cac009 3960 {
e17a4113
UW
3961 LONGEST regval = extract_signed_integer (val, partial_len,
3962 byte_order);
4246e332 3963 /* Value may need to be sign extended, because
1b13c4f6 3964 mips_isa_regsize() != mips_abi_regsize(). */
46cac009
AC
3965
3966 /* A non-floating-point argument being passed in a
3967 general register. If a struct or union, and if
3968 the remaining length is smaller than the register
3969 size, we have to adjust the register value on
3970 big endian targets.
3971
3972 It does not seem to be necessary to do the
3973 same for integral types.
3974
3975 Also don't do this adjustment on O64 binaries.
3976
3977 cagney/2001-07-23: gdb/179: Also, GCC, when
3978 outputting LE O32 with sizeof (struct) <
e914cb17
MR
3979 mips_abi_regsize(), generates a left shift
3980 as part of storing the argument in a register
3981 (the left shift isn't generated when
1b13c4f6 3982 sizeof (struct) >= mips_abi_regsize()). Since
480d3dd2
AC
3983 it is quite possible that this is GCC
3984 contradicting the LE/O32 ABI, GDB has not been
3985 adjusted to accommodate this. Either someone
3986 needs to demonstrate that the LE/O32 ABI
3987 specifies such a left shift OR this new ABI gets
3988 identified as such and GDB gets tweaked
3989 accordingly. */
3990
72a155b4 3991 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG
1a69e1e4 3992 && partial_len < MIPS32_REGSIZE
06f9a1af
MR
3993 && (typecode == TYPE_CODE_STRUCT
3994 || typecode == TYPE_CODE_UNION))
1a69e1e4 3995 regval <<= ((MIPS32_REGSIZE - partial_len)
9ecf7166 3996 * TARGET_CHAR_BIT);
46cac009
AC
3997
3998 if (mips_debug)
3999 fprintf_filtered (gdb_stdlog, " - reg=%d val=%s",
4000 argreg,
1a69e1e4 4001 phex (regval, MIPS32_REGSIZE));
9c9acae0 4002 regcache_cooked_write_unsigned (regcache, argreg, regval);
46cac009
AC
4003 argreg++;
4004
4005 /* Prevent subsequent floating point arguments from
4006 being passed in floating point registers. */
74ed0bb4 4007 float_argreg = MIPS_LAST_FP_ARG_REGNUM (gdbarch) + 1;
46cac009
AC
4008 }
4009
4010 len -= partial_len;
4011 val += partial_len;
4012
b021a221
MS
4013 /* Compute the offset into the stack at which we will
4014 copy the next parameter.
46cac009 4015
6d82d43b
AC
4016 In older ABIs, the caller reserved space for
4017 registers that contained arguments. This was loosely
4018 refered to as their "home". Consequently, space is
4019 always allocated. */
46cac009 4020
1a69e1e4 4021 stack_offset += align_up (partial_len, MIPS32_REGSIZE);
46cac009
AC
4022 }
4023 }
4024 if (mips_debug)
4025 fprintf_unfiltered (gdb_stdlog, "\n");
4026 }
4027
f10683bb 4028 regcache_cooked_write_signed (regcache, MIPS_SP_REGNUM, sp);
310e9b6a 4029
46cac009
AC
4030 /* Return adjusted stack pointer. */
4031 return sp;
4032}
4033
6d82d43b 4034static enum return_value_convention
c055b101
CV
4035mips_o32_return_value (struct gdbarch *gdbarch, struct type *func_type,
4036 struct type *type, struct regcache *regcache,
47a35522 4037 gdb_byte *readbuf, const gdb_byte *writebuf)
6d82d43b 4038{
72a155b4 4039 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
6d82d43b
AC
4040
4041 if (TYPE_CODE (type) == TYPE_CODE_STRUCT
4042 || TYPE_CODE (type) == TYPE_CODE_UNION
4043 || TYPE_CODE (type) == TYPE_CODE_ARRAY)
4044 return RETURN_VALUE_STRUCT_CONVENTION;
4045 else if (TYPE_CODE (type) == TYPE_CODE_FLT
4046 && TYPE_LENGTH (type) == 4 && tdep->mips_fpu_type != MIPS_FPU_NONE)
4047 {
4048 /* A single-precision floating-point value. It fits in the
4049 least significant part of FP0. */
4050 if (mips_debug)
4051 fprintf_unfiltered (gdb_stderr, "Return float in $fp0\n");
ba32f989 4052 mips_xfer_register (gdbarch, regcache,
72a155b4
UW
4053 gdbarch_num_regs (gdbarch)
4054 + mips_regnum (gdbarch)->fp0,
6d82d43b 4055 TYPE_LENGTH (type),
72a155b4 4056 gdbarch_byte_order (gdbarch),
4c6b5505 4057 readbuf, writebuf, 0);
6d82d43b
AC
4058 return RETURN_VALUE_REGISTER_CONVENTION;
4059 }
4060 else if (TYPE_CODE (type) == TYPE_CODE_FLT
4061 && TYPE_LENGTH (type) == 8 && tdep->mips_fpu_type != MIPS_FPU_NONE)
4062 {
4063 /* A double-precision floating-point value. The most
4064 significant part goes in FP1, and the least significant in
4065 FP0. */
4066 if (mips_debug)
4067 fprintf_unfiltered (gdb_stderr, "Return float in $fp1/$fp0\n");
72a155b4 4068 switch (gdbarch_byte_order (gdbarch))
6d82d43b
AC
4069 {
4070 case BFD_ENDIAN_LITTLE:
ba32f989 4071 mips_xfer_register (gdbarch, regcache,
72a155b4
UW
4072 gdbarch_num_regs (gdbarch)
4073 + mips_regnum (gdbarch)->fp0 +
4074 0, 4, gdbarch_byte_order (gdbarch),
4c6b5505 4075 readbuf, writebuf, 0);
ba32f989 4076 mips_xfer_register (gdbarch, regcache,
72a155b4
UW
4077 gdbarch_num_regs (gdbarch)
4078 + mips_regnum (gdbarch)->fp0 + 1,
4079 4, gdbarch_byte_order (gdbarch),
4c6b5505 4080 readbuf, writebuf, 4);
6d82d43b
AC
4081 break;
4082 case BFD_ENDIAN_BIG:
ba32f989 4083 mips_xfer_register (gdbarch, regcache,
72a155b4
UW
4084 gdbarch_num_regs (gdbarch)
4085 + mips_regnum (gdbarch)->fp0 + 1,
4086 4, gdbarch_byte_order (gdbarch),
4c6b5505 4087 readbuf, writebuf, 0);
ba32f989 4088 mips_xfer_register (gdbarch, regcache,
72a155b4
UW
4089 gdbarch_num_regs (gdbarch)
4090 + mips_regnum (gdbarch)->fp0 + 0,
4091 4, gdbarch_byte_order (gdbarch),
4c6b5505 4092 readbuf, writebuf, 4);
6d82d43b
AC
4093 break;
4094 default:
e2e0b3e5 4095 internal_error (__FILE__, __LINE__, _("bad switch"));
6d82d43b
AC
4096 }
4097 return RETURN_VALUE_REGISTER_CONVENTION;
4098 }
4099#if 0
4100 else if (TYPE_CODE (type) == TYPE_CODE_STRUCT
4101 && TYPE_NFIELDS (type) <= 2
4102 && TYPE_NFIELDS (type) >= 1
4103 && ((TYPE_NFIELDS (type) == 1
4104 && (TYPE_CODE (TYPE_FIELD_TYPE (type, 0))
4105 == TYPE_CODE_FLT))
4106 || (TYPE_NFIELDS (type) == 2
4107 && (TYPE_CODE (TYPE_FIELD_TYPE (type, 0))
4108 == TYPE_CODE_FLT)
4109 && (TYPE_CODE (TYPE_FIELD_TYPE (type, 1))
4110 == TYPE_CODE_FLT)))
4111 && tdep->mips_fpu_type != MIPS_FPU_NONE)
4112 {
4113 /* A struct that contains one or two floats. Each value is part
4114 in the least significant part of their floating point
4115 register.. */
870cd05e 4116 gdb_byte reg[MAX_REGISTER_SIZE];
6d82d43b
AC
4117 int regnum;
4118 int field;
72a155b4 4119 for (field = 0, regnum = mips_regnum (gdbarch)->fp0;
6d82d43b
AC
4120 field < TYPE_NFIELDS (type); field++, regnum += 2)
4121 {
4122 int offset = (FIELD_BITPOS (TYPE_FIELDS (type)[field])
4123 / TARGET_CHAR_BIT);
4124 if (mips_debug)
4125 fprintf_unfiltered (gdb_stderr, "Return float struct+%d\n",
4126 offset);
ba32f989
DJ
4127 mips_xfer_register (gdbarch, regcache,
4128 gdbarch_num_regs (gdbarch) + regnum,
6d82d43b 4129 TYPE_LENGTH (TYPE_FIELD_TYPE (type, field)),
72a155b4 4130 gdbarch_byte_order (gdbarch),
4c6b5505 4131 readbuf, writebuf, offset);
6d82d43b
AC
4132 }
4133 return RETURN_VALUE_REGISTER_CONVENTION;
4134 }
4135#endif
4136#if 0
4137 else if (TYPE_CODE (type) == TYPE_CODE_STRUCT
4138 || TYPE_CODE (type) == TYPE_CODE_UNION)
4139 {
4140 /* A structure or union. Extract the left justified value,
4141 regardless of the byte order. I.e. DO NOT USE
4142 mips_xfer_lower. */
4143 int offset;
4144 int regnum;
4c7d22cb 4145 for (offset = 0, regnum = MIPS_V0_REGNUM;
6d82d43b 4146 offset < TYPE_LENGTH (type);
72a155b4 4147 offset += register_size (gdbarch, regnum), regnum++)
6d82d43b 4148 {
72a155b4 4149 int xfer = register_size (gdbarch, regnum);
6d82d43b
AC
4150 if (offset + xfer > TYPE_LENGTH (type))
4151 xfer = TYPE_LENGTH (type) - offset;
4152 if (mips_debug)
4153 fprintf_unfiltered (gdb_stderr, "Return struct+%d:%d in $%d\n",
4154 offset, xfer, regnum);
ba32f989
DJ
4155 mips_xfer_register (gdbarch, regcache,
4156 gdbarch_num_regs (gdbarch) + regnum, xfer,
6d82d43b
AC
4157 BFD_ENDIAN_UNKNOWN, readbuf, writebuf, offset);
4158 }
4159 return RETURN_VALUE_REGISTER_CONVENTION;
4160 }
4161#endif
4162 else
4163 {
4164 /* A scalar extract each part but least-significant-byte
4165 justified. o32 thinks registers are 4 byte, regardless of
1a69e1e4 4166 the ISA. */
6d82d43b
AC
4167 int offset;
4168 int regnum;
4c7d22cb 4169 for (offset = 0, regnum = MIPS_V0_REGNUM;
6d82d43b 4170 offset < TYPE_LENGTH (type);
1a69e1e4 4171 offset += MIPS32_REGSIZE, regnum++)
6d82d43b 4172 {
1a69e1e4 4173 int xfer = MIPS32_REGSIZE;
6d82d43b
AC
4174 if (offset + xfer > TYPE_LENGTH (type))
4175 xfer = TYPE_LENGTH (type) - offset;
4176 if (mips_debug)
4177 fprintf_unfiltered (gdb_stderr, "Return scalar+%d:%d in $%d\n",
4178 offset, xfer, regnum);
ba32f989
DJ
4179 mips_xfer_register (gdbarch, regcache,
4180 gdbarch_num_regs (gdbarch) + regnum, xfer,
72a155b4 4181 gdbarch_byte_order (gdbarch),
4c6b5505 4182 readbuf, writebuf, offset);
6d82d43b
AC
4183 }
4184 return RETURN_VALUE_REGISTER_CONVENTION;
4185 }
4186}
4187
4188/* O64 ABI. This is a hacked up kind of 64-bit version of the o32
4189 ABI. */
46cac009
AC
4190
4191static CORE_ADDR
7d9b040b 4192mips_o64_push_dummy_call (struct gdbarch *gdbarch, struct value *function,
6d82d43b
AC
4193 struct regcache *regcache, CORE_ADDR bp_addr,
4194 int nargs,
4195 struct value **args, CORE_ADDR sp,
4196 int struct_return, CORE_ADDR struct_addr)
46cac009
AC
4197{
4198 int argreg;
4199 int float_argreg;
4200 int argnum;
4201 int len = 0;
4202 int stack_offset = 0;
480d3dd2 4203 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
e17a4113 4204 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
7d9b040b 4205 CORE_ADDR func_addr = find_function_addr (function, NULL);
46cac009 4206
25ab4790
AC
4207 /* For shared libraries, "t9" needs to point at the function
4208 address. */
4c7d22cb 4209 regcache_cooked_write_signed (regcache, MIPS_T9_REGNUM, func_addr);
25ab4790
AC
4210
4211 /* Set the return address register to point to the entry point of
4212 the program, where a breakpoint lies in wait. */
4c7d22cb 4213 regcache_cooked_write_signed (regcache, MIPS_RA_REGNUM, bp_addr);
25ab4790 4214
46cac009
AC
4215 /* First ensure that the stack and structure return address (if any)
4216 are properly aligned. The stack has to be at least 64-bit
4217 aligned even on 32-bit machines, because doubles must be 64-bit
4218 aligned. For n32 and n64, stack frames need to be 128-bit
4219 aligned, so we round to this widest known alignment. */
4220
5b03f266
AC
4221 sp = align_down (sp, 16);
4222 struct_addr = align_down (struct_addr, 16);
46cac009
AC
4223
4224 /* Now make space on the stack for the args. */
4225 for (argnum = 0; argnum < nargs; argnum++)
968b5391
MR
4226 {
4227 struct type *arg_type = check_typedef (value_type (args[argnum]));
4228 int arglen = TYPE_LENGTH (arg_type);
4229
968b5391 4230 /* Allocate space on the stack. */
1a69e1e4 4231 len += align_up (arglen, MIPS64_REGSIZE);
968b5391 4232 }
5b03f266 4233 sp -= align_up (len, 16);
46cac009
AC
4234
4235 if (mips_debug)
6d82d43b 4236 fprintf_unfiltered (gdb_stdlog,
5af949e3
UW
4237 "mips_o64_push_dummy_call: sp=%s allocated %ld\n",
4238 paddress (gdbarch, sp), (long) align_up (len, 16));
46cac009
AC
4239
4240 /* Initialize the integer and float register pointers. */
4c7d22cb 4241 argreg = MIPS_A0_REGNUM;
72a155b4 4242 float_argreg = mips_fpa0_regnum (gdbarch);
46cac009
AC
4243
4244 /* The struct_return pointer occupies the first parameter-passing reg. */
4245 if (struct_return)
4246 {
4247 if (mips_debug)
4248 fprintf_unfiltered (gdb_stdlog,
025bb325
MS
4249 "mips_o64_push_dummy_call: "
4250 "struct_return reg=%d %s\n",
5af949e3 4251 argreg, paddress (gdbarch, struct_addr));
9c9acae0 4252 regcache_cooked_write_unsigned (regcache, argreg++, struct_addr);
1a69e1e4 4253 stack_offset += MIPS64_REGSIZE;
46cac009
AC
4254 }
4255
4256 /* Now load as many as possible of the first arguments into
4257 registers, and push the rest onto the stack. Loop thru args
4258 from first to last. */
4259 for (argnum = 0; argnum < nargs; argnum++)
4260 {
47a35522 4261 const gdb_byte *val;
930bd0e0 4262 gdb_byte valbuf[MAX_REGISTER_SIZE];
46cac009 4263 struct value *arg = args[argnum];
4991999e 4264 struct type *arg_type = check_typedef (value_type (arg));
46cac009
AC
4265 int len = TYPE_LENGTH (arg_type);
4266 enum type_code typecode = TYPE_CODE (arg_type);
4267
4268 if (mips_debug)
4269 fprintf_unfiltered (gdb_stdlog,
25ab4790 4270 "mips_o64_push_dummy_call: %d len=%d type=%d",
ebafbe83
MS
4271 argnum + 1, len, (int) typecode);
4272
47a35522 4273 val = value_contents (arg);
ebafbe83 4274
930bd0e0
KB
4275 /* Function pointer arguments to mips16 code need to be made into
4276 mips16 pointers. */
4277 if (typecode == TYPE_CODE_PTR
4278 && TYPE_CODE (TYPE_TARGET_TYPE (arg_type)) == TYPE_CODE_FUNC)
4279 {
4280 CORE_ADDR addr = extract_signed_integer (value_contents (arg),
4281 len, byte_order);
4282 if (mips_pc_is_mips16 (addr))
4283 {
4284 store_signed_integer (valbuf, len, byte_order,
4285 make_mips16_addr (addr));
4286 val = valbuf;
4287 }
4288 }
4289
ebafbe83
MS
4290 /* Floating point arguments passed in registers have to be
4291 treated specially. On 32-bit architectures, doubles
4292 are passed in register pairs; the even register gets
4293 the low word, and the odd register gets the high word.
4294 On O32/O64, the first two floating point arguments are
4295 also copied to general registers, because MIPS16 functions
4296 don't use float registers for arguments. This duplication of
4297 arguments in general registers can't hurt non-MIPS16 functions
4298 because those registers are normally skipped. */
4299
74ed0bb4
MD
4300 if (fp_register_arg_p (gdbarch, typecode, arg_type)
4301 && float_argreg <= MIPS_LAST_FP_ARG_REGNUM (gdbarch))
ebafbe83 4302 {
e17a4113 4303 LONGEST regval = extract_unsigned_integer (val, len, byte_order);
2afd3f0a
MR
4304 if (mips_debug)
4305 fprintf_unfiltered (gdb_stdlog, " - fpreg=%d val=%s",
4306 float_argreg, phex (regval, len));
9c9acae0 4307 regcache_cooked_write_unsigned (regcache, float_argreg++, regval);
2afd3f0a
MR
4308 if (mips_debug)
4309 fprintf_unfiltered (gdb_stdlog, " - reg=%d val=%s",
4310 argreg, phex (regval, len));
9c9acae0 4311 regcache_cooked_write_unsigned (regcache, argreg, regval);
2afd3f0a 4312 argreg++;
ebafbe83 4313 /* Reserve space for the FP register. */
1a69e1e4 4314 stack_offset += align_up (len, MIPS64_REGSIZE);
ebafbe83
MS
4315 }
4316 else
4317 {
4318 /* Copy the argument to general registers or the stack in
4319 register-sized pieces. Large arguments are split between
4320 registers and stack. */
1a69e1e4 4321 /* Note: structs whose size is not a multiple of MIPS64_REGSIZE
436aafc4
MR
4322 are treated specially: Irix cc passes them in registers
4323 where gcc sometimes puts them on the stack. For maximum
4324 compatibility, we will put them in both places. */
1a69e1e4
DJ
4325 int odd_sized_struct = (len > MIPS64_REGSIZE
4326 && len % MIPS64_REGSIZE != 0);
ebafbe83
MS
4327 while (len > 0)
4328 {
4329 /* Remember if the argument was written to the stack. */
4330 int stack_used_p = 0;
1a69e1e4 4331 int partial_len = (len < MIPS64_REGSIZE ? len : MIPS64_REGSIZE);
ebafbe83
MS
4332
4333 if (mips_debug)
4334 fprintf_unfiltered (gdb_stdlog, " -- partial=%d",
4335 partial_len);
4336
4337 /* Write this portion of the argument to the stack. */
74ed0bb4 4338 if (argreg > MIPS_LAST_ARG_REGNUM (gdbarch)
968b5391 4339 || odd_sized_struct)
ebafbe83
MS
4340 {
4341 /* Should shorter than int integer values be
025bb325 4342 promoted to int before being stored? */
ebafbe83
MS
4343 int longword_offset = 0;
4344 CORE_ADDR addr;
4345 stack_used_p = 1;
72a155b4 4346 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG)
ebafbe83 4347 {
1a69e1e4
DJ
4348 if ((typecode == TYPE_CODE_INT
4349 || typecode == TYPE_CODE_PTR
4350 || typecode == TYPE_CODE_FLT)
4351 && len <= 4)
4352 longword_offset = MIPS64_REGSIZE - len;
ebafbe83
MS
4353 }
4354
4355 if (mips_debug)
4356 {
5af949e3
UW
4357 fprintf_unfiltered (gdb_stdlog, " - stack_offset=%s",
4358 paddress (gdbarch, stack_offset));
4359 fprintf_unfiltered (gdb_stdlog, " longword_offset=%s",
4360 paddress (gdbarch, longword_offset));
ebafbe83
MS
4361 }
4362
4363 addr = sp + stack_offset + longword_offset;
4364
4365 if (mips_debug)
4366 {
4367 int i;
5af949e3
UW
4368 fprintf_unfiltered (gdb_stdlog, " @%s ",
4369 paddress (gdbarch, addr));
ebafbe83
MS
4370 for (i = 0; i < partial_len; i++)
4371 {
6d82d43b 4372 fprintf_unfiltered (gdb_stdlog, "%02x",
ebafbe83
MS
4373 val[i] & 0xff);
4374 }
4375 }
4376 write_memory (addr, val, partial_len);
4377 }
4378
4379 /* Note!!! This is NOT an else clause. Odd sized
968b5391 4380 structs may go thru BOTH paths. */
ebafbe83 4381 /* Write this portion of the argument to a general
6d82d43b 4382 purpose register. */
74ed0bb4 4383 if (argreg <= MIPS_LAST_ARG_REGNUM (gdbarch))
ebafbe83 4384 {
e17a4113
UW
4385 LONGEST regval = extract_signed_integer (val, partial_len,
4386 byte_order);
4246e332 4387 /* Value may need to be sign extended, because
1b13c4f6 4388 mips_isa_regsize() != mips_abi_regsize(). */
ebafbe83
MS
4389
4390 /* A non-floating-point argument being passed in a
4391 general register. If a struct or union, and if
4392 the remaining length is smaller than the register
4393 size, we have to adjust the register value on
4394 big endian targets.
4395
4396 It does not seem to be necessary to do the
025bb325 4397 same for integral types. */
480d3dd2 4398
72a155b4 4399 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG
1a69e1e4 4400 && partial_len < MIPS64_REGSIZE
06f9a1af
MR
4401 && (typecode == TYPE_CODE_STRUCT
4402 || typecode == TYPE_CODE_UNION))
1a69e1e4 4403 regval <<= ((MIPS64_REGSIZE - partial_len)
9ecf7166 4404 * TARGET_CHAR_BIT);
ebafbe83
MS
4405
4406 if (mips_debug)
4407 fprintf_filtered (gdb_stdlog, " - reg=%d val=%s",
4408 argreg,
1a69e1e4 4409 phex (regval, MIPS64_REGSIZE));
9c9acae0 4410 regcache_cooked_write_unsigned (regcache, argreg, regval);
ebafbe83
MS
4411 argreg++;
4412
4413 /* Prevent subsequent floating point arguments from
4414 being passed in floating point registers. */
74ed0bb4 4415 float_argreg = MIPS_LAST_FP_ARG_REGNUM (gdbarch) + 1;
ebafbe83
MS
4416 }
4417
4418 len -= partial_len;
4419 val += partial_len;
4420
b021a221
MS
4421 /* Compute the offset into the stack at which we will
4422 copy the next parameter.
ebafbe83 4423
6d82d43b
AC
4424 In older ABIs, the caller reserved space for
4425 registers that contained arguments. This was loosely
4426 refered to as their "home". Consequently, space is
4427 always allocated. */
ebafbe83 4428
1a69e1e4 4429 stack_offset += align_up (partial_len, MIPS64_REGSIZE);
ebafbe83
MS
4430 }
4431 }
4432 if (mips_debug)
4433 fprintf_unfiltered (gdb_stdlog, "\n");
4434 }
4435
f10683bb 4436 regcache_cooked_write_signed (regcache, MIPS_SP_REGNUM, sp);
310e9b6a 4437
ebafbe83
MS
4438 /* Return adjusted stack pointer. */
4439 return sp;
4440}
4441
9c8fdbfa 4442static enum return_value_convention
c055b101 4443mips_o64_return_value (struct gdbarch *gdbarch, struct type *func_type,
9c8fdbfa 4444 struct type *type, struct regcache *regcache,
47a35522 4445 gdb_byte *readbuf, const gdb_byte *writebuf)
6d82d43b 4446{
72a155b4 4447 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
7a076fd2
FF
4448
4449 if (TYPE_CODE (type) == TYPE_CODE_STRUCT
4450 || TYPE_CODE (type) == TYPE_CODE_UNION
4451 || TYPE_CODE (type) == TYPE_CODE_ARRAY)
4452 return RETURN_VALUE_STRUCT_CONVENTION;
74ed0bb4 4453 else if (fp_register_arg_p (gdbarch, TYPE_CODE (type), type))
7a076fd2
FF
4454 {
4455 /* A floating-point value. It fits in the least significant
4456 part of FP0. */
4457 if (mips_debug)
4458 fprintf_unfiltered (gdb_stderr, "Return float in $fp0\n");
ba32f989 4459 mips_xfer_register (gdbarch, regcache,
72a155b4
UW
4460 gdbarch_num_regs (gdbarch)
4461 + mips_regnum (gdbarch)->fp0,
7a076fd2 4462 TYPE_LENGTH (type),
72a155b4 4463 gdbarch_byte_order (gdbarch),
4c6b5505 4464 readbuf, writebuf, 0);
7a076fd2
FF
4465 return RETURN_VALUE_REGISTER_CONVENTION;
4466 }
4467 else
4468 {
4469 /* A scalar extract each part but least-significant-byte
025bb325 4470 justified. */
7a076fd2
FF
4471 int offset;
4472 int regnum;
4473 for (offset = 0, regnum = MIPS_V0_REGNUM;
4474 offset < TYPE_LENGTH (type);
1a69e1e4 4475 offset += MIPS64_REGSIZE, regnum++)
7a076fd2 4476 {
1a69e1e4 4477 int xfer = MIPS64_REGSIZE;
7a076fd2
FF
4478 if (offset + xfer > TYPE_LENGTH (type))
4479 xfer = TYPE_LENGTH (type) - offset;
4480 if (mips_debug)
4481 fprintf_unfiltered (gdb_stderr, "Return scalar+%d:%d in $%d\n",
4482 offset, xfer, regnum);
ba32f989
DJ
4483 mips_xfer_register (gdbarch, regcache,
4484 gdbarch_num_regs (gdbarch) + regnum,
72a155b4 4485 xfer, gdbarch_byte_order (gdbarch),
4c6b5505 4486 readbuf, writebuf, offset);
7a076fd2
FF
4487 }
4488 return RETURN_VALUE_REGISTER_CONVENTION;
4489 }
6d82d43b
AC
4490}
4491
dd824b04
DJ
4492/* Floating point register management.
4493
4494 Background: MIPS1 & 2 fp registers are 32 bits wide. To support
4495 64bit operations, these early MIPS cpus treat fp register pairs
4496 (f0,f1) as a single register (d0). Later MIPS cpu's have 64 bit fp
4497 registers and offer a compatibility mode that emulates the MIPS2 fp
4498 model. When operating in MIPS2 fp compat mode, later cpu's split
4499 double precision floats into two 32-bit chunks and store them in
4500 consecutive fp regs. To display 64-bit floats stored in this
4501 fashion, we have to combine 32 bits from f0 and 32 bits from f1.
4502 Throw in user-configurable endianness and you have a real mess.
4503
4504 The way this works is:
4505 - If we are in 32-bit mode or on a 32-bit processor, then a 64-bit
4506 double-precision value will be split across two logical registers.
4507 The lower-numbered logical register will hold the low-order bits,
4508 regardless of the processor's endianness.
4509 - If we are on a 64-bit processor, and we are looking for a
4510 single-precision value, it will be in the low ordered bits
4511 of a 64-bit GPR (after mfc1, for example) or a 64-bit register
4512 save slot in memory.
4513 - If we are in 64-bit mode, everything is straightforward.
4514
4515 Note that this code only deals with "live" registers at the top of the
4516 stack. We will attempt to deal with saved registers later, when
025bb325 4517 the raw/cooked register interface is in place. (We need a general
dd824b04
DJ
4518 interface that can deal with dynamic saved register sizes -- fp
4519 regs could be 32 bits wide in one frame and 64 on the frame above
4520 and below). */
4521
4522/* Copy a 32-bit single-precision value from the current frame
4523 into rare_buffer. */
4524
4525static void
e11c53d2 4526mips_read_fp_register_single (struct frame_info *frame, int regno,
47a35522 4527 gdb_byte *rare_buffer)
dd824b04 4528{
72a155b4
UW
4529 struct gdbarch *gdbarch = get_frame_arch (frame);
4530 int raw_size = register_size (gdbarch, regno);
47a35522 4531 gdb_byte *raw_buffer = alloca (raw_size);
dd824b04 4532
e11c53d2 4533 if (!frame_register_read (frame, regno, raw_buffer))
c9f4d572 4534 error (_("can't read register %d (%s)"),
72a155b4 4535 regno, gdbarch_register_name (gdbarch, regno));
dd824b04
DJ
4536 if (raw_size == 8)
4537 {
4538 /* We have a 64-bit value for this register. Find the low-order
6d82d43b 4539 32 bits. */
dd824b04
DJ
4540 int offset;
4541
72a155b4 4542 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG)
dd824b04
DJ
4543 offset = 4;
4544 else
4545 offset = 0;
4546
4547 memcpy (rare_buffer, raw_buffer + offset, 4);
4548 }
4549 else
4550 {
4551 memcpy (rare_buffer, raw_buffer, 4);
4552 }
4553}
4554
4555/* Copy a 64-bit double-precision value from the current frame into
4556 rare_buffer. This may include getting half of it from the next
4557 register. */
4558
4559static void
e11c53d2 4560mips_read_fp_register_double (struct frame_info *frame, int regno,
47a35522 4561 gdb_byte *rare_buffer)
dd824b04 4562{
72a155b4
UW
4563 struct gdbarch *gdbarch = get_frame_arch (frame);
4564 int raw_size = register_size (gdbarch, regno);
dd824b04 4565
9c9acae0 4566 if (raw_size == 8 && !mips2_fp_compat (frame))
dd824b04
DJ
4567 {
4568 /* We have a 64-bit value for this register, and we should use
6d82d43b 4569 all 64 bits. */
e11c53d2 4570 if (!frame_register_read (frame, regno, rare_buffer))
c9f4d572 4571 error (_("can't read register %d (%s)"),
72a155b4 4572 regno, gdbarch_register_name (gdbarch, regno));
dd824b04
DJ
4573 }
4574 else
4575 {
72a155b4 4576 int rawnum = regno % gdbarch_num_regs (gdbarch);
82e91389 4577
72a155b4 4578 if ((rawnum - mips_regnum (gdbarch)->fp0) & 1)
dd824b04 4579 internal_error (__FILE__, __LINE__,
e2e0b3e5
AC
4580 _("mips_read_fp_register_double: bad access to "
4581 "odd-numbered FP register"));
dd824b04
DJ
4582
4583 /* mips_read_fp_register_single will find the correct 32 bits from
6d82d43b 4584 each register. */
72a155b4 4585 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG)
dd824b04 4586 {
e11c53d2
AC
4587 mips_read_fp_register_single (frame, regno, rare_buffer + 4);
4588 mips_read_fp_register_single (frame, regno + 1, rare_buffer);
dd824b04 4589 }
361d1df0 4590 else
dd824b04 4591 {
e11c53d2
AC
4592 mips_read_fp_register_single (frame, regno, rare_buffer);
4593 mips_read_fp_register_single (frame, regno + 1, rare_buffer + 4);
dd824b04
DJ
4594 }
4595 }
4596}
4597
c906108c 4598static void
e11c53d2
AC
4599mips_print_fp_register (struct ui_file *file, struct frame_info *frame,
4600 int regnum)
025bb325 4601{ /* Do values for FP (float) regs. */
72a155b4 4602 struct gdbarch *gdbarch = get_frame_arch (frame);
47a35522 4603 gdb_byte *raw_buffer;
025bb325 4604 double doub, flt1; /* Doubles extracted from raw hex data. */
3903d437 4605 int inv1, inv2;
c5aa993b 4606
025bb325
MS
4607 raw_buffer = alloca (2 * register_size (gdbarch,
4608 mips_regnum (gdbarch)->fp0));
c906108c 4609
72a155b4 4610 fprintf_filtered (file, "%s:", gdbarch_register_name (gdbarch, regnum));
c9f4d572 4611 fprintf_filtered (file, "%*s",
72a155b4 4612 4 - (int) strlen (gdbarch_register_name (gdbarch, regnum)),
e11c53d2 4613 "");
f0ef6b29 4614
72a155b4 4615 if (register_size (gdbarch, regnum) == 4 || mips2_fp_compat (frame))
c906108c 4616 {
79a45b7d
TT
4617 struct value_print_options opts;
4618
f0ef6b29
KB
4619 /* 4-byte registers: Print hex and floating. Also print even
4620 numbered registers as doubles. */
e11c53d2 4621 mips_read_fp_register_single (frame, regnum, raw_buffer);
025bb325
MS
4622 flt1 = unpack_double (builtin_type (gdbarch)->builtin_float,
4623 raw_buffer, &inv1);
c5aa993b 4624
79a45b7d 4625 get_formatted_print_options (&opts, 'x');
df4df182
UW
4626 print_scalar_formatted (raw_buffer,
4627 builtin_type (gdbarch)->builtin_uint32,
4628 &opts, 'w', file);
dd824b04 4629
e11c53d2 4630 fprintf_filtered (file, " flt: ");
1adad886 4631 if (inv1)
e11c53d2 4632 fprintf_filtered (file, " <invalid float> ");
1adad886 4633 else
e11c53d2 4634 fprintf_filtered (file, "%-17.9g", flt1);
1adad886 4635
72a155b4 4636 if ((regnum - gdbarch_num_regs (gdbarch)) % 2 == 0)
f0ef6b29 4637 {
e11c53d2 4638 mips_read_fp_register_double (frame, regnum, raw_buffer);
27067745
UW
4639 doub = unpack_double (builtin_type (gdbarch)->builtin_double,
4640 raw_buffer, &inv2);
1adad886 4641
e11c53d2 4642 fprintf_filtered (file, " dbl: ");
f0ef6b29 4643 if (inv2)
e11c53d2 4644 fprintf_filtered (file, "<invalid double>");
f0ef6b29 4645 else
e11c53d2 4646 fprintf_filtered (file, "%-24.17g", doub);
f0ef6b29 4647 }
c906108c
SS
4648 }
4649 else
dd824b04 4650 {
79a45b7d
TT
4651 struct value_print_options opts;
4652
f0ef6b29 4653 /* Eight byte registers: print each one as hex, float and double. */
e11c53d2 4654 mips_read_fp_register_single (frame, regnum, raw_buffer);
27067745
UW
4655 flt1 = unpack_double (builtin_type (gdbarch)->builtin_float,
4656 raw_buffer, &inv1);
c906108c 4657
e11c53d2 4658 mips_read_fp_register_double (frame, regnum, raw_buffer);
27067745
UW
4659 doub = unpack_double (builtin_type (gdbarch)->builtin_double,
4660 raw_buffer, &inv2);
f0ef6b29 4661
79a45b7d 4662 get_formatted_print_options (&opts, 'x');
df4df182
UW
4663 print_scalar_formatted (raw_buffer,
4664 builtin_type (gdbarch)->builtin_uint64,
4665 &opts, 'g', file);
f0ef6b29 4666
e11c53d2 4667 fprintf_filtered (file, " flt: ");
1adad886 4668 if (inv1)
e11c53d2 4669 fprintf_filtered (file, "<invalid float>");
1adad886 4670 else
e11c53d2 4671 fprintf_filtered (file, "%-17.9g", flt1);
1adad886 4672
e11c53d2 4673 fprintf_filtered (file, " dbl: ");
f0ef6b29 4674 if (inv2)
e11c53d2 4675 fprintf_filtered (file, "<invalid double>");
1adad886 4676 else
e11c53d2 4677 fprintf_filtered (file, "%-24.17g", doub);
f0ef6b29
KB
4678 }
4679}
4680
4681static void
e11c53d2 4682mips_print_register (struct ui_file *file, struct frame_info *frame,
0cc93a06 4683 int regnum)
f0ef6b29 4684{
a4b8ebc8 4685 struct gdbarch *gdbarch = get_frame_arch (frame);
f0ef6b29 4686 int offset;
79a45b7d 4687 struct value_print_options opts;
de15c4ab 4688 struct value *val;
1adad886 4689
7b9ee6a8 4690 if (TYPE_CODE (register_type (gdbarch, regnum)) == TYPE_CODE_FLT)
f0ef6b29 4691 {
e11c53d2 4692 mips_print_fp_register (file, frame, regnum);
f0ef6b29
KB
4693 return;
4694 }
4695
de15c4ab
PA
4696 val = get_frame_register_value (frame, regnum);
4697 if (value_optimized_out (val))
f0ef6b29 4698 {
c9f4d572 4699 fprintf_filtered (file, "%s: [Invalid]",
72a155b4 4700 gdbarch_register_name (gdbarch, regnum));
f0ef6b29 4701 return;
c906108c 4702 }
f0ef6b29 4703
72a155b4 4704 fputs_filtered (gdbarch_register_name (gdbarch, regnum), file);
f0ef6b29
KB
4705
4706 /* The problem with printing numeric register names (r26, etc.) is that
4707 the user can't use them on input. Probably the best solution is to
4708 fix it so that either the numeric or the funky (a2, etc.) names
4709 are accepted on input. */
4710 if (regnum < MIPS_NUMREGS)
e11c53d2 4711 fprintf_filtered (file, "(r%d): ", regnum);
f0ef6b29 4712 else
e11c53d2 4713 fprintf_filtered (file, ": ");
f0ef6b29 4714
79a45b7d 4715 get_formatted_print_options (&opts, 'x');
de15c4ab
PA
4716 val_print_scalar_formatted (value_type (val),
4717 value_contents_for_printing (val),
4718 value_embedded_offset (val),
4719 val,
4720 &opts, 0, file);
c906108c
SS
4721}
4722
f0ef6b29
KB
4723/* Replacement for generic do_registers_info.
4724 Print regs in pretty columns. */
4725
4726static int
e11c53d2
AC
4727print_fp_register_row (struct ui_file *file, struct frame_info *frame,
4728 int regnum)
f0ef6b29 4729{
e11c53d2
AC
4730 fprintf_filtered (file, " ");
4731 mips_print_fp_register (file, frame, regnum);
4732 fprintf_filtered (file, "\n");
f0ef6b29
KB
4733 return regnum + 1;
4734}
4735
4736
025bb325 4737/* Print a row's worth of GP (int) registers, with name labels above. */
c906108c
SS
4738
4739static int
e11c53d2 4740print_gp_register_row (struct ui_file *file, struct frame_info *frame,
a4b8ebc8 4741 int start_regnum)
c906108c 4742{
a4b8ebc8 4743 struct gdbarch *gdbarch = get_frame_arch (frame);
025bb325 4744 /* Do values for GP (int) regs. */
47a35522 4745 gdb_byte raw_buffer[MAX_REGISTER_SIZE];
025bb325
MS
4746 int ncols = (mips_abi_regsize (gdbarch) == 8 ? 4 : 8); /* display cols
4747 per row. */
c906108c 4748 int col, byte;
a4b8ebc8 4749 int regnum;
c906108c 4750
025bb325 4751 /* For GP registers, we print a separate row of names above the vals. */
a4b8ebc8 4752 for (col = 0, regnum = start_regnum;
72a155b4
UW
4753 col < ncols && regnum < gdbarch_num_regs (gdbarch)
4754 + gdbarch_num_pseudo_regs (gdbarch);
f57d151a 4755 regnum++)
c906108c 4756 {
72a155b4 4757 if (*gdbarch_register_name (gdbarch, regnum) == '\0')
c5aa993b 4758 continue; /* unused register */
7b9ee6a8 4759 if (TYPE_CODE (register_type (gdbarch, regnum)) ==
6d82d43b 4760 TYPE_CODE_FLT)
025bb325 4761 break; /* End the row: reached FP register. */
0cc93a06 4762 /* Large registers are handled separately. */
72a155b4 4763 if (register_size (gdbarch, regnum) > mips_abi_regsize (gdbarch))
0cc93a06
DJ
4764 {
4765 if (col > 0)
4766 break; /* End the row before this register. */
4767
4768 /* Print this register on a row by itself. */
4769 mips_print_register (file, frame, regnum);
4770 fprintf_filtered (file, "\n");
4771 return regnum + 1;
4772 }
d05f6826
DJ
4773 if (col == 0)
4774 fprintf_filtered (file, " ");
6d82d43b 4775 fprintf_filtered (file,
72a155b4
UW
4776 mips_abi_regsize (gdbarch) == 8 ? "%17s" : "%9s",
4777 gdbarch_register_name (gdbarch, regnum));
c906108c
SS
4778 col++;
4779 }
d05f6826
DJ
4780
4781 if (col == 0)
4782 return regnum;
4783
025bb325 4784 /* Print the R0 to R31 names. */
72a155b4 4785 if ((start_regnum % gdbarch_num_regs (gdbarch)) < MIPS_NUMREGS)
f57d151a 4786 fprintf_filtered (file, "\n R%-4d",
72a155b4 4787 start_regnum % gdbarch_num_regs (gdbarch));
20e6603c
AC
4788 else
4789 fprintf_filtered (file, "\n ");
c906108c 4790
025bb325 4791 /* Now print the values in hex, 4 or 8 to the row. */
a4b8ebc8 4792 for (col = 0, regnum = start_regnum;
72a155b4
UW
4793 col < ncols && regnum < gdbarch_num_regs (gdbarch)
4794 + gdbarch_num_pseudo_regs (gdbarch);
f57d151a 4795 regnum++)
c906108c 4796 {
72a155b4 4797 if (*gdbarch_register_name (gdbarch, regnum) == '\0')
c5aa993b 4798 continue; /* unused register */
7b9ee6a8 4799 if (TYPE_CODE (register_type (gdbarch, regnum)) ==
6d82d43b 4800 TYPE_CODE_FLT)
025bb325 4801 break; /* End row: reached FP register. */
72a155b4 4802 if (register_size (gdbarch, regnum) > mips_abi_regsize (gdbarch))
0cc93a06
DJ
4803 break; /* End row: large register. */
4804
c906108c 4805 /* OK: get the data in raw format. */
e11c53d2 4806 if (!frame_register_read (frame, regnum, raw_buffer))
c9f4d572 4807 error (_("can't read register %d (%s)"),
72a155b4 4808 regnum, gdbarch_register_name (gdbarch, regnum));
c906108c 4809 /* pad small registers */
4246e332 4810 for (byte = 0;
72a155b4
UW
4811 byte < (mips_abi_regsize (gdbarch)
4812 - register_size (gdbarch, regnum)); byte++)
c906108c 4813 printf_filtered (" ");
025bb325 4814 /* Now print the register value in hex, endian order. */
72a155b4 4815 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG)
6d82d43b 4816 for (byte =
72a155b4
UW
4817 register_size (gdbarch, regnum) - register_size (gdbarch, regnum);
4818 byte < register_size (gdbarch, regnum); byte++)
47a35522 4819 fprintf_filtered (file, "%02x", raw_buffer[byte]);
c906108c 4820 else
72a155b4 4821 for (byte = register_size (gdbarch, regnum) - 1;
6d82d43b 4822 byte >= 0; byte--)
47a35522 4823 fprintf_filtered (file, "%02x", raw_buffer[byte]);
e11c53d2 4824 fprintf_filtered (file, " ");
c906108c
SS
4825 col++;
4826 }
025bb325 4827 if (col > 0) /* ie. if we actually printed anything... */
e11c53d2 4828 fprintf_filtered (file, "\n");
c906108c
SS
4829
4830 return regnum;
4831}
4832
025bb325 4833/* MIPS_DO_REGISTERS_INFO(): called by "info register" command. */
c906108c 4834
bf1f5b4c 4835static void
e11c53d2
AC
4836mips_print_registers_info (struct gdbarch *gdbarch, struct ui_file *file,
4837 struct frame_info *frame, int regnum, int all)
c906108c 4838{
025bb325 4839 if (regnum != -1) /* Do one specified register. */
c906108c 4840 {
72a155b4
UW
4841 gdb_assert (regnum >= gdbarch_num_regs (gdbarch));
4842 if (*(gdbarch_register_name (gdbarch, regnum)) == '\0')
8a3fe4f8 4843 error (_("Not a valid register for the current processor type"));
c906108c 4844
0cc93a06 4845 mips_print_register (file, frame, regnum);
e11c53d2 4846 fprintf_filtered (file, "\n");
c906108c 4847 }
c5aa993b 4848 else
025bb325 4849 /* Do all (or most) registers. */
c906108c 4850 {
72a155b4
UW
4851 regnum = gdbarch_num_regs (gdbarch);
4852 while (regnum < gdbarch_num_regs (gdbarch)
4853 + gdbarch_num_pseudo_regs (gdbarch))
c906108c 4854 {
7b9ee6a8 4855 if (TYPE_CODE (register_type (gdbarch, regnum)) ==
6d82d43b 4856 TYPE_CODE_FLT)
e11c53d2 4857 {
025bb325 4858 if (all) /* True for "INFO ALL-REGISTERS" command. */
e11c53d2
AC
4859 regnum = print_fp_register_row (file, frame, regnum);
4860 else
025bb325 4861 regnum += MIPS_NUMREGS; /* Skip floating point regs. */
e11c53d2 4862 }
c906108c 4863 else
e11c53d2 4864 regnum = print_gp_register_row (file, frame, regnum);
c906108c
SS
4865 }
4866 }
4867}
4868
c906108c
SS
4869/* Is this a branch with a delay slot? */
4870
c906108c 4871static int
acdb74a0 4872is_delayed (unsigned long insn)
c906108c
SS
4873{
4874 int i;
4875 for (i = 0; i < NUMOPCODES; ++i)
4876 if (mips_opcodes[i].pinfo != INSN_MACRO
4877 && (insn & mips_opcodes[i].mask) == mips_opcodes[i].match)
4878 break;
4879 return (i < NUMOPCODES
4880 && (mips_opcodes[i].pinfo & (INSN_UNCOND_BRANCH_DELAY
4881 | INSN_COND_BRANCH_DELAY
4882 | INSN_COND_BRANCH_LIKELY)));
4883}
4884
63807e1d 4885static int
3352ef37
AC
4886mips_single_step_through_delay (struct gdbarch *gdbarch,
4887 struct frame_info *frame)
c906108c 4888{
e17a4113 4889 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
3352ef37 4890 CORE_ADDR pc = get_frame_pc (frame);
47a35522 4891 gdb_byte buf[MIPS_INSN32_SIZE];
c906108c
SS
4892
4893 /* There is no branch delay slot on MIPS16. */
0fe7e7c8 4894 if (mips_pc_is_mips16 (pc))
c906108c
SS
4895 return 0;
4896
6c95b8df 4897 if (!breakpoint_here_p (get_frame_address_space (frame), pc + 4))
06648491
MK
4898 return 0;
4899
3352ef37
AC
4900 if (!safe_frame_unwind_memory (frame, pc, buf, sizeof buf))
4901 /* If error reading memory, guess that it is not a delayed
4902 branch. */
c906108c 4903 return 0;
e17a4113 4904 return is_delayed (extract_unsigned_integer (buf, sizeof buf, byte_order));
c906108c
SS
4905}
4906
6d82d43b
AC
4907/* To skip prologues, I use this predicate. Returns either PC itself
4908 if the code at PC does not look like a function prologue; otherwise
4909 returns an address that (if we're lucky) follows the prologue. If
4910 LENIENT, then we must skip everything which is involved in setting
4911 up the frame (it's OK to skip more, just so long as we don't skip
4912 anything which might clobber the registers which are being saved.
4913 We must skip more in the case where part of the prologue is in the
4914 delay slot of a non-prologue instruction). */
4915
4916static CORE_ADDR
6093d2eb 4917mips_skip_prologue (struct gdbarch *gdbarch, CORE_ADDR pc)
6d82d43b 4918{
8b622e6a
AC
4919 CORE_ADDR limit_pc;
4920 CORE_ADDR func_addr;
4921
6d82d43b
AC
4922 /* See if we can determine the end of the prologue via the symbol table.
4923 If so, then return either PC, or the PC after the prologue, whichever
4924 is greater. */
8b622e6a
AC
4925 if (find_pc_partial_function (pc, NULL, &func_addr, NULL))
4926 {
d80b854b
UW
4927 CORE_ADDR post_prologue_pc
4928 = skip_prologue_using_sal (gdbarch, func_addr);
8b622e6a
AC
4929 if (post_prologue_pc != 0)
4930 return max (pc, post_prologue_pc);
4931 }
6d82d43b
AC
4932
4933 /* Can't determine prologue from the symbol table, need to examine
4934 instructions. */
4935
98b4dd94
JB
4936 /* Find an upper limit on the function prologue using the debug
4937 information. If the debug information could not be used to provide
4938 that bound, then use an arbitrary large number as the upper bound. */
d80b854b 4939 limit_pc = skip_prologue_using_sal (gdbarch, pc);
98b4dd94
JB
4940 if (limit_pc == 0)
4941 limit_pc = pc + 100; /* Magic. */
4942
0fe7e7c8 4943 if (mips_pc_is_mips16 (pc))
e17a4113 4944 return mips16_scan_prologue (gdbarch, pc, limit_pc, NULL, NULL);
6d82d43b 4945 else
e17a4113 4946 return mips32_scan_prologue (gdbarch, pc, limit_pc, NULL, NULL);
88658117
AC
4947}
4948
97ab0fdd
MR
4949/* Check whether the PC is in a function epilogue (32-bit version).
4950 This is a helper function for mips_in_function_epilogue_p. */
4951static int
e17a4113 4952mips32_in_function_epilogue_p (struct gdbarch *gdbarch, CORE_ADDR pc)
97ab0fdd
MR
4953{
4954 CORE_ADDR func_addr = 0, func_end = 0;
4955
4956 if (find_pc_partial_function (pc, NULL, &func_addr, &func_end))
4957 {
4958 /* The MIPS epilogue is max. 12 bytes long. */
4959 CORE_ADDR addr = func_end - 12;
4960
4961 if (addr < func_addr + 4)
4962 addr = func_addr + 4;
4963 if (pc < addr)
4964 return 0;
4965
4966 for (; pc < func_end; pc += MIPS_INSN32_SIZE)
4967 {
4968 unsigned long high_word;
4969 unsigned long inst;
4970
e17a4113 4971 inst = mips_fetch_instruction (gdbarch, pc);
97ab0fdd
MR
4972 high_word = (inst >> 16) & 0xffff;
4973
4974 if (high_word != 0x27bd /* addiu $sp,$sp,offset */
4975 && high_word != 0x67bd /* daddiu $sp,$sp,offset */
4976 && inst != 0x03e00008 /* jr $ra */
4977 && inst != 0x00000000) /* nop */
4978 return 0;
4979 }
4980
4981 return 1;
4982 }
4983
4984 return 0;
4985}
4986
4987/* Check whether the PC is in a function epilogue (16-bit version).
4988 This is a helper function for mips_in_function_epilogue_p. */
4989static int
e17a4113 4990mips16_in_function_epilogue_p (struct gdbarch *gdbarch, CORE_ADDR pc)
97ab0fdd
MR
4991{
4992 CORE_ADDR func_addr = 0, func_end = 0;
4993
4994 if (find_pc_partial_function (pc, NULL, &func_addr, &func_end))
4995 {
4996 /* The MIPS epilogue is max. 12 bytes long. */
4997 CORE_ADDR addr = func_end - 12;
4998
4999 if (addr < func_addr + 4)
5000 addr = func_addr + 4;
5001 if (pc < addr)
5002 return 0;
5003
5004 for (; pc < func_end; pc += MIPS_INSN16_SIZE)
5005 {
5006 unsigned short inst;
5007
e17a4113 5008 inst = mips_fetch_instruction (gdbarch, pc);
97ab0fdd
MR
5009
5010 if ((inst & 0xf800) == 0xf000) /* extend */
5011 continue;
5012
5013 if (inst != 0x6300 /* addiu $sp,offset */
5014 && inst != 0xfb00 /* daddiu $sp,$sp,offset */
5015 && inst != 0xe820 /* jr $ra */
5016 && inst != 0xe8a0 /* jrc $ra */
5017 && inst != 0x6500) /* nop */
5018 return 0;
5019 }
5020
5021 return 1;
5022 }
5023
5024 return 0;
5025}
5026
5027/* The epilogue is defined here as the area at the end of a function,
5028 after an instruction which destroys the function's stack frame. */
5029static int
5030mips_in_function_epilogue_p (struct gdbarch *gdbarch, CORE_ADDR pc)
5031{
5032 if (mips_pc_is_mips16 (pc))
e17a4113 5033 return mips16_in_function_epilogue_p (gdbarch, pc);
97ab0fdd 5034 else
e17a4113 5035 return mips32_in_function_epilogue_p (gdbarch, pc);
97ab0fdd
MR
5036}
5037
025bb325 5038/* Root of all "set mips "/"show mips " commands. This will eventually be
a5ea2558
AC
5039 used for all MIPS-specific commands. */
5040
a5ea2558 5041static void
acdb74a0 5042show_mips_command (char *args, int from_tty)
a5ea2558
AC
5043{
5044 help_list (showmipscmdlist, "show mips ", all_commands, gdb_stdout);
5045}
5046
a5ea2558 5047static void
acdb74a0 5048set_mips_command (char *args, int from_tty)
a5ea2558 5049{
6d82d43b
AC
5050 printf_unfiltered
5051 ("\"set mips\" must be followed by an appropriate subcommand.\n");
a5ea2558
AC
5052 help_list (setmipscmdlist, "set mips ", all_commands, gdb_stdout);
5053}
5054
c906108c
SS
5055/* Commands to show/set the MIPS FPU type. */
5056
c906108c 5057static void
acdb74a0 5058show_mipsfpu_command (char *args, int from_tty)
c906108c 5059{
c906108c 5060 char *fpu;
6ca0852e 5061
1cf3db46 5062 if (gdbarch_bfd_arch_info (target_gdbarch)->arch != bfd_arch_mips)
6ca0852e
UW
5063 {
5064 printf_unfiltered
5065 ("The MIPS floating-point coprocessor is unknown "
5066 "because the current architecture is not MIPS.\n");
5067 return;
5068 }
5069
1cf3db46 5070 switch (MIPS_FPU_TYPE (target_gdbarch))
c906108c
SS
5071 {
5072 case MIPS_FPU_SINGLE:
5073 fpu = "single-precision";
5074 break;
5075 case MIPS_FPU_DOUBLE:
5076 fpu = "double-precision";
5077 break;
5078 case MIPS_FPU_NONE:
5079 fpu = "absent (none)";
5080 break;
93d56215 5081 default:
e2e0b3e5 5082 internal_error (__FILE__, __LINE__, _("bad switch"));
c906108c
SS
5083 }
5084 if (mips_fpu_type_auto)
025bb325
MS
5085 printf_unfiltered ("The MIPS floating-point coprocessor "
5086 "is set automatically (currently %s)\n",
5087 fpu);
c906108c 5088 else
6d82d43b
AC
5089 printf_unfiltered
5090 ("The MIPS floating-point coprocessor is assumed to be %s\n", fpu);
c906108c
SS
5091}
5092
5093
c906108c 5094static void
acdb74a0 5095set_mipsfpu_command (char *args, int from_tty)
c906108c 5096{
025bb325
MS
5097 printf_unfiltered ("\"set mipsfpu\" must be followed by \"double\", "
5098 "\"single\",\"none\" or \"auto\".\n");
c906108c
SS
5099 show_mipsfpu_command (args, from_tty);
5100}
5101
c906108c 5102static void
acdb74a0 5103set_mipsfpu_single_command (char *args, int from_tty)
c906108c 5104{
8d5838b5
AC
5105 struct gdbarch_info info;
5106 gdbarch_info_init (&info);
c906108c
SS
5107 mips_fpu_type = MIPS_FPU_SINGLE;
5108 mips_fpu_type_auto = 0;
8d5838b5
AC
5109 /* FIXME: cagney/2003-11-15: Should be setting a field in "info"
5110 instead of relying on globals. Doing that would let generic code
5111 handle the search for this specific architecture. */
5112 if (!gdbarch_update_p (info))
e2e0b3e5 5113 internal_error (__FILE__, __LINE__, _("set mipsfpu failed"));
c906108c
SS
5114}
5115
c906108c 5116static void
acdb74a0 5117set_mipsfpu_double_command (char *args, int from_tty)
c906108c 5118{
8d5838b5
AC
5119 struct gdbarch_info info;
5120 gdbarch_info_init (&info);
c906108c
SS
5121 mips_fpu_type = MIPS_FPU_DOUBLE;
5122 mips_fpu_type_auto = 0;
8d5838b5
AC
5123 /* FIXME: cagney/2003-11-15: Should be setting a field in "info"
5124 instead of relying on globals. Doing that would let generic code
5125 handle the search for this specific architecture. */
5126 if (!gdbarch_update_p (info))
e2e0b3e5 5127 internal_error (__FILE__, __LINE__, _("set mipsfpu failed"));
c906108c
SS
5128}
5129
c906108c 5130static void
acdb74a0 5131set_mipsfpu_none_command (char *args, int from_tty)
c906108c 5132{
8d5838b5
AC
5133 struct gdbarch_info info;
5134 gdbarch_info_init (&info);
c906108c
SS
5135 mips_fpu_type = MIPS_FPU_NONE;
5136 mips_fpu_type_auto = 0;
8d5838b5
AC
5137 /* FIXME: cagney/2003-11-15: Should be setting a field in "info"
5138 instead of relying on globals. Doing that would let generic code
5139 handle the search for this specific architecture. */
5140 if (!gdbarch_update_p (info))
e2e0b3e5 5141 internal_error (__FILE__, __LINE__, _("set mipsfpu failed"));
c906108c
SS
5142}
5143
c906108c 5144static void
acdb74a0 5145set_mipsfpu_auto_command (char *args, int from_tty)
c906108c
SS
5146{
5147 mips_fpu_type_auto = 1;
5148}
5149
c906108c 5150/* Attempt to identify the particular processor model by reading the
691c0433
AC
5151 processor id. NOTE: cagney/2003-11-15: Firstly it isn't clear that
5152 the relevant processor still exists (it dates back to '94) and
5153 secondly this is not the way to do this. The processor type should
5154 be set by forcing an architecture change. */
c906108c 5155
691c0433
AC
5156void
5157deprecated_mips_set_processor_regs_hack (void)
c906108c 5158{
bb486190
UW
5159 struct regcache *regcache = get_current_regcache ();
5160 struct gdbarch *gdbarch = get_regcache_arch (regcache);
5161 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
a9614958 5162 ULONGEST prid;
c906108c 5163
bb486190 5164 regcache_cooked_read_unsigned (regcache, MIPS_PRID_REGNUM, &prid);
c906108c 5165 if ((prid & ~0xf) == 0x700)
691c0433 5166 tdep->mips_processor_reg_names = mips_r3041_reg_names;
c906108c
SS
5167}
5168
5169/* Just like reinit_frame_cache, but with the right arguments to be
5170 callable as an sfunc. */
5171
5172static void
acdb74a0
AC
5173reinit_frame_cache_sfunc (char *args, int from_tty,
5174 struct cmd_list_element *c)
c906108c
SS
5175{
5176 reinit_frame_cache ();
5177}
5178
a89aa300
AC
5179static int
5180gdb_print_insn_mips (bfd_vma memaddr, struct disassemble_info *info)
c906108c 5181{
d31431ed
AC
5182 /* FIXME: cagney/2003-06-26: Is this even necessary? The
5183 disassembler needs to be able to locally determine the ISA, and
5184 not rely on GDB. Otherwize the stand-alone 'objdump -d' will not
5185 work. */
ec4045ea
AC
5186 if (mips_pc_is_mips16 (memaddr))
5187 info->mach = bfd_mach_mips16;
c906108c
SS
5188
5189 /* Round down the instruction address to the appropriate boundary. */
65c11066 5190 memaddr &= (info->mach == bfd_mach_mips16 ? ~1 : ~3);
c5aa993b 5191
e5ab0dce 5192 /* Set the disassembler options. */
9dae60cc 5193 if (!info->disassembler_options)
e5ab0dce
AC
5194 /* This string is not recognized explicitly by the disassembler,
5195 but it tells the disassembler to not try to guess the ABI from
5196 the bfd elf headers, such that, if the user overrides the ABI
5197 of a program linked as NewABI, the disassembly will follow the
5198 register naming conventions specified by the user. */
5199 info->disassembler_options = "gpr-names=32";
5200
c906108c 5201 /* Call the appropriate disassembler based on the target endian-ness. */
40887e1a 5202 if (info->endian == BFD_ENDIAN_BIG)
c906108c
SS
5203 return print_insn_big_mips (memaddr, info);
5204 else
5205 return print_insn_little_mips (memaddr, info);
5206}
5207
9dae60cc
UW
5208static int
5209gdb_print_insn_mips_n32 (bfd_vma memaddr, struct disassemble_info *info)
5210{
5211 /* Set up the disassembler info, so that we get the right
5212 register names from libopcodes. */
5213 info->disassembler_options = "gpr-names=n32";
5214 info->flavour = bfd_target_elf_flavour;
5215
5216 return gdb_print_insn_mips (memaddr, info);
5217}
5218
5219static int
5220gdb_print_insn_mips_n64 (bfd_vma memaddr, struct disassemble_info *info)
5221{
5222 /* Set up the disassembler info, so that we get the right
5223 register names from libopcodes. */
5224 info->disassembler_options = "gpr-names=64";
5225 info->flavour = bfd_target_elf_flavour;
5226
5227 return gdb_print_insn_mips (memaddr, info);
5228}
5229
025bb325
MS
5230/* This function implements gdbarch_breakpoint_from_pc. It uses the
5231 program counter value to determine whether a 16- or 32-bit breakpoint
5232 should be used. It returns a pointer to a string of bytes that encode a
5233 breakpoint instruction, stores the length of the string to *lenptr, and
5234 adjusts pc (if necessary) to point to the actual memory location where
5235 the breakpoint should be inserted. */
c906108c 5236
47a35522 5237static const gdb_byte *
025bb325
MS
5238mips_breakpoint_from_pc (struct gdbarch *gdbarch,
5239 CORE_ADDR *pcptr, int *lenptr)
c906108c 5240{
67d57894 5241 if (gdbarch_byte_order (gdbarch) == BFD_ENDIAN_BIG)
c906108c 5242 {
0fe7e7c8 5243 if (mips_pc_is_mips16 (*pcptr))
c906108c 5244 {
47a35522 5245 static gdb_byte mips16_big_breakpoint[] = { 0xe8, 0xa5 };
95404a3e 5246 *pcptr = unmake_mips16_addr (*pcptr);
c5aa993b 5247 *lenptr = sizeof (mips16_big_breakpoint);
c906108c
SS
5248 return mips16_big_breakpoint;
5249 }
5250 else
5251 {
aaab4dba
AC
5252 /* The IDT board uses an unusual breakpoint value, and
5253 sometimes gets confused when it sees the usual MIPS
5254 breakpoint instruction. */
47a35522
MK
5255 static gdb_byte big_breakpoint[] = { 0, 0x5, 0, 0xd };
5256 static gdb_byte pmon_big_breakpoint[] = { 0, 0, 0, 0xd };
5257 static gdb_byte idt_big_breakpoint[] = { 0, 0, 0x0a, 0xd };
f2ec0ecf 5258 /* Likewise, IRIX appears to expect a different breakpoint,
025bb325 5259 although this is not apparent until you try to use pthreads. */
f2ec0ecf 5260 static gdb_byte irix_big_breakpoint[] = { 0, 0, 0, 0xd };
c906108c 5261
c5aa993b 5262 *lenptr = sizeof (big_breakpoint);
c906108c
SS
5263
5264 if (strcmp (target_shortname, "mips") == 0)
5265 return idt_big_breakpoint;
5266 else if (strcmp (target_shortname, "ddb") == 0
5267 || strcmp (target_shortname, "pmon") == 0
5268 || strcmp (target_shortname, "lsi") == 0)
5269 return pmon_big_breakpoint;
f2ec0ecf
JB
5270 else if (gdbarch_osabi (gdbarch) == GDB_OSABI_IRIX)
5271 return irix_big_breakpoint;
c906108c
SS
5272 else
5273 return big_breakpoint;
5274 }
5275 }
5276 else
5277 {
0fe7e7c8 5278 if (mips_pc_is_mips16 (*pcptr))
c906108c 5279 {
47a35522 5280 static gdb_byte mips16_little_breakpoint[] = { 0xa5, 0xe8 };
95404a3e 5281 *pcptr = unmake_mips16_addr (*pcptr);
c5aa993b 5282 *lenptr = sizeof (mips16_little_breakpoint);
c906108c
SS
5283 return mips16_little_breakpoint;
5284 }
5285 else
5286 {
47a35522
MK
5287 static gdb_byte little_breakpoint[] = { 0xd, 0, 0x5, 0 };
5288 static gdb_byte pmon_little_breakpoint[] = { 0xd, 0, 0, 0 };
5289 static gdb_byte idt_little_breakpoint[] = { 0xd, 0x0a, 0, 0 };
c906108c 5290
c5aa993b 5291 *lenptr = sizeof (little_breakpoint);
c906108c
SS
5292
5293 if (strcmp (target_shortname, "mips") == 0)
5294 return idt_little_breakpoint;
5295 else if (strcmp (target_shortname, "ddb") == 0
5296 || strcmp (target_shortname, "pmon") == 0
5297 || strcmp (target_shortname, "lsi") == 0)
5298 return pmon_little_breakpoint;
5299 else
5300 return little_breakpoint;
5301 }
5302 }
5303}
5304
5305/* If PC is in a mips16 call or return stub, return the address of the target
5306 PC, which is either the callee or the caller. There are several
5307 cases which must be handled:
5308
5309 * If the PC is in __mips16_ret_{d,s}f, this is a return stub and the
c5aa993b 5310 target PC is in $31 ($ra).
c906108c 5311 * If the PC is in __mips16_call_stub_{1..10}, this is a call stub
c5aa993b 5312 and the target PC is in $2.
c906108c 5313 * If the PC at the start of __mips16_call_stub_{s,d}f_{0..10}, i.e.
c5aa993b 5314 before the jal instruction, this is effectively a call stub
b021a221 5315 and the target PC is in $2. Otherwise this is effectively
c5aa993b 5316 a return stub and the target PC is in $18.
c906108c
SS
5317
5318 See the source code for the stubs in gcc/config/mips/mips16.S for
e7d6a6d2 5319 gory details. */
c906108c 5320
757a7cc6 5321static CORE_ADDR
db5f024e 5322mips_skip_mips16_trampoline_code (struct frame_info *frame, CORE_ADDR pc)
c906108c 5323{
e17a4113 5324 struct gdbarch *gdbarch = get_frame_arch (frame);
c906108c
SS
5325 char *name;
5326 CORE_ADDR start_addr;
5327
5328 /* Find the starting address and name of the function containing the PC. */
5329 if (find_pc_partial_function (pc, &name, &start_addr, NULL) == 0)
5330 return 0;
5331
5332 /* If the PC is in __mips16_ret_{d,s}f, this is a return stub and the
5333 target PC is in $31 ($ra). */
5334 if (strcmp (name, "__mips16_ret_sf") == 0
5335 || strcmp (name, "__mips16_ret_df") == 0)
52f729a7 5336 return get_frame_register_signed (frame, MIPS_RA_REGNUM);
c906108c
SS
5337
5338 if (strncmp (name, "__mips16_call_stub_", 19) == 0)
5339 {
5340 /* If the PC is in __mips16_call_stub_{1..10}, this is a call stub
5341 and the target PC is in $2. */
5342 if (name[19] >= '0' && name[19] <= '9')
52f729a7 5343 return get_frame_register_signed (frame, 2);
c906108c
SS
5344
5345 /* If the PC at the start of __mips16_call_stub_{s,d}f_{0..10}, i.e.
c5aa993b 5346 before the jal instruction, this is effectively a call stub
b021a221 5347 and the target PC is in $2. Otherwise this is effectively
c5aa993b 5348 a return stub and the target PC is in $18. */
c906108c
SS
5349 else if (name[19] == 's' || name[19] == 'd')
5350 {
5351 if (pc == start_addr)
5352 {
5353 /* Check if the target of the stub is a compiler-generated
c5aa993b
JM
5354 stub. Such a stub for a function bar might have a name
5355 like __fn_stub_bar, and might look like this:
5356 mfc1 $4,$f13
5357 mfc1 $5,$f12
5358 mfc1 $6,$f15
5359 mfc1 $7,$f14
5360 la $1,bar (becomes a lui/addiu pair)
5361 jr $1
5362 So scan down to the lui/addi and extract the target
5363 address from those two instructions. */
c906108c 5364
52f729a7 5365 CORE_ADDR target_pc = get_frame_register_signed (frame, 2);
d37cca3d 5366 ULONGEST inst;
c906108c
SS
5367 int i;
5368
5369 /* See if the name of the target function is __fn_stub_*. */
6d82d43b
AC
5370 if (find_pc_partial_function (target_pc, &name, NULL, NULL) ==
5371 0)
c906108c
SS
5372 return target_pc;
5373 if (strncmp (name, "__fn_stub_", 10) != 0
5374 && strcmp (name, "etext") != 0
5375 && strcmp (name, "_etext") != 0)
5376 return target_pc;
5377
5378 /* Scan through this _fn_stub_ code for the lui/addiu pair.
c5aa993b
JM
5379 The limit on the search is arbitrarily set to 20
5380 instructions. FIXME. */
95ac2dcf 5381 for (i = 0, pc = 0; i < 20; i++, target_pc += MIPS_INSN32_SIZE)
c906108c 5382 {
e17a4113 5383 inst = mips_fetch_instruction (gdbarch, target_pc);
c5aa993b 5384 if ((inst & 0xffff0000) == 0x3c010000) /* lui $at */
025bb325 5385 pc = (inst << 16) & 0xffff0000; /* high word */
c5aa993b 5386 else if ((inst & 0xffff0000) == 0x24210000) /* addiu $at */
025bb325 5387 return pc | (inst & 0xffff); /* low word */
c906108c
SS
5388 }
5389
5390 /* Couldn't find the lui/addui pair, so return stub address. */
5391 return target_pc;
5392 }
5393 else
5394 /* This is the 'return' part of a call stub. The return
5395 address is in $r18. */
52f729a7 5396 return get_frame_register_signed (frame, 18);
c906108c
SS
5397 }
5398 }
c5aa993b 5399 return 0; /* not a stub */
c906108c
SS
5400}
5401
db5f024e
DJ
5402/* If the current PC is the start of a non-PIC-to-PIC stub, return the
5403 PC of the stub target. The stub just loads $t9 and jumps to it,
5404 so that $t9 has the correct value at function entry. */
5405
5406static CORE_ADDR
5407mips_skip_pic_trampoline_code (struct frame_info *frame, CORE_ADDR pc)
5408{
e17a4113
UW
5409 struct gdbarch *gdbarch = get_frame_arch (frame);
5410 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
db5f024e
DJ
5411 struct minimal_symbol *msym;
5412 int i;
5413 gdb_byte stub_code[16];
5414 int32_t stub_words[4];
5415
5416 /* The stub for foo is named ".pic.foo", and is either two
5417 instructions inserted before foo or a three instruction sequence
5418 which jumps to foo. */
5419 msym = lookup_minimal_symbol_by_pc (pc);
5420 if (msym == NULL
5421 || SYMBOL_VALUE_ADDRESS (msym) != pc
5422 || SYMBOL_LINKAGE_NAME (msym) == NULL
5423 || strncmp (SYMBOL_LINKAGE_NAME (msym), ".pic.", 5) != 0)
5424 return 0;
5425
5426 /* A two-instruction header. */
5427 if (MSYMBOL_SIZE (msym) == 8)
5428 return pc + 8;
5429
5430 /* A three-instruction (plus delay slot) trampoline. */
5431 if (MSYMBOL_SIZE (msym) == 16)
5432 {
5433 if (target_read_memory (pc, stub_code, 16) != 0)
5434 return 0;
5435 for (i = 0; i < 4; i++)
e17a4113
UW
5436 stub_words[i] = extract_unsigned_integer (stub_code + i * 4,
5437 4, byte_order);
db5f024e
DJ
5438
5439 /* A stub contains these instructions:
5440 lui t9, %hi(target)
5441 j target
5442 addiu t9, t9, %lo(target)
5443 nop
5444
5445 This works even for N64, since stubs are only generated with
5446 -msym32. */
5447 if ((stub_words[0] & 0xffff0000U) == 0x3c190000
5448 && (stub_words[1] & 0xfc000000U) == 0x08000000
5449 && (stub_words[2] & 0xffff0000U) == 0x27390000
5450 && stub_words[3] == 0x00000000)
5451 return (((stub_words[0] & 0x0000ffff) << 16)
5452 + (stub_words[2] & 0x0000ffff));
5453 }
5454
5455 /* Not a recognized stub. */
5456 return 0;
5457}
5458
5459static CORE_ADDR
5460mips_skip_trampoline_code (struct frame_info *frame, CORE_ADDR pc)
5461{
5462 CORE_ADDR target_pc;
5463
5464 target_pc = mips_skip_mips16_trampoline_code (frame, pc);
5465 if (target_pc)
5466 return target_pc;
5467
5468 target_pc = find_solib_trampoline_target (frame, pc);
5469 if (target_pc)
5470 return target_pc;
5471
5472 target_pc = mips_skip_pic_trampoline_code (frame, pc);
5473 if (target_pc)
5474 return target_pc;
5475
5476 return 0;
5477}
5478
a4b8ebc8 5479/* Convert a dbx stab register number (from `r' declaration) to a GDB
f57d151a 5480 [1 * gdbarch_num_regs .. 2 * gdbarch_num_regs) REGNUM. */
88c72b7d
AC
5481
5482static int
d3f73121 5483mips_stab_reg_to_regnum (struct gdbarch *gdbarch, int num)
88c72b7d 5484{
a4b8ebc8 5485 int regnum;
2f38ef89 5486 if (num >= 0 && num < 32)
a4b8ebc8 5487 regnum = num;
2f38ef89 5488 else if (num >= 38 && num < 70)
d3f73121 5489 regnum = num + mips_regnum (gdbarch)->fp0 - 38;
040b99fd 5490 else if (num == 70)
d3f73121 5491 regnum = mips_regnum (gdbarch)->hi;
040b99fd 5492 else if (num == 71)
d3f73121 5493 regnum = mips_regnum (gdbarch)->lo;
2f38ef89 5494 else
a4b8ebc8
AC
5495 /* This will hopefully (eventually) provoke a warning. Should
5496 we be calling complaint() here? */
d3f73121
MD
5497 return gdbarch_num_regs (gdbarch) + gdbarch_num_pseudo_regs (gdbarch);
5498 return gdbarch_num_regs (gdbarch) + regnum;
88c72b7d
AC
5499}
5500
2f38ef89 5501
a4b8ebc8 5502/* Convert a dwarf, dwarf2, or ecoff register number to a GDB [1 *
f57d151a 5503 gdbarch_num_regs .. 2 * gdbarch_num_regs) REGNUM. */
88c72b7d
AC
5504
5505static int
d3f73121 5506mips_dwarf_dwarf2_ecoff_reg_to_regnum (struct gdbarch *gdbarch, int num)
88c72b7d 5507{
a4b8ebc8 5508 int regnum;
2f38ef89 5509 if (num >= 0 && num < 32)
a4b8ebc8 5510 regnum = num;
2f38ef89 5511 else if (num >= 32 && num < 64)
d3f73121 5512 regnum = num + mips_regnum (gdbarch)->fp0 - 32;
040b99fd 5513 else if (num == 64)
d3f73121 5514 regnum = mips_regnum (gdbarch)->hi;
040b99fd 5515 else if (num == 65)
d3f73121 5516 regnum = mips_regnum (gdbarch)->lo;
2f38ef89 5517 else
a4b8ebc8
AC
5518 /* This will hopefully (eventually) provoke a warning. Should we
5519 be calling complaint() here? */
d3f73121
MD
5520 return gdbarch_num_regs (gdbarch) + gdbarch_num_pseudo_regs (gdbarch);
5521 return gdbarch_num_regs (gdbarch) + regnum;
a4b8ebc8
AC
5522}
5523
5524static int
e7faf938 5525mips_register_sim_regno (struct gdbarch *gdbarch, int regnum)
a4b8ebc8
AC
5526{
5527 /* Only makes sense to supply raw registers. */
e7faf938 5528 gdb_assert (regnum >= 0 && regnum < gdbarch_num_regs (gdbarch));
a4b8ebc8
AC
5529 /* FIXME: cagney/2002-05-13: Need to look at the pseudo register to
5530 decide if it is valid. Should instead define a standard sim/gdb
5531 register numbering scheme. */
e7faf938
MD
5532 if (gdbarch_register_name (gdbarch,
5533 gdbarch_num_regs (gdbarch) + regnum) != NULL
5534 && gdbarch_register_name (gdbarch,
025bb325
MS
5535 gdbarch_num_regs (gdbarch)
5536 + regnum)[0] != '\0')
a4b8ebc8
AC
5537 return regnum;
5538 else
6d82d43b 5539 return LEGACY_SIM_REGNO_IGNORE;
88c72b7d
AC
5540}
5541
2f38ef89 5542
4844f454
CV
5543/* Convert an integer into an address. Extracting the value signed
5544 guarantees a correctly sign extended address. */
fc0c74b1
AC
5545
5546static CORE_ADDR
79dd2d24 5547mips_integer_to_address (struct gdbarch *gdbarch,
870cd05e 5548 struct type *type, const gdb_byte *buf)
fc0c74b1 5549{
e17a4113
UW
5550 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
5551 return extract_signed_integer (buf, TYPE_LENGTH (type), byte_order);
fc0c74b1
AC
5552}
5553
82e91389
DJ
5554/* Dummy virtual frame pointer method. This is no more or less accurate
5555 than most other architectures; we just need to be explicit about it,
5556 because the pseudo-register gdbarch_sp_regnum will otherwise lead to
5557 an assertion failure. */
5558
5559static void
a54fba4c
MD
5560mips_virtual_frame_pointer (struct gdbarch *gdbarch,
5561 CORE_ADDR pc, int *reg, LONGEST *offset)
82e91389
DJ
5562{
5563 *reg = MIPS_SP_REGNUM;
5564 *offset = 0;
5565}
5566
caaa3122
DJ
5567static void
5568mips_find_abi_section (bfd *abfd, asection *sect, void *obj)
5569{
5570 enum mips_abi *abip = (enum mips_abi *) obj;
5571 const char *name = bfd_get_section_name (abfd, sect);
5572
5573 if (*abip != MIPS_ABI_UNKNOWN)
5574 return;
5575
5576 if (strncmp (name, ".mdebug.", 8) != 0)
5577 return;
5578
5579 if (strcmp (name, ".mdebug.abi32") == 0)
5580 *abip = MIPS_ABI_O32;
5581 else if (strcmp (name, ".mdebug.abiN32") == 0)
5582 *abip = MIPS_ABI_N32;
62a49b2c 5583 else if (strcmp (name, ".mdebug.abi64") == 0)
e3bddbfa 5584 *abip = MIPS_ABI_N64;
caaa3122
DJ
5585 else if (strcmp (name, ".mdebug.abiO64") == 0)
5586 *abip = MIPS_ABI_O64;
5587 else if (strcmp (name, ".mdebug.eabi32") == 0)
5588 *abip = MIPS_ABI_EABI32;
5589 else if (strcmp (name, ".mdebug.eabi64") == 0)
5590 *abip = MIPS_ABI_EABI64;
5591 else
8a3fe4f8 5592 warning (_("unsupported ABI %s."), name + 8);
caaa3122
DJ
5593}
5594
22e47e37
FF
5595static void
5596mips_find_long_section (bfd *abfd, asection *sect, void *obj)
5597{
5598 int *lbp = (int *) obj;
5599 const char *name = bfd_get_section_name (abfd, sect);
5600
5601 if (strncmp (name, ".gcc_compiled_long32", 20) == 0)
5602 *lbp = 32;
5603 else if (strncmp (name, ".gcc_compiled_long64", 20) == 0)
5604 *lbp = 64;
5605 else if (strncmp (name, ".gcc_compiled_long", 18) == 0)
5606 warning (_("unrecognized .gcc_compiled_longXX"));
5607}
5608
2e4ebe70
DJ
5609static enum mips_abi
5610global_mips_abi (void)
5611{
5612 int i;
5613
5614 for (i = 0; mips_abi_strings[i] != NULL; i++)
5615 if (mips_abi_strings[i] == mips_abi_string)
5616 return (enum mips_abi) i;
5617
e2e0b3e5 5618 internal_error (__FILE__, __LINE__, _("unknown ABI string"));
2e4ebe70
DJ
5619}
5620
29709017
DJ
5621static void
5622mips_register_g_packet_guesses (struct gdbarch *gdbarch)
5623{
29709017
DJ
5624 /* If the size matches the set of 32-bit or 64-bit integer registers,
5625 assume that's what we've got. */
4eb0ad19
DJ
5626 register_remote_g_packet_guess (gdbarch, 38 * 4, mips_tdesc_gp32);
5627 register_remote_g_packet_guess (gdbarch, 38 * 8, mips_tdesc_gp64);
29709017
DJ
5628
5629 /* If the size matches the full set of registers GDB traditionally
5630 knows about, including floating point, for either 32-bit or
5631 64-bit, assume that's what we've got. */
4eb0ad19
DJ
5632 register_remote_g_packet_guess (gdbarch, 90 * 4, mips_tdesc_gp32);
5633 register_remote_g_packet_guess (gdbarch, 90 * 8, mips_tdesc_gp64);
29709017
DJ
5634
5635 /* Otherwise we don't have a useful guess. */
5636}
5637
f8b73d13
DJ
5638static struct value *
5639value_of_mips_user_reg (struct frame_info *frame, const void *baton)
5640{
5641 const int *reg_p = baton;
5642 return value_of_register (*reg_p, frame);
5643}
5644
c2d11a7d 5645static struct gdbarch *
6d82d43b 5646mips_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches)
c2d11a7d 5647{
c2d11a7d
JM
5648 struct gdbarch *gdbarch;
5649 struct gdbarch_tdep *tdep;
5650 int elf_flags;
2e4ebe70 5651 enum mips_abi mips_abi, found_abi, wanted_abi;
f8b73d13 5652 int i, num_regs;
8d5838b5 5653 enum mips_fpu_type fpu_type;
f8b73d13 5654 struct tdesc_arch_data *tdesc_data = NULL;
609ca2b9 5655 int elf_fpu_type = 0;
f8b73d13
DJ
5656
5657 /* Check any target description for validity. */
5658 if (tdesc_has_registers (info.target_desc))
5659 {
5660 static const char *const mips_gprs[] = {
5661 "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
5662 "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
5663 "r16", "r17", "r18", "r19", "r20", "r21", "r22", "r23",
5664 "r24", "r25", "r26", "r27", "r28", "r29", "r30", "r31"
5665 };
5666 static const char *const mips_fprs[] = {
5667 "f0", "f1", "f2", "f3", "f4", "f5", "f6", "f7",
5668 "f8", "f9", "f10", "f11", "f12", "f13", "f14", "f15",
5669 "f16", "f17", "f18", "f19", "f20", "f21", "f22", "f23",
5670 "f24", "f25", "f26", "f27", "f28", "f29", "f30", "f31",
5671 };
5672
5673 const struct tdesc_feature *feature;
5674 int valid_p;
5675
5676 feature = tdesc_find_feature (info.target_desc,
5677 "org.gnu.gdb.mips.cpu");
5678 if (feature == NULL)
5679 return NULL;
5680
5681 tdesc_data = tdesc_data_alloc ();
5682
5683 valid_p = 1;
5684 for (i = MIPS_ZERO_REGNUM; i <= MIPS_RA_REGNUM; i++)
5685 valid_p &= tdesc_numbered_register (feature, tdesc_data, i,
5686 mips_gprs[i]);
5687
5688
5689 valid_p &= tdesc_numbered_register (feature, tdesc_data,
5690 MIPS_EMBED_LO_REGNUM, "lo");
5691 valid_p &= tdesc_numbered_register (feature, tdesc_data,
5692 MIPS_EMBED_HI_REGNUM, "hi");
5693 valid_p &= tdesc_numbered_register (feature, tdesc_data,
5694 MIPS_EMBED_PC_REGNUM, "pc");
5695
5696 if (!valid_p)
5697 {
5698 tdesc_data_cleanup (tdesc_data);
5699 return NULL;
5700 }
5701
5702 feature = tdesc_find_feature (info.target_desc,
5703 "org.gnu.gdb.mips.cp0");
5704 if (feature == NULL)
5705 {
5706 tdesc_data_cleanup (tdesc_data);
5707 return NULL;
5708 }
5709
5710 valid_p = 1;
5711 valid_p &= tdesc_numbered_register (feature, tdesc_data,
5712 MIPS_EMBED_BADVADDR_REGNUM,
5713 "badvaddr");
5714 valid_p &= tdesc_numbered_register (feature, tdesc_data,
5715 MIPS_PS_REGNUM, "status");
5716 valid_p &= tdesc_numbered_register (feature, tdesc_data,
5717 MIPS_EMBED_CAUSE_REGNUM, "cause");
5718
5719 if (!valid_p)
5720 {
5721 tdesc_data_cleanup (tdesc_data);
5722 return NULL;
5723 }
5724
5725 /* FIXME drow/2007-05-17: The FPU should be optional. The MIPS
5726 backend is not prepared for that, though. */
5727 feature = tdesc_find_feature (info.target_desc,
5728 "org.gnu.gdb.mips.fpu");
5729 if (feature == NULL)
5730 {
5731 tdesc_data_cleanup (tdesc_data);
5732 return NULL;
5733 }
5734
5735 valid_p = 1;
5736 for (i = 0; i < 32; i++)
5737 valid_p &= tdesc_numbered_register (feature, tdesc_data,
5738 i + MIPS_EMBED_FP0_REGNUM,
5739 mips_fprs[i]);
5740
5741 valid_p &= tdesc_numbered_register (feature, tdesc_data,
5742 MIPS_EMBED_FP0_REGNUM + 32, "fcsr");
5743 valid_p &= tdesc_numbered_register (feature, tdesc_data,
5744 MIPS_EMBED_FP0_REGNUM + 33, "fir");
5745
5746 if (!valid_p)
5747 {
5748 tdesc_data_cleanup (tdesc_data);
5749 return NULL;
5750 }
5751
5752 /* It would be nice to detect an attempt to use a 64-bit ABI
5753 when only 32-bit registers are provided. */
5754 }
c2d11a7d 5755
ec03c1ac
AC
5756 /* First of all, extract the elf_flags, if available. */
5757 if (info.abfd && bfd_get_flavour (info.abfd) == bfd_target_elf_flavour)
5758 elf_flags = elf_elfheader (info.abfd)->e_flags;
6214a8a1
AC
5759 else if (arches != NULL)
5760 elf_flags = gdbarch_tdep (arches->gdbarch)->elf_flags;
ec03c1ac
AC
5761 else
5762 elf_flags = 0;
5763 if (gdbarch_debug)
5764 fprintf_unfiltered (gdb_stdlog,
6d82d43b 5765 "mips_gdbarch_init: elf_flags = 0x%08x\n", elf_flags);
c2d11a7d 5766
102182a9 5767 /* Check ELF_FLAGS to see if it specifies the ABI being used. */
0dadbba0
AC
5768 switch ((elf_flags & EF_MIPS_ABI))
5769 {
5770 case E_MIPS_ABI_O32:
ec03c1ac 5771 found_abi = MIPS_ABI_O32;
0dadbba0
AC
5772 break;
5773 case E_MIPS_ABI_O64:
ec03c1ac 5774 found_abi = MIPS_ABI_O64;
0dadbba0
AC
5775 break;
5776 case E_MIPS_ABI_EABI32:
ec03c1ac 5777 found_abi = MIPS_ABI_EABI32;
0dadbba0
AC
5778 break;
5779 case E_MIPS_ABI_EABI64:
ec03c1ac 5780 found_abi = MIPS_ABI_EABI64;
0dadbba0
AC
5781 break;
5782 default:
acdb74a0 5783 if ((elf_flags & EF_MIPS_ABI2))
ec03c1ac 5784 found_abi = MIPS_ABI_N32;
acdb74a0 5785 else
ec03c1ac 5786 found_abi = MIPS_ABI_UNKNOWN;
0dadbba0
AC
5787 break;
5788 }
acdb74a0 5789
caaa3122 5790 /* GCC creates a pseudo-section whose name describes the ABI. */
ec03c1ac
AC
5791 if (found_abi == MIPS_ABI_UNKNOWN && info.abfd != NULL)
5792 bfd_map_over_sections (info.abfd, mips_find_abi_section, &found_abi);
caaa3122 5793
dc305454 5794 /* If we have no useful BFD information, use the ABI from the last
ec03c1ac
AC
5795 MIPS architecture (if there is one). */
5796 if (found_abi == MIPS_ABI_UNKNOWN && info.abfd == NULL && arches != NULL)
5797 found_abi = gdbarch_tdep (arches->gdbarch)->found_abi;
2e4ebe70 5798
32a6503c 5799 /* Try the architecture for any hint of the correct ABI. */
ec03c1ac 5800 if (found_abi == MIPS_ABI_UNKNOWN
bf64bfd6
AC
5801 && info.bfd_arch_info != NULL
5802 && info.bfd_arch_info->arch == bfd_arch_mips)
5803 {
5804 switch (info.bfd_arch_info->mach)
5805 {
5806 case bfd_mach_mips3900:
ec03c1ac 5807 found_abi = MIPS_ABI_EABI32;
bf64bfd6
AC
5808 break;
5809 case bfd_mach_mips4100:
5810 case bfd_mach_mips5000:
ec03c1ac 5811 found_abi = MIPS_ABI_EABI64;
bf64bfd6 5812 break;
1d06468c
EZ
5813 case bfd_mach_mips8000:
5814 case bfd_mach_mips10000:
32a6503c
KB
5815 /* On Irix, ELF64 executables use the N64 ABI. The
5816 pseudo-sections which describe the ABI aren't present
5817 on IRIX. (Even for executables created by gcc.) */
28d169de
KB
5818 if (bfd_get_flavour (info.abfd) == bfd_target_elf_flavour
5819 && elf_elfheader (info.abfd)->e_ident[EI_CLASS] == ELFCLASS64)
ec03c1ac 5820 found_abi = MIPS_ABI_N64;
28d169de 5821 else
ec03c1ac 5822 found_abi = MIPS_ABI_N32;
1d06468c 5823 break;
bf64bfd6
AC
5824 }
5825 }
2e4ebe70 5826
26c53e50
DJ
5827 /* Default 64-bit objects to N64 instead of O32. */
5828 if (found_abi == MIPS_ABI_UNKNOWN
5829 && info.abfd != NULL
5830 && bfd_get_flavour (info.abfd) == bfd_target_elf_flavour
5831 && elf_elfheader (info.abfd)->e_ident[EI_CLASS] == ELFCLASS64)
5832 found_abi = MIPS_ABI_N64;
5833
ec03c1ac
AC
5834 if (gdbarch_debug)
5835 fprintf_unfiltered (gdb_stdlog, "mips_gdbarch_init: found_abi = %d\n",
5836 found_abi);
5837
5838 /* What has the user specified from the command line? */
5839 wanted_abi = global_mips_abi ();
5840 if (gdbarch_debug)
5841 fprintf_unfiltered (gdb_stdlog, "mips_gdbarch_init: wanted_abi = %d\n",
5842 wanted_abi);
2e4ebe70
DJ
5843
5844 /* Now that we have found what the ABI for this binary would be,
5845 check whether the user is overriding it. */
2e4ebe70
DJ
5846 if (wanted_abi != MIPS_ABI_UNKNOWN)
5847 mips_abi = wanted_abi;
ec03c1ac
AC
5848 else if (found_abi != MIPS_ABI_UNKNOWN)
5849 mips_abi = found_abi;
5850 else
5851 mips_abi = MIPS_ABI_O32;
5852 if (gdbarch_debug)
5853 fprintf_unfiltered (gdb_stdlog, "mips_gdbarch_init: mips_abi = %d\n",
5854 mips_abi);
2e4ebe70 5855
ec03c1ac 5856 /* Also used when doing an architecture lookup. */
4b9b3959 5857 if (gdbarch_debug)
ec03c1ac 5858 fprintf_unfiltered (gdb_stdlog,
025bb325
MS
5859 "mips_gdbarch_init: "
5860 "mips64_transfers_32bit_regs_p = %d\n",
ec03c1ac 5861 mips64_transfers_32bit_regs_p);
0dadbba0 5862
8d5838b5 5863 /* Determine the MIPS FPU type. */
609ca2b9
DJ
5864#ifdef HAVE_ELF
5865 if (info.abfd
5866 && bfd_get_flavour (info.abfd) == bfd_target_elf_flavour)
5867 elf_fpu_type = bfd_elf_get_obj_attr_int (info.abfd, OBJ_ATTR_GNU,
5868 Tag_GNU_MIPS_ABI_FP);
5869#endif /* HAVE_ELF */
5870
8d5838b5
AC
5871 if (!mips_fpu_type_auto)
5872 fpu_type = mips_fpu_type;
609ca2b9
DJ
5873 else if (elf_fpu_type != 0)
5874 {
5875 switch (elf_fpu_type)
5876 {
5877 case 1:
5878 fpu_type = MIPS_FPU_DOUBLE;
5879 break;
5880 case 2:
5881 fpu_type = MIPS_FPU_SINGLE;
5882 break;
5883 case 3:
5884 default:
5885 /* Soft float or unknown. */
5886 fpu_type = MIPS_FPU_NONE;
5887 break;
5888 }
5889 }
8d5838b5
AC
5890 else if (info.bfd_arch_info != NULL
5891 && info.bfd_arch_info->arch == bfd_arch_mips)
5892 switch (info.bfd_arch_info->mach)
5893 {
5894 case bfd_mach_mips3900:
5895 case bfd_mach_mips4100:
5896 case bfd_mach_mips4111:
a9d61c86 5897 case bfd_mach_mips4120:
8d5838b5
AC
5898 fpu_type = MIPS_FPU_NONE;
5899 break;
5900 case bfd_mach_mips4650:
5901 fpu_type = MIPS_FPU_SINGLE;
5902 break;
5903 default:
5904 fpu_type = MIPS_FPU_DOUBLE;
5905 break;
5906 }
5907 else if (arches != NULL)
5908 fpu_type = gdbarch_tdep (arches->gdbarch)->mips_fpu_type;
5909 else
5910 fpu_type = MIPS_FPU_DOUBLE;
5911 if (gdbarch_debug)
5912 fprintf_unfiltered (gdb_stdlog,
6d82d43b 5913 "mips_gdbarch_init: fpu_type = %d\n", fpu_type);
8d5838b5 5914
29709017
DJ
5915 /* Check for blatant incompatibilities. */
5916
5917 /* If we have only 32-bit registers, then we can't debug a 64-bit
5918 ABI. */
5919 if (info.target_desc
5920 && tdesc_property (info.target_desc, PROPERTY_GP32) != NULL
5921 && mips_abi != MIPS_ABI_EABI32
5922 && mips_abi != MIPS_ABI_O32)
f8b73d13
DJ
5923 {
5924 if (tdesc_data != NULL)
5925 tdesc_data_cleanup (tdesc_data);
5926 return NULL;
5927 }
29709017 5928
025bb325 5929 /* Try to find a pre-existing architecture. */
c2d11a7d
JM
5930 for (arches = gdbarch_list_lookup_by_info (arches, &info);
5931 arches != NULL;
5932 arches = gdbarch_list_lookup_by_info (arches->next, &info))
5933 {
5934 /* MIPS needs to be pedantic about which ABI the object is
102182a9 5935 using. */
9103eae0 5936 if (gdbarch_tdep (arches->gdbarch)->elf_flags != elf_flags)
c2d11a7d 5937 continue;
9103eae0 5938 if (gdbarch_tdep (arches->gdbarch)->mips_abi != mips_abi)
0dadbba0 5939 continue;
719ec221
AC
5940 /* Need to be pedantic about which register virtual size is
5941 used. */
5942 if (gdbarch_tdep (arches->gdbarch)->mips64_transfers_32bit_regs_p
5943 != mips64_transfers_32bit_regs_p)
5944 continue;
8d5838b5
AC
5945 /* Be pedantic about which FPU is selected. */
5946 if (gdbarch_tdep (arches->gdbarch)->mips_fpu_type != fpu_type)
5947 continue;
f8b73d13
DJ
5948
5949 if (tdesc_data != NULL)
5950 tdesc_data_cleanup (tdesc_data);
4be87837 5951 return arches->gdbarch;
c2d11a7d
JM
5952 }
5953
102182a9 5954 /* Need a new architecture. Fill in a target specific vector. */
c2d11a7d
JM
5955 tdep = (struct gdbarch_tdep *) xmalloc (sizeof (struct gdbarch_tdep));
5956 gdbarch = gdbarch_alloc (&info, tdep);
5957 tdep->elf_flags = elf_flags;
719ec221 5958 tdep->mips64_transfers_32bit_regs_p = mips64_transfers_32bit_regs_p;
ec03c1ac
AC
5959 tdep->found_abi = found_abi;
5960 tdep->mips_abi = mips_abi;
8d5838b5 5961 tdep->mips_fpu_type = fpu_type;
29709017
DJ
5962 tdep->register_size_valid_p = 0;
5963 tdep->register_size = 0;
50e8a0d5
HZ
5964 tdep->gregset = NULL;
5965 tdep->gregset64 = NULL;
5966 tdep->fpregset = NULL;
5967 tdep->fpregset64 = NULL;
29709017
DJ
5968
5969 if (info.target_desc)
5970 {
5971 /* Some useful properties can be inferred from the target. */
5972 if (tdesc_property (info.target_desc, PROPERTY_GP32) != NULL)
5973 {
5974 tdep->register_size_valid_p = 1;
5975 tdep->register_size = 4;
5976 }
5977 else if (tdesc_property (info.target_desc, PROPERTY_GP64) != NULL)
5978 {
5979 tdep->register_size_valid_p = 1;
5980 tdep->register_size = 8;
5981 }
5982 }
c2d11a7d 5983
102182a9 5984 /* Initially set everything according to the default ABI/ISA. */
c2d11a7d
JM
5985 set_gdbarch_short_bit (gdbarch, 16);
5986 set_gdbarch_int_bit (gdbarch, 32);
5987 set_gdbarch_float_bit (gdbarch, 32);
5988 set_gdbarch_double_bit (gdbarch, 64);
5989 set_gdbarch_long_double_bit (gdbarch, 64);
a4b8ebc8
AC
5990 set_gdbarch_register_reggroup_p (gdbarch, mips_register_reggroup_p);
5991 set_gdbarch_pseudo_register_read (gdbarch, mips_pseudo_register_read);
5992 set_gdbarch_pseudo_register_write (gdbarch, mips_pseudo_register_write);
1d06468c 5993
175ff332
HZ
5994 set_gdbarch_ax_pseudo_register_collect (gdbarch,
5995 mips_ax_pseudo_register_collect);
5996 set_gdbarch_ax_pseudo_register_push_stack
5997 (gdbarch, mips_ax_pseudo_register_push_stack);
5998
6d82d43b 5999 set_gdbarch_elf_make_msymbol_special (gdbarch,
f7ab6ec6
MS
6000 mips_elf_make_msymbol_special);
6001
16e109ca 6002 /* Fill in the OS dependant register numbers and names. */
56cea623 6003 {
16e109ca 6004 const char **reg_names;
56cea623
AC
6005 struct mips_regnum *regnum = GDBARCH_OBSTACK_ZALLOC (gdbarch,
6006 struct mips_regnum);
f8b73d13
DJ
6007 if (tdesc_has_registers (info.target_desc))
6008 {
6009 regnum->lo = MIPS_EMBED_LO_REGNUM;
6010 regnum->hi = MIPS_EMBED_HI_REGNUM;
6011 regnum->badvaddr = MIPS_EMBED_BADVADDR_REGNUM;
6012 regnum->cause = MIPS_EMBED_CAUSE_REGNUM;
6013 regnum->pc = MIPS_EMBED_PC_REGNUM;
6014 regnum->fp0 = MIPS_EMBED_FP0_REGNUM;
6015 regnum->fp_control_status = 70;
6016 regnum->fp_implementation_revision = 71;
6017 num_regs = MIPS_LAST_EMBED_REGNUM + 1;
6018 reg_names = NULL;
6019 }
6020 else if (info.osabi == GDB_OSABI_IRIX)
56cea623
AC
6021 {
6022 regnum->fp0 = 32;
6023 regnum->pc = 64;
6024 regnum->cause = 65;
6025 regnum->badvaddr = 66;
6026 regnum->hi = 67;
6027 regnum->lo = 68;
6028 regnum->fp_control_status = 69;
6029 regnum->fp_implementation_revision = 70;
6030 num_regs = 71;
16e109ca 6031 reg_names = mips_irix_reg_names;
56cea623
AC
6032 }
6033 else
6034 {
6035 regnum->lo = MIPS_EMBED_LO_REGNUM;
6036 regnum->hi = MIPS_EMBED_HI_REGNUM;
6037 regnum->badvaddr = MIPS_EMBED_BADVADDR_REGNUM;
6038 regnum->cause = MIPS_EMBED_CAUSE_REGNUM;
6039 regnum->pc = MIPS_EMBED_PC_REGNUM;
6040 regnum->fp0 = MIPS_EMBED_FP0_REGNUM;
6041 regnum->fp_control_status = 70;
6042 regnum->fp_implementation_revision = 71;
6043 num_regs = 90;
16e109ca
AC
6044 if (info.bfd_arch_info != NULL
6045 && info.bfd_arch_info->mach == bfd_mach_mips3900)
6046 reg_names = mips_tx39_reg_names;
6047 else
6048 reg_names = mips_generic_reg_names;
56cea623 6049 }
3e8c568d 6050 /* FIXME: cagney/2003-11-15: For MIPS, hasn't gdbarch_pc_regnum been
fb14de7b 6051 replaced by gdbarch_read_pc? */
f10683bb
MH
6052 set_gdbarch_pc_regnum (gdbarch, regnum->pc + num_regs);
6053 set_gdbarch_sp_regnum (gdbarch, MIPS_SP_REGNUM + num_regs);
56cea623
AC
6054 set_gdbarch_fp0_regnum (gdbarch, regnum->fp0);
6055 set_gdbarch_num_regs (gdbarch, num_regs);
6056 set_gdbarch_num_pseudo_regs (gdbarch, num_regs);
16e109ca 6057 set_gdbarch_register_name (gdbarch, mips_register_name);
82e91389 6058 set_gdbarch_virtual_frame_pointer (gdbarch, mips_virtual_frame_pointer);
16e109ca
AC
6059 tdep->mips_processor_reg_names = reg_names;
6060 tdep->regnum = regnum;
56cea623 6061 }
fe29b929 6062
0dadbba0 6063 switch (mips_abi)
c2d11a7d 6064 {
0dadbba0 6065 case MIPS_ABI_O32:
25ab4790 6066 set_gdbarch_push_dummy_call (gdbarch, mips_o32_push_dummy_call);
29dfb2ac 6067 set_gdbarch_return_value (gdbarch, mips_o32_return_value);
4c7d22cb 6068 tdep->mips_last_arg_regnum = MIPS_A0_REGNUM + 4 - 1;
56cea623 6069 tdep->mips_last_fp_arg_regnum = tdep->regnum->fp0 + 12 + 4 - 1;
4014092b 6070 tdep->default_mask_address_p = 0;
c2d11a7d
JM
6071 set_gdbarch_long_bit (gdbarch, 32);
6072 set_gdbarch_ptr_bit (gdbarch, 32);
6073 set_gdbarch_long_long_bit (gdbarch, 64);
6074 break;
0dadbba0 6075 case MIPS_ABI_O64:
25ab4790 6076 set_gdbarch_push_dummy_call (gdbarch, mips_o64_push_dummy_call);
9c8fdbfa 6077 set_gdbarch_return_value (gdbarch, mips_o64_return_value);
4c7d22cb 6078 tdep->mips_last_arg_regnum = MIPS_A0_REGNUM + 4 - 1;
56cea623 6079 tdep->mips_last_fp_arg_regnum = tdep->regnum->fp0 + 12 + 4 - 1;
361d1df0 6080 tdep->default_mask_address_p = 0;
c2d11a7d
JM
6081 set_gdbarch_long_bit (gdbarch, 32);
6082 set_gdbarch_ptr_bit (gdbarch, 32);
6083 set_gdbarch_long_long_bit (gdbarch, 64);
6084 break;
0dadbba0 6085 case MIPS_ABI_EABI32:
25ab4790 6086 set_gdbarch_push_dummy_call (gdbarch, mips_eabi_push_dummy_call);
9c8fdbfa 6087 set_gdbarch_return_value (gdbarch, mips_eabi_return_value);
4c7d22cb 6088 tdep->mips_last_arg_regnum = MIPS_A0_REGNUM + 8 - 1;
56cea623 6089 tdep->mips_last_fp_arg_regnum = tdep->regnum->fp0 + 12 + 8 - 1;
4014092b 6090 tdep->default_mask_address_p = 0;
c2d11a7d
JM
6091 set_gdbarch_long_bit (gdbarch, 32);
6092 set_gdbarch_ptr_bit (gdbarch, 32);
6093 set_gdbarch_long_long_bit (gdbarch, 64);
6094 break;
0dadbba0 6095 case MIPS_ABI_EABI64:
25ab4790 6096 set_gdbarch_push_dummy_call (gdbarch, mips_eabi_push_dummy_call);
9c8fdbfa 6097 set_gdbarch_return_value (gdbarch, mips_eabi_return_value);
4c7d22cb 6098 tdep->mips_last_arg_regnum = MIPS_A0_REGNUM + 8 - 1;
56cea623 6099 tdep->mips_last_fp_arg_regnum = tdep->regnum->fp0 + 12 + 8 - 1;
4014092b 6100 tdep->default_mask_address_p = 0;
c2d11a7d
JM
6101 set_gdbarch_long_bit (gdbarch, 64);
6102 set_gdbarch_ptr_bit (gdbarch, 64);
6103 set_gdbarch_long_long_bit (gdbarch, 64);
6104 break;
0dadbba0 6105 case MIPS_ABI_N32:
25ab4790 6106 set_gdbarch_push_dummy_call (gdbarch, mips_n32n64_push_dummy_call);
29dfb2ac 6107 set_gdbarch_return_value (gdbarch, mips_n32n64_return_value);
4c7d22cb 6108 tdep->mips_last_arg_regnum = MIPS_A0_REGNUM + 8 - 1;
56cea623 6109 tdep->mips_last_fp_arg_regnum = tdep->regnum->fp0 + 12 + 8 - 1;
4014092b 6110 tdep->default_mask_address_p = 0;
0dadbba0
AC
6111 set_gdbarch_long_bit (gdbarch, 32);
6112 set_gdbarch_ptr_bit (gdbarch, 32);
6113 set_gdbarch_long_long_bit (gdbarch, 64);
fed7ba43 6114 set_gdbarch_long_double_bit (gdbarch, 128);
b14d30e1 6115 set_gdbarch_long_double_format (gdbarch, floatformats_ibm_long_double);
28d169de
KB
6116 break;
6117 case MIPS_ABI_N64:
25ab4790 6118 set_gdbarch_push_dummy_call (gdbarch, mips_n32n64_push_dummy_call);
29dfb2ac 6119 set_gdbarch_return_value (gdbarch, mips_n32n64_return_value);
4c7d22cb 6120 tdep->mips_last_arg_regnum = MIPS_A0_REGNUM + 8 - 1;
56cea623 6121 tdep->mips_last_fp_arg_regnum = tdep->regnum->fp0 + 12 + 8 - 1;
28d169de
KB
6122 tdep->default_mask_address_p = 0;
6123 set_gdbarch_long_bit (gdbarch, 64);
6124 set_gdbarch_ptr_bit (gdbarch, 64);
6125 set_gdbarch_long_long_bit (gdbarch, 64);
fed7ba43 6126 set_gdbarch_long_double_bit (gdbarch, 128);
b14d30e1 6127 set_gdbarch_long_double_format (gdbarch, floatformats_ibm_long_double);
0dadbba0 6128 break;
c2d11a7d 6129 default:
e2e0b3e5 6130 internal_error (__FILE__, __LINE__, _("unknown ABI in switch"));
c2d11a7d
JM
6131 }
6132
22e47e37
FF
6133 /* GCC creates a pseudo-section whose name specifies the size of
6134 longs, since -mlong32 or -mlong64 may be used independent of
6135 other options. How those options affect pointer sizes is ABI and
6136 architecture dependent, so use them to override the default sizes
6137 set by the ABI. This table shows the relationship between ABI,
6138 -mlongXX, and size of pointers:
6139
6140 ABI -mlongXX ptr bits
6141 --- -------- --------
6142 o32 32 32
6143 o32 64 32
6144 n32 32 32
6145 n32 64 64
6146 o64 32 32
6147 o64 64 64
6148 n64 32 32
6149 n64 64 64
6150 eabi32 32 32
6151 eabi32 64 32
6152 eabi64 32 32
6153 eabi64 64 64
6154
6155 Note that for o32 and eabi32, pointers are always 32 bits
6156 regardless of any -mlongXX option. For all others, pointers and
025bb325 6157 longs are the same, as set by -mlongXX or set by defaults. */
22e47e37
FF
6158
6159 if (info.abfd != NULL)
6160 {
6161 int long_bit = 0;
6162
6163 bfd_map_over_sections (info.abfd, mips_find_long_section, &long_bit);
6164 if (long_bit)
6165 {
6166 set_gdbarch_long_bit (gdbarch, long_bit);
6167 switch (mips_abi)
6168 {
6169 case MIPS_ABI_O32:
6170 case MIPS_ABI_EABI32:
6171 break;
6172 case MIPS_ABI_N32:
6173 case MIPS_ABI_O64:
6174 case MIPS_ABI_N64:
6175 case MIPS_ABI_EABI64:
6176 set_gdbarch_ptr_bit (gdbarch, long_bit);
6177 break;
6178 default:
6179 internal_error (__FILE__, __LINE__, _("unknown ABI in switch"));
6180 }
6181 }
6182 }
6183
a5ea2558
AC
6184 /* FIXME: jlarmour/2000-04-07: There *is* a flag EF_MIPS_32BIT_MODE
6185 that could indicate -gp32 BUT gas/config/tc-mips.c contains the
6186 comment:
6187
6188 ``We deliberately don't allow "-gp32" to set the MIPS_32BITMODE
6189 flag in object files because to do so would make it impossible to
102182a9 6190 link with libraries compiled without "-gp32". This is
a5ea2558 6191 unnecessarily restrictive.
361d1df0 6192
a5ea2558
AC
6193 We could solve this problem by adding "-gp32" multilibs to gcc,
6194 but to set this flag before gcc is built with such multilibs will
6195 break too many systems.''
6196
6197 But even more unhelpfully, the default linker output target for
6198 mips64-elf is elf32-bigmips, and has EF_MIPS_32BIT_MODE set, even
6199 for 64-bit programs - you need to change the ABI to change this,
102182a9 6200 and not all gcc targets support that currently. Therefore using
a5ea2558
AC
6201 this flag to detect 32-bit mode would do the wrong thing given
6202 the current gcc - it would make GDB treat these 64-bit programs
102182a9 6203 as 32-bit programs by default. */
a5ea2558 6204
6c997a34 6205 set_gdbarch_read_pc (gdbarch, mips_read_pc);
b6cb9035 6206 set_gdbarch_write_pc (gdbarch, mips_write_pc);
c2d11a7d 6207
102182a9
MS
6208 /* Add/remove bits from an address. The MIPS needs be careful to
6209 ensure that all 32 bit addresses are sign extended to 64 bits. */
875e1767
AC
6210 set_gdbarch_addr_bits_remove (gdbarch, mips_addr_bits_remove);
6211
58dfe9ff
AC
6212 /* Unwind the frame. */
6213 set_gdbarch_unwind_pc (gdbarch, mips_unwind_pc);
30244cd8 6214 set_gdbarch_unwind_sp (gdbarch, mips_unwind_sp);
b8a22b94 6215 set_gdbarch_dummy_id (gdbarch, mips_dummy_id);
10312cc4 6216
102182a9 6217 /* Map debug register numbers onto internal register numbers. */
88c72b7d 6218 set_gdbarch_stab_reg_to_regnum (gdbarch, mips_stab_reg_to_regnum);
6d82d43b
AC
6219 set_gdbarch_ecoff_reg_to_regnum (gdbarch,
6220 mips_dwarf_dwarf2_ecoff_reg_to_regnum);
6d82d43b
AC
6221 set_gdbarch_dwarf2_reg_to_regnum (gdbarch,
6222 mips_dwarf_dwarf2_ecoff_reg_to_regnum);
a4b8ebc8 6223 set_gdbarch_register_sim_regno (gdbarch, mips_register_sim_regno);
88c72b7d 6224
025bb325 6225 /* MIPS version of CALL_DUMMY. */
c2d11a7d 6226
9710e734
AC
6227 /* NOTE: cagney/2003-08-05: Eventually call dummy location will be
6228 replaced by a command, and all targets will default to on stack
6229 (regardless of the stack's execute status). */
6230 set_gdbarch_call_dummy_location (gdbarch, AT_SYMBOL);
dc604539 6231 set_gdbarch_frame_align (gdbarch, mips_frame_align);
d05285fa 6232
87783b8b
AC
6233 set_gdbarch_convert_register_p (gdbarch, mips_convert_register_p);
6234 set_gdbarch_register_to_value (gdbarch, mips_register_to_value);
6235 set_gdbarch_value_to_register (gdbarch, mips_value_to_register);
6236
f7b9e9fc
AC
6237 set_gdbarch_inner_than (gdbarch, core_addr_lessthan);
6238 set_gdbarch_breakpoint_from_pc (gdbarch, mips_breakpoint_from_pc);
f7b9e9fc
AC
6239
6240 set_gdbarch_skip_prologue (gdbarch, mips_skip_prologue);
f7b9e9fc 6241
97ab0fdd
MR
6242 set_gdbarch_in_function_epilogue_p (gdbarch, mips_in_function_epilogue_p);
6243
fc0c74b1
AC
6244 set_gdbarch_pointer_to_address (gdbarch, signed_pointer_to_address);
6245 set_gdbarch_address_to_pointer (gdbarch, address_to_signed_pointer);
6246 set_gdbarch_integer_to_address (gdbarch, mips_integer_to_address);
70f80edf 6247
a4b8ebc8 6248 set_gdbarch_register_type (gdbarch, mips_register_type);
78fde5f8 6249
e11c53d2 6250 set_gdbarch_print_registers_info (gdbarch, mips_print_registers_info);
bf1f5b4c 6251
9dae60cc
UW
6252 if (mips_abi == MIPS_ABI_N32)
6253 set_gdbarch_print_insn (gdbarch, gdb_print_insn_mips_n32);
6254 else if (mips_abi == MIPS_ABI_N64)
6255 set_gdbarch_print_insn (gdbarch, gdb_print_insn_mips_n64);
6256 else
6257 set_gdbarch_print_insn (gdbarch, gdb_print_insn_mips);
e5ab0dce 6258
d92524f1
PM
6259 /* FIXME: cagney/2003-08-29: The macros target_have_steppable_watchpoint,
6260 HAVE_NONSTEPPABLE_WATCHPOINT, and target_have_continuable_watchpoint
3a3bc038 6261 need to all be folded into the target vector. Since they are
d92524f1
PM
6262 being used as guards for target_stopped_by_watchpoint, why not have
6263 target_stopped_by_watchpoint return the type of watchpoint that the code
3a3bc038
AC
6264 is sitting on? */
6265 set_gdbarch_have_nonsteppable_watchpoint (gdbarch, 1);
6266
e7d6a6d2 6267 set_gdbarch_skip_trampoline_code (gdbarch, mips_skip_trampoline_code);
757a7cc6 6268
025bb325
MS
6269 set_gdbarch_single_step_through_delay (gdbarch,
6270 mips_single_step_through_delay);
3352ef37 6271
0d5de010
DJ
6272 /* Virtual tables. */
6273 set_gdbarch_vbit_in_delta (gdbarch, 1);
6274
29709017
DJ
6275 mips_register_g_packet_guesses (gdbarch);
6276
6de918a6 6277 /* Hook in OS ABI-specific overrides, if they have been registered. */
822b6570 6278 info.tdep_info = (void *) tdesc_data;
6de918a6 6279 gdbarch_init_osabi (info, gdbarch);
757a7cc6 6280
5792a79b 6281 /* Unwind the frame. */
b8a22b94
DJ
6282 dwarf2_append_unwinders (gdbarch);
6283 frame_unwind_append_unwinder (gdbarch, &mips_stub_frame_unwind);
6284 frame_unwind_append_unwinder (gdbarch, &mips_insn16_frame_unwind);
6285 frame_unwind_append_unwinder (gdbarch, &mips_insn32_frame_unwind);
2bd0c3d7 6286 frame_base_append_sniffer (gdbarch, dwarf2_frame_base_sniffer);
eec63939 6287 frame_base_append_sniffer (gdbarch, mips_stub_frame_base_sniffer);
45c9dd44
AC
6288 frame_base_append_sniffer (gdbarch, mips_insn16_frame_base_sniffer);
6289 frame_base_append_sniffer (gdbarch, mips_insn32_frame_base_sniffer);
5792a79b 6290
f8b73d13
DJ
6291 if (tdesc_data)
6292 {
6293 set_tdesc_pseudo_register_type (gdbarch, mips_pseudo_register_type);
7cc46491 6294 tdesc_use_registers (gdbarch, info.target_desc, tdesc_data);
f8b73d13
DJ
6295
6296 /* Override the normal target description methods to handle our
6297 dual real and pseudo registers. */
6298 set_gdbarch_register_name (gdbarch, mips_register_name);
025bb325
MS
6299 set_gdbarch_register_reggroup_p (gdbarch,
6300 mips_tdesc_register_reggroup_p);
f8b73d13
DJ
6301
6302 num_regs = gdbarch_num_regs (gdbarch);
6303 set_gdbarch_num_pseudo_regs (gdbarch, num_regs);
6304 set_gdbarch_pc_regnum (gdbarch, tdep->regnum->pc + num_regs);
6305 set_gdbarch_sp_regnum (gdbarch, MIPS_SP_REGNUM + num_regs);
6306 }
6307
6308 /* Add ABI-specific aliases for the registers. */
6309 if (mips_abi == MIPS_ABI_N32 || mips_abi == MIPS_ABI_N64)
6310 for (i = 0; i < ARRAY_SIZE (mips_n32_n64_aliases); i++)
6311 user_reg_add (gdbarch, mips_n32_n64_aliases[i].name,
6312 value_of_mips_user_reg, &mips_n32_n64_aliases[i].regnum);
6313 else
6314 for (i = 0; i < ARRAY_SIZE (mips_o32_aliases); i++)
6315 user_reg_add (gdbarch, mips_o32_aliases[i].name,
6316 value_of_mips_user_reg, &mips_o32_aliases[i].regnum);
6317
6318 /* Add some other standard aliases. */
6319 for (i = 0; i < ARRAY_SIZE (mips_register_aliases); i++)
6320 user_reg_add (gdbarch, mips_register_aliases[i].name,
6321 value_of_mips_user_reg, &mips_register_aliases[i].regnum);
6322
865093a3
AR
6323 for (i = 0; i < ARRAY_SIZE (mips_numeric_register_aliases); i++)
6324 user_reg_add (gdbarch, mips_numeric_register_aliases[i].name,
6325 value_of_mips_user_reg,
6326 &mips_numeric_register_aliases[i].regnum);
6327
4b9b3959
AC
6328 return gdbarch;
6329}
6330
2e4ebe70 6331static void
6d82d43b 6332mips_abi_update (char *ignore_args, int from_tty, struct cmd_list_element *c)
2e4ebe70
DJ
6333{
6334 struct gdbarch_info info;
6335
6336 /* Force the architecture to update, and (if it's a MIPS architecture)
6337 mips_gdbarch_init will take care of the rest. */
6338 gdbarch_info_init (&info);
6339 gdbarch_update_p (info);
6340}
6341
ad188201
KB
6342/* Print out which MIPS ABI is in use. */
6343
6344static void
1f8ca57c
JB
6345show_mips_abi (struct ui_file *file,
6346 int from_tty,
6347 struct cmd_list_element *ignored_cmd,
6348 const char *ignored_value)
ad188201 6349{
1cf3db46 6350 if (gdbarch_bfd_arch_info (target_gdbarch)->arch != bfd_arch_mips)
1f8ca57c
JB
6351 fprintf_filtered
6352 (file,
6353 "The MIPS ABI is unknown because the current architecture "
6354 "is not MIPS.\n");
ad188201
KB
6355 else
6356 {
6357 enum mips_abi global_abi = global_mips_abi ();
1cf3db46 6358 enum mips_abi actual_abi = mips_abi (target_gdbarch);
ad188201
KB
6359 const char *actual_abi_str = mips_abi_strings[actual_abi];
6360
6361 if (global_abi == MIPS_ABI_UNKNOWN)
1f8ca57c
JB
6362 fprintf_filtered
6363 (file,
6364 "The MIPS ABI is set automatically (currently \"%s\").\n",
6d82d43b 6365 actual_abi_str);
ad188201 6366 else if (global_abi == actual_abi)
1f8ca57c
JB
6367 fprintf_filtered
6368 (file,
6369 "The MIPS ABI is assumed to be \"%s\" (due to user setting).\n",
6d82d43b 6370 actual_abi_str);
ad188201
KB
6371 else
6372 {
6373 /* Probably shouldn't happen... */
025bb325
MS
6374 fprintf_filtered (file,
6375 "The (auto detected) MIPS ABI \"%s\" is in use "
6376 "even though the user setting was \"%s\".\n",
6d82d43b 6377 actual_abi_str, mips_abi_strings[global_abi]);
ad188201
KB
6378 }
6379 }
6380}
6381
4b9b3959 6382static void
72a155b4 6383mips_dump_tdep (struct gdbarch *gdbarch, struct ui_file *file)
4b9b3959 6384{
72a155b4 6385 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
4b9b3959 6386 if (tdep != NULL)
c2d11a7d 6387 {
acdb74a0
AC
6388 int ef_mips_arch;
6389 int ef_mips_32bitmode;
f49e4e6d 6390 /* Determine the ISA. */
acdb74a0
AC
6391 switch (tdep->elf_flags & EF_MIPS_ARCH)
6392 {
6393 case E_MIPS_ARCH_1:
6394 ef_mips_arch = 1;
6395 break;
6396 case E_MIPS_ARCH_2:
6397 ef_mips_arch = 2;
6398 break;
6399 case E_MIPS_ARCH_3:
6400 ef_mips_arch = 3;
6401 break;
6402 case E_MIPS_ARCH_4:
93d56215 6403 ef_mips_arch = 4;
acdb74a0
AC
6404 break;
6405 default:
93d56215 6406 ef_mips_arch = 0;
acdb74a0
AC
6407 break;
6408 }
f49e4e6d 6409 /* Determine the size of a pointer. */
acdb74a0 6410 ef_mips_32bitmode = (tdep->elf_flags & EF_MIPS_32BITMODE);
4b9b3959
AC
6411 fprintf_unfiltered (file,
6412 "mips_dump_tdep: tdep->elf_flags = 0x%x\n",
0dadbba0 6413 tdep->elf_flags);
4b9b3959 6414 fprintf_unfiltered (file,
acdb74a0
AC
6415 "mips_dump_tdep: ef_mips_32bitmode = %d\n",
6416 ef_mips_32bitmode);
6417 fprintf_unfiltered (file,
6418 "mips_dump_tdep: ef_mips_arch = %d\n",
6419 ef_mips_arch);
6420 fprintf_unfiltered (file,
6421 "mips_dump_tdep: tdep->mips_abi = %d (%s)\n",
6d82d43b 6422 tdep->mips_abi, mips_abi_strings[tdep->mips_abi]);
4014092b 6423 fprintf_unfiltered (file,
025bb325
MS
6424 "mips_dump_tdep: "
6425 "mips_mask_address_p() %d (default %d)\n",
480d3dd2 6426 mips_mask_address_p (tdep),
4014092b 6427 tdep->default_mask_address_p);
c2d11a7d 6428 }
4b9b3959
AC
6429 fprintf_unfiltered (file,
6430 "mips_dump_tdep: MIPS_DEFAULT_FPU_TYPE = %d (%s)\n",
6431 MIPS_DEFAULT_FPU_TYPE,
6432 (MIPS_DEFAULT_FPU_TYPE == MIPS_FPU_NONE ? "none"
6433 : MIPS_DEFAULT_FPU_TYPE == MIPS_FPU_SINGLE ? "single"
6434 : MIPS_DEFAULT_FPU_TYPE == MIPS_FPU_DOUBLE ? "double"
6435 : "???"));
74ed0bb4
MD
6436 fprintf_unfiltered (file, "mips_dump_tdep: MIPS_EABI = %d\n",
6437 MIPS_EABI (gdbarch));
4b9b3959
AC
6438 fprintf_unfiltered (file,
6439 "mips_dump_tdep: MIPS_FPU_TYPE = %d (%s)\n",
74ed0bb4
MD
6440 MIPS_FPU_TYPE (gdbarch),
6441 (MIPS_FPU_TYPE (gdbarch) == MIPS_FPU_NONE ? "none"
6442 : MIPS_FPU_TYPE (gdbarch) == MIPS_FPU_SINGLE ? "single"
6443 : MIPS_FPU_TYPE (gdbarch) == MIPS_FPU_DOUBLE ? "double"
4b9b3959 6444 : "???"));
c2d11a7d
JM
6445}
6446
025bb325 6447extern initialize_file_ftype _initialize_mips_tdep; /* -Wmissing-prototypes */
a78f21af 6448
c906108c 6449void
acdb74a0 6450_initialize_mips_tdep (void)
c906108c
SS
6451{
6452 static struct cmd_list_element *mipsfpulist = NULL;
6453 struct cmd_list_element *c;
6454
6d82d43b 6455 mips_abi_string = mips_abi_strings[MIPS_ABI_UNKNOWN];
2e4ebe70
DJ
6456 if (MIPS_ABI_LAST + 1
6457 != sizeof (mips_abi_strings) / sizeof (mips_abi_strings[0]))
e2e0b3e5 6458 internal_error (__FILE__, __LINE__, _("mips_abi_strings out of sync"));
2e4ebe70 6459
4b9b3959 6460 gdbarch_register (bfd_arch_mips, mips_gdbarch_init, mips_dump_tdep);
c906108c 6461
8d5f9dcb
DJ
6462 mips_pdr_data = register_objfile_data ();
6463
4eb0ad19
DJ
6464 /* Create feature sets with the appropriate properties. The values
6465 are not important. */
6466 mips_tdesc_gp32 = allocate_target_description ();
6467 set_tdesc_property (mips_tdesc_gp32, PROPERTY_GP32, "");
6468
6469 mips_tdesc_gp64 = allocate_target_description ();
6470 set_tdesc_property (mips_tdesc_gp64, PROPERTY_GP64, "");
6471
025bb325 6472 /* Add root prefix command for all "set mips"/"show mips" commands. */
a5ea2558 6473 add_prefix_cmd ("mips", no_class, set_mips_command,
1bedd215 6474 _("Various MIPS specific commands."),
a5ea2558
AC
6475 &setmipscmdlist, "set mips ", 0, &setlist);
6476
6477 add_prefix_cmd ("mips", no_class, show_mips_command,
1bedd215 6478 _("Various MIPS specific commands."),
a5ea2558
AC
6479 &showmipscmdlist, "show mips ", 0, &showlist);
6480
025bb325 6481 /* Allow the user to override the ABI. */
7ab04401
AC
6482 add_setshow_enum_cmd ("abi", class_obscure, mips_abi_strings,
6483 &mips_abi_string, _("\
6484Set the MIPS ABI used by this program."), _("\
6485Show the MIPS ABI used by this program."), _("\
6486This option can be set to one of:\n\
6487 auto - the default ABI associated with the current binary\n\
6488 o32\n\
6489 o64\n\
6490 n32\n\
6491 n64\n\
6492 eabi32\n\
6493 eabi64"),
6494 mips_abi_update,
6495 show_mips_abi,
6496 &setmipscmdlist, &showmipscmdlist);
2e4ebe70 6497
c906108c
SS
6498 /* Let the user turn off floating point and set the fence post for
6499 heuristic_proc_start. */
6500
6501 add_prefix_cmd ("mipsfpu", class_support, set_mipsfpu_command,
1bedd215 6502 _("Set use of MIPS floating-point coprocessor."),
c906108c
SS
6503 &mipsfpulist, "set mipsfpu ", 0, &setlist);
6504 add_cmd ("single", class_support, set_mipsfpu_single_command,
1a966eab 6505 _("Select single-precision MIPS floating-point coprocessor."),
c906108c
SS
6506 &mipsfpulist);
6507 add_cmd ("double", class_support, set_mipsfpu_double_command,
1a966eab 6508 _("Select double-precision MIPS floating-point coprocessor."),
c906108c
SS
6509 &mipsfpulist);
6510 add_alias_cmd ("on", "double", class_support, 1, &mipsfpulist);
6511 add_alias_cmd ("yes", "double", class_support, 1, &mipsfpulist);
6512 add_alias_cmd ("1", "double", class_support, 1, &mipsfpulist);
6513 add_cmd ("none", class_support, set_mipsfpu_none_command,
1a966eab 6514 _("Select no MIPS floating-point coprocessor."), &mipsfpulist);
c906108c
SS
6515 add_alias_cmd ("off", "none", class_support, 1, &mipsfpulist);
6516 add_alias_cmd ("no", "none", class_support, 1, &mipsfpulist);
6517 add_alias_cmd ("0", "none", class_support, 1, &mipsfpulist);
6518 add_cmd ("auto", class_support, set_mipsfpu_auto_command,
1a966eab 6519 _("Select MIPS floating-point coprocessor automatically."),
c906108c
SS
6520 &mipsfpulist);
6521 add_cmd ("mipsfpu", class_support, show_mipsfpu_command,
1a966eab 6522 _("Show current use of MIPS floating-point coprocessor target."),
c906108c
SS
6523 &showlist);
6524
c906108c
SS
6525 /* We really would like to have both "0" and "unlimited" work, but
6526 command.c doesn't deal with that. So make it a var_zinteger
6527 because the user can always use "999999" or some such for unlimited. */
6bcadd06 6528 add_setshow_zinteger_cmd ("heuristic-fence-post", class_support,
7915a72c
AC
6529 &heuristic_fence_post, _("\
6530Set the distance searched for the start of a function."), _("\
6531Show the distance searched for the start of a function."), _("\
c906108c
SS
6532If you are debugging a stripped executable, GDB needs to search through the\n\
6533program for the start of a function. This command sets the distance of the\n\
7915a72c 6534search. The only need to set it is when debugging a stripped executable."),
2c5b56ce 6535 reinit_frame_cache_sfunc,
025bb325
MS
6536 NULL, /* FIXME: i18n: The distance searched for
6537 the start of a function is %s. */
6bcadd06 6538 &setlist, &showlist);
c906108c
SS
6539
6540 /* Allow the user to control whether the upper bits of 64-bit
6541 addresses should be zeroed. */
7915a72c
AC
6542 add_setshow_auto_boolean_cmd ("mask-address", no_class,
6543 &mask_address_var, _("\
6544Set zeroing of upper 32 bits of 64-bit addresses."), _("\
6545Show zeroing of upper 32 bits of 64-bit addresses."), _("\
cce7e648 6546Use \"on\" to enable the masking, \"off\" to disable it and \"auto\" to\n\
7915a72c 6547allow GDB to determine the correct value."),
08546159
AC
6548 NULL, show_mask_address,
6549 &setmipscmdlist, &showmipscmdlist);
43e526b9
JM
6550
6551 /* Allow the user to control the size of 32 bit registers within the
6552 raw remote packet. */
b3f42336 6553 add_setshow_boolean_cmd ("remote-mips64-transfers-32bit-regs", class_obscure,
7915a72c
AC
6554 &mips64_transfers_32bit_regs_p, _("\
6555Set compatibility with 64-bit MIPS target that transfers 32-bit quantities."),
6556 _("\
6557Show compatibility with 64-bit MIPS target that transfers 32-bit quantities."),
6558 _("\
719ec221
AC
6559Use \"on\" to enable backward compatibility with older MIPS 64 GDB+target\n\
6560that would transfer 32 bits for some registers (e.g. SR, FSR) and\n\
7915a72c 656164 bits for others. Use \"off\" to disable compatibility mode"),
2c5b56ce 6562 set_mips64_transfers_32bit_regs,
025bb325
MS
6563 NULL, /* FIXME: i18n: Compatibility with 64-bit
6564 MIPS target that transfers 32-bit
6565 quantities is %s. */
7915a72c 6566 &setlist, &showlist);
9ace0497 6567
025bb325 6568 /* Debug this files internals. */
6bcadd06 6569 add_setshow_zinteger_cmd ("mips", class_maintenance,
7915a72c
AC
6570 &mips_debug, _("\
6571Set mips debugging."), _("\
6572Show mips debugging."), _("\
6573When non-zero, mips specific debugging is enabled."),
2c5b56ce 6574 NULL,
025bb325
MS
6575 NULL, /* FIXME: i18n: Mips debugging is
6576 currently %s. */
6bcadd06 6577 &setdebuglist, &showdebuglist);
c906108c 6578}
This page took 1.607634 seconds and 4 git commands to generate.