* Fix 16.0 handling. - Patches added: * gdb-testsuite-fix-gdb.python-py-format-string.exp-wi.patch * gdb-testsuite-fix-gdb.python-py-mi-cmd.exp-with-pyth.patch * gdb-testsuite-fix-gdb.ada-mi_task_arg.exp-on-arm-lin.patch * gdb-testsuite-fix-regexp-in-gdb.ada-mi_var_access.ex.patch * gdb-testsuite-check-gnatmake-version-in-gdb.ada-scal.patch * gdb-testsuite-fix-gdb.arch-arm-pseudo-unwind.exp-wit.patch * gdb-symtab-fix-target-type-of-complex-long-double-on.patch * gdb-testsuite-don-t-use-set-auto-solib-add-off.patch * gdb-tdep-fix-arm-thumb2-hw-breakpoint.patch * gdb-testsuite-fix-gdb.cp-m-static.exp-on-arm.patch * gdb-testsuite-fix-gdb.dwarf2-dw2-fixed-point.exp-on-.patch * gdb-testsuite-fix-gdb.dwarf2-dw2-lines.exp-on-arm-li.patch * gdb-exp-fix-gdb.fortran-intrinsics.exp-fail-on-arm.patch * gdb-tdep-handle-sycall-statx-for-arm-linux.patch * gdb-tdep-fix-recording-of-t1-push.patch * gdb-tdep-handle-syscall-clock_gettime64-for-arm-linu.patch * fix-gdb.dwarf2-shortpiece.exp-on-s390x.patch * handle-address-class-annotation-for-s390x-in-some-te.patch * fix-gdb.dap-step-out.exp-on-s390x.patch * use-setvariable-in-gdb.dap-scopes.exp.patch * fix-gdb.base-finish-pretty.exp-on-s390x.patch * fix-gdb.base-readnever.exp-on-s390x.patch * add-dwarf_expr_piece.op.patch * add-gdbarch_dwarf2_reg_piece_offset-hook.patch * fix-gdb.base-store.exp-on-s390x.patch * fix-gdb.ada-o2_float_param.exp-on-s390x-linux.patch * gdb-testsuite-fix-gdb.base-branch-to-self.exp-on-arm.patch * gdb-tdep-fix-gdb.cp-non-trivial-retval.exp-on-riscv6.patch * gdb-testsuite-fix-gdb.cp-non-trivial-retval.exp-on-a.patch * gdb-testsuite-fix-gdb.rust-completion.exp-timeout-on.patch * gdb-testsuite-require-supports_process_record-in-gdb.patch * gdb-testsuite-fix-regexp-in-gdb.arch-i386-disp-step-.patch * gdb-testsuite-fix-gdb.arch-arm-single-step-kernel-he.patch * gdb-testsuite-fix-gdb.python-py-format-address.exp-o.patch * gdb-testsuite-fix-gdb.arch-riscv-tdesc-regs.exp.patch * gdb-testsuite-fix-gdb.base-list-dot-nodebug-and-make.patch * gdb-testsuite-fix-gdb.base-list-dot-nodebug.exp-on-o.patch * gdb-testsuite-fix-gdb.base-empty-host-env-vars.exp.patch * gdb-prune-inferior-after-switching-inferior.patch * gdb-testsuite-use-nostdlib-in-gdb.base-list-dot-node.patch * gdb-testsuite-fix-timeout-in-gdb.mi-mi-multi-command.patch * gdb-testsuite-require-can_spawn_for_attach-in-gdb.ba.patch * fixup-gdb-6.5-gcore-buffer-limit-test.patch * gdb-testsuite-fix-gdb.ada-big_packed_array.exp-on-s3.patch * gdb-testsuite-fix-gdb.ada-convvar_comp.exp-on-s390x-.patch * gdb-testsuite-fix-regexp-in-gdb.threads-stepi-over-c.patch OBS-URL: https://build.opensuse.org/package/show/devel:gcc/gdb?expand=0&rev=437
101 lines
3.3 KiB
Diff
101 lines
3.3 KiB
Diff
From 89cf6ba4a207f5342db58d9e43178ae516cc220e Mon Sep 17 00:00:00 2001
|
|
From: Tom de Vries <tdevries@suse.de>
|
|
Date: Wed, 15 Jan 2025 17:02:00 +0100
|
|
Subject: [PATCH 23/46] Add dwarf_expr_piece.op
|
|
|
|
Add a new field "dwarf_location_atom op" to dwarf_expr_piece to keep track of
|
|
which dwarf_location_atom caused a dwarf_expr_piece to be added.
|
|
|
|
This is used in the following patch.
|
|
|
|
Tested on s390x-linux.
|
|
|
|
Approved-By: Tom Tromey <tom@tromey.com>
|
|
---
|
|
gdb/dwarf2/expr.c | 10 ++++++----
|
|
gdb/dwarf2/expr.h | 6 +++++-
|
|
2 files changed, 11 insertions(+), 5 deletions(-)
|
|
|
|
diff --git a/gdb/dwarf2/expr.c b/gdb/dwarf2/expr.c
|
|
index cb80dbf60b1..03107f90575 100644
|
|
--- a/gdb/dwarf2/expr.c
|
|
+++ b/gdb/dwarf2/expr.c
|
|
@@ -1198,13 +1198,15 @@ dwarf_expr_context::stack_empty_p () const
|
|
|
|
/* Add a new piece to the dwarf_expr_context's piece list. */
|
|
void
|
|
-dwarf_expr_context::add_piece (ULONGEST size, ULONGEST offset)
|
|
+dwarf_expr_context::add_piece (ULONGEST size, ULONGEST offset,
|
|
+ enum dwarf_location_atom op)
|
|
{
|
|
dwarf_expr_piece &p = this->m_pieces.emplace_back ();
|
|
|
|
p.location = this->m_location;
|
|
p.size = size;
|
|
p.offset = offset;
|
|
+ p.op = op;
|
|
|
|
if (p.location == DWARF_VALUE_LITERAL)
|
|
{
|
|
@@ -2169,7 +2171,7 @@ dwarf_expr_context::execute_stack_op (const gdb_byte *op_ptr,
|
|
|
|
/* Record the piece. */
|
|
op_ptr = safe_read_uleb128 (op_ptr, op_end, &size);
|
|
- add_piece (8 * size, 0);
|
|
+ add_piece (8 * size, 0, op);
|
|
|
|
/* Pop off the address/regnum, and reset the location
|
|
type. */
|
|
@@ -2187,7 +2189,7 @@ dwarf_expr_context::execute_stack_op (const gdb_byte *op_ptr,
|
|
/* Record the piece. */
|
|
op_ptr = safe_read_uleb128 (op_ptr, op_end, &size);
|
|
op_ptr = safe_read_uleb128 (op_ptr, op_end, &uleb_offset);
|
|
- add_piece (size, uleb_offset);
|
|
+ add_piece (size, uleb_offset, op);
|
|
|
|
/* Pop off the address/regnum, and reset the location
|
|
type. */
|
|
@@ -2389,7 +2391,7 @@ dwarf_expr_context::execute_stack_op (const gdb_byte *op_ptr,
|
|
pointer, then make a pieced value. This is ok because we can't
|
|
have implicit pointers in contexts where pieces are invalid. */
|
|
if (this->m_location == DWARF_VALUE_IMPLICIT_POINTER)
|
|
- add_piece (8 * this->m_addr_size, 0);
|
|
+ add_piece (8 * this->m_addr_size, 0, DW_OP_implicit_pointer);
|
|
|
|
this->m_recursion_depth--;
|
|
gdb_assert (this->m_recursion_depth >= 0);
|
|
diff --git a/gdb/dwarf2/expr.h b/gdb/dwarf2/expr.h
|
|
index b02cc531640..957c58f30c4 100644
|
|
--- a/gdb/dwarf2/expr.h
|
|
+++ b/gdb/dwarf2/expr.h
|
|
@@ -24,6 +24,7 @@
|
|
|
|
#include "leb128.h"
|
|
#include "dwarf2/call-site.h"
|
|
+#include "dwarf2.h"
|
|
|
|
struct dwarf2_per_objfile;
|
|
|
|
@@ -54,6 +55,9 @@ enum dwarf_value_location
|
|
/* A piece of an object, as recorded by DW_OP_piece or DW_OP_bit_piece. */
|
|
struct dwarf_expr_piece
|
|
{
|
|
+ /* The DWARF operation for which the piece was created. */
|
|
+ enum dwarf_location_atom op;
|
|
+
|
|
enum dwarf_value_location location;
|
|
|
|
union
|
|
@@ -208,7 +212,7 @@ struct dwarf_expr_context
|
|
struct type *address_type () const;
|
|
void push (struct value *value, bool in_stack_memory);
|
|
bool stack_empty_p () const;
|
|
- void add_piece (ULONGEST size, ULONGEST offset);
|
|
+ void add_piece (ULONGEST size, ULONGEST offset, enum dwarf_location_atom op);
|
|
void execute_stack_op (const gdb_byte *op_ptr, const gdb_byte *op_end);
|
|
void pop ();
|
|
struct value *fetch (int n);
|
|
--
|
|
2.43.0
|
|
|