Commit f8bce518 by Richard Guenther Committed by Richard Biener

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
parent bb1f7929
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
......
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
......
/* { 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);
}
......@@ -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;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment