mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-24 12:35:55 +08:00
232bfb8644
This patch adds support for registers of the Event Based Branching and Performance Monitoring Units for the powerpc linux native and core file targets, and for the powerpc linux server stub. All three EBB registers are accessible. Only a subset of the PMU registers can be accessed through ptrace. Because of this, the PMU registers are enumerated individually in gdbarch_tdep, as opposed to having a single "have_pmu" flag. This is intended to make it easier to add additional PMU registers in the future, since checking a "have_pmu" flag elsewhere in the code would no longer be correct. The tdesc feature is named org.gnu.gdb.power.linux.pmu because of this. It's unclear if it makes sense to save and restore these registers across function calls, since some of them can be modified asynchronously. They are also not tracked in record-replay mode. The kernel can return ENODATA when ptrace is used to get the EBB registers, unless a linux performance event that uses EBB is open in the inferior. For this reason, the "fill" functions in the server stub for the ebb register sets is not implemented. Since gdbserver writes all registers in one go before resuming the inferior, this error would not be detected at the time the user tries to write to one of the registers on the client side, and gdbserver would print out warnings every time it resumes the inferior when no ebb performance event is opened, so there is currently no straightforward way to handle this case. This means the ebb registers in the client-side regcache can become dirty when the user tries to write to them, until the inferior is resumed and stopped again. A related issue is that 'G' packets used to write to unrelated registers will include bad data for the EBB registers if they are unavailable, since no register status information is included in the 'G' packet. This data won't be written to the inferior by the gdbserver stub because the "fill" functions are not implemented, and currently the gdbserver stub doesn't change the status of the registers in its own regcache in response to 'G' packets. Another limitation for the ebb registers is that traceframes don't record if registers are available or not, so if these registers are collected when a tracepoint is hit and the inferior has no ebb event opened, the user will see zero values for all of them, instead of the usual <unavailable>. Because these registers are often unavailable, trying to store them with target_store_registers with -1 for the regno argument (all registers) would almost always fail, so they are ignored in this case. gdb/ChangeLog: 2018-10-26 Edjunior Barbosa Machado <emachado@linux.vnet.ibm.com> Pedro Franco de Carvalho <pedromfc@linux.ibm.com> * arch/ppc-linux-common.h (PPC_LINUX_SIZEOF_EBBREGSET) (PPC_LINUX_SIZEOF_PMUREGSET): Declare. * nat/ppc-linux.h (PPC_FEATURE2_EBB, NT_PPC_EBB, NT_PPC_PMU): Define if not already defined. * features/rs6000/power-ebb.xml: New file. * features/rs6000/power-linux-pmu.xml: New file. * features/rs6000/powerpc-isa207-vsx32l.xml: Include ebb and pmu features. * features/rs6000/powerpc-isa207-vsx64l.xml: Likewise. * features/rs6000/powerpc-isa207-vsx32l.c: Re-generate. * features/rs6000/powerpc-isa207-vsx64l.c: Re-generate. * regformats/rs6000/powerpc-isa207-vsx32l.dat: Re-generate. * regformats/rs6000/powerpc-isa207-vsx64l.dat: Re-generate. * ppc-linux-nat.c (fetch_register, fetch_ppc_registers): Call fetch_regset with ebb and pmu regsets. (store_register, store_ppc_registers): Call store_regset with ebb and pmu regsets. (ppc_linux_nat_target::read_description): Set isa207 field in the features struct if ebb and pmu are avaiable. * ppc-linux-tdep.c (ppc32_regmap_ebb, ppc32_regmap_pmu) (ppc32_linux_ebbregset, ppc32_linux_pmuregset): New globals. (ppc_linux_iterate_over_regset_sections): Call back with the ebb and pmu regsets. (ppc_linux_core_read_description): Check if the pmu section is present and set isa207 in the features struct. * ppc-linux-tdep.h (ppc32_linux_ebbregset) (ppc32_linux_pmuregset): Declare. * ppc-tdep.h (struct gdbarch_tdep) <ppc_mmcr0_regnum>: New field. <ppc_mmcr2_regnum, ppc_siar_regnum, ppc_sdar_regnum>: New fields. <ppc_sier_regnum>: New field. (enum): <PPC_BESCR_REGNUM, PPC_EBBHR_REGNUM, PPC_EBBRR_REGNUM>: New enum values. <PPC_MMCR0_REGNUM, PPC_MMCR2_REGNUM, PPC_SIAR_REGNUM>: New enum values. <PPC_SDAR_REGNUM, PPC_SIER_REGNUM>: New enum values. (PPC_IS_EBB_REGNUM, PPC_IS_PMU_REGNUM): Define. * rs6000-tdep.c (rs6000_gdbarch_init): Look for and validate the ebb and pmu features. gdb/gdbserver/ChangeLog: 2018-10-26 Pedro Franco de Carvalho <pedromfc@linux.ibm.com> * configure.srv (powerpc*-*-linux*): Add rs6000/power-ebb.xml and rs6000/power-linux-pmu.xml to srv_xmlfiles. * linux-ppc-low.c (ppc_store_ebbregset, ppc_fill_pmuregset) (ppc_store_pmuregset): New functions. (ppc_regsets): Add entries for ebb and pmu regsets. (ppc_arch_setup): Set isa207 in features struct if the ebb and pmu regsets are available. Set sizes for these regsets. gdb/doc/ChangeLog: 2018-10-26 Pedro Franco de Carvalho <pedromfc@linux.ibm.com> * gdb.texinfo (PowerPC Features): Describe new features "org.gnu.gdb.power.ebb" and "org.gnu.gdb.power.linux.pmu".
216 lines
12 KiB
C
216 lines
12 KiB
C
/* THIS FILE IS GENERATED. -*- buffer-read-only: t -*- vi:set ro:
|
|
Original: powerpc-isa207-vsx32l.xml */
|
|
|
|
#include "defs.h"
|
|
#include "osabi.h"
|
|
#include "target-descriptions.h"
|
|
|
|
struct target_desc *tdesc_powerpc_isa207_vsx32l;
|
|
static void
|
|
initialize_tdesc_powerpc_isa207_vsx32l (void)
|
|
{
|
|
struct target_desc *result = allocate_target_description ();
|
|
set_tdesc_architecture (result, bfd_scan_arch ("powerpc:common"));
|
|
|
|
struct tdesc_feature *feature;
|
|
|
|
feature = tdesc_create_feature (result, "org.gnu.gdb.power.core");
|
|
tdesc_create_reg (feature, "r0", 0, 1, NULL, 32, "uint32");
|
|
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, "r16", 16, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "r17", 17, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "r18", 18, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "r19", 19, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "r20", 20, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "r21", 21, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "r22", 22, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "r23", 23, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "r24", 24, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "r25", 25, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "r26", 26, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "r27", 27, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "r28", 28, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "r29", 29, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "r30", 30, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "r31", 31, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "pc", 64, 1, NULL, 32, "code_ptr");
|
|
tdesc_create_reg (feature, "msr", 65, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "cr", 66, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "lr", 67, 1, NULL, 32, "code_ptr");
|
|
tdesc_create_reg (feature, "ctr", 68, 1, NULL, 32, "uint32");
|
|
tdesc_create_reg (feature, "xer", 69, 1, NULL, 32, "uint32");
|
|
|
|
feature = tdesc_create_feature (result, "org.gnu.gdb.power.fpu");
|
|
tdesc_create_reg (feature, "f0", 32, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f1", 33, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f2", 34, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f3", 35, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f4", 36, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f5", 37, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f6", 38, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f7", 39, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f8", 40, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f9", 41, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f10", 42, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f11", 43, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f12", 44, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f13", 45, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f14", 46, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f15", 47, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f16", 48, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f17", 49, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f18", 50, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f19", 51, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f20", 52, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f21", 53, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f22", 54, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f23", 55, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f24", 56, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f25", 57, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f26", 58, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f27", 59, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f28", 60, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f29", 61, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f30", 62, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "f31", 63, 1, NULL, 64, "ieee_double");
|
|
tdesc_create_reg (feature, "fpscr", 70, 1, "float", 64, "int");
|
|
|
|
feature = tdesc_create_feature (result, "org.gnu.gdb.power.linux");
|
|
tdesc_create_reg (feature, "orig_r3", 71, 1, NULL, 32, "int");
|
|
tdesc_create_reg (feature, "trap", 72, 1, NULL, 32, "int");
|
|
|
|
feature = tdesc_create_feature (result, "org.gnu.gdb.power.altivec");
|
|
tdesc_type *element_type;
|
|
element_type = tdesc_named_type (feature, "ieee_single");
|
|
tdesc_create_vector (feature, "v4f", element_type, 4);
|
|
|
|
element_type = tdesc_named_type (feature, "int32");
|
|
tdesc_create_vector (feature, "v4i32", element_type, 4);
|
|
|
|
element_type = tdesc_named_type (feature, "int16");
|
|
tdesc_create_vector (feature, "v8i16", element_type, 8);
|
|
|
|
element_type = tdesc_named_type (feature, "int8");
|
|
tdesc_create_vector (feature, "v16i8", element_type, 16);
|
|
|
|
tdesc_type_with_fields *type_with_fields;
|
|
type_with_fields = tdesc_create_union (feature, "vec128");
|
|
tdesc_type *field_type;
|
|
field_type = tdesc_named_type (feature, "uint128");
|
|
tdesc_add_field (type_with_fields, "uint128", field_type);
|
|
field_type = tdesc_named_type (feature, "v4f");
|
|
tdesc_add_field (type_with_fields, "v4_float", field_type);
|
|
field_type = tdesc_named_type (feature, "v4i32");
|
|
tdesc_add_field (type_with_fields, "v4_int32", field_type);
|
|
field_type = tdesc_named_type (feature, "v8i16");
|
|
tdesc_add_field (type_with_fields, "v8_int16", field_type);
|
|
field_type = tdesc_named_type (feature, "v16i8");
|
|
tdesc_add_field (type_with_fields, "v16_int8", field_type);
|
|
|
|
tdesc_create_reg (feature, "vr0", 73, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr1", 74, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr2", 75, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr3", 76, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr4", 77, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr5", 78, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr6", 79, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr7", 80, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr8", 81, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr9", 82, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr10", 83, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr11", 84, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr12", 85, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr13", 86, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr14", 87, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr15", 88, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr16", 89, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr17", 90, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr18", 91, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr19", 92, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr20", 93, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr21", 94, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr22", 95, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr23", 96, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr24", 97, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr25", 98, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr26", 99, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr27", 100, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr28", 101, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr29", 102, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr30", 103, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vr31", 104, 1, NULL, 128, "vec128");
|
|
tdesc_create_reg (feature, "vscr", 105, 1, "vector", 32, "int");
|
|
tdesc_create_reg (feature, "vrsave", 106, 1, "vector", 32, "int");
|
|
|
|
feature = tdesc_create_feature (result, "org.gnu.gdb.power.vsx");
|
|
tdesc_create_reg (feature, "vs0h", 107, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs1h", 108, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs2h", 109, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs3h", 110, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs4h", 111, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs5h", 112, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs6h", 113, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs7h", 114, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs8h", 115, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs9h", 116, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs10h", 117, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs11h", 118, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs12h", 119, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs13h", 120, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs14h", 121, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs15h", 122, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs16h", 123, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs17h", 124, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs18h", 125, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs19h", 126, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs20h", 127, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs21h", 128, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs22h", 129, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs23h", 130, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs24h", 131, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs25h", 132, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs26h", 133, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs27h", 134, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs28h", 135, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs29h", 136, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs30h", 137, 1, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "vs31h", 138, 1, NULL, 64, "uint64");
|
|
|
|
feature = tdesc_create_feature (result, "org.gnu.gdb.power.ppr");
|
|
tdesc_create_reg (feature, "ppr", 139, 1, NULL, 64, "uint64");
|
|
|
|
feature = tdesc_create_feature (result, "org.gnu.gdb.power.dscr");
|
|
tdesc_create_reg (feature, "dscr", 140, 1, NULL, 64, "uint64");
|
|
|
|
feature = tdesc_create_feature (result, "org.gnu.gdb.power.tar");
|
|
tdesc_create_reg (feature, "tar", 141, 1, NULL, 64, "uint64");
|
|
|
|
feature = tdesc_create_feature (result, "org.gnu.gdb.power.ebb");
|
|
tdesc_create_reg (feature, "bescr", 142, 0, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "ebbhr", 143, 0, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "ebbrr", 144, 0, NULL, 64, "uint64");
|
|
|
|
feature = tdesc_create_feature (result, "org.gnu.gdb.power.linux.pmu");
|
|
tdesc_create_reg (feature, "mmcr0", 145, 0, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "mmcr2", 146, 0, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "siar", 147, 0, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "sdar", 148, 0, NULL, 64, "uint64");
|
|
tdesc_create_reg (feature, "sier", 149, 0, NULL, 64, "uint64");
|
|
|
|
tdesc_powerpc_isa207_vsx32l = result;
|
|
}
|