summaryrefslogtreecommitdiff
path: root/gcc/var-tracking.c
diff options
context:
space:
mode:
authorrth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>2007-02-19 16:21:59 +0000
committerrth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>2007-02-19 16:21:59 +0000
commit390189067e8f5fe6e5155e943d38ee264de88de3 (patch)
treebf7902c05a109c05b4b467d6f373afeb6aa67e9e /gcc/var-tracking.c
parent347301d649b114115df434e93448c10964d33c57 (diff)
downloadgcc-390189067e8f5fe6e5155e943d38ee264de88de3.tar.gz
PR debug/29558
* var-tracking.c (track_expr_p): Disallow AGGREGATE_TYPE_P in memory. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@122131 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/var-tracking.c')
-rw-r--r--gcc/var-tracking.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/gcc/var-tracking.c b/gcc/var-tracking.c
index 815facae182..d9f21b5aa21 100644
--- a/gcc/var-tracking.c
+++ b/gcc/var-tracking.c
@@ -1529,7 +1529,8 @@ track_expr_p (tree expr)
if (MEM_P (decl_rtl))
{
/* Do not track structures and arrays. */
- if (GET_MODE (decl_rtl) == BLKmode)
+ if (GET_MODE (decl_rtl) == BLKmode
+ || AGGREGATE_TYPE_P (TREE_TYPE (realdecl)))
return 0;
if (MEM_SIZE (decl_rtl)
&& INTVAL (MEM_SIZE (decl_rtl)) > MAX_VAR_PARTS)