mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2024-11-23 18:14:13 +08:00
d2f8a107b7
There is a single declaration of set_tdesc_osabi that is shared between gdbserver/ and gdb/, this declaration takes a 'const char *' argument which is the string representing an osabi. Then in gdb/ we have an overload of set_tdesc_osabi which takes an 'enum gdb_osabi'. In this commit I change the shared set_tdesc_osabi to be the version which takes an 'enum gdb_osabi', and I remove the version which takes a 'const char *'. All users of set_tdesc_osabi are updated to pass an 'enum gdb_osabi'. The features/ code, which is generated from the xml files, requires a new function to be added to osabi.{c,h} which can return a string representation of an 'enum gdb_osabi'. With that new function in place the features/ code is regenerated. This change is being made to support the next commit. In the next commit gdbserver will be updated to call set_tdesc_osabi in more cases. The problem is that gdbserver stores the osabi as a string. The issue here is that a typo in the gdbserver/ code might go unnoticed and result in gdbserver sending back an invalid osabi string. To fix this we want gdbserver to pass an 'enum gdb_osabi' to the set_tdesc_osabi function. With that requirement in place it seems to make sense if all calls to set_tdesc_osabi pass an 'enum gdb_osabi'. There should be no user visible changes after this commit. Approved-By: Luis Machado <luis.machado@arm.com> Approved-By: Simon Marchi <simon.marchi@efficios.com>
78 lines
3.6 KiB
C
78 lines
3.6 KiB
C
/* THIS FILE IS GENERATED. -*- buffer-read-only: t -*- vi:set ro:
|
|
Original: or1k-linux.xml */
|
|
|
|
#include "osabi.h"
|
|
#include "target-descriptions.h"
|
|
|
|
const struct target_desc *tdesc_or1k_linux;
|
|
static void
|
|
initialize_tdesc_or1k_linux (void)
|
|
{
|
|
target_desc_up result = allocate_target_description ();
|
|
set_tdesc_architecture (result.get (), bfd_scan_arch ("or1k"));
|
|
|
|
set_tdesc_osabi (result.get (), GDB_OSABI_LINUX);
|
|
|
|
struct tdesc_feature *feature;
|
|
|
|
feature = tdesc_create_feature (result.get (), "org.gnu.gdb.or1k.group0");
|
|
tdesc_type_with_fields *type_with_fields;
|
|
type_with_fields = tdesc_create_flags (feature, "sr_flags", 4);
|
|
tdesc_add_flag (type_with_fields, 0, "SM");
|
|
tdesc_add_flag (type_with_fields, 1, "TEE");
|
|
tdesc_add_flag (type_with_fields, 2, "IEE");
|
|
tdesc_add_flag (type_with_fields, 3, "DCE");
|
|
tdesc_add_flag (type_with_fields, 4, "ICE");
|
|
tdesc_add_flag (type_with_fields, 5, "DME");
|
|
tdesc_add_flag (type_with_fields, 6, "IME");
|
|
tdesc_add_flag (type_with_fields, 7, "LEE");
|
|
tdesc_add_flag (type_with_fields, 8, "CE");
|
|
tdesc_add_flag (type_with_fields, 9, "F");
|
|
tdesc_add_flag (type_with_fields, 10, "CY");
|
|
tdesc_add_flag (type_with_fields, 11, "OV");
|
|
tdesc_add_flag (type_with_fields, 12, "OVE");
|
|
tdesc_add_flag (type_with_fields, 13, "DSX");
|
|
tdesc_add_flag (type_with_fields, 14, "EPH");
|
|
tdesc_add_flag (type_with_fields, 15, "FO");
|
|
tdesc_add_flag (type_with_fields, 16, "SUMRA");
|
|
tdesc_add_bitfield (type_with_fields, "CID", 28, 31);
|
|
|
|
tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r1", 1, 1, NULL, 32, "data_ptr");
|
|
tdesc_create_reg (feature, "r2", 2, 1, NULL, 32, "data_ptr");
|
|
tdesc_create_reg (feature, "r3", 3, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r4", 4, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r5", 5, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r6", 6, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r7", 7, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r8", 8, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r9", 9, 1, NULL, 32, "code_ptr");
|
|
tdesc_create_reg (feature, "r10", 10, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r11", 11, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r12", 12, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r13", 13, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r14", 14, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r15", 15, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r16", 16, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r17", 17, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r18", 18, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r19", 19, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r20", 20, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r21", 21, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r22", 22, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r23", 23, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r24", 24, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r25", 25, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r26", 26, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r27", 27, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r28", 28, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r29", 29, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r30", 30, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "r31", 31, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "ppc", 32, 1, NULL, 32, "code_ptr");
|
|
tdesc_create_reg (feature, "npc", 33, 1, NULL, 32, "code_ptr");
|
|
tdesc_create_reg (feature, "sr", 34, 1, NULL, 32, "sr_flags");
|
|
|
|
tdesc_or1k_linux = result.release ();
|
|
}
|