2015-03-24 03:15:32 +08:00
|
|
|
/* Target-dependent code for FT32.
|
|
|
|
|
2017-01-01 14:50:51 +08:00
|
|
|
Copyright (C) 2009-2017 Free Software Foundation, Inc.
|
2015-03-24 03:15:32 +08:00
|
|
|
|
|
|
|
This file is part of GDB.
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation; either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
|
|
|
|
|
|
|
#include "defs.h"
|
|
|
|
#include "frame.h"
|
|
|
|
#include "frame-unwind.h"
|
|
|
|
#include "frame-base.h"
|
|
|
|
#include "symtab.h"
|
|
|
|
#include "gdbtypes.h"
|
|
|
|
#include "gdbcmd.h"
|
|
|
|
#include "gdbcore.h"
|
|
|
|
#include "value.h"
|
|
|
|
#include "inferior.h"
|
|
|
|
#include "symfile.h"
|
|
|
|
#include "objfiles.h"
|
|
|
|
#include "osabi.h"
|
|
|
|
#include "language.h"
|
|
|
|
#include "arch-utils.h"
|
|
|
|
#include "regcache.h"
|
|
|
|
#include "trad-frame.h"
|
|
|
|
#include "dis-asm.h"
|
|
|
|
#include "record.h"
|
|
|
|
|
2015-09-30 00:06:29 +08:00
|
|
|
#include "opcode/ft32.h"
|
|
|
|
|
2015-03-24 03:15:32 +08:00
|
|
|
#include "ft32-tdep.h"
|
|
|
|
#include "gdb/sim-ft32.h"
|
gdb: Use std::min and std::max throughout
Otherwise including <string> or some other C++ header is broken.
E.g.:
In file included from /opt/gcc/include/c++/7.0.0/bits/char_traits.h:39:0,
from /opt/gcc/include/c++/7.0.0/string:40,
from /home/pedro/gdb/mygit/cxx-convertion/src/gdb/infrun.c:68:
/opt/gcc/include/c++/7.0.0/bits/stl_algobase.h:243:56: error: macro "min" passed 3 arguments, but takes just 2
min(const _Tp& __a, const _Tp& __b, _Compare __comp)
^
/opt/gcc/include/c++/7.0.0/bits/stl_algobase.h:265:56: error: macro "max" passed 3 arguments, but takes just 2
max(const _Tp& __a, const _Tp& __b, _Compare __comp)
^
In file included from .../src/gdb/infrun.c:21:0:
To the best of my grepping abilities, I believe I adjusted all min/max
calls.
gdb/ChangeLog:
2016-09-16 Pedro Alves <palves@redhat.com>
* defs.h (min, max): Delete.
* aarch64-tdep.c: Include <algorithm> and use std::min and
std::max throughout.
* aarch64-tdep.c: Likewise.
* alpha-tdep.c: Likewise.
* amd64-tdep.c: Likewise.
* amd64-windows-tdep.c: Likewise.
* arm-tdep.c: Likewise.
* avr-tdep.c: Likewise.
* breakpoint.c: Likewise.
* btrace.c: Likewise.
* ctf.c: Likewise.
* disasm.c: Likewise.
* doublest.c: Likewise.
* dwarf2loc.c: Likewise.
* dwarf2read.c: Likewise.
* environ.c: Likewise.
* exec.c: Likewise.
* f-exp.y: Likewise.
* findcmd.c: Likewise.
* ft32-tdep.c: Likewise.
* gcore.c: Likewise.
* hppa-tdep.c: Likewise.
* i386-darwin-tdep.c: Likewise.
* i386-tdep.c: Likewise.
* linux-thread-db.c: Likewise.
* lm32-tdep.c: Likewise.
* m32r-tdep.c: Likewise.
* m88k-tdep.c: Likewise.
* memrange.c: Likewise.
* minidebug.c: Likewise.
* mips-tdep.c: Likewise.
* moxie-tdep.c: Likewise.
* nds32-tdep.c: Likewise.
* nios2-tdep.c: Likewise.
* nto-procfs.c: Likewise.
* parse.c: Likewise.
* ppc-sysv-tdep.c: Likewise.
* probe.c: Likewise.
* record-btrace.c: Likewise.
* remote.c: Likewise.
* rs6000-tdep.c: Likewise.
* rx-tdep.c: Likewise.
* s390-linux-nat.c: Likewise.
* s390-linux-tdep.c: Likewise.
* ser-tcp.c: Likewise.
* sh-tdep.c: Likewise.
* sh64-tdep.c: Likewise.
* source.c: Likewise.
* sparc-tdep.c: Likewise.
* symfile.c: Likewise.
* target-memory.c: Likewise.
* target.c: Likewise.
* tic6x-tdep.c: Likewise.
* tilegx-tdep.c: Likewise.
* tracefile-tfile.c: Likewise.
* tracepoint.c: Likewise.
* valprint.c: Likewise.
* value.c: Likewise.
* xtensa-tdep.c: Likewise.
* cli/cli-cmds.c: Likewise.
* compile/compile-object-load.c: Likewise.
2016-09-17 02:55:17 +08:00
|
|
|
#include <algorithm>
|
2015-03-24 03:15:32 +08:00
|
|
|
|
|
|
|
#define RAM_BIAS 0x800000 /* Bias added to RAM addresses. */
|
|
|
|
|
|
|
|
/* Use an invalid address -1 as 'not available' marker. */
|
|
|
|
enum { REG_UNAVAIL = (CORE_ADDR) (-1) };
|
|
|
|
|
|
|
|
struct ft32_frame_cache
|
|
|
|
{
|
|
|
|
/* Base address of the frame */
|
|
|
|
CORE_ADDR base;
|
|
|
|
/* Function this frame belongs to */
|
|
|
|
CORE_ADDR pc;
|
|
|
|
/* Total size of this frame */
|
|
|
|
LONGEST framesize;
|
|
|
|
/* Saved registers in this frame */
|
|
|
|
CORE_ADDR saved_regs[FT32_NUM_REGS];
|
|
|
|
/* Saved SP in this frame */
|
|
|
|
CORE_ADDR saved_sp;
|
|
|
|
/* Has the new frame been LINKed. */
|
|
|
|
bfd_boolean established;
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Implement the "frame_align" gdbarch method. */
|
|
|
|
|
|
|
|
static CORE_ADDR
|
|
|
|
ft32_frame_align (struct gdbarch *gdbarch, CORE_ADDR sp)
|
|
|
|
{
|
|
|
|
/* Align to the size of an instruction (so that they can safely be
|
|
|
|
pushed onto the stack. */
|
|
|
|
return sp & ~1;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-11-03 22:35:14 +08:00
|
|
|
constexpr gdb_byte ft32_break_insn[] = { 0x02, 0x00, 0x34, 0x00 };
|
2015-03-24 03:15:32 +08:00
|
|
|
|
2016-11-03 22:35:14 +08:00
|
|
|
typedef BP_MANIPULATION (ft32_break_insn) ft32_breakpoint;
|
2015-03-24 03:15:32 +08:00
|
|
|
|
|
|
|
/* FT32 register names. */
|
|
|
|
|
|
|
|
static const char *const ft32_register_names[] =
|
|
|
|
{
|
|
|
|
"fp", "sp",
|
|
|
|
"r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
|
|
|
|
"r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
|
|
|
|
"r16", "r17", "r18", "r19", "r20", "r21", "r22", "r23",
|
|
|
|
"r24", "r25", "r26", "r27", "r28", "cc",
|
|
|
|
"pc"
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Implement the "register_name" gdbarch method. */
|
|
|
|
|
|
|
|
static const char *
|
|
|
|
ft32_register_name (struct gdbarch *gdbarch, int reg_nr)
|
|
|
|
{
|
|
|
|
if (reg_nr < 0)
|
|
|
|
return NULL;
|
|
|
|
if (reg_nr >= FT32_NUM_REGS)
|
|
|
|
return NULL;
|
|
|
|
return ft32_register_names[reg_nr];
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Implement the "register_type" gdbarch method. */
|
|
|
|
|
|
|
|
static struct type *
|
|
|
|
ft32_register_type (struct gdbarch *gdbarch, int reg_nr)
|
|
|
|
{
|
|
|
|
if (reg_nr == FT32_PC_REGNUM)
|
2015-09-25 07:07:35 +08:00
|
|
|
return gdbarch_tdep (gdbarch)->pc_type;
|
2015-03-24 03:15:32 +08:00
|
|
|
else if (reg_nr == FT32_SP_REGNUM || reg_nr == FT32_FP_REGNUM)
|
|
|
|
return builtin_type (gdbarch)->builtin_data_ptr;
|
|
|
|
else
|
|
|
|
return builtin_type (gdbarch)->builtin_int32;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Write into appropriate registers a function return value
|
|
|
|
of type TYPE, given in virtual format. */
|
|
|
|
|
|
|
|
static void
|
|
|
|
ft32_store_return_value (struct type *type, struct regcache *regcache,
|
|
|
|
const gdb_byte *valbuf)
|
|
|
|
{
|
2017-10-25 23:37:03 +08:00
|
|
|
struct gdbarch *gdbarch = regcache->arch ();
|
2015-03-24 03:15:32 +08:00
|
|
|
enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
|
|
|
|
CORE_ADDR regval;
|
|
|
|
int len = TYPE_LENGTH (type);
|
|
|
|
|
|
|
|
/* Things always get returned in RET1_REGNUM, RET2_REGNUM. */
|
|
|
|
regval = extract_unsigned_integer (valbuf, len > 4 ? 4 : len, byte_order);
|
|
|
|
regcache_cooked_write_unsigned (regcache, FT32_R0_REGNUM, regval);
|
|
|
|
if (len > 4)
|
|
|
|
{
|
|
|
|
regval = extract_unsigned_integer (valbuf + 4,
|
|
|
|
len - 4, byte_order);
|
|
|
|
regcache_cooked_write_unsigned (regcache, FT32_R1_REGNUM, regval);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-02 09:34:25 +08:00
|
|
|
/* Fetch a single 32-bit instruction from address a. If memory contains
|
|
|
|
a compressed instruction pair, return the expanded instruction. */
|
|
|
|
|
|
|
|
static ULONGEST
|
|
|
|
ft32_fetch_instruction (CORE_ADDR a, int *isize,
|
|
|
|
enum bfd_endian byte_order)
|
|
|
|
{
|
|
|
|
unsigned int sc[2];
|
|
|
|
ULONGEST inst;
|
|
|
|
|
|
|
|
CORE_ADDR a4 = a & ~3;
|
|
|
|
inst = read_code_unsigned_integer (a4, 4, byte_order);
|
|
|
|
*isize = ft32_decode_shortcode (a4, inst, sc) ? 2 : 4;
|
|
|
|
if (*isize == 2)
|
|
|
|
return sc[1 & (a >> 1)];
|
|
|
|
else
|
|
|
|
return inst;
|
|
|
|
}
|
|
|
|
|
2015-03-24 03:15:32 +08:00
|
|
|
/* Decode the instructions within the given address range. Decide
|
|
|
|
when we must have reached the end of the function prologue. If a
|
|
|
|
frame_info pointer is provided, fill in its saved_regs etc.
|
|
|
|
|
|
|
|
Returns the address of the first instruction after the prologue. */
|
|
|
|
|
|
|
|
static CORE_ADDR
|
|
|
|
ft32_analyze_prologue (CORE_ADDR start_addr, CORE_ADDR end_addr,
|
|
|
|
struct ft32_frame_cache *cache,
|
|
|
|
struct gdbarch *gdbarch)
|
|
|
|
{
|
|
|
|
enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
|
|
|
|
CORE_ADDR next_addr;
|
2016-04-19 01:16:27 +08:00
|
|
|
ULONGEST inst;
|
2017-11-02 09:34:25 +08:00
|
|
|
int isize = 0;
|
2015-10-03 08:32:47 +08:00
|
|
|
int regnum, pushreg;
|
|
|
|
struct bound_minimal_symbol msymbol;
|
|
|
|
const int first_saved_reg = 13; /* The first saved register. */
|
|
|
|
/* PROLOGS are addresses of the subroutine prologs, PROLOGS[n]
|
|
|
|
is the address of __prolog_$rN.
|
|
|
|
__prolog_$rN pushes registers from 13 through n inclusive.
|
|
|
|
So for example CALL __prolog_$r15 is equivalent to:
|
|
|
|
PUSH $r13
|
|
|
|
PUSH $r14
|
|
|
|
PUSH $r15
|
|
|
|
Note that PROLOGS[0] through PROLOGS[12] are unused. */
|
|
|
|
CORE_ADDR prologs[32];
|
2015-03-24 03:15:32 +08:00
|
|
|
|
|
|
|
cache->saved_regs[FT32_PC_REGNUM] = 0;
|
|
|
|
cache->framesize = 0;
|
|
|
|
|
2015-10-03 08:32:47 +08:00
|
|
|
for (regnum = first_saved_reg; regnum < 32; regnum++)
|
|
|
|
{
|
|
|
|
char prolog_symbol[32];
|
|
|
|
|
|
|
|
snprintf (prolog_symbol, sizeof (prolog_symbol), "__prolog_$r%02d",
|
|
|
|
regnum);
|
|
|
|
msymbol = lookup_minimal_symbol (prolog_symbol, NULL, NULL);
|
|
|
|
if (msymbol.minsym)
|
|
|
|
prologs[regnum] = BMSYMBOL_VALUE_ADDRESS (msymbol);
|
|
|
|
else
|
|
|
|
prologs[regnum] = 0;
|
|
|
|
}
|
|
|
|
|
2015-03-24 03:15:32 +08:00
|
|
|
if (start_addr >= end_addr)
|
2015-10-03 08:32:47 +08:00
|
|
|
return end_addr;
|
2015-03-24 03:15:32 +08:00
|
|
|
|
|
|
|
cache->established = 0;
|
2017-11-02 09:34:25 +08:00
|
|
|
for (next_addr = start_addr; next_addr < end_addr; next_addr += isize)
|
2015-03-24 03:15:32 +08:00
|
|
|
{
|
2017-11-02 09:34:25 +08:00
|
|
|
inst = ft32_fetch_instruction (next_addr, &isize, byte_order);
|
2015-03-24 03:15:32 +08:00
|
|
|
|
2015-09-30 00:06:29 +08:00
|
|
|
if (FT32_IS_PUSH (inst))
|
2015-03-24 03:15:32 +08:00
|
|
|
{
|
2015-10-03 08:32:47 +08:00
|
|
|
pushreg = FT32_PUSH_REG (inst);
|
2015-03-24 03:15:32 +08:00
|
|
|
cache->framesize += 4;
|
2015-10-03 08:32:47 +08:00
|
|
|
cache->saved_regs[FT32_R0_REGNUM + pushreg] = cache->framesize;
|
2015-03-24 03:15:32 +08:00
|
|
|
}
|
2015-10-03 08:32:47 +08:00
|
|
|
else if (FT32_IS_CALL (inst))
|
|
|
|
{
|
|
|
|
for (regnum = first_saved_reg; regnum < 32; regnum++)
|
|
|
|
{
|
|
|
|
if ((4 * (inst & 0x3ffff)) == prologs[regnum])
|
|
|
|
{
|
|
|
|
for (pushreg = first_saved_reg; pushreg <= regnum;
|
|
|
|
pushreg++)
|
|
|
|
{
|
|
|
|
cache->framesize += 4;
|
|
|
|
cache->saved_regs[FT32_R0_REGNUM + pushreg] =
|
|
|
|
cache->framesize;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
2015-03-24 03:15:32 +08:00
|
|
|
else
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
for (regnum = FT32_R0_REGNUM; regnum < FT32_PC_REGNUM; regnum++)
|
|
|
|
{
|
|
|
|
if (cache->saved_regs[regnum] != REG_UNAVAIL)
|
2015-10-03 08:32:47 +08:00
|
|
|
cache->saved_regs[regnum] =
|
|
|
|
cache->framesize - cache->saved_regs[regnum];
|
2015-03-24 03:15:32 +08:00
|
|
|
}
|
|
|
|
cache->saved_regs[FT32_PC_REGNUM] = cache->framesize;
|
|
|
|
|
|
|
|
/* It is a LINK? */
|
|
|
|
if (next_addr < end_addr)
|
|
|
|
{
|
2017-11-02 09:34:25 +08:00
|
|
|
inst = ft32_fetch_instruction (next_addr, &isize, byte_order);
|
2015-09-30 00:06:29 +08:00
|
|
|
if (FT32_IS_LINK (inst))
|
2015-03-24 03:15:32 +08:00
|
|
|
{
|
|
|
|
cache->established = 1;
|
|
|
|
for (regnum = FT32_R0_REGNUM; regnum < FT32_PC_REGNUM; regnum++)
|
|
|
|
{
|
|
|
|
if (cache->saved_regs[regnum] != REG_UNAVAIL)
|
|
|
|
cache->saved_regs[regnum] += 4;
|
|
|
|
}
|
|
|
|
cache->saved_regs[FT32_PC_REGNUM] = cache->framesize + 4;
|
|
|
|
cache->saved_regs[FT32_FP_REGNUM] = 0;
|
2015-09-30 00:06:29 +08:00
|
|
|
cache->framesize += FT32_LINK_SIZE (inst);
|
2017-11-02 09:34:25 +08:00
|
|
|
next_addr += isize;
|
2015-03-24 03:15:32 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return next_addr;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Find the end of function prologue. */
|
|
|
|
|
|
|
|
static CORE_ADDR
|
|
|
|
ft32_skip_prologue (struct gdbarch *gdbarch, CORE_ADDR pc)
|
|
|
|
{
|
|
|
|
CORE_ADDR func_addr = 0, func_end = 0;
|
|
|
|
const char *func_name;
|
|
|
|
|
|
|
|
/* See if we can determine the end of the prologue via the symbol table.
|
|
|
|
If so, then return either PC, or the PC after the prologue, whichever
|
|
|
|
is greater. */
|
|
|
|
if (find_pc_partial_function (pc, &func_name, &func_addr, &func_end))
|
|
|
|
{
|
|
|
|
CORE_ADDR post_prologue_pc
|
|
|
|
= skip_prologue_using_sal (gdbarch, func_addr);
|
|
|
|
if (post_prologue_pc != 0)
|
gdb: Use std::min and std::max throughout
Otherwise including <string> or some other C++ header is broken.
E.g.:
In file included from /opt/gcc/include/c++/7.0.0/bits/char_traits.h:39:0,
from /opt/gcc/include/c++/7.0.0/string:40,
from /home/pedro/gdb/mygit/cxx-convertion/src/gdb/infrun.c:68:
/opt/gcc/include/c++/7.0.0/bits/stl_algobase.h:243:56: error: macro "min" passed 3 arguments, but takes just 2
min(const _Tp& __a, const _Tp& __b, _Compare __comp)
^
/opt/gcc/include/c++/7.0.0/bits/stl_algobase.h:265:56: error: macro "max" passed 3 arguments, but takes just 2
max(const _Tp& __a, const _Tp& __b, _Compare __comp)
^
In file included from .../src/gdb/infrun.c:21:0:
To the best of my grepping abilities, I believe I adjusted all min/max
calls.
gdb/ChangeLog:
2016-09-16 Pedro Alves <palves@redhat.com>
* defs.h (min, max): Delete.
* aarch64-tdep.c: Include <algorithm> and use std::min and
std::max throughout.
* aarch64-tdep.c: Likewise.
* alpha-tdep.c: Likewise.
* amd64-tdep.c: Likewise.
* amd64-windows-tdep.c: Likewise.
* arm-tdep.c: Likewise.
* avr-tdep.c: Likewise.
* breakpoint.c: Likewise.
* btrace.c: Likewise.
* ctf.c: Likewise.
* disasm.c: Likewise.
* doublest.c: Likewise.
* dwarf2loc.c: Likewise.
* dwarf2read.c: Likewise.
* environ.c: Likewise.
* exec.c: Likewise.
* f-exp.y: Likewise.
* findcmd.c: Likewise.
* ft32-tdep.c: Likewise.
* gcore.c: Likewise.
* hppa-tdep.c: Likewise.
* i386-darwin-tdep.c: Likewise.
* i386-tdep.c: Likewise.
* linux-thread-db.c: Likewise.
* lm32-tdep.c: Likewise.
* m32r-tdep.c: Likewise.
* m88k-tdep.c: Likewise.
* memrange.c: Likewise.
* minidebug.c: Likewise.
* mips-tdep.c: Likewise.
* moxie-tdep.c: Likewise.
* nds32-tdep.c: Likewise.
* nios2-tdep.c: Likewise.
* nto-procfs.c: Likewise.
* parse.c: Likewise.
* ppc-sysv-tdep.c: Likewise.
* probe.c: Likewise.
* record-btrace.c: Likewise.
* remote.c: Likewise.
* rs6000-tdep.c: Likewise.
* rx-tdep.c: Likewise.
* s390-linux-nat.c: Likewise.
* s390-linux-tdep.c: Likewise.
* ser-tcp.c: Likewise.
* sh-tdep.c: Likewise.
* sh64-tdep.c: Likewise.
* source.c: Likewise.
* sparc-tdep.c: Likewise.
* symfile.c: Likewise.
* target-memory.c: Likewise.
* target.c: Likewise.
* tic6x-tdep.c: Likewise.
* tilegx-tdep.c: Likewise.
* tracefile-tfile.c: Likewise.
* tracepoint.c: Likewise.
* valprint.c: Likewise.
* value.c: Likewise.
* xtensa-tdep.c: Likewise.
* cli/cli-cmds.c: Likewise.
* compile/compile-object-load.c: Likewise.
2016-09-17 02:55:17 +08:00
|
|
|
return std::max (pc, post_prologue_pc);
|
2015-03-24 03:15:32 +08:00
|
|
|
else
|
|
|
|
{
|
|
|
|
/* Can't determine prologue from the symbol table, need to examine
|
|
|
|
instructions. */
|
|
|
|
struct symtab_and_line sal;
|
|
|
|
struct symbol *sym;
|
|
|
|
struct ft32_frame_cache cache;
|
|
|
|
CORE_ADDR plg_end;
|
|
|
|
|
|
|
|
memset (&cache, 0, sizeof cache);
|
|
|
|
|
|
|
|
plg_end = ft32_analyze_prologue (func_addr,
|
|
|
|
func_end, &cache, gdbarch);
|
|
|
|
/* Found a function. */
|
2015-08-01 17:25:44 +08:00
|
|
|
sym = lookup_symbol (func_name, NULL, VAR_DOMAIN, NULL).symbol;
|
2015-03-24 03:15:32 +08:00
|
|
|
/* Don't use line number debug info for assembly source files. */
|
|
|
|
if ((sym != NULL) && SYMBOL_LANGUAGE (sym) != language_asm)
|
|
|
|
{
|
|
|
|
sal = find_pc_line (func_addr, 0);
|
|
|
|
if (sal.end && sal.end < func_end)
|
|
|
|
{
|
|
|
|
/* Found a line number, use it as end of prologue. */
|
|
|
|
return sal.end;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
/* No useable line symbol. Use result of prologue parsing method. */
|
|
|
|
return plg_end;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* No function symbol -- just return the PC. */
|
|
|
|
return pc;
|
|
|
|
}
|
|
|
|
|
2015-09-25 07:07:35 +08:00
|
|
|
/* Implementation of `pointer_to_address' gdbarch method.
|
|
|
|
|
|
|
|
On FT32 address space zero is RAM, address space 1 is flash.
|
|
|
|
RAM appears at address RAM_BIAS, flash at address 0. */
|
|
|
|
|
|
|
|
static CORE_ADDR
|
|
|
|
ft32_pointer_to_address (struct gdbarch *gdbarch,
|
|
|
|
struct type *type, const gdb_byte *buf)
|
|
|
|
{
|
|
|
|
enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
|
|
|
|
CORE_ADDR addr
|
|
|
|
= extract_unsigned_integer (buf, TYPE_LENGTH (type), byte_order);
|
|
|
|
|
|
|
|
if (TYPE_ADDRESS_CLASS_1 (type))
|
|
|
|
return addr;
|
|
|
|
else
|
|
|
|
return addr | RAM_BIAS;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Implementation of `address_class_type_flags' gdbarch method.
|
|
|
|
|
|
|
|
This method maps DW_AT_address_class attributes to a
|
|
|
|
type_instance_flag_value. */
|
|
|
|
|
|
|
|
static int
|
|
|
|
ft32_address_class_type_flags (int byte_size, int dwarf2_addr_class)
|
|
|
|
{
|
|
|
|
/* The value 1 of the DW_AT_address_class attribute corresponds to the
|
|
|
|
__flash__ qualifier, meaning pointer to data in FT32 program memory.
|
|
|
|
*/
|
|
|
|
if (dwarf2_addr_class == 1)
|
|
|
|
return TYPE_INSTANCE_FLAG_ADDRESS_CLASS_1;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Implementation of `address_class_type_flags_to_name' gdbarch method.
|
|
|
|
|
|
|
|
Convert a type_instance_flag_value to an address space qualifier. */
|
|
|
|
|
|
|
|
static const char*
|
|
|
|
ft32_address_class_type_flags_to_name (struct gdbarch *gdbarch, int type_flags)
|
|
|
|
{
|
|
|
|
if (type_flags & TYPE_INSTANCE_FLAG_ADDRESS_CLASS_1)
|
|
|
|
return "flash";
|
|
|
|
else
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Implementation of `address_class_name_to_type_flags' gdbarch method.
|
|
|
|
|
|
|
|
Convert an address space qualifier to a type_instance_flag_value. */
|
|
|
|
|
|
|
|
static int
|
|
|
|
ft32_address_class_name_to_type_flags (struct gdbarch *gdbarch,
|
|
|
|
const char* name,
|
|
|
|
int *type_flags_ptr)
|
|
|
|
{
|
|
|
|
if (strcmp (name, "flash") == 0)
|
|
|
|
{
|
|
|
|
*type_flags_ptr = TYPE_INSTANCE_FLAG_ADDRESS_CLASS_1;
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2015-03-24 03:15:32 +08:00
|
|
|
/* Implement the "read_pc" gdbarch method. */
|
|
|
|
|
|
|
|
static CORE_ADDR
|
|
|
|
ft32_read_pc (struct regcache *regcache)
|
|
|
|
{
|
|
|
|
ULONGEST pc;
|
|
|
|
|
|
|
|
regcache_cooked_read_unsigned (regcache, FT32_PC_REGNUM, &pc);
|
|
|
|
return pc;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Implement the "write_pc" gdbarch method. */
|
|
|
|
|
|
|
|
static void
|
|
|
|
ft32_write_pc (struct regcache *regcache, CORE_ADDR val)
|
|
|
|
{
|
|
|
|
regcache_cooked_write_unsigned (regcache, FT32_PC_REGNUM, val);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Implement the "unwind_sp" gdbarch method. */
|
|
|
|
|
|
|
|
static CORE_ADDR
|
|
|
|
ft32_unwind_sp (struct gdbarch *gdbarch, struct frame_info *next_frame)
|
|
|
|
{
|
|
|
|
return frame_unwind_register_unsigned (next_frame, FT32_SP_REGNUM);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Given a return value in `regbuf' with a type `valtype',
|
|
|
|
extract and copy its value into `valbuf'. */
|
|
|
|
|
|
|
|
static void
|
|
|
|
ft32_extract_return_value (struct type *type, struct regcache *regcache,
|
|
|
|
gdb_byte *dst)
|
|
|
|
{
|
2017-10-25 23:37:03 +08:00
|
|
|
struct gdbarch *gdbarch = regcache->arch ();
|
2015-03-24 03:15:32 +08:00
|
|
|
enum bfd_endian byte_order = gdbarch_byte_order (gdbarch);
|
|
|
|
bfd_byte *valbuf = dst;
|
|
|
|
int len = TYPE_LENGTH (type);
|
|
|
|
ULONGEST tmp;
|
|
|
|
|
|
|
|
/* By using store_unsigned_integer we avoid having to do
|
|
|
|
anything special for small big-endian values. */
|
|
|
|
regcache_cooked_read_unsigned (regcache, FT32_R0_REGNUM, &tmp);
|
|
|
|
store_unsigned_integer (valbuf, (len > 4 ? len - 4 : len), byte_order, tmp);
|
|
|
|
|
|
|
|
/* Ignore return values more than 8 bytes in size because the ft32
|
|
|
|
returns anything more than 8 bytes in the stack. */
|
|
|
|
if (len > 4)
|
|
|
|
{
|
|
|
|
regcache_cooked_read_unsigned (regcache, FT32_R1_REGNUM, &tmp);
|
|
|
|
store_unsigned_integer (valbuf + len - 4, 4, byte_order, tmp);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Implement the "return_value" gdbarch method. */
|
|
|
|
|
|
|
|
static enum return_value_convention
|
|
|
|
ft32_return_value (struct gdbarch *gdbarch, struct value *function,
|
|
|
|
struct type *valtype, struct regcache *regcache,
|
|
|
|
gdb_byte *readbuf, const gdb_byte *writebuf)
|
|
|
|
{
|
|
|
|
if (TYPE_LENGTH (valtype) > 8)
|
|
|
|
return RETURN_VALUE_STRUCT_CONVENTION;
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if (readbuf != NULL)
|
|
|
|
ft32_extract_return_value (valtype, regcache, readbuf);
|
|
|
|
if (writebuf != NULL)
|
|
|
|
ft32_store_return_value (valtype, regcache, writebuf);
|
|
|
|
return RETURN_VALUE_REGISTER_CONVENTION;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Allocate and initialize a ft32_frame_cache object. */
|
|
|
|
|
|
|
|
static struct ft32_frame_cache *
|
|
|
|
ft32_alloc_frame_cache (void)
|
|
|
|
{
|
|
|
|
struct ft32_frame_cache *cache;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
cache = FRAME_OBSTACK_ZALLOC (struct ft32_frame_cache);
|
|
|
|
|
|
|
|
for (i = 0; i < FT32_NUM_REGS; ++i)
|
|
|
|
cache->saved_regs[i] = REG_UNAVAIL;
|
|
|
|
|
|
|
|
return cache;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Populate a ft32_frame_cache object for this_frame. */
|
|
|
|
|
|
|
|
static struct ft32_frame_cache *
|
|
|
|
ft32_frame_cache (struct frame_info *this_frame, void **this_cache)
|
|
|
|
{
|
|
|
|
struct ft32_frame_cache *cache;
|
|
|
|
CORE_ADDR current_pc;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
if (*this_cache)
|
Add some more casts (1/2)
Note: I needed to split this patch in two, otherwise it's too big for
the mailing list.
This patch adds explicit casts to situations where a void pointer is
assigned to a pointer to the "real" type. Building in C++ mode requires
those assignments to use an explicit cast. This includes, for example:
- callback arguments (cleanups, comparison functions, ...)
- data attached to some object (objfile, program space, etc) in the form
of a void pointer
- "user data" passed to some function
This patch comes from the commit "(mostly) auto-generated patch to insert
casts needed for C++", taken from Pedro's C++ branch.
Only files built on x86 with --enable-targets=all are modified, so the
native files for other arches will need to be dealt with separately.
I built-tested this with --enable-targets=all and reg-tested. To my
surprise, a test case (selftest.exp) had to be adjusted.
Here's the ChangeLog entry. Again, this was relatively quick to make
despite the length, thanks to David Malcom's script, although I don't
believe it's very useful information in that particular case...
gdb/ChangeLog:
* aarch64-tdep.c (aarch64_make_prologue_cache): Add cast(s).
(aarch64_make_stub_cache): Likewise.
(value_of_aarch64_user_reg): Likewise.
* ada-lang.c (ada_inferior_data_cleanup): Likewise.
(get_ada_inferior_data): Likewise.
(get_ada_pspace_data): Likewise.
(ada_pspace_data_cleanup): Likewise.
(ada_complete_symbol_matcher): Likewise.
(ada_exc_search_name_matches): Likewise.
* ada-tasks.c (get_ada_tasks_pspace_data): Likewise.
(get_ada_tasks_inferior_data): Likewise.
* addrmap.c (addrmap_mutable_foreach_worker): Likewise.
(splay_obstack_alloc): Likewise.
(splay_obstack_free): Likewise.
* alpha-linux-tdep.c (alpha_linux_supply_gregset): Likewise.
(alpha_linux_collect_gregset): Likewise.
(alpha_linux_supply_fpregset): Likewise.
(alpha_linux_collect_fpregset): Likewise.
* alpha-mdebug-tdep.c (alpha_mdebug_frame_unwind_cache): Likewise.
* alpha-tdep.c (alpha_lds): Likewise.
(alpha_sts): Likewise.
(alpha_sigtramp_frame_unwind_cache): Likewise.
(alpha_heuristic_frame_unwind_cache): Likewise.
(alpha_supply_int_regs): Likewise.
(alpha_fill_int_regs): Likewise.
(alpha_supply_fp_regs): Likewise.
(alpha_fill_fp_regs): Likewise.
* alphanbsd-tdep.c (alphanbsd_supply_fpregset): Likewise.
(alphanbsd_aout_supply_gregset): Likewise.
(alphanbsd_supply_gregset): Likewise.
* amd64-linux-tdep.c (amd64_linux_init_abi): Likewise.
(amd64_x32_linux_init_abi): Likewise.
* amd64-nat.c (amd64_supply_native_gregset): Likewise.
(amd64_collect_native_gregset): Likewise.
* amd64-tdep.c (amd64_frame_cache): Likewise.
(amd64_sigtramp_frame_cache): Likewise.
(amd64_epilogue_frame_cache): Likewise.
(amd64_supply_fxsave): Likewise.
(amd64_supply_xsave): Likewise.
(amd64_collect_fxsave): Likewise.
(amd64_collect_xsave): Likewise.
* amd64-windows-tdep.c (amd64_windows_frame_cache): Likewise.
* amd64obsd-tdep.c (amd64obsd_trapframe_cache): Likewise.
* arm-linux-tdep.c (arm_linux_supply_gregset): Likewise.
(arm_linux_collect_gregset): Likewise.
(arm_linux_supply_nwfpe): Likewise.
(arm_linux_collect_nwfpe): Likewise.
(arm_linux_supply_vfp): Likewise.
(arm_linux_collect_vfp): Likewise.
* arm-tdep.c (arm_find_mapping_symbol): Likewise.
(arm_prologue_unwind_stop_reason): Likewise.
(arm_prologue_this_id): Likewise.
(arm_prologue_prev_register): Likewise.
(arm_exidx_data_free): Likewise.
(arm_find_exidx_entry): Likewise.
(arm_stub_this_id): Likewise.
(arm_m_exception_this_id): Likewise.
(arm_m_exception_prev_register): Likewise.
(arm_normal_frame_base): Likewise.
(gdb_print_insn_arm): Likewise.
(arm_objfile_data_free): Likewise.
(arm_record_special_symbol): Likewise.
(value_of_arm_user_reg): Likewise.
* armbsd-tdep.c (armbsd_supply_fpregset): Likewise.
(armbsd_supply_gregset): Likewise.
* auto-load.c (auto_load_pspace_data_cleanup): Likewise.
(get_auto_load_pspace_data): Likewise.
(hash_loaded_script_entry): Likewise.
(eq_loaded_script_entry): Likewise.
(clear_section_scripts): Likewise.
(collect_matching_scripts): Likewise.
* auxv.c (auxv_inferior_data_cleanup): Likewise.
(get_auxv_inferior_data): Likewise.
* avr-tdep.c (avr_frame_unwind_cache): Likewise.
* ax-general.c (do_free_agent_expr_cleanup): Likewise.
* bfd-target.c (target_bfd_xfer_partial): Likewise.
(target_bfd_xclose): Likewise.
(target_bfd_get_section_table): Likewise.
* bfin-tdep.c (bfin_frame_cache): Likewise.
* block.c (find_block_in_blockvector): Likewise.
(call_site_for_pc): Likewise.
(block_find_non_opaque_type_preferred): Likewise.
* break-catch-sig.c (signal_catchpoint_insert_location): Likewise.
(signal_catchpoint_remove_location): Likewise.
(signal_catchpoint_breakpoint_hit): Likewise.
(signal_catchpoint_print_one): Likewise.
(signal_catchpoint_print_mention): Likewise.
(signal_catchpoint_print_recreate): Likewise.
* break-catch-syscall.c (get_catch_syscall_inferior_data): Likewise.
* breakpoint.c (do_cleanup_counted_command_line): Likewise.
(bp_location_compare_addrs): Likewise.
(get_first_locp_gte_addr): Likewise.
(check_tracepoint_command): Likewise.
(do_map_commands_command): Likewise.
(get_breakpoint_objfile_data): Likewise.
(free_breakpoint_probes): Likewise.
(do_captured_breakpoint_query): Likewise.
(compare_breakpoints): Likewise.
(bp_location_compare): Likewise.
(bpstat_remove_breakpoint_callback): Likewise.
(do_delete_breakpoint_cleanup): Likewise.
* bsd-uthread.c (bsd_uthread_set_supply_uthread): Likewise.
(bsd_uthread_set_collect_uthread): Likewise.
(bsd_uthread_activate): Likewise.
(bsd_uthread_fetch_registers): Likewise.
(bsd_uthread_store_registers): Likewise.
* btrace.c (check_xml_btrace_version): Likewise.
(parse_xml_btrace_block): Likewise.
(parse_xml_btrace_pt_config_cpu): Likewise.
(parse_xml_btrace_pt_raw): Likewise.
(parse_xml_btrace_pt): Likewise.
(parse_xml_btrace_conf_bts): Likewise.
(parse_xml_btrace_conf_pt): Likewise.
(do_btrace_data_cleanup): Likewise.
* c-typeprint.c (find_typedef_for_canonicalize): Likewise.
* charset.c (cleanup_iconv): Likewise.
(do_cleanup_iterator): Likewise.
* cli-out.c (cli_uiout_dtor): Likewise.
(cli_table_begin): Likewise.
(cli_table_body): Likewise.
(cli_table_end): Likewise.
(cli_table_header): Likewise.
(cli_begin): Likewise.
(cli_end): Likewise.
(cli_field_int): Likewise.
(cli_field_skip): Likewise.
(cli_field_string): Likewise.
(cli_field_fmt): Likewise.
(cli_spaces): Likewise.
(cli_text): Likewise.
(cli_message): Likewise.
(cli_wrap_hint): Likewise.
(cli_flush): Likewise.
(cli_redirect): Likewise.
(out_field_fmt): Likewise.
(field_separator): Likewise.
(cli_out_set_stream): Likewise.
* cli/cli-cmds.c (compare_symtabs): Likewise.
* cli/cli-dump.c (call_dump_func): Likewise.
(restore_section_callback): Likewise.
* cli/cli-script.c (clear_hook_in_cleanup): Likewise.
(do_restore_user_call_depth): Likewise.
(do_free_command_lines_cleanup): Likewise.
* coff-pe-read.c (get_section_vmas): Likewise.
(pe_as16): Likewise.
(pe_as32): Likewise.
* coffread.c (coff_symfile_read): Likewise.
* common/agent.c (agent_look_up_symbols): Likewise.
* common/filestuff.c (do_close_cleanup): Likewise.
* common/format.c (free_format_pieces_cleanup): Likewise.
* common/vec.c (vec_o_reserve): Likewise.
* compile/compile-c-support.c (print_one_macro): Likewise.
* compile/compile-c-symbols.c (hash_symbol_error): Likewise.
(eq_symbol_error): Likewise.
(del_symbol_error): Likewise.
(error_symbol_once): Likewise.
(gcc_convert_symbol): Likewise.
(gcc_symbol_address): Likewise.
(hash_symname): Likewise.
(eq_symname): Likewise.
* compile/compile-c-types.c (hash_type_map_instance): Likewise.
(eq_type_map_instance): Likewise.
(insert_type): Likewise.
(convert_type): Likewise.
* compile/compile-object-load.c (munmap_listp_free_cleanup): Likewise.
(setup_sections): Likewise.
(link_hash_table_free): Likewise.
(copy_sections): Likewise.
* compile/compile-object-run.c (do_module_cleanup): Likewise.
* compile/compile.c (compile_print_value): Likewise.
(do_rmdir): Likewise.
(cleanup_compile_instance): Likewise.
(cleanup_unlink_file): Likewise.
* completer.c (free_completion_tracker): Likewise.
* corelow.c (add_to_spuid_list): Likewise.
* cp-namespace.c (reset_directive_searched): Likewise.
* cp-support.c (reset_directive_searched): Likewise.
* cris-tdep.c (cris_sigtramp_frame_unwind_cache): Likewise.
(cris_frame_unwind_cache): Likewise.
* d-lang.c (builtin_d_type): Likewise.
* d-namespace.c (reset_directive_searched): Likewise.
* dbxread.c (dbx_free_symfile_info): Likewise.
(do_free_bincl_list_cleanup): Likewise.
* disasm.c (hash_dis_line_entry): Likewise.
(eq_dis_line_entry): Likewise.
(dis_asm_print_address): Likewise.
(fprintf_disasm): Likewise.
(do_ui_file_delete): Likewise.
* doublest.c (convert_floatformat_to_doublest): Likewise.
* dummy-frame.c (pop_dummy_frame_bpt): Likewise.
(dummy_frame_prev_register): Likewise.
(dummy_frame_this_id): Likewise.
* dwarf2-frame-tailcall.c (cache_hash): Likewise.
(cache_eq): Likewise.
(cache_find): Likewise.
(tailcall_frame_this_id): Likewise.
(dwarf2_tailcall_prev_register_first): Likewise.
(tailcall_frame_prev_register): Likewise.
(tailcall_frame_dealloc_cache): Likewise.
(tailcall_frame_prev_arch): Likewise.
* dwarf2-frame.c (dwarf2_frame_state_free): Likewise.
(dwarf2_frame_set_init_reg): Likewise.
(dwarf2_frame_init_reg): Likewise.
(dwarf2_frame_set_signal_frame_p): Likewise.
(dwarf2_frame_signal_frame_p): Likewise.
(dwarf2_frame_set_adjust_regnum): Likewise.
(dwarf2_frame_adjust_regnum): Likewise.
(clear_pointer_cleanup): Likewise.
(dwarf2_frame_cache): Likewise.
(find_cie): Likewise.
(dwarf2_frame_find_fde): Likewise.
* dwarf2expr.c (dwarf_expr_address_type): Likewise.
(free_dwarf_expr_context_cleanup): Likewise.
* dwarf2loc.c (locexpr_find_frame_base_location): Likewise.
(locexpr_get_frame_base): Likewise.
(loclist_find_frame_base_location): Likewise.
(loclist_get_frame_base): Likewise.
(dwarf_expr_dwarf_call): Likewise.
(dwarf_expr_get_base_type): Likewise.
(dwarf_expr_push_dwarf_reg_entry_value): Likewise.
(dwarf_expr_get_obj_addr): Likewise.
(entry_data_value_coerce_ref): Likewise.
(entry_data_value_copy_closure): Likewise.
(entry_data_value_free_closure): Likewise.
(get_frame_address_in_block_wrapper): Likewise.
(dwarf2_evaluate_property): Likewise.
(dwarf2_compile_property_to_c): Likewise.
(needs_frame_read_addr_from_reg): Likewise.
(needs_frame_get_reg_value): Likewise.
(needs_frame_frame_base): Likewise.
(needs_frame_frame_cfa): Likewise.
(needs_frame_tls_address): Likewise.
(needs_frame_dwarf_call): Likewise.
(needs_dwarf_reg_entry_value): Likewise.
(get_ax_pc): Likewise.
(locexpr_read_variable): Likewise.
(locexpr_read_variable_at_entry): Likewise.
(locexpr_read_needs_frame): Likewise.
(locexpr_describe_location): Likewise.
(locexpr_tracepoint_var_ref): Likewise.
(locexpr_generate_c_location): Likewise.
(loclist_read_variable): Likewise.
(loclist_read_variable_at_entry): Likewise.
(loclist_describe_location): Likewise.
(loclist_tracepoint_var_ref): Likewise.
(loclist_generate_c_location): Likewise.
* dwarf2read.c (line_header_hash_voidp): Likewise.
(line_header_eq_voidp): Likewise.
(dwarf2_has_info): Likewise.
(dwarf2_get_section_info): Likewise.
(locate_dwz_sections): Likewise.
(hash_file_name_entry): Likewise.
(eq_file_name_entry): Likewise.
(delete_file_name_entry): Likewise.
(dw2_setup): Likewise.
(dw2_get_file_names_reader): Likewise.
(dw2_find_pc_sect_compunit_symtab): Likewise.
(hash_signatured_type): Likewise.
(eq_signatured_type): Likewise.
(add_signatured_type_cu_to_table): Likewise.
(create_debug_types_hash_table): Likewise.
(lookup_dwo_signatured_type): Likewise.
(lookup_dwp_signatured_type): Likewise.
(lookup_signatured_type): Likewise.
(hash_type_unit_group): Likewise.
(eq_type_unit_group): Likewise.
(get_type_unit_group): Likewise.
(process_psymtab_comp_unit_reader): Likewise.
(sort_tu_by_abbrev_offset): Likewise.
(process_skeletonless_type_unit): Likewise.
(psymtabs_addrmap_cleanup): Likewise.
(dwarf2_read_symtab): Likewise.
(psymtab_to_symtab_1): Likewise.
(die_hash): Likewise.
(die_eq): Likewise.
(load_full_comp_unit_reader): Likewise.
(reset_die_in_process): Likewise.
(free_cu_line_header): Likewise.
(handle_DW_AT_stmt_list): Likewise.
(hash_dwo_file): Likewise.
(eq_dwo_file): Likewise.
(hash_dwo_unit): Likewise.
(eq_dwo_unit): Likewise.
(create_dwo_cu_reader): Likewise.
(create_dwo_unit_in_dwp_v1): Likewise.
(create_dwo_unit_in_dwp_v2): Likewise.
(lookup_dwo_unit_in_dwp): Likewise.
(dwarf2_locate_dwo_sections): Likewise.
(dwarf2_locate_common_dwp_sections): Likewise.
(dwarf2_locate_v2_dwp_sections): Likewise.
(hash_dwp_loaded_cutus): Likewise.
(eq_dwp_loaded_cutus): Likewise.
(lookup_dwo_cutu): Likewise.
(abbrev_table_free_cleanup): Likewise.
(dwarf2_free_abbrev_table): Likewise.
(find_partial_die_in_comp_unit): Likewise.
(free_line_header_voidp): Likewise.
(follow_die_offset): Likewise.
(follow_die_sig_1): Likewise.
(free_heap_comp_unit): Likewise.
(free_stack_comp_unit): Likewise.
(dwarf2_free_objfile): Likewise.
(per_cu_offset_and_type_hash): Likewise.
(per_cu_offset_and_type_eq): Likewise.
(get_die_type_at_offset): Likewise.
(partial_die_hash): Likewise.
(partial_die_eq): Likewise.
(dwarf2_per_objfile_free): Likewise.
(hash_strtab_entry): Likewise.
(eq_strtab_entry): Likewise.
(add_string): Likewise.
(hash_symtab_entry): Likewise.
(eq_symtab_entry): Likewise.
(delete_symtab_entry): Likewise.
(cleanup_mapped_symtab): Likewise.
(add_indices_to_cpool): Likewise.
(hash_psymtab_cu_index): Likewise.
(eq_psymtab_cu_index): Likewise.
(add_address_entry_worker): Likewise.
(unlink_if_set): Likewise.
(write_one_signatured_type): Likewise.
(save_gdb_index_command): Likewise.
* elfread.c (elf_symtab_read): Likewise.
(elf_gnu_ifunc_cache_hash): Likewise.
(elf_gnu_ifunc_cache_eq): Likewise.
(elf_gnu_ifunc_record_cache): Likewise.
(elf_gnu_ifunc_resolve_by_cache): Likewise.
(elf_get_probes): Likewise.
(probe_key_free): Likewise.
* f-lang.c (builtin_f_type): Likewise.
* frame-base.c (frame_base_append_sniffer): Likewise.
(frame_base_set_default): Likewise.
(frame_base_find_by_frame): Likewise.
* frame-unwind.c (frame_unwind_prepend_unwinder): Likewise.
(frame_unwind_append_unwinder): Likewise.
(frame_unwind_find_by_frame): Likewise.
* frame.c (frame_addr_hash): Likewise.
(frame_addr_hash_eq): Likewise.
(frame_stash_find): Likewise.
(do_frame_register_read): Likewise.
(unwind_to_current_frame): Likewise.
(frame_cleanup_after_sniffer): Likewise.
* frv-linux-tdep.c (frv_linux_sigtramp_frame_cache): Likewise.
* frv-tdep.c (frv_frame_unwind_cache): Likewise.
* ft32-tdep.c (ft32_frame_cache): Likewise.
* gcore.c (do_bfd_delete_cleanup): Likewise.
(gcore_create_callback): Likewise.
* gdb_bfd.c (hash_bfd): Likewise.
(eq_bfd): Likewise.
(gdb_bfd_open): Likewise.
(free_one_bfd_section): Likewise.
(gdb_bfd_ref): Likewise.
(gdb_bfd_unref): Likewise.
(get_section_descriptor): Likewise.
(gdb_bfd_map_section): Likewise.
(gdb_bfd_crc): Likewise.
(gdb_bfd_mark_parent): Likewise.
(gdb_bfd_record_inclusion): Likewise.
(gdb_bfd_requires_relocations): Likewise.
(print_one_bfd): Likewise.
* gdbtypes.c (type_pair_hash): Likewise.
(type_pair_eq): Likewise.
(builtin_type): Likewise.
(objfile_type): Likewise.
* gnu-v3-abi.c (vtable_ptrdiff_type): Likewise.
(vtable_address_point_offset): Likewise.
(gnuv3_get_vtable): Likewise.
(hash_value_and_voffset): Likewise.
(eq_value_and_voffset): Likewise.
(compare_value_and_voffset): Likewise.
(compute_vtable_size): Likewise.
(gnuv3_get_typeid_type): Likewise.
* go-lang.c (builtin_go_type): Likewise.
* guile/scm-block.c (bkscm_hash_block_smob): Likewise.
(bkscm_eq_block_smob): Likewise.
(bkscm_objfile_block_map): Likewise.
(bkscm_del_objfile_blocks): Likewise.
* guile/scm-breakpoint.c (bpscm_build_bp_list): Likewise.
* guile/scm-disasm.c (gdbscm_disasm_read_memory_worker): Likewise.
(gdbscm_disasm_print_address): Likewise.
* guile/scm-frame.c (frscm_hash_frame_smob): Likewise.
(frscm_eq_frame_smob): Likewise.
(frscm_inferior_frame_map): Likewise.
(frscm_del_inferior_frames): Likewise.
* guile/scm-gsmob.c (gdbscm_add_objfile_ref): Likewise.
* guile/scm-objfile.c (ofscm_handle_objfile_deleted): Likewise.
(ofscm_objfile_smob_from_objfile): Likewise.
* guile/scm-ports.c (ioscm_write): Likewise.
(ioscm_file_port_delete): Likewise.
(ioscm_file_port_rewind): Likewise.
(ioscm_file_port_put): Likewise.
(ioscm_file_port_write): Likewise.
* guile/scm-progspace.c (psscm_handle_pspace_deleted): Likewise.
(psscm_pspace_smob_from_pspace): Likewise.
* guile/scm-safe-call.c (scscm_recording_pre_unwind_handler): Likewise.
(scscm_recording_unwind_handler): Likewise.
(gdbscm_with_catch): Likewise.
(scscm_call_0_body): Likewise.
(scscm_call_1_body): Likewise.
(scscm_call_2_body): Likewise.
(scscm_call_3_body): Likewise.
(scscm_call_4_body): Likewise.
(scscm_apply_1_body): Likewise.
(scscm_eval_scheme_string): Likewise.
(gdbscm_safe_eval_string): Likewise.
(scscm_source_scheme_script): Likewise.
(gdbscm_safe_source_script): Likewise.
* guile/scm-string.c (gdbscm_call_scm_to_stringn): Likewise.
(gdbscm_call_scm_from_stringn): Likewise.
* guile/scm-symbol.c (syscm_hash_symbol_smob): Likewise.
(syscm_eq_symbol_smob): Likewise.
(syscm_get_symbol_map): Likewise.
(syscm_del_objfile_symbols): Likewise.
* guile/scm-symtab.c (stscm_hash_symtab_smob): Likewise.
(stscm_eq_symtab_smob): Likewise.
(stscm_objfile_symtab_map): Likewise.
(stscm_del_objfile_symtabs): Likewise.
* guile/scm-type.c (tyscm_hash_type_smob): Likewise.
(tyscm_eq_type_smob): Likewise.
(tyscm_type_map): Likewise.
(tyscm_copy_type_recursive): Likewise.
(save_objfile_types): Likewise.
* guile/scm-utils.c (extract_arg): Likewise.
* h8300-tdep.c (h8300_frame_cache): Likewise.
* hppa-linux-tdep.c (hppa_linux_sigtramp_frame_unwind_cache): Likewise.
* hppa-tdep.c (compare_unwind_entries): Likewise.
(find_unwind_entry): Likewise.
(hppa_frame_cache): Likewise.
(hppa_stub_frame_unwind_cache): Likewise.
* hppanbsd-tdep.c (hppanbsd_supply_gregset): Likewise.
* hppaobsd-tdep.c (hppaobsd_supply_gregset): Likewise.
(hppaobsd_supply_fpregset): Likewise.
* i386-cygwin-tdep.c (core_process_module_section): Likewise.
* i386-linux-tdep.c (i386_linux_init_abi): Likewise.
* i386-tdep.c (i386_frame_cache): Likewise.
(i386_epilogue_frame_cache): Likewise.
(i386_sigtramp_frame_cache): Likewise.
(i386_supply_gregset): Likewise.
(i386_collect_gregset): Likewise.
(i386_gdbarch_init): Likewise.
* i386obsd-tdep.c (i386obsd_aout_supply_regset): Likewise.
(i386obsd_trapframe_cache): Likewise.
* i387-tdep.c (i387_supply_fsave): Likewise.
(i387_collect_fsave): Likewise.
(i387_supply_fxsave): Likewise.
(i387_collect_fxsave): Likewise.
(i387_supply_xsave): Likewise.
(i387_collect_xsave): Likewise.
* ia64-tdep.c (ia64_frame_cache): Likewise.
(ia64_sigtramp_frame_cache): Likewise.
* infcmd.c (attach_command_continuation): Likewise.
(attach_command_continuation_free_args): Likewise.
* inferior.c (restore_inferior): Likewise.
(delete_thread_of_inferior): Likewise.
* inflow.c (inflow_inferior_data_cleanup): Likewise.
(get_inflow_inferior_data): Likewise.
(inflow_inferior_exit): Likewise.
* infrun.c (displaced_step_clear_cleanup): Likewise.
(restore_current_uiout_cleanup): Likewise.
(release_stop_context_cleanup): Likewise.
(do_restore_infcall_suspend_state_cleanup): Likewise.
(do_restore_infcall_control_state_cleanup): Likewise.
(restore_inferior_ptid): Likewise.
* inline-frame.c (block_starting_point_at): Likewise.
* iq2000-tdep.c (iq2000_frame_cache): Likewise.
* jit.c (get_jit_objfile_data): Likewise.
(get_jit_program_space_data): Likewise.
(jit_object_close_impl): Likewise.
(jit_find_objf_with_entry_addr): Likewise.
(jit_breakpoint_deleted): Likewise.
(jit_unwind_reg_set_impl): Likewise.
(jit_unwind_reg_get_impl): Likewise.
(jit_dealloc_cache): Likewise.
(jit_frame_sniffer): Likewise.
(jit_frame_prev_register): Likewise.
(jit_prepend_unwinder): Likewise.
(jit_inferior_exit_hook): Likewise.
(free_objfile_data): Likewise.
* jv-lang.c (jv_per_objfile_free): Likewise.
(get_dynamics_objfile): Likewise.
(get_java_class_symtab): Likewise.
(builtin_java_type): Likewise.
* language.c (language_string_char_type): Likewise.
(language_bool_type): Likewise.
(language_lookup_primitive_type): Likewise.
(language_lookup_primitive_type_as_symbol): Likewise.
* linespec.c (hash_address_entry): Likewise.
(eq_address_entry): Likewise.
(iterate_inline_only): Likewise.
(iterate_name_matcher): Likewise.
(decode_line_2_compare_items): Likewise.
(collect_one_symbol): Likewise.
(compare_symbols): Likewise.
(compare_msymbols): Likewise.
(add_symtabs_to_list): Likewise.
(collect_symbols): Likewise.
(compare_msyms): Likewise.
(add_minsym): Likewise.
(cleanup_linespec_result): Likewise.
* linux-fork.c (inferior_call_waitpid_cleanup): Likewise.
* linux-nat.c (delete_lwp_cleanup): Likewise.
(count_events_callback): Likewise.
(select_event_lwp_callback): Likewise.
(resume_stopped_resumed_lwps): Likewise.
* linux-tdep.c (get_linux_gdbarch_data): Likewise.
(invalidate_linux_cache_inf): Likewise.
(get_linux_inferior_data): Likewise.
(linux_find_memory_regions_thunk): Likewise.
(linux_make_mappings_callback): Likewise.
(linux_corefile_thread_callback): Likewise.
(find_mapping_size): Likewise.
* linux-thread-db.c (find_new_threads_callback): Likewise.
* lm32-tdep.c (lm32_frame_cache): Likewise.
* m2-lang.c (builtin_m2_type): Likewise.
* m32c-tdep.c (m32c_analyze_frame_prologue): Likewise.
* m32r-linux-tdep.c (m32r_linux_sigtramp_frame_cache): Likewise.
(m32r_linux_supply_gregset): Likewise.
(m32r_linux_collect_gregset): Likewise.
* m32r-tdep.c (m32r_frame_unwind_cache): Likewise.
* m68hc11-tdep.c (m68hc11_frame_unwind_cache): Likewise.
* m68k-tdep.c (m68k_frame_cache): Likewise.
* m68kbsd-tdep.c (m68kbsd_supply_fpregset): Likewise.
(m68kbsd_supply_gregset): Likewise.
* m68klinux-tdep.c (m68k_linux_sigtramp_frame_cache): Likewise.
* m88k-tdep.c (m88k_frame_cache): Likewise.
(m88k_supply_gregset): Likewise.
gdb/gdbserver/ChangeLog:
* dll.c (match_dll): Add cast(s).
(unloaded_dll): Likewise.
* linux-low.c (second_thread_of_pid_p): Likewise.
(delete_lwp_callback): Likewise.
(count_events_callback): Likewise.
(select_event_lwp_callback): Likewise.
(linux_set_resume_request): Likewise.
* server.c (accumulate_file_name_length): Likewise.
(emit_dll_description): Likewise.
(handle_qxfer_threads_worker): Likewise.
(visit_actioned_threads): Likewise.
* thread-db.c (any_thread_of): Likewise.
* tracepoint.c (same_process_p): Likewise.
(match_blocktype): Likewise.
(build_traceframe_info_xml): Likewise.
gdb/testsuite/ChangeLog:
* gdb.gdb/selftest.exp (do_steps_and_nexts): Adjust expected
source line.
2015-09-26 02:08:07 +08:00
|
|
|
return (struct ft32_frame_cache *) *this_cache;
|
2015-03-24 03:15:32 +08:00
|
|
|
|
|
|
|
cache = ft32_alloc_frame_cache ();
|
|
|
|
*this_cache = cache;
|
|
|
|
|
|
|
|
cache->base = get_frame_register_unsigned (this_frame, FT32_FP_REGNUM);
|
|
|
|
if (cache->base == 0)
|
|
|
|
return cache;
|
|
|
|
|
|
|
|
cache->pc = get_frame_func (this_frame);
|
|
|
|
current_pc = get_frame_pc (this_frame);
|
|
|
|
if (cache->pc)
|
|
|
|
{
|
|
|
|
struct gdbarch *gdbarch = get_frame_arch (this_frame);
|
|
|
|
|
|
|
|
ft32_analyze_prologue (cache->pc, current_pc, cache, gdbarch);
|
|
|
|
if (!cache->established)
|
|
|
|
cache->base = get_frame_register_unsigned (this_frame, FT32_SP_REGNUM);
|
|
|
|
}
|
|
|
|
|
|
|
|
cache->saved_sp = cache->base - 4;
|
|
|
|
|
|
|
|
for (i = 0; i < FT32_NUM_REGS; ++i)
|
|
|
|
if (cache->saved_regs[i] != REG_UNAVAIL)
|
|
|
|
cache->saved_regs[i] = cache->base + cache->saved_regs[i];
|
|
|
|
|
|
|
|
return cache;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Implement the "unwind_pc" gdbarch method. */
|
|
|
|
|
|
|
|
static CORE_ADDR
|
|
|
|
ft32_unwind_pc (struct gdbarch *gdbarch, struct frame_info *next_frame)
|
|
|
|
{
|
|
|
|
return frame_unwind_register_unsigned (next_frame, FT32_PC_REGNUM);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Given a GDB frame, determine the address of the calling function's
|
|
|
|
frame. This will be used to create a new GDB frame struct. */
|
|
|
|
|
|
|
|
static void
|
|
|
|
ft32_frame_this_id (struct frame_info *this_frame,
|
|
|
|
void **this_prologue_cache, struct frame_id *this_id)
|
|
|
|
{
|
|
|
|
struct ft32_frame_cache *cache = ft32_frame_cache (this_frame,
|
|
|
|
this_prologue_cache);
|
|
|
|
|
|
|
|
/* This marks the outermost frame. */
|
|
|
|
if (cache->base == 0)
|
|
|
|
return;
|
|
|
|
|
|
|
|
*this_id = frame_id_build (cache->saved_sp, cache->pc);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Get the value of register regnum in the previous stack frame. */
|
|
|
|
|
|
|
|
static struct value *
|
|
|
|
ft32_frame_prev_register (struct frame_info *this_frame,
|
|
|
|
void **this_prologue_cache, int regnum)
|
|
|
|
{
|
|
|
|
struct ft32_frame_cache *cache = ft32_frame_cache (this_frame,
|
|
|
|
this_prologue_cache);
|
|
|
|
|
|
|
|
gdb_assert (regnum >= 0);
|
|
|
|
|
|
|
|
if (regnum == FT32_SP_REGNUM && cache->saved_sp)
|
|
|
|
return frame_unwind_got_constant (this_frame, regnum, cache->saved_sp);
|
|
|
|
|
|
|
|
if (regnum < FT32_NUM_REGS && cache->saved_regs[regnum] != REG_UNAVAIL)
|
|
|
|
return frame_unwind_got_memory (this_frame, regnum,
|
|
|
|
RAM_BIAS | cache->saved_regs[regnum]);
|
|
|
|
|
|
|
|
return frame_unwind_got_register (this_frame, regnum, regnum);
|
|
|
|
}
|
|
|
|
|
|
|
|
static const struct frame_unwind ft32_frame_unwind =
|
|
|
|
{
|
|
|
|
NORMAL_FRAME,
|
|
|
|
default_frame_unwind_stop_reason,
|
|
|
|
ft32_frame_this_id,
|
|
|
|
ft32_frame_prev_register,
|
|
|
|
NULL,
|
|
|
|
default_frame_sniffer
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Return the base address of this_frame. */
|
|
|
|
|
|
|
|
static CORE_ADDR
|
|
|
|
ft32_frame_base_address (struct frame_info *this_frame, void **this_cache)
|
|
|
|
{
|
|
|
|
struct ft32_frame_cache *cache = ft32_frame_cache (this_frame,
|
|
|
|
this_cache);
|
|
|
|
|
|
|
|
return cache->base;
|
|
|
|
}
|
|
|
|
|
|
|
|
static const struct frame_base ft32_frame_base =
|
|
|
|
{
|
|
|
|
&ft32_frame_unwind,
|
|
|
|
ft32_frame_base_address,
|
|
|
|
ft32_frame_base_address,
|
|
|
|
ft32_frame_base_address
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct frame_id
|
|
|
|
ft32_dummy_id (struct gdbarch *gdbarch, struct frame_info *this_frame)
|
|
|
|
{
|
|
|
|
CORE_ADDR sp = get_frame_register_unsigned (this_frame, FT32_SP_REGNUM);
|
|
|
|
|
|
|
|
return frame_id_build (sp, get_frame_pc (this_frame));
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Allocate and initialize the ft32 gdbarch object. */
|
|
|
|
|
|
|
|
static struct gdbarch *
|
|
|
|
ft32_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches)
|
|
|
|
{
|
|
|
|
struct gdbarch *gdbarch;
|
|
|
|
struct gdbarch_tdep *tdep;
|
2015-09-25 07:07:35 +08:00
|
|
|
struct type *void_type;
|
|
|
|
struct type *func_void_type;
|
2015-03-24 03:15:32 +08:00
|
|
|
|
|
|
|
/* If there is already a candidate, use it. */
|
|
|
|
arches = gdbarch_list_lookup_by_info (arches, &info);
|
|
|
|
if (arches != NULL)
|
|
|
|
return arches->gdbarch;
|
|
|
|
|
|
|
|
/* Allocate space for the new architecture. */
|
2017-05-25 05:15:23 +08:00
|
|
|
tdep = XCNEW (struct gdbarch_tdep);
|
2015-03-24 03:15:32 +08:00
|
|
|
gdbarch = gdbarch_alloc (&info, tdep);
|
|
|
|
|
2015-09-25 07:07:35 +08:00
|
|
|
/* Create a type for PC. We can't use builtin types here, as they may not
|
|
|
|
be defined. */
|
2017-09-28 01:02:00 +08:00
|
|
|
void_type = arch_type (gdbarch, TYPE_CODE_VOID, TARGET_CHAR_BIT, "void");
|
2015-09-25 07:07:35 +08:00
|
|
|
func_void_type = make_function_type (void_type, NULL);
|
2016-09-06 23:26:32 +08:00
|
|
|
tdep->pc_type = arch_pointer_type (gdbarch, 4 * TARGET_CHAR_BIT, NULL,
|
|
|
|
func_void_type);
|
2015-09-25 07:07:35 +08:00
|
|
|
TYPE_INSTANCE_FLAGS (tdep->pc_type) |= TYPE_INSTANCE_FLAG_ADDRESS_CLASS_1;
|
|
|
|
|
2015-03-24 03:15:32 +08:00
|
|
|
set_gdbarch_read_pc (gdbarch, ft32_read_pc);
|
|
|
|
set_gdbarch_write_pc (gdbarch, ft32_write_pc);
|
|
|
|
set_gdbarch_unwind_sp (gdbarch, ft32_unwind_sp);
|
|
|
|
|
|
|
|
set_gdbarch_num_regs (gdbarch, FT32_NUM_REGS);
|
|
|
|
set_gdbarch_sp_regnum (gdbarch, FT32_SP_REGNUM);
|
|
|
|
set_gdbarch_pc_regnum (gdbarch, FT32_PC_REGNUM);
|
|
|
|
set_gdbarch_register_name (gdbarch, ft32_register_name);
|
|
|
|
set_gdbarch_register_type (gdbarch, ft32_register_type);
|
|
|
|
|
|
|
|
set_gdbarch_return_value (gdbarch, ft32_return_value);
|
|
|
|
|
2015-09-25 07:07:35 +08:00
|
|
|
set_gdbarch_pointer_to_address (gdbarch, ft32_pointer_to_address);
|
|
|
|
|
2015-03-24 03:15:32 +08:00
|
|
|
set_gdbarch_skip_prologue (gdbarch, ft32_skip_prologue);
|
|
|
|
set_gdbarch_inner_than (gdbarch, core_addr_lessthan);
|
2016-11-03 22:35:14 +08:00
|
|
|
set_gdbarch_breakpoint_kind_from_pc (gdbarch, ft32_breakpoint::kind_from_pc);
|
|
|
|
set_gdbarch_sw_breakpoint_from_kind (gdbarch, ft32_breakpoint::bp_from_kind);
|
2015-03-24 03:15:32 +08:00
|
|
|
set_gdbarch_frame_align (gdbarch, ft32_frame_align);
|
|
|
|
|
|
|
|
frame_base_set_default (gdbarch, &ft32_frame_base);
|
|
|
|
|
|
|
|
/* Methods for saving / extracting a dummy frame's ID. The ID's
|
|
|
|
stack address must match the SP value returned by
|
|
|
|
PUSH_DUMMY_CALL, and saved by generic_save_dummy_frame_tos. */
|
|
|
|
set_gdbarch_dummy_id (gdbarch, ft32_dummy_id);
|
|
|
|
|
|
|
|
set_gdbarch_unwind_pc (gdbarch, ft32_unwind_pc);
|
|
|
|
|
|
|
|
/* Hook in ABI-specific overrides, if they have been registered. */
|
|
|
|
gdbarch_init_osabi (info, gdbarch);
|
|
|
|
|
|
|
|
/* Hook in the default unwinders. */
|
|
|
|
frame_unwind_append_unwinder (gdbarch, &ft32_frame_unwind);
|
|
|
|
|
|
|
|
/* Support simple overlay manager. */
|
|
|
|
set_gdbarch_overlay_update (gdbarch, simple_overlay_update);
|
|
|
|
|
2015-09-25 07:07:35 +08:00
|
|
|
set_gdbarch_address_class_type_flags (gdbarch, ft32_address_class_type_flags);
|
|
|
|
set_gdbarch_address_class_name_to_type_flags
|
|
|
|
(gdbarch, ft32_address_class_name_to_type_flags);
|
|
|
|
set_gdbarch_address_class_type_flags_to_name
|
|
|
|
(gdbarch, ft32_address_class_type_flags_to_name);
|
|
|
|
|
2015-03-24 03:15:32 +08:00
|
|
|
return gdbarch;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Register this machine's init routine. */
|
|
|
|
|
|
|
|
void
|
|
|
|
_initialize_ft32_tdep (void)
|
|
|
|
{
|
|
|
|
register_gdbarch_init (bfd_arch_ft32, ft32_gdbarch_init);
|
|
|
|
}
|