aboutsummaryrefslogtreecommitdiff
path: root/gcc/cfgexpand.c
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2011-03-16 09:35:31 +0100
committerJakub Jelinek <jakub@gcc.gnu.org>2011-03-16 09:35:31 +0100
commita58a8e4b1f724fdb5edfd09660963404439428f7 (patch)
treee1c308ef8c1fe2a484b5a77d166cb4b3682c3f18 /gcc/cfgexpand.c
parent2b1c543325692d744eec22f779656e13605c3ceb (diff)
downloadgcc-a58a8e4b1f724fdb5edfd09660963404439428f7.zip
gcc-a58a8e4b1f724fdb5edfd09660963404439428f7.tar.gz
gcc-a58a8e4b1f724fdb5edfd09660963404439428f7.tar.bz2
re PR debug/45882 (No debug info for vars depending on unused parameter)
PR debug/45882 * rtl.def (ENTRY_VALUE): Change format from "e" to "0". * rtl.h (ENTRY_VALUE_EXP): Define. * rtl.c (rtx_equal_p_cb, rtx_equal_p): Handle ENTRY_VALUE. * cselib.c (rtx_equal_for_cselib_p, cselib_hash_rtx): Likewise. * print-rtl.c (print_rtx): Likewise. * gengtype.c (adjust_field_rtx_def): Likewise. * var-tracking.c (vt_add_function_parameter): Adjust gen_rtx_ENTRY_VALUE uses, use ENTRY_VALUE_EXP macro. * dwarf2out.c (mem_loc_descriptor): Use ENTRY_VALUE_EXP macro. * cfgexpand.c (expand_debug_expr): If a SSA_NAME without partition is a default definition of a PARM_DECL, use ENTRY_VALUE of its DECL_INCOMING_RTL if possible, or its DECL_RTL if set. * gcc.dg/guality/pr45882.c: New test. From-SVN: r171035
Diffstat (limited to 'gcc/cfgexpand.c')
-rw-r--r--gcc/cfgexpand.c26
1 files changed, 25 insertions, 1 deletions
diff --git a/gcc/cfgexpand.c b/gcc/cfgexpand.c
index 059c5b2..ebe0a03 100644
--- a/gcc/cfgexpand.c
+++ b/gcc/cfgexpand.c
@@ -3171,7 +3171,31 @@ expand_debug_expr (tree exp)
int part = var_to_partition (SA.map, exp);
if (part == NO_PARTITION)
- return NULL;
+ {
+ /* If this is a reference to an incoming value of parameter
+ that is never used in the code or where the incoming
+ value is never used in the code, use PARM_DECL's
+ DECL_RTL if set. */
+ if (SSA_NAME_IS_DEFAULT_DEF (exp)
+ && TREE_CODE (SSA_NAME_VAR (exp)) == PARM_DECL)
+ {
+ rtx incoming = DECL_INCOMING_RTL (SSA_NAME_VAR (exp));
+ if (incoming
+ && GET_MODE (incoming) != BLKmode
+ && (REG_P (incoming)
+ || (MEM_P (incoming) && REG_P (XEXP (incoming, 0)))))
+ {
+ op0 = gen_rtx_ENTRY_VALUE (GET_MODE (incoming));
+ ENTRY_VALUE_EXP (op0) = incoming;
+ goto adjust_mode;
+ }
+ op0 = expand_debug_expr (SSA_NAME_VAR (exp));
+ if (!op0)
+ return NULL;
+ goto adjust_mode;
+ }
+ return NULL;
+ }
gcc_assert (part >= 0 && (unsigned)part < SA.map->num_partitions);