]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blob - gdb/m68k-tdep.c
GDB copyright headers update after running GDB's copyright.py script.
[thirdparty/binutils-gdb.git] / gdb / m68k-tdep.c
1 /* Target-dependent code for the Motorola 68000 series.
2
3 Copyright (C) 1990-2016 Free Software Foundation, Inc.
4
5 This file is part of GDB.
6
7 This program is free software; you can redistribute it and/or modify
8 it under the terms of the GNU General Public License as published by
9 the Free Software Foundation; either version 3 of the License, or
10 (at your option) any later version.
11
12 This program is distributed in the hope that it will be useful,
13 but WITHOUT ANY WARRANTY; without even the implied warranty of
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 GNU General Public License for more details.
16
17 You should have received a copy of the GNU General Public License
18 along with this program. If not, see <http://www.gnu.org/licenses/>. */
19
20 #include "defs.h"
21 #include "dwarf2-frame.h"
22 #include "frame.h"
23 #include "frame-base.h"
24 #include "frame-unwind.h"
25 #include "gdbtypes.h"
26 #include "symtab.h"
27 #include "gdbcore.h"
28 #include "value.h"
29 #include "inferior.h"
30 #include "regcache.h"
31 #include "arch-utils.h"
32 #include "osabi.h"
33 #include "dis-asm.h"
34 #include "target-descriptions.h"
35
36 #include "m68k-tdep.h"
37 \f
38
39 #define P_LINKL_FP 0x480e
40 #define P_LINKW_FP 0x4e56
41 #define P_PEA_FP 0x4856
42 #define P_MOVEAL_SP_FP 0x2c4f
43 #define P_ADDAW_SP 0xdefc
44 #define P_ADDAL_SP 0xdffc
45 #define P_SUBQW_SP 0x514f
46 #define P_SUBQL_SP 0x518f
47 #define P_LEA_SP_SP 0x4fef
48 #define P_LEA_PC_A5 0x4bfb0170
49 #define P_FMOVEMX_SP 0xf227
50 #define P_MOVEL_SP 0x2f00
51 #define P_MOVEML_SP 0x48e7
52
53 /* Offset from SP to first arg on stack at first instruction of a function. */
54 #define SP_ARG0 (1 * 4)
55
56 #if !defined (BPT_VECTOR)
57 #define BPT_VECTOR 0xf
58 #endif
59
60 static const gdb_byte *
61 m68k_local_breakpoint_from_pc (struct gdbarch *gdbarch,
62 CORE_ADDR *pcptr, int *lenptr)
63 {
64 static gdb_byte break_insn[] = {0x4e, (0x40 | BPT_VECTOR)};
65 *lenptr = sizeof (break_insn);
66 return break_insn;
67 }
68 \f
69
70 /* Construct types for ISA-specific registers. */
71 static struct type *
72 m68k_ps_type (struct gdbarch *gdbarch)
73 {
74 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
75
76 if (!tdep->m68k_ps_type)
77 {
78 struct type *type;
79
80 type = arch_flags_type (gdbarch, "builtin_type_m68k_ps", 4);
81 append_flags_type_flag (type, 0, "C");
82 append_flags_type_flag (type, 1, "V");
83 append_flags_type_flag (type, 2, "Z");
84 append_flags_type_flag (type, 3, "N");
85 append_flags_type_flag (type, 4, "X");
86 append_flags_type_flag (type, 8, "I0");
87 append_flags_type_flag (type, 9, "I1");
88 append_flags_type_flag (type, 10, "I2");
89 append_flags_type_flag (type, 12, "M");
90 append_flags_type_flag (type, 13, "S");
91 append_flags_type_flag (type, 14, "T0");
92 append_flags_type_flag (type, 15, "T1");
93
94 tdep->m68k_ps_type = type;
95 }
96
97 return tdep->m68k_ps_type;
98 }
99
100 static struct type *
101 m68881_ext_type (struct gdbarch *gdbarch)
102 {
103 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
104
105 if (!tdep->m68881_ext_type)
106 tdep->m68881_ext_type
107 = arch_float_type (gdbarch, -1, "builtin_type_m68881_ext",
108 floatformats_m68881_ext);
109
110 return tdep->m68881_ext_type;
111 }
112
113 /* Return the GDB type object for the "standard" data type of data in
114 register N. This should be int for D0-D7, SR, FPCONTROL and
115 FPSTATUS, long double for FP0-FP7, and void pointer for all others
116 (A0-A7, PC, FPIADDR). Note, for registers which contain
117 addresses return pointer to void, not pointer to char, because we
118 don't want to attempt to print the string after printing the
119 address. */
120
121 static struct type *
122 m68k_register_type (struct gdbarch *gdbarch, int regnum)
123 {
124 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
125
126 if (tdep->fpregs_present)
127 {
128 if (regnum >= gdbarch_fp0_regnum (gdbarch)
129 && regnum <= gdbarch_fp0_regnum (gdbarch) + 7)
130 {
131 if (tdep->flavour == m68k_coldfire_flavour)
132 return builtin_type (gdbarch)->builtin_double;
133 else
134 return m68881_ext_type (gdbarch);
135 }
136
137 if (regnum == M68K_FPI_REGNUM)
138 return builtin_type (gdbarch)->builtin_func_ptr;
139
140 if (regnum == M68K_FPC_REGNUM || regnum == M68K_FPS_REGNUM)
141 return builtin_type (gdbarch)->builtin_int32;
142 }
143 else
144 {
145 if (regnum >= M68K_FP0_REGNUM && regnum <= M68K_FPI_REGNUM)
146 return builtin_type (gdbarch)->builtin_int0;
147 }
148
149 if (regnum == gdbarch_pc_regnum (gdbarch))
150 return builtin_type (gdbarch)->builtin_func_ptr;
151
152 if (regnum >= M68K_A0_REGNUM && regnum <= M68K_A0_REGNUM + 7)
153 return builtin_type (gdbarch)->builtin_data_ptr;
154
155 if (regnum == M68K_PS_REGNUM)
156 return m68k_ps_type (gdbarch);
157
158 return builtin_type (gdbarch)->builtin_int32;
159 }
160
161 static const char *m68k_register_names[] = {
162 "d0", "d1", "d2", "d3", "d4", "d5", "d6", "d7",
163 "a0", "a1", "a2", "a3", "a4", "a5", "fp", "sp",
164 "ps", "pc",
165 "fp0", "fp1", "fp2", "fp3", "fp4", "fp5", "fp6", "fp7",
166 "fpcontrol", "fpstatus", "fpiaddr"
167 };
168
169 /* Function: m68k_register_name
170 Returns the name of the standard m68k register regnum. */
171
172 static const char *
173 m68k_register_name (struct gdbarch *gdbarch, int regnum)
174 {
175 if (regnum < 0 || regnum >= ARRAY_SIZE (m68k_register_names))
176 internal_error (__FILE__, __LINE__,
177 _("m68k_register_name: illegal register number %d"),
178 regnum);
179 else if (regnum >= M68K_FP0_REGNUM && regnum <= M68K_FPI_REGNUM
180 && gdbarch_tdep (gdbarch)->fpregs_present == 0)
181 return "";
182 else
183 return m68k_register_names[regnum];
184 }
185 \f
186 /* Return nonzero if a value of type TYPE stored in register REGNUM
187 needs any special handling. */
188
189 static int
190 m68k_convert_register_p (struct gdbarch *gdbarch,
191 int regnum, struct type *type)
192 {
193 if (!gdbarch_tdep (gdbarch)->fpregs_present)
194 return 0;
195 return (regnum >= M68K_FP0_REGNUM && regnum <= M68K_FP0_REGNUM + 7
196 && type != register_type (gdbarch, M68K_FP0_REGNUM));
197 }
198
199 /* Read a value of type TYPE from register REGNUM in frame FRAME, and
200 return its contents in TO. */
201
202 static int
203 m68k_register_to_value (struct frame_info *frame, int regnum,
204 struct type *type, gdb_byte *to,
205 int *optimizedp, int *unavailablep)
206 {
207 gdb_byte from[M68K_MAX_REGISTER_SIZE];
208 struct type *fpreg_type = register_type (get_frame_arch (frame),
209 M68K_FP0_REGNUM);
210
211 /* We only support floating-point values. */
212 if (TYPE_CODE (type) != TYPE_CODE_FLT)
213 {
214 warning (_("Cannot convert floating-point register value "
215 "to non-floating-point type."));
216 *optimizedp = *unavailablep = 0;
217 return 0;
218 }
219
220 /* Convert to TYPE. */
221
222 /* Convert to TYPE. */
223 if (!get_frame_register_bytes (frame, regnum, 0, TYPE_LENGTH (type),
224 from, optimizedp, unavailablep))
225 return 0;
226
227 convert_typed_floating (from, fpreg_type, to, type);
228 *optimizedp = *unavailablep = 0;
229 return 1;
230 }
231
232 /* Write the contents FROM of a value of type TYPE into register
233 REGNUM in frame FRAME. */
234
235 static void
236 m68k_value_to_register (struct frame_info *frame, int regnum,
237 struct type *type, const gdb_byte *from)
238 {
239 gdb_byte to[M68K_MAX_REGISTER_SIZE];
240 struct type *fpreg_type = register_type (get_frame_arch (frame),
241 M68K_FP0_REGNUM);
242
243 /* We only support floating-point values. */
244 if (TYPE_CODE (type) != TYPE_CODE_FLT)
245 {
246 warning (_("Cannot convert non-floating-point type "
247 "to floating-point register value."));
248 return;
249 }
250
251 /* Convert from TYPE. */
252 convert_typed_floating (from, type, to, fpreg_type);
253 put_frame_register (frame, regnum, to);
254 }
255
256 \f
257 /* There is a fair number of calling conventions that are in somewhat
258 wide use. The 68000/08/10 don't support an FPU, not even as a
259 coprocessor. All function return values are stored in %d0/%d1.
260 Structures are returned in a static buffer, a pointer to which is
261 returned in %d0. This means that functions returning a structure
262 are not re-entrant. To avoid this problem some systems use a
263 convention where the caller passes a pointer to a buffer in %a1
264 where the return values is to be stored. This convention is the
265 default, and is implemented in the function m68k_return_value.
266
267 The 68020/030/040/060 do support an FPU, either as a coprocessor
268 (68881/2) or built-in (68040/68060). That's why System V release 4
269 (SVR4) instroduces a new calling convention specified by the SVR4
270 psABI. Integer values are returned in %d0/%d1, pointer return
271 values in %a0 and floating values in %fp0. When calling functions
272 returning a structure the caller should pass a pointer to a buffer
273 for the return value in %a0. This convention is implemented in the
274 function m68k_svr4_return_value, and by appropriately setting the
275 struct_value_regnum member of `struct gdbarch_tdep'.
276
277 GNU/Linux returns values in the same way as SVR4 does, but uses %a1
278 for passing the structure return value buffer.
279
280 GCC can also generate code where small structures are returned in
281 %d0/%d1 instead of in memory by using -freg-struct-return. This is
282 the default on NetBSD a.out, OpenBSD and GNU/Linux and several
283 embedded systems. This convention is implemented by setting the
284 struct_return member of `struct gdbarch_tdep' to reg_struct_return. */
285
286 /* Read a function return value of TYPE from REGCACHE, and copy that
287 into VALBUF. */
288
289 static void
290 m68k_extract_return_value (struct type *type, struct regcache *regcache,
291 gdb_byte *valbuf)
292 {
293 int len = TYPE_LENGTH (type);
294 gdb_byte buf[M68K_MAX_REGISTER_SIZE];
295
296 if (len <= 4)
297 {
298 regcache_raw_read (regcache, M68K_D0_REGNUM, buf);
299 memcpy (valbuf, buf + (4 - len), len);
300 }
301 else if (len <= 8)
302 {
303 regcache_raw_read (regcache, M68K_D0_REGNUM, buf);
304 memcpy (valbuf, buf + (8 - len), len - 4);
305 regcache_raw_read (regcache, M68K_D1_REGNUM, valbuf + (len - 4));
306 }
307 else
308 internal_error (__FILE__, __LINE__,
309 _("Cannot extract return value of %d bytes long."), len);
310 }
311
312 static void
313 m68k_svr4_extract_return_value (struct type *type, struct regcache *regcache,
314 gdb_byte *valbuf)
315 {
316 gdb_byte buf[M68K_MAX_REGISTER_SIZE];
317 struct gdbarch *gdbarch = get_regcache_arch (regcache);
318 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
319
320 if (tdep->float_return && TYPE_CODE (type) == TYPE_CODE_FLT)
321 {
322 struct type *fpreg_type = register_type (gdbarch, M68K_FP0_REGNUM);
323 regcache_raw_read (regcache, M68K_FP0_REGNUM, buf);
324 convert_typed_floating (buf, fpreg_type, valbuf, type);
325 }
326 else if (TYPE_CODE (type) == TYPE_CODE_PTR && TYPE_LENGTH (type) == 4)
327 regcache_raw_read (regcache, M68K_A0_REGNUM, valbuf);
328 else
329 m68k_extract_return_value (type, regcache, valbuf);
330 }
331
332 /* Write a function return value of TYPE from VALBUF into REGCACHE. */
333
334 static void
335 m68k_store_return_value (struct type *type, struct regcache *regcache,
336 const gdb_byte *valbuf)
337 {
338 int len = TYPE_LENGTH (type);
339
340 if (len <= 4)
341 regcache_raw_write_part (regcache, M68K_D0_REGNUM, 4 - len, len, valbuf);
342 else if (len <= 8)
343 {
344 regcache_raw_write_part (regcache, M68K_D0_REGNUM, 8 - len,
345 len - 4, valbuf);
346 regcache_raw_write (regcache, M68K_D1_REGNUM, valbuf + (len - 4));
347 }
348 else
349 internal_error (__FILE__, __LINE__,
350 _("Cannot store return value of %d bytes long."), len);
351 }
352
353 static void
354 m68k_svr4_store_return_value (struct type *type, struct regcache *regcache,
355 const gdb_byte *valbuf)
356 {
357 struct gdbarch *gdbarch = get_regcache_arch (regcache);
358 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
359
360 if (tdep->float_return && TYPE_CODE (type) == TYPE_CODE_FLT)
361 {
362 struct type *fpreg_type = register_type (gdbarch, M68K_FP0_REGNUM);
363 gdb_byte buf[M68K_MAX_REGISTER_SIZE];
364 convert_typed_floating (valbuf, type, buf, fpreg_type);
365 regcache_raw_write (regcache, M68K_FP0_REGNUM, buf);
366 }
367 else if (TYPE_CODE (type) == TYPE_CODE_PTR && TYPE_LENGTH (type) == 4)
368 {
369 regcache_raw_write (regcache, M68K_A0_REGNUM, valbuf);
370 regcache_raw_write (regcache, M68K_D0_REGNUM, valbuf);
371 }
372 else
373 m68k_store_return_value (type, regcache, valbuf);
374 }
375
376 /* Return non-zero if TYPE, which is assumed to be a structure, union or
377 complex type, should be returned in registers for architecture
378 GDBARCH. */
379
380 static int
381 m68k_reg_struct_return_p (struct gdbarch *gdbarch, struct type *type)
382 {
383 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
384 enum type_code code = TYPE_CODE (type);
385 int len = TYPE_LENGTH (type);
386
387 gdb_assert (code == TYPE_CODE_STRUCT || code == TYPE_CODE_UNION
388 || code == TYPE_CODE_COMPLEX);
389
390 if (tdep->struct_return == pcc_struct_return)
391 return 0;
392
393 return (len == 1 || len == 2 || len == 4 || len == 8);
394 }
395
396 /* Determine, for architecture GDBARCH, how a return value of TYPE
397 should be returned. If it is supposed to be returned in registers,
398 and READBUF is non-zero, read the appropriate value from REGCACHE,
399 and copy it into READBUF. If WRITEBUF is non-zero, write the value
400 from WRITEBUF into REGCACHE. */
401
402 static enum return_value_convention
403 m68k_return_value (struct gdbarch *gdbarch, struct value *function,
404 struct type *type, struct regcache *regcache,
405 gdb_byte *readbuf, const gdb_byte *writebuf)
406 {
407 enum type_code code = TYPE_CODE (type);
408
409 /* GCC returns a `long double' in memory too. */
410 if (((code == TYPE_CODE_STRUCT || code == TYPE_CODE_UNION
411 || code == TYPE_CODE_COMPLEX)
412 && !m68k_reg_struct_return_p (gdbarch, type))
413 || (code == TYPE_CODE_FLT && TYPE_LENGTH (type) == 12))
414 {
415 /* The default on m68k is to return structures in static memory.
416 Consequently a function must return the address where we can
417 find the return value. */
418
419 if (readbuf)
420 {
421 ULONGEST addr;
422
423 regcache_raw_read_unsigned (regcache, M68K_D0_REGNUM, &addr);
424 read_memory (addr, readbuf, TYPE_LENGTH (type));
425 }
426
427 return RETURN_VALUE_ABI_RETURNS_ADDRESS;
428 }
429
430 if (readbuf)
431 m68k_extract_return_value (type, regcache, readbuf);
432 if (writebuf)
433 m68k_store_return_value (type, regcache, writebuf);
434
435 return RETURN_VALUE_REGISTER_CONVENTION;
436 }
437
438 static enum return_value_convention
439 m68k_svr4_return_value (struct gdbarch *gdbarch, struct value *function,
440 struct type *type, struct regcache *regcache,
441 gdb_byte *readbuf, const gdb_byte *writebuf)
442 {
443 enum type_code code = TYPE_CODE (type);
444
445 if ((code == TYPE_CODE_STRUCT || code == TYPE_CODE_UNION
446 || code == TYPE_CODE_COMPLEX)
447 && !m68k_reg_struct_return_p (gdbarch, type))
448 {
449 /* The System V ABI says that:
450
451 "A function returning a structure or union also sets %a0 to
452 the value it finds in %a0. Thus when the caller receives
453 control again, the address of the returned object resides in
454 register %a0."
455
456 So the ABI guarantees that we can always find the return
457 value just after the function has returned. */
458
459 if (readbuf)
460 {
461 ULONGEST addr;
462
463 regcache_raw_read_unsigned (regcache, M68K_A0_REGNUM, &addr);
464 read_memory (addr, readbuf, TYPE_LENGTH (type));
465 }
466
467 return RETURN_VALUE_ABI_RETURNS_ADDRESS;
468 }
469
470 /* This special case is for structures consisting of a single
471 `float' or `double' member. These structures are returned in
472 %fp0. For these structures, we call ourselves recursively,
473 changing TYPE into the type of the first member of the structure.
474 Since that should work for all structures that have only one
475 member, we don't bother to check the member's type here. */
476 if (code == TYPE_CODE_STRUCT && TYPE_NFIELDS (type) == 1)
477 {
478 type = check_typedef (TYPE_FIELD_TYPE (type, 0));
479 return m68k_svr4_return_value (gdbarch, function, type, regcache,
480 readbuf, writebuf);
481 }
482
483 if (readbuf)
484 m68k_svr4_extract_return_value (type, regcache, readbuf);
485 if (writebuf)
486 m68k_svr4_store_return_value (type, regcache, writebuf);
487
488 return RETURN_VALUE_REGISTER_CONVENTION;
489 }
490 \f
491
492 /* Always align the frame to a 4-byte boundary. This is required on
493 coldfire and harmless on the rest. */
494
495 static CORE_ADDR
496 m68k_frame_align (struct gdbarch *gdbarch, CORE_ADDR sp)
497 {
498 /* Align the stack to four bytes. */
499 return sp & ~3;
500 }
501
502 static CORE_ADDR
503 m68k_push_dummy_call (struct gdbarch *gdbarch, struct value *function,
504 struct regcache *regcache, CORE_ADDR bp_addr, int nargs,
505 struct value **args, CORE_ADDR sp, int struct_return,
506 CORE_ADDR struct_addr)
507 {
508 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
509 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
510 gdb_byte buf[4];
511 int i;
512
513 /* Push arguments in reverse order. */
514 for (i = nargs - 1; i >= 0; i--)
515 {
516 struct type *value_type = value_enclosing_type (args[i]);
517 int len = TYPE_LENGTH (value_type);
518 int container_len = (len + 3) & ~3;
519 int offset;
520
521 /* Non-scalars bigger than 4 bytes are left aligned, others are
522 right aligned. */
523 if ((TYPE_CODE (value_type) == TYPE_CODE_STRUCT
524 || TYPE_CODE (value_type) == TYPE_CODE_UNION
525 || TYPE_CODE (value_type) == TYPE_CODE_ARRAY)
526 && len > 4)
527 offset = 0;
528 else
529 offset = container_len - len;
530 sp -= container_len;
531 write_memory (sp + offset, value_contents_all (args[i]), len);
532 }
533
534 /* Store struct value address. */
535 if (struct_return)
536 {
537 store_unsigned_integer (buf, 4, byte_order, struct_addr);
538 regcache_cooked_write (regcache, tdep->struct_value_regnum, buf);
539 }
540
541 /* Store return address. */
542 sp -= 4;
543 store_unsigned_integer (buf, 4, byte_order, bp_addr);
544 write_memory (sp, buf, 4);
545
546 /* Finally, update the stack pointer... */
547 store_unsigned_integer (buf, 4, byte_order, sp);
548 regcache_cooked_write (regcache, M68K_SP_REGNUM, buf);
549
550 /* ...and fake a frame pointer. */
551 regcache_cooked_write (regcache, M68K_FP_REGNUM, buf);
552
553 /* DWARF2/GCC uses the stack address *before* the function call as a
554 frame's CFA. */
555 return sp + 8;
556 }
557
558 /* Convert a dwarf or dwarf2 regnumber to a GDB regnum. */
559
560 static int
561 m68k_dwarf_reg_to_regnum (struct gdbarch *gdbarch, int num)
562 {
563 if (num < 8)
564 /* d0..7 */
565 return (num - 0) + M68K_D0_REGNUM;
566 else if (num < 16)
567 /* a0..7 */
568 return (num - 8) + M68K_A0_REGNUM;
569 else if (num < 24 && gdbarch_tdep (gdbarch)->fpregs_present)
570 /* fp0..7 */
571 return (num - 16) + M68K_FP0_REGNUM;
572 else if (num == 25)
573 /* pc */
574 return M68K_PC_REGNUM;
575 else
576 return -1;
577 }
578
579 \f
580 struct m68k_frame_cache
581 {
582 /* Base address. */
583 CORE_ADDR base;
584 CORE_ADDR sp_offset;
585 CORE_ADDR pc;
586
587 /* Saved registers. */
588 CORE_ADDR saved_regs[M68K_NUM_REGS];
589 CORE_ADDR saved_sp;
590
591 /* Stack space reserved for local variables. */
592 long locals;
593 };
594
595 /* Allocate and initialize a frame cache. */
596
597 static struct m68k_frame_cache *
598 m68k_alloc_frame_cache (void)
599 {
600 struct m68k_frame_cache *cache;
601 int i;
602
603 cache = FRAME_OBSTACK_ZALLOC (struct m68k_frame_cache);
604
605 /* Base address. */
606 cache->base = 0;
607 cache->sp_offset = -4;
608 cache->pc = 0;
609
610 /* Saved registers. We initialize these to -1 since zero is a valid
611 offset (that's where %fp is supposed to be stored). */
612 for (i = 0; i < M68K_NUM_REGS; i++)
613 cache->saved_regs[i] = -1;
614
615 /* Frameless until proven otherwise. */
616 cache->locals = -1;
617
618 return cache;
619 }
620
621 /* Check whether PC points at a code that sets up a new stack frame.
622 If so, it updates CACHE and returns the address of the first
623 instruction after the sequence that sets removes the "hidden"
624 argument from the stack or CURRENT_PC, whichever is smaller.
625 Otherwise, return PC. */
626
627 static CORE_ADDR
628 m68k_analyze_frame_setup (struct gdbarch *gdbarch,
629 CORE_ADDR pc, CORE_ADDR current_pc,
630 struct m68k_frame_cache *cache)
631 {
632 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
633 int op;
634
635 if (pc >= current_pc)
636 return current_pc;
637
638 op = read_memory_unsigned_integer (pc, 2, byte_order);
639
640 if (op == P_LINKW_FP || op == P_LINKL_FP || op == P_PEA_FP)
641 {
642 cache->saved_regs[M68K_FP_REGNUM] = 0;
643 cache->sp_offset += 4;
644 if (op == P_LINKW_FP)
645 {
646 /* link.w %fp, #-N */
647 /* link.w %fp, #0; adda.l #-N, %sp */
648 cache->locals = -read_memory_integer (pc + 2, 2, byte_order);
649
650 if (pc + 4 < current_pc && cache->locals == 0)
651 {
652 op = read_memory_unsigned_integer (pc + 4, 2, byte_order);
653 if (op == P_ADDAL_SP)
654 {
655 cache->locals = read_memory_integer (pc + 6, 4, byte_order);
656 return pc + 10;
657 }
658 }
659
660 return pc + 4;
661 }
662 else if (op == P_LINKL_FP)
663 {
664 /* link.l %fp, #-N */
665 cache->locals = -read_memory_integer (pc + 2, 4, byte_order);
666 return pc + 6;
667 }
668 else
669 {
670 /* pea (%fp); movea.l %sp, %fp */
671 cache->locals = 0;
672
673 if (pc + 2 < current_pc)
674 {
675 op = read_memory_unsigned_integer (pc + 2, 2, byte_order);
676
677 if (op == P_MOVEAL_SP_FP)
678 {
679 /* move.l %sp, %fp */
680 return pc + 4;
681 }
682 }
683
684 return pc + 2;
685 }
686 }
687 else if ((op & 0170777) == P_SUBQW_SP || (op & 0170777) == P_SUBQL_SP)
688 {
689 /* subq.[wl] #N,%sp */
690 /* subq.[wl] #8,%sp; subq.[wl] #N,%sp */
691 cache->locals = (op & 07000) == 0 ? 8 : (op & 07000) >> 9;
692 if (pc + 2 < current_pc)
693 {
694 op = read_memory_unsigned_integer (pc + 2, 2, byte_order);
695 if ((op & 0170777) == P_SUBQW_SP || (op & 0170777) == P_SUBQL_SP)
696 {
697 cache->locals += (op & 07000) == 0 ? 8 : (op & 07000) >> 9;
698 return pc + 4;
699 }
700 }
701 return pc + 2;
702 }
703 else if (op == P_ADDAW_SP || op == P_LEA_SP_SP)
704 {
705 /* adda.w #-N,%sp */
706 /* lea (-N,%sp),%sp */
707 cache->locals = -read_memory_integer (pc + 2, 2, byte_order);
708 return pc + 4;
709 }
710 else if (op == P_ADDAL_SP)
711 {
712 /* adda.l #-N,%sp */
713 cache->locals = -read_memory_integer (pc + 2, 4, byte_order);
714 return pc + 6;
715 }
716
717 return pc;
718 }
719
720 /* Check whether PC points at code that saves registers on the stack.
721 If so, it updates CACHE and returns the address of the first
722 instruction after the register saves or CURRENT_PC, whichever is
723 smaller. Otherwise, return PC. */
724
725 static CORE_ADDR
726 m68k_analyze_register_saves (struct gdbarch *gdbarch, CORE_ADDR pc,
727 CORE_ADDR current_pc,
728 struct m68k_frame_cache *cache)
729 {
730 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
731
732 if (cache->locals >= 0)
733 {
734 CORE_ADDR offset;
735 int op;
736 int i, mask, regno;
737
738 offset = -4 - cache->locals;
739 while (pc < current_pc)
740 {
741 op = read_memory_unsigned_integer (pc, 2, byte_order);
742 if (op == P_FMOVEMX_SP
743 && gdbarch_tdep (gdbarch)->fpregs_present)
744 {
745 /* fmovem.x REGS,-(%sp) */
746 op = read_memory_unsigned_integer (pc + 2, 2, byte_order);
747 if ((op & 0xff00) == 0xe000)
748 {
749 mask = op & 0xff;
750 for (i = 0; i < 16; i++, mask >>= 1)
751 {
752 if (mask & 1)
753 {
754 cache->saved_regs[i + M68K_FP0_REGNUM] = offset;
755 offset -= 12;
756 }
757 }
758 pc += 4;
759 }
760 else
761 break;
762 }
763 else if ((op & 0177760) == P_MOVEL_SP)
764 {
765 /* move.l %R,-(%sp) */
766 regno = op & 017;
767 cache->saved_regs[regno] = offset;
768 offset -= 4;
769 pc += 2;
770 }
771 else if (op == P_MOVEML_SP)
772 {
773 /* movem.l REGS,-(%sp) */
774 mask = read_memory_unsigned_integer (pc + 2, 2, byte_order);
775 for (i = 0; i < 16; i++, mask >>= 1)
776 {
777 if (mask & 1)
778 {
779 cache->saved_regs[15 - i] = offset;
780 offset -= 4;
781 }
782 }
783 pc += 4;
784 }
785 else
786 break;
787 }
788 }
789
790 return pc;
791 }
792
793
794 /* Do a full analysis of the prologue at PC and update CACHE
795 accordingly. Bail out early if CURRENT_PC is reached. Return the
796 address where the analysis stopped.
797
798 We handle all cases that can be generated by gcc.
799
800 For allocating a stack frame:
801
802 link.w %a6,#-N
803 link.l %a6,#-N
804 pea (%fp); move.l %sp,%fp
805 link.w %a6,#0; add.l #-N,%sp
806 subq.l #N,%sp
807 subq.w #N,%sp
808 subq.w #8,%sp; subq.w #N-8,%sp
809 add.w #-N,%sp
810 lea (-N,%sp),%sp
811 add.l #-N,%sp
812
813 For saving registers:
814
815 fmovem.x REGS,-(%sp)
816 move.l R1,-(%sp)
817 move.l R1,-(%sp); move.l R2,-(%sp)
818 movem.l REGS,-(%sp)
819
820 For setting up the PIC register:
821
822 lea (%pc,N),%a5
823
824 */
825
826 static CORE_ADDR
827 m68k_analyze_prologue (struct gdbarch *gdbarch, CORE_ADDR pc,
828 CORE_ADDR current_pc, struct m68k_frame_cache *cache)
829 {
830 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
831 unsigned int op;
832
833 pc = m68k_analyze_frame_setup (gdbarch, pc, current_pc, cache);
834 pc = m68k_analyze_register_saves (gdbarch, pc, current_pc, cache);
835 if (pc >= current_pc)
836 return current_pc;
837
838 /* Check for GOT setup. */
839 op = read_memory_unsigned_integer (pc, 4, byte_order);
840 if (op == P_LEA_PC_A5)
841 {
842 /* lea (%pc,N),%a5 */
843 return pc + 8;
844 }
845
846 return pc;
847 }
848
849 /* Return PC of first real instruction. */
850
851 static CORE_ADDR
852 m68k_skip_prologue (struct gdbarch *gdbarch, CORE_ADDR start_pc)
853 {
854 struct m68k_frame_cache cache;
855 CORE_ADDR pc;
856
857 cache.locals = -1;
858 pc = m68k_analyze_prologue (gdbarch, start_pc, (CORE_ADDR) -1, &cache);
859 if (cache.locals < 0)
860 return start_pc;
861 return pc;
862 }
863
864 static CORE_ADDR
865 m68k_unwind_pc (struct gdbarch *gdbarch, struct frame_info *next_frame)
866 {
867 gdb_byte buf[8];
868
869 frame_unwind_register (next_frame, gdbarch_pc_regnum (gdbarch), buf);
870 return extract_typed_address (buf, builtin_type (gdbarch)->builtin_func_ptr);
871 }
872 \f
873 /* Normal frames. */
874
875 static struct m68k_frame_cache *
876 m68k_frame_cache (struct frame_info *this_frame, void **this_cache)
877 {
878 struct gdbarch *gdbarch = get_frame_arch (this_frame);
879 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
880 struct m68k_frame_cache *cache;
881 gdb_byte buf[4];
882 int i;
883
884 if (*this_cache)
885 return (struct m68k_frame_cache *) *this_cache;
886
887 cache = m68k_alloc_frame_cache ();
888 *this_cache = cache;
889
890 /* In principle, for normal frames, %fp holds the frame pointer,
891 which holds the base address for the current stack frame.
892 However, for functions that don't need it, the frame pointer is
893 optional. For these "frameless" functions the frame pointer is
894 actually the frame pointer of the calling frame. Signal
895 trampolines are just a special case of a "frameless" function.
896 They (usually) share their frame pointer with the frame that was
897 in progress when the signal occurred. */
898
899 get_frame_register (this_frame, M68K_FP_REGNUM, buf);
900 cache->base = extract_unsigned_integer (buf, 4, byte_order);
901 if (cache->base == 0)
902 return cache;
903
904 /* For normal frames, %pc is stored at 4(%fp). */
905 cache->saved_regs[M68K_PC_REGNUM] = 4;
906
907 cache->pc = get_frame_func (this_frame);
908 if (cache->pc != 0)
909 m68k_analyze_prologue (get_frame_arch (this_frame), cache->pc,
910 get_frame_pc (this_frame), cache);
911
912 if (cache->locals < 0)
913 {
914 /* We didn't find a valid frame, which means that CACHE->base
915 currently holds the frame pointer for our calling frame. If
916 we're at the start of a function, or somewhere half-way its
917 prologue, the function's frame probably hasn't been fully
918 setup yet. Try to reconstruct the base address for the stack
919 frame by looking at the stack pointer. For truly "frameless"
920 functions this might work too. */
921
922 get_frame_register (this_frame, M68K_SP_REGNUM, buf);
923 cache->base = extract_unsigned_integer (buf, 4, byte_order)
924 + cache->sp_offset;
925 }
926
927 /* Now that we have the base address for the stack frame we can
928 calculate the value of %sp in the calling frame. */
929 cache->saved_sp = cache->base + 8;
930
931 /* Adjust all the saved registers such that they contain addresses
932 instead of offsets. */
933 for (i = 0; i < M68K_NUM_REGS; i++)
934 if (cache->saved_regs[i] != -1)
935 cache->saved_regs[i] += cache->base;
936
937 return cache;
938 }
939
940 static void
941 m68k_frame_this_id (struct frame_info *this_frame, void **this_cache,
942 struct frame_id *this_id)
943 {
944 struct m68k_frame_cache *cache = m68k_frame_cache (this_frame, this_cache);
945
946 /* This marks the outermost frame. */
947 if (cache->base == 0)
948 return;
949
950 /* See the end of m68k_push_dummy_call. */
951 *this_id = frame_id_build (cache->base + 8, cache->pc);
952 }
953
954 static struct value *
955 m68k_frame_prev_register (struct frame_info *this_frame, void **this_cache,
956 int regnum)
957 {
958 struct m68k_frame_cache *cache = m68k_frame_cache (this_frame, this_cache);
959
960 gdb_assert (regnum >= 0);
961
962 if (regnum == M68K_SP_REGNUM && cache->saved_sp)
963 return frame_unwind_got_constant (this_frame, regnum, cache->saved_sp);
964
965 if (regnum < M68K_NUM_REGS && cache->saved_regs[regnum] != -1)
966 return frame_unwind_got_memory (this_frame, regnum,
967 cache->saved_regs[regnum]);
968
969 return frame_unwind_got_register (this_frame, regnum, regnum);
970 }
971
972 static const struct frame_unwind m68k_frame_unwind =
973 {
974 NORMAL_FRAME,
975 default_frame_unwind_stop_reason,
976 m68k_frame_this_id,
977 m68k_frame_prev_register,
978 NULL,
979 default_frame_sniffer
980 };
981 \f
982 static CORE_ADDR
983 m68k_frame_base_address (struct frame_info *this_frame, void **this_cache)
984 {
985 struct m68k_frame_cache *cache = m68k_frame_cache (this_frame, this_cache);
986
987 return cache->base;
988 }
989
990 static const struct frame_base m68k_frame_base =
991 {
992 &m68k_frame_unwind,
993 m68k_frame_base_address,
994 m68k_frame_base_address,
995 m68k_frame_base_address
996 };
997
998 static struct frame_id
999 m68k_dummy_id (struct gdbarch *gdbarch, struct frame_info *this_frame)
1000 {
1001 CORE_ADDR fp;
1002
1003 fp = get_frame_register_unsigned (this_frame, M68K_FP_REGNUM);
1004
1005 /* See the end of m68k_push_dummy_call. */
1006 return frame_id_build (fp + 8, get_frame_pc (this_frame));
1007 }
1008 \f
1009
1010 /* Figure out where the longjmp will land. Slurp the args out of the stack.
1011 We expect the first arg to be a pointer to the jmp_buf structure from which
1012 we extract the pc (JB_PC) that we will land at. The pc is copied into PC.
1013 This routine returns true on success. */
1014
1015 static int
1016 m68k_get_longjmp_target (struct frame_info *frame, CORE_ADDR *pc)
1017 {
1018 gdb_byte *buf;
1019 CORE_ADDR sp, jb_addr;
1020 struct gdbarch *gdbarch = get_frame_arch (frame);
1021 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
1022 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
1023
1024 if (tdep->jb_pc < 0)
1025 {
1026 internal_error (__FILE__, __LINE__,
1027 _("m68k_get_longjmp_target: not implemented"));
1028 return 0;
1029 }
1030
1031 buf = (gdb_byte *) alloca (gdbarch_ptr_bit (gdbarch) / TARGET_CHAR_BIT);
1032 sp = get_frame_register_unsigned (frame, gdbarch_sp_regnum (gdbarch));
1033
1034 if (target_read_memory (sp + SP_ARG0, /* Offset of first arg on stack. */
1035 buf, gdbarch_ptr_bit (gdbarch) / TARGET_CHAR_BIT))
1036 return 0;
1037
1038 jb_addr = extract_unsigned_integer (buf, gdbarch_ptr_bit (gdbarch)
1039 / TARGET_CHAR_BIT, byte_order);
1040
1041 if (target_read_memory (jb_addr + tdep->jb_pc * tdep->jb_elt_size, buf,
1042 gdbarch_ptr_bit (gdbarch) / TARGET_CHAR_BIT),
1043 byte_order)
1044 return 0;
1045
1046 *pc = extract_unsigned_integer (buf, gdbarch_ptr_bit (gdbarch)
1047 / TARGET_CHAR_BIT, byte_order);
1048 return 1;
1049 }
1050 \f
1051
1052 /* This is the implementation of gdbarch method
1053 return_in_first_hidden_param_p. */
1054
1055 static int
1056 m68k_return_in_first_hidden_param_p (struct gdbarch *gdbarch,
1057 struct type *type)
1058 {
1059 return 0;
1060 }
1061
1062 /* System V Release 4 (SVR4). */
1063
1064 void
1065 m68k_svr4_init_abi (struct gdbarch_info info, struct gdbarch *gdbarch)
1066 {
1067 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
1068
1069 /* SVR4 uses a different calling convention. */
1070 set_gdbarch_return_value (gdbarch, m68k_svr4_return_value);
1071
1072 /* SVR4 uses %a0 instead of %a1. */
1073 tdep->struct_value_regnum = M68K_A0_REGNUM;
1074 }
1075 \f
1076
1077 /* Function: m68k_gdbarch_init
1078 Initializer function for the m68k gdbarch vector.
1079 Called by gdbarch. Sets up the gdbarch vector(s) for this target. */
1080
1081 static struct gdbarch *
1082 m68k_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches)
1083 {
1084 struct gdbarch_tdep *tdep = NULL;
1085 struct gdbarch *gdbarch;
1086 struct gdbarch_list *best_arch;
1087 struct tdesc_arch_data *tdesc_data = NULL;
1088 int i;
1089 enum m68k_flavour flavour = m68k_no_flavour;
1090 int has_fp = 1;
1091 const struct floatformat **long_double_format = floatformats_m68881_ext;
1092
1093 /* Check any target description for validity. */
1094 if (tdesc_has_registers (info.target_desc))
1095 {
1096 const struct tdesc_feature *feature;
1097 int valid_p;
1098
1099 feature = tdesc_find_feature (info.target_desc,
1100 "org.gnu.gdb.m68k.core");
1101
1102 if (feature == NULL)
1103 {
1104 feature = tdesc_find_feature (info.target_desc,
1105 "org.gnu.gdb.coldfire.core");
1106 if (feature != NULL)
1107 flavour = m68k_coldfire_flavour;
1108 }
1109
1110 if (feature == NULL)
1111 {
1112 feature = tdesc_find_feature (info.target_desc,
1113 "org.gnu.gdb.fido.core");
1114 if (feature != NULL)
1115 flavour = m68k_fido_flavour;
1116 }
1117
1118 if (feature == NULL)
1119 return NULL;
1120
1121 tdesc_data = tdesc_data_alloc ();
1122
1123 valid_p = 1;
1124 for (i = 0; i <= M68K_PC_REGNUM; i++)
1125 valid_p &= tdesc_numbered_register (feature, tdesc_data, i,
1126 m68k_register_names[i]);
1127
1128 if (!valid_p)
1129 {
1130 tdesc_data_cleanup (tdesc_data);
1131 return NULL;
1132 }
1133
1134 feature = tdesc_find_feature (info.target_desc,
1135 "org.gnu.gdb.coldfire.fp");
1136 if (feature != NULL)
1137 {
1138 valid_p = 1;
1139 for (i = M68K_FP0_REGNUM; i <= M68K_FPI_REGNUM; i++)
1140 valid_p &= tdesc_numbered_register (feature, tdesc_data, i,
1141 m68k_register_names[i]);
1142 if (!valid_p)
1143 {
1144 tdesc_data_cleanup (tdesc_data);
1145 return NULL;
1146 }
1147 }
1148 else
1149 has_fp = 0;
1150 }
1151
1152 /* The mechanism for returning floating values from function
1153 and the type of long double depend on whether we're
1154 on ColdFire or standard m68k. */
1155
1156 if (info.bfd_arch_info && info.bfd_arch_info->mach != 0)
1157 {
1158 const bfd_arch_info_type *coldfire_arch =
1159 bfd_lookup_arch (bfd_arch_m68k, bfd_mach_mcf_isa_a_nodiv);
1160
1161 if (coldfire_arch
1162 && ((*info.bfd_arch_info->compatible)
1163 (info.bfd_arch_info, coldfire_arch)))
1164 flavour = m68k_coldfire_flavour;
1165 }
1166
1167 /* If there is already a candidate, use it. */
1168 for (best_arch = gdbarch_list_lookup_by_info (arches, &info);
1169 best_arch != NULL;
1170 best_arch = gdbarch_list_lookup_by_info (best_arch->next, &info))
1171 {
1172 if (flavour != gdbarch_tdep (best_arch->gdbarch)->flavour)
1173 continue;
1174
1175 if (has_fp != gdbarch_tdep (best_arch->gdbarch)->fpregs_present)
1176 continue;
1177
1178 break;
1179 }
1180
1181 if (best_arch != NULL)
1182 {
1183 if (tdesc_data != NULL)
1184 tdesc_data_cleanup (tdesc_data);
1185 return best_arch->gdbarch;
1186 }
1187
1188 tdep = XCNEW (struct gdbarch_tdep);
1189 gdbarch = gdbarch_alloc (&info, tdep);
1190 tdep->fpregs_present = has_fp;
1191 tdep->flavour = flavour;
1192
1193 if (flavour == m68k_coldfire_flavour || flavour == m68k_fido_flavour)
1194 long_double_format = floatformats_ieee_double;
1195 set_gdbarch_long_double_format (gdbarch, long_double_format);
1196 set_gdbarch_long_double_bit (gdbarch, long_double_format[0]->totalsize);
1197
1198 set_gdbarch_skip_prologue (gdbarch, m68k_skip_prologue);
1199 set_gdbarch_breakpoint_from_pc (gdbarch, m68k_local_breakpoint_from_pc);
1200
1201 /* Stack grows down. */
1202 set_gdbarch_inner_than (gdbarch, core_addr_lessthan);
1203 set_gdbarch_frame_align (gdbarch, m68k_frame_align);
1204
1205 set_gdbarch_believe_pcc_promotion (gdbarch, 1);
1206 if (flavour == m68k_coldfire_flavour || flavour == m68k_fido_flavour)
1207 set_gdbarch_decr_pc_after_break (gdbarch, 2);
1208
1209 set_gdbarch_frame_args_skip (gdbarch, 8);
1210 set_gdbarch_dwarf2_reg_to_regnum (gdbarch, m68k_dwarf_reg_to_regnum);
1211
1212 set_gdbarch_register_type (gdbarch, m68k_register_type);
1213 set_gdbarch_register_name (gdbarch, m68k_register_name);
1214 set_gdbarch_num_regs (gdbarch, M68K_NUM_REGS);
1215 set_gdbarch_sp_regnum (gdbarch, M68K_SP_REGNUM);
1216 set_gdbarch_pc_regnum (gdbarch, M68K_PC_REGNUM);
1217 set_gdbarch_ps_regnum (gdbarch, M68K_PS_REGNUM);
1218 set_gdbarch_convert_register_p (gdbarch, m68k_convert_register_p);
1219 set_gdbarch_register_to_value (gdbarch, m68k_register_to_value);
1220 set_gdbarch_value_to_register (gdbarch, m68k_value_to_register);
1221
1222 if (has_fp)
1223 set_gdbarch_fp0_regnum (gdbarch, M68K_FP0_REGNUM);
1224
1225 /* Try to figure out if the arch uses floating registers to return
1226 floating point values from functions. */
1227 if (has_fp)
1228 {
1229 /* On ColdFire, floating point values are returned in D0. */
1230 if (flavour == m68k_coldfire_flavour)
1231 tdep->float_return = 0;
1232 else
1233 tdep->float_return = 1;
1234 }
1235 else
1236 {
1237 /* No floating registers, so can't use them for returning values. */
1238 tdep->float_return = 0;
1239 }
1240
1241 /* Function call & return. */
1242 set_gdbarch_push_dummy_call (gdbarch, m68k_push_dummy_call);
1243 set_gdbarch_return_value (gdbarch, m68k_return_value);
1244 set_gdbarch_return_in_first_hidden_param_p (gdbarch,
1245 m68k_return_in_first_hidden_param_p);
1246
1247
1248 /* Disassembler. */
1249 set_gdbarch_print_insn (gdbarch, print_insn_m68k);
1250
1251 #if defined JB_PC && defined JB_ELEMENT_SIZE
1252 tdep->jb_pc = JB_PC;
1253 tdep->jb_elt_size = JB_ELEMENT_SIZE;
1254 #else
1255 tdep->jb_pc = -1;
1256 #endif
1257 tdep->struct_value_regnum = M68K_A1_REGNUM;
1258 tdep->struct_return = reg_struct_return;
1259
1260 /* Frame unwinder. */
1261 set_gdbarch_dummy_id (gdbarch, m68k_dummy_id);
1262 set_gdbarch_unwind_pc (gdbarch, m68k_unwind_pc);
1263
1264 /* Hook in the DWARF CFI frame unwinder. */
1265 dwarf2_append_unwinders (gdbarch);
1266
1267 frame_base_set_default (gdbarch, &m68k_frame_base);
1268
1269 /* Hook in ABI-specific overrides, if they have been registered. */
1270 gdbarch_init_osabi (info, gdbarch);
1271
1272 /* Now we have tuned the configuration, set a few final things,
1273 based on what the OS ABI has told us. */
1274
1275 if (tdep->jb_pc >= 0)
1276 set_gdbarch_get_longjmp_target (gdbarch, m68k_get_longjmp_target);
1277
1278 frame_unwind_append_unwinder (gdbarch, &m68k_frame_unwind);
1279
1280 if (tdesc_data)
1281 tdesc_use_registers (gdbarch, info.target_desc, tdesc_data);
1282
1283 return gdbarch;
1284 }
1285
1286
1287 static void
1288 m68k_dump_tdep (struct gdbarch *gdbarch, struct ui_file *file)
1289 {
1290 struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
1291
1292 if (tdep == NULL)
1293 return;
1294 }
1295
1296 extern initialize_file_ftype _initialize_m68k_tdep; /* -Wmissing-prototypes */
1297
1298 void
1299 _initialize_m68k_tdep (void)
1300 {
1301 gdbarch_register (bfd_arch_m68k, m68k_gdbarch_init, m68k_dump_tdep);
1302 }