File pr29558.patch of Package gcc41

Subject: Bug 29558

Author: rth
Date: Mon Feb 19 16:21:59 2007
New Revision: 122131

URL: http://gcc.gnu.org/viewcvs?root=gcc&view=rev&rev=122131
Log:
        PR debug/29558
        * var-tracking.c (track_expr_p): Disallow AGGREGATE_TYPE_P
        in memory.

Added:
    trunk/gcc/testsuite/gcc.dg/debug/pr29558.c
Modified:
    trunk/gcc/ChangeLog
    trunk/gcc/var-tracking.c

Index: gcc/var-tracking.c
===================================================================
--- gcc/var-tracking.c.orig	2009-11-20 13:41:33.000000000 +0100
+++ gcc/var-tracking.c	2009-11-20 13:41:46.000000000 +0100
@@ -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)
Index: gcc/testsuite/gcc.dg/debug/pr29558.c
===================================================================
--- /dev/null	1970-01-01 00:00:00.000000000 +0000
+++ gcc/testsuite/gcc.dg/debug/pr29558.c	2009-11-20 13:41:46.000000000 +0100
@@ -0,0 +1,30 @@
+/* { dg-do compile } */
+
+void stpi_unpack_16_1(int length, unsigned char *out, unsigned char bit)
+{
+  unsigned char tempin;
+  unsigned char temp[16];
+  for (bit = 128; length > 0; length--) {
+    if (tempin & 128)
+      temp[0] |= bit;
+    else
+      {
+        *out++ = temp[1];
+        *out++ = temp[2];
+        *out++ = temp[3];
+        *out++ = temp[4];
+        *out++ = temp[5];
+        *out++ = temp[6];
+        *out++ = temp[7];
+        *out++ = temp[9];
+        *out++ = temp[10];
+        *out++ = temp[11];
+        *out++ = temp[12];
+        *out++ = temp[13];
+        *out++ = temp[14];
+        *out++ = temp[15];
+        __builtin_memset (temp, 0, 16);
+     }
+  }
+}
+
openSUSE Build Service is sponsored by