aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRichard Guenther <rguenther@suse.de>2011-03-17 13:19:01 +0000
committerRichard Biener <rguenth@gcc.gnu.org>2011-03-17 13:19:01 +0000
commitf8bce518af5367b22e543127f49e8fd970c3fc5e (patch)
tree36741b7951efb09388d608d6af36baf18b06a2d1 /gcc
parentbb1f792960e1dd896529286d2d2302491959d591 (diff)
downloadgcc-f8bce518af5367b22e543127f49e8fd970c3fc5e.zip
gcc-f8bce518af5367b22e543127f49e8fd970c3fc5e.tar.gz
gcc-f8bce518af5367b22e543127f49e8fd970c3fc5e.tar.bz2
re PR tree-optimization/48165 (gcc-4.6: internal compiler error: in build2_stat)
2011-03-17 Richard Guenther <rguenther@suse.de> PR middle-end/48165 * tree-object-size.c (compute_object_offset): Properly return the offset operand of MEM_REFs as sizetype. * g++.dg/torture/pr48165.C: New testcase. From-SVN: r171092
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/g++.dg/torture/pr48165.C38
-rw-r--r--gcc/tree-object-size.c2
4 files changed, 50 insertions, 1 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index fce8c0a..cfb20ed 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2011-03-17 Richard Guenther <rguenther@suse.de>
+
+ PR middle-end/48165
+ * tree-object-size.c (compute_object_offset): Properly return
+ the offset operand of MEM_REFs as sizetype.
+
2011-03-17 Jakub Jelinek <jakub@redhat.com>
PR rtl-optimization/48141
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index b76cd47..a7d8749 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2011-03-17 Richard Guenther <rguenther@suse.de>
+
+ PR middle-end/48165
+ * g++.dg/torture/pr48165.C: New testcase.
+
2011-03-17 Jakub Jelinek <jakub@redhat.com>
PR rtl-optimization/48141
diff --git a/gcc/testsuite/g++.dg/torture/pr48165.C b/gcc/testsuite/g++.dg/torture/pr48165.C
new file mode 100644
index 0000000..a42893f
--- /dev/null
+++ b/gcc/testsuite/g++.dg/torture/pr48165.C
@@ -0,0 +1,38 @@
+/* { dg-do compile } */
+
+typedef __SIZE_TYPE__ size_t;
+
+extern "C" {
+ extern __inline __attribute__ ((__always_inline__))
+ __attribute__ ((__gnu_inline__, __artificial__)) void *
+ memcpy (void *__restrict __dest, __const void *__restrict __src,
+ size_t __len) throw ()
+ {
+ return __builtin___memcpy_chk (__dest, __src, __len,
+ __builtin_object_size (__dest, 0));
+ }
+}
+
+typedef char TCODE[20];
+typedef TCODE TCODE_ARRAY[5];
+typedef struct PARAM
+{
+ TCODE_ARRAY tcode;
+} PARAM;
+
+static void foo (void* p)
+{
+ char buffer[4+sizeof(PARAM)];
+ PARAM *param = (PARAM *)(buffer + 4);
+ int i;
+
+ for (i=0; i < 5; i++)
+ {
+ memcpy( param->tcode[i], p, 20 );
+ }
+}
+
+void bar (void* p)
+{
+ foo (p);
+}
diff --git a/gcc/tree-object-size.c b/gcc/tree-object-size.c
index 23abcfe..6a74d19 100644
--- a/gcc/tree-object-size.c
+++ b/gcc/tree-object-size.c
@@ -143,7 +143,7 @@ compute_object_offset (const_tree expr, const_tree var)
case MEM_REF:
gcc_assert (TREE_CODE (TREE_OPERAND (expr, 0)) == ADDR_EXPR);
- return TREE_OPERAND (expr, 1);
+ return double_int_to_tree (sizetype, mem_ref_offset (expr));
default:
return error_mark_node;