Convert some frame functions to use gdb::array_view.
[deliverable/binutils-gdb.git] / gdb / tilegx-tdep.c
CommitLineData
ade64f0e
PA
1/* Target-dependent code for the Tilera TILE-Gx processor.
2
3666a048 3 Copyright (C) 2012-2021 Free Software Foundation, Inc.
ade64f0e
PA
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 "frame.h"
22#include "frame-base.h"
23#include "frame-unwind.h"
82ca8957 24#include "dwarf2/frame.h"
ade64f0e
PA
25#include "trad-frame.h"
26#include "symtab.h"
27#include "gdbtypes.h"
28#include "gdbcmd.h"
29#include "gdbcore.h"
30#include "value.h"
31#include "dis-asm.h"
32#include "inferior.h"
ade64f0e 33#include "arch-utils.h"
ade64f0e
PA
34#include "regcache.h"
35#include "regset.h"
ade64f0e
PA
36#include "osabi.h"
37#include "linux-tdep.h"
38#include "objfiles.h"
39#include "solib-svr4.h"
ade64f0e
PA
40#include "tilegx-tdep.h"
41#include "opcode/tilegx.h"
325fac50 42#include <algorithm>
268a13a5 43#include "gdbsupport/byte-vector.h"
ade64f0e
PA
44
45struct tilegx_frame_cache
46{
47 /* Base address. */
48 CORE_ADDR base;
49 /* Function start. */
50 CORE_ADDR start_pc;
51
52 /* Table of saved registers. */
098caef4 53 trad_frame_saved_reg *saved_regs;
ade64f0e
PA
54};
55
56/* Register state values used by analyze_prologue. */
57enum reverse_state
58 {
59 REVERSE_STATE_REGISTER,
60 REVERSE_STATE_VALUE,
61 REVERSE_STATE_UNKNOWN
62 };
63
64/* Register state used by analyze_prologue(). */
65struct tilegx_reverse_regs
66{
67 LONGEST value;
68 enum reverse_state state;
69};
70
71static const struct tilegx_reverse_regs
72template_reverse_regs[TILEGX_NUM_PHYS_REGS] =
73 {
74 { TILEGX_R0_REGNUM, REVERSE_STATE_REGISTER },
75 { TILEGX_R1_REGNUM, REVERSE_STATE_REGISTER },
76 { TILEGX_R2_REGNUM, REVERSE_STATE_REGISTER },
77 { TILEGX_R3_REGNUM, REVERSE_STATE_REGISTER },
78 { TILEGX_R4_REGNUM, REVERSE_STATE_REGISTER },
79 { TILEGX_R5_REGNUM, REVERSE_STATE_REGISTER },
80 { TILEGX_R6_REGNUM, REVERSE_STATE_REGISTER },
81 { TILEGX_R7_REGNUM, REVERSE_STATE_REGISTER },
82 { TILEGX_R8_REGNUM, REVERSE_STATE_REGISTER },
83 { TILEGX_R9_REGNUM, REVERSE_STATE_REGISTER },
84 { TILEGX_R10_REGNUM, REVERSE_STATE_REGISTER },
85 { TILEGX_R11_REGNUM, REVERSE_STATE_REGISTER },
86 { TILEGX_R12_REGNUM, REVERSE_STATE_REGISTER },
87 { TILEGX_R13_REGNUM, REVERSE_STATE_REGISTER },
88 { TILEGX_R14_REGNUM, REVERSE_STATE_REGISTER },
89 { TILEGX_R15_REGNUM, REVERSE_STATE_REGISTER },
90 { TILEGX_R16_REGNUM, REVERSE_STATE_REGISTER },
91 { TILEGX_R17_REGNUM, REVERSE_STATE_REGISTER },
92 { TILEGX_R18_REGNUM, REVERSE_STATE_REGISTER },
93 { TILEGX_R19_REGNUM, REVERSE_STATE_REGISTER },
94 { TILEGX_R20_REGNUM, REVERSE_STATE_REGISTER },
95 { TILEGX_R21_REGNUM, REVERSE_STATE_REGISTER },
96 { TILEGX_R22_REGNUM, REVERSE_STATE_REGISTER },
97 { TILEGX_R23_REGNUM, REVERSE_STATE_REGISTER },
98 { TILEGX_R24_REGNUM, REVERSE_STATE_REGISTER },
99 { TILEGX_R25_REGNUM, REVERSE_STATE_REGISTER },
100 { TILEGX_R26_REGNUM, REVERSE_STATE_REGISTER },
101 { TILEGX_R27_REGNUM, REVERSE_STATE_REGISTER },
102 { TILEGX_R28_REGNUM, REVERSE_STATE_REGISTER },
103 { TILEGX_R29_REGNUM, REVERSE_STATE_REGISTER },
104 { TILEGX_R30_REGNUM, REVERSE_STATE_REGISTER },
105 { TILEGX_R31_REGNUM, REVERSE_STATE_REGISTER },
106 { TILEGX_R32_REGNUM, REVERSE_STATE_REGISTER },
107 { TILEGX_R33_REGNUM, REVERSE_STATE_REGISTER },
108 { TILEGX_R34_REGNUM, REVERSE_STATE_REGISTER },
109 { TILEGX_R35_REGNUM, REVERSE_STATE_REGISTER },
110 { TILEGX_R36_REGNUM, REVERSE_STATE_REGISTER },
111 { TILEGX_R37_REGNUM, REVERSE_STATE_REGISTER },
112 { TILEGX_R38_REGNUM, REVERSE_STATE_REGISTER },
113 { TILEGX_R39_REGNUM, REVERSE_STATE_REGISTER },
114 { TILEGX_R40_REGNUM, REVERSE_STATE_REGISTER },
115 { TILEGX_R41_REGNUM, REVERSE_STATE_REGISTER },
116 { TILEGX_R42_REGNUM, REVERSE_STATE_REGISTER },
117 { TILEGX_R43_REGNUM, REVERSE_STATE_REGISTER },
118 { TILEGX_R44_REGNUM, REVERSE_STATE_REGISTER },
119 { TILEGX_R45_REGNUM, REVERSE_STATE_REGISTER },
120 { TILEGX_R46_REGNUM, REVERSE_STATE_REGISTER },
121 { TILEGX_R47_REGNUM, REVERSE_STATE_REGISTER },
122 { TILEGX_R48_REGNUM, REVERSE_STATE_REGISTER },
123 { TILEGX_R49_REGNUM, REVERSE_STATE_REGISTER },
124 { TILEGX_R50_REGNUM, REVERSE_STATE_REGISTER },
125 { TILEGX_R51_REGNUM, REVERSE_STATE_REGISTER },
126 { TILEGX_R52_REGNUM, REVERSE_STATE_REGISTER },
127 { TILEGX_TP_REGNUM, REVERSE_STATE_REGISTER },
128 { TILEGX_SP_REGNUM, REVERSE_STATE_REGISTER },
129 { TILEGX_LR_REGNUM, REVERSE_STATE_REGISTER },
130 { 0, REVERSE_STATE_UNKNOWN },
131 { 0, REVERSE_STATE_UNKNOWN },
132 { 0, REVERSE_STATE_UNKNOWN },
133 { 0, REVERSE_STATE_UNKNOWN },
134 { 0, REVERSE_STATE_UNKNOWN },
135 { 0, REVERSE_STATE_UNKNOWN },
136 { 0, REVERSE_STATE_UNKNOWN },
137 { TILEGX_ZERO_REGNUM, REVERSE_STATE_VALUE }
138 };
139
140/* Implement the "register_name" gdbarch method. */
141
142static const char *
143tilegx_register_name (struct gdbarch *gdbarch, int regnum)
144{
145 static const char *const register_names[TILEGX_NUM_REGS] =
146 {
147 "r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
148 "r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
149 "r16", "r17", "r18", "r19", "r20", "r21", "r22", "r23",
150 "r24", "r25", "r26", "r27", "r28", "r29", "r30", "r31",
151 "r32", "r33", "r34", "r35", "r36", "r37", "r38", "r39",
152 "r40", "r41", "r42", "r43", "r44", "r45", "r46", "r47",
153 "r48", "r49", "r50", "r51", "r52", "tp", "sp", "lr",
154 "sn", "idn0", "idn1", "udn0", "udn1", "udn2", "udn3", "zero",
4aaf2503 155 "pc", "faultnum",
ade64f0e
PA
156 };
157
158 if (regnum < 0 || regnum >= TILEGX_NUM_REGS)
159 internal_error (__FILE__, __LINE__,
160 "tilegx_register_name: invalid register number %d",
161 regnum);
162
163 return register_names[regnum];
164}
165
166/* This is the implementation of gdbarch method register_type. */
167
168static struct type *
169tilegx_register_type (struct gdbarch *gdbarch, int regnum)
170{
171 if (regnum == TILEGX_PC_REGNUM)
172 return builtin_type (gdbarch)->builtin_func_ptr;
173 else
174 return builtin_type (gdbarch)->builtin_uint64;
175}
176
177/* This is the implementation of gdbarch method dwarf2_reg_to_regnum. */
178
179static int
180tilegx_dwarf2_reg_to_regnum (struct gdbarch *gdbarch, int num)
181{
182 return num;
183}
184
185/* Makes the decision of whether a given type is a scalar type.
186 Scalar types are returned in the registers r2-r11 as they fit. */
187
188static int
189tilegx_type_is_scalar (struct type *t)
190{
78134374
SM
191 return (t->code () != TYPE_CODE_STRUCT
192 && t->code () != TYPE_CODE_UNION
193 && t->code () != TYPE_CODE_ARRAY);
ade64f0e
PA
194}
195
196/* Returns non-zero if the given struct type will be returned using
197 a special convention, rather than the normal function return method.
198 Used in the context of the "return" command, and target function
199 calls from the debugger. */
200
201static int
202tilegx_use_struct_convention (struct type *type)
203{
204 /* Only scalars which fit in R0 - R9 can be returned in registers.
205 Otherwise, they are returned via a pointer passed in R0. */
206 return (!tilegx_type_is_scalar (type)
207 && (TYPE_LENGTH (type) > (1 + TILEGX_R9_REGNUM - TILEGX_R0_REGNUM)
208 * tilegx_reg_size));
209}
210
211/* Find a function's return value in the appropriate registers (in
212 REGCACHE), and copy it into VALBUF. */
213
214static void
215tilegx_extract_return_value (struct type *type, struct regcache *regcache,
216 gdb_byte *valbuf)
217{
218 int len = TYPE_LENGTH (type);
219 int i, regnum = TILEGX_R0_REGNUM;
220
221 for (i = 0; i < len; i += tilegx_reg_size)
0b883586 222 regcache->raw_read (regnum++, valbuf + i);
ade64f0e
PA
223}
224
225/* Copy the function return value from VALBUF into the proper
226 location for a function return.
227 Called only in the context of the "return" command. */
228
229static void
230tilegx_store_return_value (struct type *type, struct regcache *regcache,
231 const void *valbuf)
232{
233 if (TYPE_LENGTH (type) < tilegx_reg_size)
234 {
235 /* Add leading zeros to the (little-endian) value. */
236 gdb_byte buf[tilegx_reg_size] = { 0 };
237
238 memcpy (buf, valbuf, TYPE_LENGTH (type));
10eaee5f 239 regcache->raw_write (TILEGX_R0_REGNUM, buf);
ade64f0e
PA
240 }
241 else
242 {
243 int len = TYPE_LENGTH (type);
244 int i, regnum = TILEGX_R0_REGNUM;
245
246 for (i = 0; i < len; i += tilegx_reg_size)
10eaee5f 247 regcache->raw_write (regnum++, (gdb_byte *) valbuf + i);
ade64f0e
PA
248 }
249}
250
251/* This is the implementation of gdbarch method return_value. */
252
253static enum return_value_convention
254tilegx_return_value (struct gdbarch *gdbarch, struct value *function,
255 struct type *type, struct regcache *regcache,
256 gdb_byte *readbuf, const gdb_byte *writebuf)
257{
258 if (tilegx_use_struct_convention (type))
259 return RETURN_VALUE_STRUCT_CONVENTION;
260 if (writebuf)
261 tilegx_store_return_value (type, regcache, writebuf);
262 else if (readbuf)
263 tilegx_extract_return_value (type, regcache, readbuf);
264 return RETURN_VALUE_REGISTER_CONVENTION;
265}
266
267/* This is the implementation of gdbarch method frame_align. */
268
269static CORE_ADDR
270tilegx_frame_align (struct gdbarch *gdbarch, CORE_ADDR addr)
271{
272 return addr & -8;
273}
274
275
276/* Implement the "push_dummy_call" gdbarch method. */
277
278static CORE_ADDR
279tilegx_push_dummy_call (struct gdbarch *gdbarch,
280 struct value *function,
281 struct regcache *regcache,
282 CORE_ADDR bp_addr, int nargs,
283 struct value **args,
cf84fa6b 284 CORE_ADDR sp, function_call_return_method return_method,
ade64f0e
PA
285 CORE_ADDR struct_addr)
286{
287 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
288 CORE_ADDR stack_dest = sp;
289 int argreg = TILEGX_R0_REGNUM;
290 int i, j;
870f88f7 291 int typelen, slacklen;
bc23a956 292 static const gdb_byte four_zero_words[16] = { 0 };
ade64f0e
PA
293
294 /* If struct_return is 1, then the struct return address will
295 consume one argument-passing register. */
cf84fa6b 296 if (return_method == return_method_struct)
ade64f0e
PA
297 regcache_cooked_write_unsigned (regcache, argreg++, struct_addr);
298
299 /* Arguments are passed in R0 - R9, and as soon as an argument
300 will not fit completely in the remaining registers, then it,
301 and all remaining arguments, are put on the stack. */
302 for (i = 0; i < nargs && argreg <= TILEGX_R9_REGNUM; i++)
303 {
304 const gdb_byte *val;
305 typelen = TYPE_LENGTH (value_enclosing_type (args[i]));
306
307 if (typelen > (TILEGX_R9_REGNUM - argreg + 1) * tilegx_reg_size)
308 break;
309
310 /* Put argument into registers wordwise. */
311 val = value_contents (args[i]);
312 for (j = 0; j < typelen; j += tilegx_reg_size)
313 {
314 /* ISSUE: Why special handling for "typelen = 4x + 1"?
315 I don't ever see "typelen" values except 4 and 8. */
316 int n = (typelen - j == 1) ? 1 : tilegx_reg_size;
317 ULONGEST w = extract_unsigned_integer (val + j, n, byte_order);
318
319 regcache_cooked_write_unsigned (regcache, argreg++, w);
320 }
321 }
322
323 /* Align SP. */
324 stack_dest = tilegx_frame_align (gdbarch, stack_dest);
325
ade64f0e
PA
326 /* Loop backwards through remaining arguments and push them on
327 the stack, word aligned. */
328 for (j = nargs - 1; j >= i; j--)
329 {
ecfb0d68 330 const gdb_byte *contents = value_contents (args[j]);
ade64f0e
PA
331
332 typelen = TYPE_LENGTH (value_enclosing_type (args[j]));
bc23a956 333 slacklen = align_up (typelen, 8) - typelen;
8f8accb5
TT
334 gdb::byte_vector val (typelen + slacklen);
335 memcpy (val.data (), contents, typelen);
336 memset (val.data () + typelen, 0, slacklen);
ade64f0e
PA
337
338 /* Now write data to the stack. The stack grows downwards. */
339 stack_dest -= typelen + slacklen;
8f8accb5 340 write_memory (stack_dest, val.data (), typelen + slacklen);
ade64f0e
PA
341 }
342
bc23a956
WL
343 /* Add 16 bytes for linkage space to the stack. */
344 stack_dest = stack_dest - 16;
345 write_memory (stack_dest, four_zero_words, 16);
ade64f0e
PA
346
347 /* Update stack pointer. */
348 regcache_cooked_write_unsigned (regcache, TILEGX_SP_REGNUM, stack_dest);
349
350 /* Set the return address register to point to the entry point of
351 the program, where a breakpoint lies in wait. */
352 regcache_cooked_write_unsigned (regcache, TILEGX_LR_REGNUM, bp_addr);
353
354 return stack_dest;
355}
356
357
358/* Decode the instructions within the given address range.
359 Decide when we must have reached the end of the function prologue.
360 If a frame_info pointer is provided, fill in its saved_regs etc.
361 Returns the address of the first instruction after the prologue.
362 NOTE: This is often called with start_addr being the start of some
363 function, and end_addr being the current PC. */
364
365static CORE_ADDR
366tilegx_analyze_prologue (struct gdbarch* gdbarch,
367 CORE_ADDR start_addr, CORE_ADDR end_addr,
368 struct tilegx_frame_cache *cache,
369 struct frame_info *next_frame)
370{
371 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
372 CORE_ADDR next_addr;
373 CORE_ADDR prolog_end = end_addr;
ade64f0e
PA
374 gdb_byte instbuf[32 * TILEGX_BUNDLE_SIZE_IN_BYTES];
375 CORE_ADDR instbuf_start;
376 unsigned int instbuf_size;
377 int status;
378 bfd_uint64_t bundle;
379 struct tilegx_decoded_instruction
380 decoded[TILEGX_MAX_INSTRUCTIONS_PER_BUNDLE];
381 int num_insns;
382 struct tilegx_reverse_regs reverse_frame[TILEGX_NUM_PHYS_REGS];
383 struct tilegx_reverse_regs
384 new_reverse_frame[TILEGX_MAX_INSTRUCTIONS_PER_BUNDLE];
385 int dest_regs[TILEGX_MAX_INSTRUCTIONS_PER_BUNDLE];
3361b059 386 int reverse_frame_valid, prolog_done, branch_seen, lr_saved_on_stack_p;
ade64f0e
PA
387 LONGEST prev_sp_value;
388 int i, j;
389
390 if (start_addr >= end_addr
391 || (start_addr % TILEGX_BUNDLE_ALIGNMENT_IN_BYTES) != 0)
392 return end_addr;
393
394 /* Initialize the reverse frame. This maps the CURRENT frame's
395 registers to the outer frame's registers (the frame on the
396 stack goes the other way). */
397 memcpy (&reverse_frame, &template_reverse_regs, sizeof (reverse_frame));
398
399 prolog_done = 0;
400 branch_seen = 0;
401 prev_sp_value = 0;
3361b059 402 lr_saved_on_stack_p = 0;
ade64f0e
PA
403
404 /* To cut down on round-trip overhead, we fetch multiple bundles
405 at once. These variables describe the range of memory we have
406 prefetched. */
407 instbuf_start = 0;
408 instbuf_size = 0;
409
410 for (next_addr = start_addr;
411 next_addr < end_addr;
412 next_addr += TILEGX_BUNDLE_SIZE_IN_BYTES)
413 {
414 /* Retrieve the next instruction. */
415 if (next_addr - instbuf_start >= instbuf_size)
416 {
417 /* Figure out how many bytes to fetch. Don't span a page
418 boundary since that might cause an unnecessary memory
419 error. */
420 unsigned int size_on_same_page = 4096 - (next_addr & 4095);
421
422 instbuf_size = sizeof instbuf;
423
424 if (instbuf_size > size_on_same_page)
425 instbuf_size = size_on_same_page;
d79e58d8 426
325fac50
PA
427 instbuf_size = std::min ((CORE_ADDR) instbuf_size,
428 (end_addr - next_addr));
ade64f0e
PA
429 instbuf_start = next_addr;
430
431 status = safe_frame_unwind_memory (next_frame, instbuf_start,
bdec2917 432 {instbuf, instbuf_size});
ade64f0e 433 if (status == 0)
f486487f 434 memory_error (TARGET_XFER_E_IO, next_addr);
ade64f0e
PA
435 }
436
437 reverse_frame_valid = 0;
438
439 bundle = extract_unsigned_integer (&instbuf[next_addr - instbuf_start],
440 8, byte_order);
441
442 num_insns = parse_insn_tilegx (bundle, next_addr, decoded);
443
444 for (i = 0; i < num_insns; i++)
445 {
446 struct tilegx_decoded_instruction *this_insn = &decoded[i];
b348d11b 447 long long *operands = this_insn->operand_values;
ade64f0e
PA
448 const struct tilegx_opcode *opcode = this_insn->opcode;
449
450 switch (opcode->mnemonic)
451 {
452 case TILEGX_OPC_ST:
453 if (cache
454 && reverse_frame[operands[0]].state == REVERSE_STATE_VALUE
455 && reverse_frame[operands[1]].state
456 == REVERSE_STATE_REGISTER)
457 {
458 LONGEST saved_address = reverse_frame[operands[0]].value;
459 unsigned saved_register
460 = (unsigned) reverse_frame[operands[1]].value;
461
462 /* realreg >= 0 and addr != -1 indicates that the
463 value of saved_register is in memory location
464 saved_address. The value of realreg is not
465 meaningful in this case but it must be >= 0.
466 See trad-frame.h. */
098caef4
LM
467 cache->saved_regs[saved_register].set_realreg (saved_register);
468 cache->saved_regs[saved_register].set_addr (saved_address);
3361b059
WL
469 }
470 else if (cache
471 && (operands[0] == TILEGX_SP_REGNUM)
472 && (operands[1] == TILEGX_LR_REGNUM))
473 lr_saved_on_stack_p = 1;
ade64f0e
PA
474 break;
475 case TILEGX_OPC_ADDI:
476 case TILEGX_OPC_ADDLI:
477 if (cache
478 && operands[0] == TILEGX_SP_REGNUM
479 && operands[1] == TILEGX_SP_REGNUM
480 && reverse_frame[operands[1]].state == REVERSE_STATE_REGISTER)
481 {
482 /* Special case. We're fixing up the stack frame. */
483 uint64_t hopefully_sp
484 = (unsigned) reverse_frame[operands[1]].value;
485 short op2_as_short = (short) operands[2];
486 signed char op2_as_char = (signed char) operands[2];
487
488 /* Fix up the sign-extension. */
489 if (opcode->mnemonic == TILEGX_OPC_ADDI)
490 op2_as_short = op2_as_char;
098caef4 491 prev_sp_value = (cache->saved_regs[hopefully_sp].addr ()
ade64f0e
PA
492 - op2_as_short);
493
494 new_reverse_frame[i].state = REVERSE_STATE_VALUE;
495 new_reverse_frame[i].value
098caef4 496 = cache->saved_regs[hopefully_sp].addr ();
ade64f0e
PA
497 trad_frame_set_value (cache->saved_regs,
498 hopefully_sp, prev_sp_value);
499 }
500 else
501 {
502 short op2_as_short = (short) operands[2];
503 signed char op2_as_char = (signed char) operands[2];
504
505 /* Fix up the sign-extension. */
506 if (opcode->mnemonic == TILEGX_OPC_ADDI)
507 op2_as_short = op2_as_char;
508
509 new_reverse_frame[i] = reverse_frame[operands[1]];
510 if (new_reverse_frame[i].state == REVERSE_STATE_VALUE)
511 new_reverse_frame[i].value += op2_as_short;
512 else
513 new_reverse_frame[i].state = REVERSE_STATE_UNKNOWN;
514 }
515 reverse_frame_valid |= 1 << i;
516 dest_regs[i] = operands[0];
517 break;
518 case TILEGX_OPC_ADD:
519 if (reverse_frame[operands[1]].state == REVERSE_STATE_VALUE
520 && reverse_frame[operands[2]].state == REVERSE_STATE_VALUE)
521 {
522 /* We have values -- we can do this. */
523 new_reverse_frame[i] = reverse_frame[operands[2]];
524 new_reverse_frame[i].value
525 += reverse_frame[operands[i]].value;
526 }
527 else
528 {
529 /* We don't know anything about the values. Punt. */
530 new_reverse_frame[i].state = REVERSE_STATE_UNKNOWN;
531 }
532 reverse_frame_valid |= 1 << i;
533 dest_regs[i] = operands[0];
534 break;
535 case TILEGX_OPC_MOVE:
536 new_reverse_frame[i] = reverse_frame[operands[1]];
537 reverse_frame_valid |= 1 << i;
538 dest_regs[i] = operands[0];
539 break;
540 case TILEGX_OPC_MOVEI:
541 case TILEGX_OPC_MOVELI:
542 new_reverse_frame[i].state = REVERSE_STATE_VALUE;
543 new_reverse_frame[i].value = operands[1];
544 reverse_frame_valid |= 1 << i;
545 dest_regs[i] = operands[0];
546 break;
547 case TILEGX_OPC_ORI:
548 if (reverse_frame[operands[1]].state == REVERSE_STATE_VALUE)
549 {
550 /* We have a value in A -- we can do this. */
551 new_reverse_frame[i] = reverse_frame[operands[1]];
552 new_reverse_frame[i].value
553 = reverse_frame[operands[1]].value | operands[2];
554 }
555 else if (operands[2] == 0)
556 {
557 /* This is a move. */
558 new_reverse_frame[i] = reverse_frame[operands[1]];
559 }
560 else
561 {
562 /* We don't know anything about the values. Punt. */
563 new_reverse_frame[i].state = REVERSE_STATE_UNKNOWN;
564 }
565 reverse_frame_valid |= 1 << i;
566 dest_regs[i] = operands[0];
567 break;
568 case TILEGX_OPC_OR:
569 if (reverse_frame[operands[1]].state == REVERSE_STATE_VALUE
570 && reverse_frame[operands[1]].value == 0)
571 {
572 /* This is a move. */
573 new_reverse_frame[i] = reverse_frame[operands[2]];
574 }
575 else if (reverse_frame[operands[2]].state == REVERSE_STATE_VALUE
576 && reverse_frame[operands[2]].value == 0)
577 {
578 /* This is a move. */
579 new_reverse_frame[i] = reverse_frame[operands[1]];
580 }
581 else
582 {
583 /* We don't know anything about the values. Punt. */
584 new_reverse_frame[i].state = REVERSE_STATE_UNKNOWN;
585 }
586 reverse_frame_valid |= 1 << i;
587 dest_regs[i] = operands[0];
588 break;
589 case TILEGX_OPC_SUB:
590 if (reverse_frame[operands[1]].state == REVERSE_STATE_VALUE
591 && reverse_frame[operands[2]].state == REVERSE_STATE_VALUE)
592 {
593 /* We have values -- we can do this. */
594 new_reverse_frame[i] = reverse_frame[operands[1]];
595 new_reverse_frame[i].value
596 -= reverse_frame[operands[2]].value;
597 }
598 else
599 {
600 /* We don't know anything about the values. Punt. */
601 new_reverse_frame[i].state = REVERSE_STATE_UNKNOWN;
602 }
603 reverse_frame_valid |= 1 << i;
604 dest_regs[i] = operands[0];
605 break;
606
607 case TILEGX_OPC_FNOP:
608 case TILEGX_OPC_INFO:
609 case TILEGX_OPC_INFOL:
610 /* Nothing to see here, move on.
611 Note that real NOP is treated as a 'real' instruction
612 because someone must have intended that it be there.
613 It therefore terminates the prolog. */
614 break;
615
616 case TILEGX_OPC_J:
617 case TILEGX_OPC_JAL:
618
619 case TILEGX_OPC_BEQZ:
620 case TILEGX_OPC_BEQZT:
621 case TILEGX_OPC_BGEZ:
622 case TILEGX_OPC_BGEZT:
623 case TILEGX_OPC_BGTZ:
624 case TILEGX_OPC_BGTZT:
625 case TILEGX_OPC_BLBC:
626 case TILEGX_OPC_BLBCT:
627 case TILEGX_OPC_BLBS:
628 case TILEGX_OPC_BLBST:
629 case TILEGX_OPC_BLEZ:
630 case TILEGX_OPC_BLEZT:
631 case TILEGX_OPC_BLTZ:
632 case TILEGX_OPC_BLTZT:
633 case TILEGX_OPC_BNEZ:
634 case TILEGX_OPC_BNEZT:
635
636 case TILEGX_OPC_IRET:
637 case TILEGX_OPC_JALR:
638 case TILEGX_OPC_JALRP:
639 case TILEGX_OPC_JR:
640 case TILEGX_OPC_JRP:
641 case TILEGX_OPC_SWINT0:
642 case TILEGX_OPC_SWINT1:
643 case TILEGX_OPC_SWINT2:
644 case TILEGX_OPC_SWINT3:
645 /* We're really done -- this is a branch. */
646 branch_seen = 1;
647 prolog_done = 1;
648 break;
649 default:
650 /* We don't know or care what this instruction is.
651 All we know is that it isn't part of a prolog, and if
652 there's a destination register, we're trashing it. */
653 prolog_done = 1;
654 for (j = 0; j < opcode->num_operands; j++)
655 {
656 if (this_insn->operands[j]->is_dest_reg)
657 {
658 dest_regs[i] = operands[j];
659 new_reverse_frame[i].state = REVERSE_STATE_UNKNOWN;
660 reverse_frame_valid |= 1 << i;
661 break;
662 }
663 }
664 break;
665 }
666 }
667
668 /* Now update the reverse frames. */
669 for (i = 0; i < num_insns; i++)
670 {
671 /* ISSUE: Does this properly handle "network" registers? */
672 if ((reverse_frame_valid & (1 << i))
673 && dest_regs[i] != TILEGX_ZERO_REGNUM)
674 reverse_frame[dest_regs[i]] = new_reverse_frame[i];
675 }
676
677 if (prev_sp_value != 0)
678 {
679 /* GCC uses R52 as a frame pointer. Have we seen "move r52, sp"? */
680 if (reverse_frame[TILEGX_R52_REGNUM].state == REVERSE_STATE_REGISTER
681 && reverse_frame[TILEGX_R52_REGNUM].value == TILEGX_SP_REGNUM)
682 {
683 reverse_frame[TILEGX_R52_REGNUM].state = REVERSE_STATE_VALUE;
684 reverse_frame[TILEGX_R52_REGNUM].value = prev_sp_value;
685 }
686
687 prev_sp_value = 0;
688 }
689
690 if (prolog_done && prolog_end == end_addr)
691 {
692 /* We found non-prolog code. As such, _this_ instruction
693 is the one after the prolog. We keep processing, because
694 there may be more prolog code in there, but this is what
695 we'll return. */
696 /* ISSUE: There may not have actually been a prologue, and
697 we may have simply skipped some random instructions. */
698 prolog_end = next_addr;
699 }
700 if (branch_seen)
701 {
702 /* We saw a branch. The prolog absolutely must be over. */
703 break;
704 }
705 }
706
707 if (prolog_end == end_addr && cache)
708 {
709 /* We may have terminated the prolog early, and we're certainly
710 at THIS point right now. It's possible that the values of
711 registers we need are currently actually in other registers
712 (and haven't been written to memory yet). Go find them. */
713 for (i = 0; i < TILEGX_NUM_PHYS_REGS; i++)
714 {
715 if (reverse_frame[i].state == REVERSE_STATE_REGISTER
716 && reverse_frame[i].value != i)
717 {
718 unsigned saved_register = (unsigned) reverse_frame[i].value;
719
098caef4
LM
720 cache->saved_regs[saved_register].set_realreg (i);
721 cache->saved_regs[saved_register].set_addr ((LONGEST) -1);
ade64f0e
PA
722 }
723 }
724 }
725
3361b059
WL
726 if (lr_saved_on_stack_p)
727 {
098caef4
LM
728 cache->saved_regs[TILEGX_LR_REGNUM].set_realreg (TILEGX_LR_REGNUM);
729 cache->saved_regs[TILEGX_LR_REGNUM].set_addr (cache->saved_regs[TILEGX_SP_REGNUM].addr ());
3361b059
WL
730 }
731
ade64f0e
PA
732 return prolog_end;
733}
734
735/* This is the implementation of gdbarch method skip_prologue. */
736
737static CORE_ADDR
3e9d5130 738tilegx_skip_prologue (struct gdbarch *gdbarch, CORE_ADDR start_pc)
ade64f0e 739{
d79e58d8
JW
740 CORE_ADDR func_start, end_pc;
741 struct obj_section *s;
ade64f0e
PA
742
743 /* This is the preferred method, find the end of the prologue by
744 using the debugging information. */
3e9d5130 745 if (find_pc_partial_function (start_pc, NULL, &func_start, NULL))
ade64f0e 746 {
3e9d5130 747 CORE_ADDR post_prologue_pc
dda83cd7 748 = skip_prologue_using_sal (gdbarch, func_start);
ade64f0e 749
3e9d5130 750 if (post_prologue_pc != 0)
dda83cd7 751 return std::max (start_pc, post_prologue_pc);
ade64f0e
PA
752 }
753
d79e58d8
JW
754 /* Don't straddle a section boundary. */
755 s = find_pc_section (start_pc);
756 end_pc = start_pc + 8 * TILEGX_BUNDLE_SIZE_IN_BYTES;
757 if (s != NULL)
325fac50 758 end_pc = std::min (end_pc, obj_section_endaddr (s));
d79e58d8 759
ade64f0e
PA
760 /* Otherwise, try to skip prologue the hard way. */
761 return tilegx_analyze_prologue (gdbarch,
3e9d5130 762 start_pc,
d79e58d8 763 end_pc,
ade64f0e
PA
764 NULL, NULL);
765}
766
c9cf6e20 767/* This is the implementation of gdbarch method stack_frame_destroyed_p. */
ade64f0e
PA
768
769static int
c9cf6e20 770tilegx_stack_frame_destroyed_p (struct gdbarch *gdbarch, CORE_ADDR pc)
ade64f0e
PA
771{
772 CORE_ADDR func_addr = 0, func_end = 0;
773
774 if (find_pc_partial_function (pc, NULL, &func_addr, &func_end))
775 {
ade64f0e
PA
776 CORE_ADDR addr = func_end - TILEGX_BUNDLE_SIZE_IN_BYTES;
777
778 /* FIXME: Find the actual epilogue. */
779 /* HACK: Just assume the final bundle is the "ret" instruction". */
780 if (pc > addr)
781 return 1;
782 }
783 return 0;
784}
785
61d8bd0e
JW
786/* This is the implementation of gdbarch method get_longjmp_target. */
787
788static int
789tilegx_get_longjmp_target (struct frame_info *frame, CORE_ADDR *pc)
790{
791 struct gdbarch *gdbarch = get_frame_arch (frame);
792 enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
793 CORE_ADDR jb_addr;
794 gdb_byte buf[8];
795
796 jb_addr = get_frame_register_unsigned (frame, TILEGX_R0_REGNUM);
797
798 /* TileGX jmp_buf contains 32 elements of type __uint_reg_t which
799 has a size of 8 bytes. The return address is stored in the 25th
800 slot. */
801 if (target_read_memory (jb_addr + 25 * 8, buf, 8))
802 return 0;
803
804 *pc = extract_unsigned_integer (buf, 8, byte_order);
805
806 return 1;
807}
808
4aaf2503
WL
809/* by assigning the 'faultnum' reg in kernel pt_regs with this value,
810 kernel do_signal will not check r0. see tilegx kernel/signal.c
811 for details. */
812#define INT_SWINT_1_SIGRETURN (~0)
813
814/* Implement the "write_pc" gdbarch method. */
815
816static void
817tilegx_write_pc (struct regcache *regcache, CORE_ADDR pc)
818{
819 regcache_cooked_write_unsigned (regcache, TILEGX_PC_REGNUM, pc);
820
821 /* We must be careful with modifying the program counter. If we
822 just interrupted a system call, the kernel might try to restart
823 it when we resume the inferior. On restarting the system call,
824 the kernel will try backing up the program counter even though it
825 no longer points at the system call. This typically results in a
826 SIGSEGV or SIGILL. We can prevent this by writing INT_SWINT_1_SIGRETURN
827 in the "faultnum" pseudo-register.
828
829 Note that "faultnum" is saved when setting up a dummy call frame.
830 This means that it is properly restored when that frame is
831 popped, and that the interrupted system call will be restarted
832 when we resume the inferior on return from a function call from
833 within GDB. In all other cases the system call will not be
834 restarted. */
835 regcache_cooked_write_unsigned (regcache, TILEGX_FAULTNUM_REGNUM,
dda83cd7 836 INT_SWINT_1_SIGRETURN);
4aaf2503
WL
837}
838
598cc9dc 839/* 64-bit pattern for a { bpt ; nop } bundle. */
04180708 840constexpr gdb_byte tilegx_break_insn[] =
598cc9dc 841 { 0x00, 0x50, 0x48, 0x51, 0xae, 0x44, 0x6a, 0x28 };
ade64f0e 842
04180708 843typedef BP_MANIPULATION (tilegx_break_insn) tilegx_breakpoint;
ade64f0e
PA
844
845/* Normal frames. */
846
847static struct tilegx_frame_cache *
848tilegx_frame_cache (struct frame_info *this_frame, void **this_cache)
849{
850 struct gdbarch *gdbarch = get_frame_arch (this_frame);
851 struct tilegx_frame_cache *cache;
852 CORE_ADDR current_pc;
ade64f0e
PA
853
854 if (*this_cache)
19ba03f4 855 return (struct tilegx_frame_cache *) *this_cache;
ade64f0e
PA
856
857 cache = FRAME_OBSTACK_ZALLOC (struct tilegx_frame_cache);
858 *this_cache = cache;
859 cache->saved_regs = trad_frame_alloc_saved_regs (this_frame);
860 cache->base = 0;
861 cache->start_pc = get_frame_func (this_frame);
862 current_pc = get_frame_pc (this_frame);
863
864 cache->base = get_frame_register_unsigned (this_frame, TILEGX_SP_REGNUM);
865 trad_frame_set_value (cache->saved_regs, TILEGX_SP_REGNUM, cache->base);
866
ade64f0e
PA
867 if (cache->start_pc)
868 tilegx_analyze_prologue (gdbarch, cache->start_pc, current_pc,
869 cache, this_frame);
870
3361b059
WL
871 cache->saved_regs[TILEGX_PC_REGNUM] = cache->saved_regs[TILEGX_LR_REGNUM];
872
ade64f0e
PA
873 return cache;
874}
875
876/* Retrieve the value of REGNUM in FRAME. */
877
878static struct value*
879tilegx_frame_prev_register (struct frame_info *this_frame,
880 void **this_cache,
881 int regnum)
882{
883 struct tilegx_frame_cache *info =
884 tilegx_frame_cache (this_frame, this_cache);
885
886 return trad_frame_get_prev_register (this_frame, info->saved_regs,
887 regnum);
888}
889
890/* Build frame id. */
891
892static void
893tilegx_frame_this_id (struct frame_info *this_frame, void **this_cache,
894 struct frame_id *this_id)
895{
896 struct tilegx_frame_cache *info =
897 tilegx_frame_cache (this_frame, this_cache);
898
899 /* This marks the outermost frame. */
900 if (info->base == 0)
901 return;
902
903 (*this_id) = frame_id_build (info->base, info->start_pc);
904}
905
906static CORE_ADDR
907tilegx_frame_base_address (struct frame_info *this_frame, void **this_cache)
908{
909 struct tilegx_frame_cache *cache =
910 tilegx_frame_cache (this_frame, this_cache);
911
912 return cache->base;
913}
914
915static const struct frame_unwind tilegx_frame_unwind = {
916 NORMAL_FRAME,
917 default_frame_unwind_stop_reason,
918 tilegx_frame_this_id,
919 tilegx_frame_prev_register,
920 NULL, /* const struct frame_data *unwind_data */
921 default_frame_sniffer, /* frame_sniffer_ftype *sniffer */
922 NULL /* frame_prev_pc_ftype *prev_pc */
923};
924
925static const struct frame_base tilegx_frame_base = {
926 &tilegx_frame_unwind,
927 tilegx_frame_base_address,
928 tilegx_frame_base_address,
929 tilegx_frame_base_address
930};
931
ade64f0e
PA
932/* We cannot read/write the "special" registers. */
933
934static int
935tilegx_cannot_reference_register (struct gdbarch *gdbarch, int regno)
936{
937 if (regno >= 0 && regno < TILEGX_NUM_EASY_REGS)
938 return 0;
4aaf2503 939 else if (regno == TILEGX_PC_REGNUM
dda83cd7 940 || regno == TILEGX_FAULTNUM_REGNUM)
ade64f0e
PA
941 return 0;
942 else
943 return 1;
944}
945
946static struct gdbarch *
947tilegx_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches)
948{
949 struct gdbarch *gdbarch;
950 int arch_size = 64;
951
952 /* Handle arch_size == 32 or 64. Default to 64. */
953 if (info.abfd)
954 arch_size = bfd_get_arch_size (info.abfd);
955
956 /* Try to find a pre-existing architecture. */
957 for (arches = gdbarch_list_lookup_by_info (arches, &info);
958 arches != NULL;
959 arches = gdbarch_list_lookup_by_info (arches->next, &info))
960 {
961 /* We only have two flavors -- just make sure arch_size matches. */
962 if (gdbarch_ptr_bit (arches->gdbarch) == arch_size)
963 return (arches->gdbarch);
964 }
965
966 gdbarch = gdbarch_alloc (&info, NULL);
967
968 /* Basic register fields and methods, datatype sizes and stuff. */
969
970 /* There are 64 physical registers which can be referenced by
971 instructions (although only 56 of them can actually be
972 debugged) and 1 magic register (the PC). The other three
973 magic registers (ex1, syscall, orig_r0) which are known to
974 "ptrace" are ignored by "gdb". Note that we simply pretend
975 that there are 65 registers, and no "pseudo registers". */
976 set_gdbarch_num_regs (gdbarch, TILEGX_NUM_REGS);
977 set_gdbarch_num_pseudo_regs (gdbarch, 0);
978
979 set_gdbarch_sp_regnum (gdbarch, TILEGX_SP_REGNUM);
980 set_gdbarch_pc_regnum (gdbarch, TILEGX_PC_REGNUM);
981
982 set_gdbarch_register_name (gdbarch, tilegx_register_name);
983 set_gdbarch_register_type (gdbarch, tilegx_register_type);
984
ade64f0e
PA
985 set_gdbarch_short_bit (gdbarch, 2 * TARGET_CHAR_BIT);
986 set_gdbarch_int_bit (gdbarch, 4 * TARGET_CHAR_BIT);
987 set_gdbarch_long_bit (gdbarch, arch_size);
988 set_gdbarch_long_long_bit (gdbarch, 8 * TARGET_CHAR_BIT);
989
990 set_gdbarch_float_bit (gdbarch, 4 * TARGET_CHAR_BIT);
991 set_gdbarch_double_bit (gdbarch, 8 * TARGET_CHAR_BIT);
992 set_gdbarch_long_double_bit (gdbarch, 8 * TARGET_CHAR_BIT);
993
994 set_gdbarch_ptr_bit (gdbarch, arch_size);
995 set_gdbarch_addr_bit (gdbarch, arch_size);
996
997 set_gdbarch_cannot_fetch_register (gdbarch,
998 tilegx_cannot_reference_register);
999 set_gdbarch_cannot_store_register (gdbarch,
1000 tilegx_cannot_reference_register);
1001
1002 /* Stack grows down. */
1003 set_gdbarch_inner_than (gdbarch, core_addr_lessthan);
1004
1005 /* Frame Info. */
ade64f0e
PA
1006 set_gdbarch_frame_align (gdbarch, tilegx_frame_align);
1007 frame_base_set_default (gdbarch, &tilegx_frame_base);
1008
1009 set_gdbarch_skip_prologue (gdbarch, tilegx_skip_prologue);
1010
c9cf6e20 1011 set_gdbarch_stack_frame_destroyed_p (gdbarch, tilegx_stack_frame_destroyed_p);
ade64f0e
PA
1012
1013 /* Map debug registers into internal register numbers. */
1014 set_gdbarch_dwarf2_reg_to_regnum (gdbarch, tilegx_dwarf2_reg_to_regnum);
1015
1016 /* These values and methods are used when gdb calls a target function. */
1017 set_gdbarch_push_dummy_call (gdbarch, tilegx_push_dummy_call);
61d8bd0e 1018 set_gdbarch_get_longjmp_target (gdbarch, tilegx_get_longjmp_target);
4aaf2503 1019 set_gdbarch_write_pc (gdbarch, tilegx_write_pc);
04180708
YQ
1020 set_gdbarch_breakpoint_kind_from_pc (gdbarch,
1021 tilegx_breakpoint::kind_from_pc);
1022 set_gdbarch_sw_breakpoint_from_kind (gdbarch,
1023 tilegx_breakpoint::bp_from_kind);
ade64f0e
PA
1024 set_gdbarch_return_value (gdbarch, tilegx_return_value);
1025
ade64f0e
PA
1026 gdbarch_init_osabi (info, gdbarch);
1027
1028 dwarf2_append_unwinders (gdbarch);
1029 frame_unwind_append_unwinder (gdbarch, &tilegx_frame_unwind);
1030
1031 return gdbarch;
1032}
1033
6c265988 1034void _initialize_tilegx_tdep ();
ade64f0e 1035void
6c265988 1036_initialize_tilegx_tdep ()
ade64f0e
PA
1037{
1038 register_gdbarch_init (bfd_arch_tilegx, tilegx_gdbarch_init);
1039}
This page took 1.037365 seconds and 4 git commands to generate.