mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2024-11-24 02:24:46 +08:00
Convert the RX target to make use of target descriptions.
gdb/ChangeLog 2019-08-25 Yoshinori Sato <ysato@users.sourceforge.jp> * gdb/rx-tdep.c (rx_register_names): New. (rx_register_name): Delete. (rx_psw_type): Delete. (rx_fpsw_type): Delete. (rx_register_type): Delete. (rx_gdbarch_init): Convert target-descriptions. (_initialize_rx_tdep): Add initialize_tdesc_rx. * gdb/features/Makefile: Add rx.xml. * gdb/features/rx.xml: New. * gdb/features/rx.c: Generated. * gdb/NEWS: Mention target description support. gdb/doc/ChangeLog: 2019-08-25 Yoshinori Sato <ysato@users.sourceforge.jp> * gdb.texinfo (Standard Target Features): Add RX Features sub-section.
This commit is contained in:
parent
25602020bc
commit
e3ec872f80
@ -1,3 +1,17 @@
|
||||
2019-08-25 Yoshinori Sato <ysato@users.sourceforge.jp>
|
||||
|
||||
* gdb/rx-tdep.c (rx_register_names): New.
|
||||
(rx_register_name): Delete.
|
||||
(rx_psw_type): Delete.
|
||||
(rx_fpsw_type): Delete.
|
||||
(rx_register_type): Delete.
|
||||
(rx_gdbarch_init): Convert target-descriptions.
|
||||
(_initialize_rx_tdep): Add initialize_tdesc_rx.
|
||||
* gdb/features/Makefile: Add rx.xml.
|
||||
* gdb/features/rx.xml: New.
|
||||
* gdb/features/rx.c: Generated.
|
||||
* gdb/NEWS: Mention target description support.
|
||||
|
||||
2019-08-22 Christian Biesinger <cbiesinger@google.com>
|
||||
|
||||
* symtab.c (symbol_cache_lookup): Always initialize *bsc_ptr and
|
||||
|
2
gdb/NEWS
2
gdb/NEWS
@ -27,6 +27,8 @@
|
||||
provide the exitcode or exit status of the shell commands launched by
|
||||
GDB commands such as "shell", "pipe" and "make".
|
||||
|
||||
* The RX port now supports XML target descriptions.
|
||||
|
||||
* Python API
|
||||
|
||||
** The gdb.Value type has a new method 'format_string' which returns a
|
||||
|
@ -1,3 +1,7 @@
|
||||
2019-08-25 Yoshinori Sato <ysato@users.sourceforge.jp>
|
||||
|
||||
* gdb.texinfo (Standard Target Features): Add RX Features sub-section.
|
||||
|
||||
2019-08-16 Alan Hayward <alan.hayward@arm.com>
|
||||
|
||||
* gdb.texinfo (AArch64 Pointer Authentication)
|
||||
|
@ -44084,6 +44084,7 @@ registers using the capitalization used in the description.
|
||||
* OpenRISC 1000 Features::
|
||||
* PowerPC Features::
|
||||
* RISC-V Features::
|
||||
* RX Features::
|
||||
* S/390 and System z Features::
|
||||
* Sparc Features::
|
||||
* TIC6x Features::
|
||||
@ -44514,6 +44515,15 @@ target has floating point hardware, but can be moved into the csr
|
||||
feature if the target has the floating point control registers, but no
|
||||
other floating point hardware.
|
||||
|
||||
@node RX Features
|
||||
@subsection RX Features
|
||||
@cindex target descriptions, RX Features
|
||||
|
||||
The @samp{org.gnu.gdb.rx.core} feature is required for RX
|
||||
targets. It should contain the registers @samp{r0} through
|
||||
@samp{r15}, @samp{usp}, @samp{isp}, @samp{psw}, @samp{pc}, @samp{intb},
|
||||
@samp{bpsw}, @samp{bpc}, @samp{fintv}, @samp{fpsw}, and @samp{acc}.
|
||||
|
||||
@node S/390 and System z Features
|
||||
@subsection S/390 and System z Features
|
||||
@cindex target descriptions, S/390 features
|
||||
|
@ -161,6 +161,7 @@ XMLTOC = \
|
||||
rs6000/powerpc-vsx64.xml \
|
||||
rs6000/powerpc-vsx64l.xml \
|
||||
rs6000/rs6000.xml \
|
||||
rx.xml \
|
||||
s390-linux32.xml \
|
||||
s390-linux32v1.xml \
|
||||
s390-linux32v2.xml \
|
||||
@ -238,6 +239,7 @@ FEATURE_XMLFILES = aarch64-core.xml \
|
||||
riscv/64bit-cpu.xml \
|
||||
riscv/64bit-csr.xml \
|
||||
riscv/64bit-fpu.xml \
|
||||
rx.xml \
|
||||
tic6x-c6xp.xml \
|
||||
tic6x-core.xml \
|
||||
tic6x-gp.xml
|
||||
|
80
gdb/features/rx.c
Normal file
80
gdb/features/rx.c
Normal file
@ -0,0 +1,80 @@
|
||||
/* THIS FILE IS GENERATED. -*- buffer-read-only: t -*- vi:set ro:
|
||||
Original: rx.xml.tmp */
|
||||
|
||||
#include "defs.h"
|
||||
#include "osabi.h"
|
||||
#include "target-descriptions.h"
|
||||
|
||||
struct target_desc *tdesc_rx;
|
||||
static void
|
||||
initialize_tdesc_rx (void)
|
||||
{
|
||||
struct target_desc *result = allocate_target_description ();
|
||||
struct tdesc_feature *feature;
|
||||
|
||||
feature = tdesc_create_feature (result, "org.gnu.gdb.rx.core");
|
||||
tdesc_type_with_fields *type_with_fields;
|
||||
type_with_fields = tdesc_create_flags (feature, "psw_flags", 4);
|
||||
tdesc_add_flag (type_with_fields, 0, "C");
|
||||
tdesc_add_flag (type_with_fields, 1, "Z");
|
||||
tdesc_add_flag (type_with_fields, 2, "S");
|
||||
tdesc_add_flag (type_with_fields, 3, "O");
|
||||
tdesc_add_flag (type_with_fields, 16, "I");
|
||||
tdesc_add_flag (type_with_fields, 17, "U");
|
||||
tdesc_add_flag (type_with_fields, 20, "PM");
|
||||
tdesc_add_flag (type_with_fields, 24, "IPL0");
|
||||
tdesc_add_flag (type_with_fields, 25, "IPL1");
|
||||
tdesc_add_flag (type_with_fields, 26, "IPL2");
|
||||
tdesc_add_flag (type_with_fields, 27, "IPL3");
|
||||
|
||||
type_with_fields = tdesc_create_flags (feature, "fpsw_flags", 4);
|
||||
tdesc_add_flag (type_with_fields, 0, "RM0");
|
||||
tdesc_add_flag (type_with_fields, 1, "RM1");
|
||||
tdesc_add_flag (type_with_fields, 2, "CV");
|
||||
tdesc_add_flag (type_with_fields, 3, "CO");
|
||||
tdesc_add_flag (type_with_fields, 4, "CZ");
|
||||
tdesc_add_flag (type_with_fields, 5, "CU");
|
||||
tdesc_add_flag (type_with_fields, 6, "CX");
|
||||
tdesc_add_flag (type_with_fields, 7, "CE");
|
||||
tdesc_add_flag (type_with_fields, 8, "DN");
|
||||
tdesc_add_flag (type_with_fields, 10, "EV");
|
||||
tdesc_add_flag (type_with_fields, 11, "EO");
|
||||
tdesc_add_flag (type_with_fields, 12, "EZ");
|
||||
tdesc_add_flag (type_with_fields, 13, "EU");
|
||||
tdesc_add_flag (type_with_fields, 14, "EX");
|
||||
tdesc_add_flag (type_with_fields, 26, "FV");
|
||||
tdesc_add_flag (type_with_fields, 27, "FO");
|
||||
tdesc_add_flag (type_with_fields, 28, "FZ");
|
||||
tdesc_add_flag (type_with_fields, 29, "FU");
|
||||
tdesc_add_flag (type_with_fields, 30, "FX");
|
||||
tdesc_add_flag (type_with_fields, 31, "FS");
|
||||
|
||||
tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "data_ptr");
|
||||
tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "uint32");
|
||||
tdesc_create_reg (feature, "r2", 2, 1, NULL, 32, "uint32");
|
||||
tdesc_create_reg (feature, "r3", 3, 1, NULL, 32, "uint32");
|
||||
tdesc_create_reg (feature, "r4", 4, 1, NULL, 32, "uint32");
|
||||
tdesc_create_reg (feature, "r5", 5, 1, NULL, 32, "uint32");
|
||||
tdesc_create_reg (feature, "r6", 6, 1, NULL, 32, "uint32");
|
||||
tdesc_create_reg (feature, "r7", 7, 1, NULL, 32, "uint32");
|
||||
tdesc_create_reg (feature, "r8", 8, 1, NULL, 32, "uint32");
|
||||
tdesc_create_reg (feature, "r9", 9, 1, NULL, 32, "uint32");
|
||||
tdesc_create_reg (feature, "r10", 10, 1, NULL, 32, "uint32");
|
||||
tdesc_create_reg (feature, "r11", 11, 1, NULL, 32, "uint32");
|
||||
tdesc_create_reg (feature, "r12", 12, 1, NULL, 32, "uint32");
|
||||
tdesc_create_reg (feature, "r13", 13, 1, NULL, 32, "uint32");
|
||||
tdesc_create_reg (feature, "r14", 14, 1, NULL, 32, "uint32");
|
||||
tdesc_create_reg (feature, "r15", 15, 1, NULL, 32, "uint32");
|
||||
tdesc_create_reg (feature, "usp", 16, 1, NULL, 32, "data_ptr");
|
||||
tdesc_create_reg (feature, "isp", 17, 1, NULL, 32, "data_ptr");
|
||||
tdesc_create_reg (feature, "psw", 18, 1, NULL, 32, "psw_flags");
|
||||
tdesc_create_reg (feature, "pc", 19, 1, NULL, 32, "code_ptr");
|
||||
tdesc_create_reg (feature, "intb", 20, 1, NULL, 32, "data_ptr");
|
||||
tdesc_create_reg (feature, "bpsw", 21, 1, NULL, 32, "psw_flags");
|
||||
tdesc_create_reg (feature, "bpc", 22, 1, NULL, 32, "code_ptr");
|
||||
tdesc_create_reg (feature, "fintv", 23, 1, NULL, 32, "code_ptr");
|
||||
tdesc_create_reg (feature, "fpsw", 24, 1, NULL, 32, "fpsw_flags");
|
||||
tdesc_create_reg (feature, "acc", 25, 1, NULL, 64, "uint64");
|
||||
|
||||
tdesc_rx = result;
|
||||
}
|
74
gdb/features/rx.xml
Normal file
74
gdb/features/rx.xml
Normal file
@ -0,0 +1,74 @@
|
||||
<?xml version="1.0"?>
|
||||
<!-- Copyright (C) 2019 Free Software Foundation, Inc.
|
||||
|
||||
Copying and distribution of this file, with or without modification,
|
||||
are permitted in any medium without royalty provided the copyright
|
||||
notice and this notice are preserved. -->
|
||||
|
||||
<!DOCTYPE feature SYSTEM "gdb-target.dtd">
|
||||
<feature name="org.gnu.gdb.rx.core">
|
||||
<reg name="r0" bitsize="32" type="data_ptr"/>
|
||||
<reg name="r1" bitsize="32" type="uint32"/>
|
||||
<reg name="r2" bitsize="32" type="uint32"/>
|
||||
<reg name="r3" bitsize="32" type="uint32"/>
|
||||
<reg name="r4" bitsize="32" type="uint32"/>
|
||||
<reg name="r5" bitsize="32" type="uint32"/>
|
||||
<reg name="r6" bitsize="32" type="uint32"/>
|
||||
<reg name="r7" bitsize="32" type="uint32"/>
|
||||
<reg name="r8" bitsize="32" type="uint32"/>
|
||||
<reg name="r9" bitsize="32" type="uint32"/>
|
||||
<reg name="r10" bitsize="32" type="uint32"/>
|
||||
<reg name="r11" bitsize="32" type="uint32"/>
|
||||
<reg name="r12" bitsize="32" type="uint32"/>
|
||||
<reg name="r13" bitsize="32" type="uint32"/>
|
||||
<reg name="r14" bitsize="32" type="uint32"/>
|
||||
<reg name="r15" bitsize="32" type="uint32"/>
|
||||
|
||||
<flags id="psw_flags" size="4">
|
||||
<field name="C" start="0" end="0"/>
|
||||
<field name="Z" start="1" end="1"/>
|
||||
<field name="S" start="2" end="2"/>
|
||||
<field name="O" start="3" end="3"/>
|
||||
<field name="I" start="16" end="16"/>
|
||||
<field name="U" start="17" end="17"/>
|
||||
<field name="PM" start="20" end="20"/>
|
||||
<field name="IPL0" start="24" end="24"/>
|
||||
<field name="IPL1" start="25" end="25"/>
|
||||
<field name="IPL2" start="26" end="26"/>
|
||||
<field name="IPL3" start="27" end="27"/>
|
||||
</flags>
|
||||
|
||||
<flags id="fpsw_flags" size="4">
|
||||
<field name="RM0" start="0" end="0"/>
|
||||
<field name="RM1" start="1" end="1"/>
|
||||
<field name="CV" start="2" end="2"/>
|
||||
<field name="CO" start="3" end="3"/>
|
||||
<field name="CZ" start="4" end="4"/>
|
||||
<field name="CU" start="5" end="5"/>
|
||||
<field name="CX" start="6" end="6"/>
|
||||
<field name="CE" start="7" end="7"/>
|
||||
<field name="DN" start="8" end="8"/>
|
||||
<field name="EV" start="10" end="10"/>
|
||||
<field name="EO" start="11" end="11"/>
|
||||
<field name="EZ" start="12" end="12"/>
|
||||
<field name="EU" start="13" end="13"/>
|
||||
<field name="EX" start="14" end="14"/>
|
||||
<field name="FV" start="26" end="26"/>
|
||||
<field name="FO" start="27" end="27"/>
|
||||
<field name="FZ" start="28" end="28"/>
|
||||
<field name="FU" start="29" end="29"/>
|
||||
<field name="FX" start="30" end="30"/>
|
||||
<field name="FS" start="31" end="31"/>
|
||||
</flags>
|
||||
|
||||
<reg name="usp" bitsize="32" type="data_ptr"/>
|
||||
<reg name="isp" bitsize="32" type="data_ptr"/>
|
||||
<reg name="psw" bitsize="32" type="psw_flags"/>
|
||||
<reg name="pc" bitsize="32" type="code_ptr"/>
|
||||
<reg name="intb" bitsize="32" type="data_ptr"/>
|
||||
<reg name="bpsw" bitsize="32" type="psw_flags"/>
|
||||
<reg name="bpc" bitsize="32" type="code_ptr"/>
|
||||
<reg name="fintv" bitsize="32" type="code_ptr"/>
|
||||
<reg name="fpsw" bitsize="32" type="fpsw_flags"/>
|
||||
<reg name="acc" bitsize="64" type="uint64"/>
|
||||
</feature>
|
160
gdb/rx-tdep.c
160
gdb/rx-tdep.c
@ -33,11 +33,15 @@
|
||||
#include "value.h"
|
||||
#include "gdbcore.h"
|
||||
#include "dwarf2-frame.h"
|
||||
#include "remote.h"
|
||||
#include "target-descriptions.h"
|
||||
|
||||
#include "elf/rx.h"
|
||||
#include "elf-bfd.h"
|
||||
#include <algorithm>
|
||||
|
||||
#include "features/rx.c"
|
||||
|
||||
/* Certain important register numbers. */
|
||||
enum
|
||||
{
|
||||
@ -114,117 +118,13 @@ struct rx_prologue
|
||||
int reg_offset[RX_NUM_REGS];
|
||||
};
|
||||
|
||||
/* Implement the "register_name" gdbarch method. */
|
||||
static const char *
|
||||
rx_register_name (struct gdbarch *gdbarch, int regnr)
|
||||
{
|
||||
static const char *const reg_names[] = {
|
||||
"r0",
|
||||
"r1",
|
||||
"r2",
|
||||
"r3",
|
||||
"r4",
|
||||
"r5",
|
||||
"r6",
|
||||
"r7",
|
||||
"r8",
|
||||
"r9",
|
||||
"r10",
|
||||
"r11",
|
||||
"r12",
|
||||
"r13",
|
||||
"r14",
|
||||
"r15",
|
||||
"usp",
|
||||
"isp",
|
||||
"psw",
|
||||
"pc",
|
||||
"intb",
|
||||
"bpsw",
|
||||
"bpc",
|
||||
"fintv",
|
||||
"fpsw",
|
||||
"acc"
|
||||
};
|
||||
|
||||
return reg_names[regnr];
|
||||
}
|
||||
|
||||
/* Construct the flags type for PSW and BPSW. */
|
||||
|
||||
static struct type *
|
||||
rx_psw_type (struct gdbarch *gdbarch)
|
||||
{
|
||||
struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
|
||||
|
||||
if (tdep->rx_psw_type == NULL)
|
||||
{
|
||||
tdep->rx_psw_type = arch_flags_type (gdbarch, "rx_psw_type", 32);
|
||||
append_flags_type_flag (tdep->rx_psw_type, 0, "C");
|
||||
append_flags_type_flag (tdep->rx_psw_type, 1, "Z");
|
||||
append_flags_type_flag (tdep->rx_psw_type, 2, "S");
|
||||
append_flags_type_flag (tdep->rx_psw_type, 3, "O");
|
||||
append_flags_type_flag (tdep->rx_psw_type, 16, "I");
|
||||
append_flags_type_flag (tdep->rx_psw_type, 17, "U");
|
||||
append_flags_type_flag (tdep->rx_psw_type, 20, "PM");
|
||||
append_flags_type_flag (tdep->rx_psw_type, 24, "IPL0");
|
||||
append_flags_type_flag (tdep->rx_psw_type, 25, "IPL1");
|
||||
append_flags_type_flag (tdep->rx_psw_type, 26, "IPL2");
|
||||
append_flags_type_flag (tdep->rx_psw_type, 27, "IPL3");
|
||||
}
|
||||
return tdep->rx_psw_type;
|
||||
}
|
||||
|
||||
/* Construct flags type for FPSW. */
|
||||
|
||||
static struct type *
|
||||
rx_fpsw_type (struct gdbarch *gdbarch)
|
||||
{
|
||||
struct gdbarch_tdep *tdep = gdbarch_tdep (gdbarch);
|
||||
|
||||
if (tdep->rx_fpsw_type == NULL)
|
||||
{
|
||||
tdep->rx_fpsw_type = arch_flags_type (gdbarch, "rx_fpsw_type", 32);
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 0, "RM0");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 1, "RM1");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 2, "CV");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 3, "CO");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 4, "CZ");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 5, "CU");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 6, "CX");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 7, "CE");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 8, "DN");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 10, "EV");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 11, "EO");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 12, "EZ");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 13, "EU");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 14, "EX");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 26, "FV");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 27, "FO");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 28, "FZ");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 29, "FU");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 30, "FX");
|
||||
append_flags_type_flag (tdep->rx_fpsw_type, 31, "FS");
|
||||
}
|
||||
|
||||
return tdep->rx_fpsw_type;
|
||||
}
|
||||
|
||||
/* Implement the "register_type" gdbarch method. */
|
||||
static struct type *
|
||||
rx_register_type (struct gdbarch *gdbarch, int reg_nr)
|
||||
{
|
||||
if (reg_nr == RX_PC_REGNUM)
|
||||
return builtin_type (gdbarch)->builtin_func_ptr;
|
||||
else if (reg_nr == RX_PSW_REGNUM || reg_nr == RX_BPSW_REGNUM)
|
||||
return rx_psw_type (gdbarch);
|
||||
else if (reg_nr == RX_FPSW_REGNUM)
|
||||
return rx_fpsw_type (gdbarch);
|
||||
else if (reg_nr == RX_ACC_REGNUM)
|
||||
return builtin_type (gdbarch)->builtin_unsigned_long_long;
|
||||
else
|
||||
return builtin_type (gdbarch)->builtin_unsigned_long;
|
||||
}
|
||||
/* RX register names */
|
||||
static const char *const rx_register_names[] = {
|
||||
"r0", "r1", "r2", "r3", "r4", "r5", "r6", "r7",
|
||||
"r8", "r9", "r10", "r11", "r12", "r13", "r14", "r15",
|
||||
"usp", "isp", "psw", "pc", "intb", "bpsw","bpc","fintv",
|
||||
"fpsw", "acc",
|
||||
};
|
||||
|
||||
|
||||
/* Function for finding saved registers in a 'struct pv_area'; this
|
||||
@ -1044,6 +944,8 @@ rx_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches)
|
||||
struct gdbarch *gdbarch;
|
||||
struct gdbarch_tdep *tdep;
|
||||
int elf_flags;
|
||||
struct tdesc_arch_data *tdesc_data = NULL;
|
||||
const struct target_desc *tdesc = info.target_desc;
|
||||
|
||||
/* Extract the elf_flags if available. */
|
||||
if (info.abfd != NULL
|
||||
@ -1065,16 +967,42 @@ rx_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches)
|
||||
return arches->gdbarch;
|
||||
}
|
||||
|
||||
/* None found, create a new architecture from the information
|
||||
provided. */
|
||||
if (tdesc == NULL)
|
||||
tdesc = tdesc_rx;
|
||||
|
||||
/* Check any target description for validity. */
|
||||
if (tdesc_has_registers (tdesc))
|
||||
{
|
||||
const struct tdesc_feature *feature;
|
||||
bool valid_p = true;
|
||||
|
||||
feature = tdesc_find_feature (tdesc, "org.gnu.gdb.rx.core");
|
||||
|
||||
if (feature != NULL)
|
||||
{
|
||||
tdesc_data = tdesc_data_alloc ();
|
||||
for (int i = 0; i < RX_NUM_REGS; i++)
|
||||
valid_p &= tdesc_numbered_register (feature, tdesc_data, i,
|
||||
rx_register_names[i]);
|
||||
}
|
||||
|
||||
if (!valid_p)
|
||||
{
|
||||
tdesc_data_cleanup (tdesc_data);
|
||||
return NULL;
|
||||
}
|
||||
}
|
||||
|
||||
gdb_assert(tdesc_data != NULL);
|
||||
|
||||
tdep = XCNEW (struct gdbarch_tdep);
|
||||
gdbarch = gdbarch_alloc (&info, tdep);
|
||||
tdep->elf_flags = elf_flags;
|
||||
|
||||
set_gdbarch_num_regs (gdbarch, RX_NUM_REGS);
|
||||
tdesc_use_registers (gdbarch, tdesc, tdesc_data);
|
||||
|
||||
set_gdbarch_num_pseudo_regs (gdbarch, 0);
|
||||
set_gdbarch_register_name (gdbarch, rx_register_name);
|
||||
set_gdbarch_register_type (gdbarch, rx_register_type);
|
||||
set_gdbarch_pc_regnum (gdbarch, RX_PC_REGNUM);
|
||||
set_gdbarch_sp_regnum (gdbarch, RX_SP_REGNUM);
|
||||
set_gdbarch_inner_than (gdbarch, core_addr_lessthan);
|
||||
@ -1092,6 +1020,7 @@ rx_gdbarch_init (struct gdbarch_info info, struct gdbarch_list *arches)
|
||||
set_gdbarch_ptr_bit (gdbarch, 32);
|
||||
set_gdbarch_float_bit (gdbarch, 32);
|
||||
set_gdbarch_float_format (gdbarch, floatformats_ieee_single);
|
||||
|
||||
if (elf_flags & E_FLAG_RX_64BIT_DOUBLES)
|
||||
{
|
||||
set_gdbarch_double_bit (gdbarch, 64);
|
||||
@ -1132,4 +1061,5 @@ void
|
||||
_initialize_rx_tdep (void)
|
||||
{
|
||||
register_gdbarch_init (bfd_arch_rx, rx_gdbarch_init);
|
||||
initialize_tdesc_rx ();
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user