aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog11
-rw-r--r--gcc/dwarf2out.c11
-rw-r--r--gcc/function.c10
3 files changed, 29 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 5182971..3e4a511 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,14 @@
+2011-03-17 Jakub Jelinek <jakub@redhat.com>
+
+ PR debug/48163
+ * function.c (assign_parms): For data.passed_pointer parms
+ use MEM of data.entry_parm instead of data.entry_parm itself
+ as DECL_INCOMING_RTL.
+ * dwarf2out.c (rtl_for_decl_location): Use DECL_INCOMING_RTL
+ also when passed and declared mode is the same, DECL_RTL
+ is a MEM with pseudo as address and DECL_INCOMING_RTL is
+ a MEM too.
+
2011-03-16 Jeff Law <law@redhat.com>
PR rtl-optimization/37273
diff --git a/gcc/dwarf2out.c b/gcc/dwarf2out.c
index f62bb48..31d9a0e 100644
--- a/gcc/dwarf2out.c
+++ b/gcc/dwarf2out.c
@@ -16721,7 +16721,13 @@ rtl_for_decl_location (tree decl)
}
else if (TREE_CODE (decl) == PARM_DECL)
{
- if (rtl == NULL_RTX || is_pseudo_reg (rtl))
+ if (rtl == NULL_RTX
+ || is_pseudo_reg (rtl)
+ || (MEM_P (rtl)
+ && is_pseudo_reg (XEXP (rtl, 0))
+ && DECL_INCOMING_RTL (decl)
+ && MEM_P (DECL_INCOMING_RTL (decl))
+ && GET_MODE (rtl) == GET_MODE (DECL_INCOMING_RTL (decl))))
{
tree declared_type = TREE_TYPE (decl);
tree passed_type = DECL_ARG_TYPE (decl);
@@ -16733,7 +16739,8 @@ rtl_for_decl_location (tree decl)
all cases where (rtl == NULL_RTX) just below. */
if (dmode == pmode)
rtl = DECL_INCOMING_RTL (decl);
- else if (SCALAR_INT_MODE_P (dmode)
+ else if ((rtl == NULL_RTX || is_pseudo_reg (rtl))
+ && SCALAR_INT_MODE_P (dmode)
&& GET_MODE_SIZE (dmode) <= GET_MODE_SIZE (pmode)
&& DECL_INCOMING_RTL (decl))
{
diff --git a/gcc/function.c b/gcc/function.c
index 1f7722c..64950a1 100644
--- a/gcc/function.c
+++ b/gcc/function.c
@@ -3403,7 +3403,15 @@ assign_parms (tree fndecl)
}
/* Record permanently how this parm was passed. */
- set_decl_incoming_rtl (parm, data.entry_parm, data.passed_pointer);
+ if (data.passed_pointer)
+ {
+ rtx incoming_rtl
+ = gen_rtx_MEM (TYPE_MODE (TREE_TYPE (data.passed_type)),
+ data.entry_parm);
+ set_decl_incoming_rtl (parm, incoming_rtl, true);
+ }
+ else
+ set_decl_incoming_rtl (parm, data.entry_parm, false);
/* Update info on where next arg arrives in registers. */
targetm.calls.function_arg_advance (&all.args_so_far, data.promoted_mode,