This is the mail archive of the
gcc-patches@gcc.gnu.org
mailing list for the GCC project.
[PATCH] Instantiate DECL_RTLs in DECL_VALUE_EXPRs of arguments and block vars (PR debug/25562) (take 2)
- From: Jakub Jelinek <jakub at redhat dot com>
- To: gcc-patches at gcc dot gnu dot org
- Date: Sat, 31 Dec 2005 07:38:12 -0500
- Subject: [PATCH] Instantiate DECL_RTLs in DECL_VALUE_EXPRs of arguments and block vars (PR debug/25562) (take 2)
- References: <20051228115903.GR22293@devserv.devel.redhat.com>
- Reply-to: Jakub Jelinek <jakub at redhat dot com>
On Wed, Dec 28, 2005 at 06:59:04AM -0500, Jakub Jelinek wrote:
> The second problem is why the address operand couldn't be represented.
> The VLA (t in this testcase) has DECL_VALUE_EXPR *(t.1) and t.1 is a compiler
> generated temporary pointer. When not optimizing, t.1 is stored on the
> stack, with (mem/f/c/i:DI (plus:DI (reg/f:DI 54 virtual-stack-vars)
> (const_int -16 [0xfffffffffffffff0])) [0 t.1+0 S8 A64])
> as DECL_RTL. In GCC 4.0.x, rtl sharing caused t.1's DECL_RTL to be
> instantiated during instantiate_virtual_regs time, when instantiating
> some insn that set t.1. But virtual reg instantiation changed since then
> and the rtl is apparently no longer shared between DECL_RTL and the insn
> that sets it. The function.c part of the following patch fixes that by
> instatiating virtual regs in DECL_RTLs of decls used in DECL_VALUE_EXPR
> of block vars and arguments in addition to DECL_RTLs of the block vars.
Bootstrapping on i386-linux revealed a minor bug in the patch, particularly
that DECL_HAS_VALUE_EXPR_P use in instantiate_decls_1 should be guarded
with TREE_CODE (t) == VAR_DECL.
Here is the updated patch, bootstrapped/regtested on i386-linux/trunk.
x86_64-linux/trunk and ppc64-linux/4.1 bootstraps are in progress.
Ok for 4.1/trunk?
2005-12-31 Jakub Jelinek <jakub@redhat.com>
PR debug/25562
* function.c (instantiate_expr): New function.
(instantiate_decls_1, instantiate_decls): If DECL_HAS_VALUE_EXPR_P,
walk its DECL_VALUE_EXPR with instantiate_expr.
* dwarf2out.c (loc_descriptor_from_tree_1): Don't add
DW_OP_deref{,_size} if address isn't going to be added.
--- gcc/function.c.jj 2005-12-20 13:43:56.000000000 +0100
+++ gcc/function.c 2005-12-31 13:14:17.000000000 +0100
@@ -1590,6 +1590,22 @@ instantiate_decl (rtx x)
for_each_rtx (&XEXP (x, 0), instantiate_virtual_regs_in_rtx, NULL);
}
+/* Helper for instantiate_decls called via walk_tree: Process all decls
+ in the given DECL_VALUE_EXPR. */
+
+static tree
+instantiate_expr (tree *tp, int *walk_subtrees, void *data ATTRIBUTE_UNUSED)
+{
+ tree t = *tp;
+ if (! EXPR_P (t))
+ {
+ *walk_subtrees = 0;
+ if (DECL_P (t) && DECL_RTL_SET_P (t))
+ instantiate_decl (DECL_RTL (t));
+ }
+ return NULL;
+}
+
/* Subroutine of instantiate_decls: Process all decls in the given
BLOCK node and all its subblocks. */
@@ -1599,8 +1615,15 @@ instantiate_decls_1 (tree let)
tree t;
for (t = BLOCK_VARS (let); t; t = TREE_CHAIN (t))
- if (DECL_RTL_SET_P (t))
- instantiate_decl (DECL_RTL (t));
+ {
+ if (DECL_RTL_SET_P (t))
+ instantiate_decl (DECL_RTL (t));
+ if (TREE_CODE (t) == VAR_DECL && DECL_HAS_VALUE_EXPR_P (t))
+ {
+ tree v = DECL_VALUE_EXPR (t);
+ walk_tree (&v, instantiate_expr, NULL, NULL);
+ }
+ }
/* Process all subblocks. */
for (t = BLOCK_SUBBLOCKS (let); t; t = TREE_CHAIN (t))
@@ -1620,6 +1643,11 @@ instantiate_decls (tree fndecl)
{
instantiate_decl (DECL_RTL (decl));
instantiate_decl (DECL_INCOMING_RTL (decl));
+ if (DECL_HAS_VALUE_EXPR_P (decl))
+ {
+ tree v = DECL_VALUE_EXPR (decl);
+ walk_tree (&v, instantiate_expr, NULL, NULL);
+ }
}
/* Now process all variables defined in the function or its subblocks. */
--- gcc/dwarf2out.c.jj 2005-12-20 13:43:56.000000000 +0100
+++ gcc/dwarf2out.c 2005-12-28 11:44:45.000000000 +0100
@@ -9420,7 +9420,7 @@ loc_descriptor_from_tree_1 (tree loc, in
return 0;
/* If we've got an address and don't want one, dereference. */
- if (!want_address && have_address)
+ if (!want_address && have_address && ret)
{
HOST_WIDE_INT size = int_size_in_bytes (TREE_TYPE (loc));
Jakub