Commit d837d73d by Richard Guenther Committed by Richard Biener

re PR middle-end/50700 (__builtin_object_size computed wrong)

2011-10-12  Richard Guenther  <rguenther@suse.de>

	PR tree-optimization/50700
	* tree-object-size.c (addr_object_size): Simplify and treat
	MEM_REF bases consistently.

	* gcc.dg/builtin-object-size-12.c: New testcase.

From-SVN: r179850
parent 39d52ae5
2011-10-12 Richard Guenther <rguenther@suse.de>
PR tree-optimization/50700
* tree-object-size.c (addr_object_size): Simplify and treat
MEM_REF bases consistently.
2011-10-12 Bernd Schmidt <bernds@codesourcery.com> 2011-10-12 Bernd Schmidt <bernds@codesourcery.com>
* function.c (prepare_shrink_wrap, bb_active_p): New function. * function.c (prepare_shrink_wrap, bb_active_p): New function.
2011-10-12 Richard Guenther <rguenther@suse.de>
PR tree-optimization/50700
* gcc.dg/builtin-object-size-12.c: New testcase.
2011-10-12 Joseph Myers <joseph@codesourcery.com> 2011-10-12 Joseph Myers <joseph@codesourcery.com>
PR c/50565 PR c/50565
......
/* { dg-do run } */
/* { dg-options "-O2" } */
extern void abort (void);
struct S {
int len;
char s[0];
};
int main()
{
char buf[sizeof (struct S) + 32];
if (__builtin_object_size (((struct S *)&buf[0])->s, 1) != 32)
abort ();
if (__builtin_object_size (((struct S *)&buf[1])->s, 1) != 31)
abort ();
if (__builtin_object_size (((struct S *)&buf[64])->s, 0) != 0)
abort ();
return 0;
}
...@@ -166,24 +166,19 @@ addr_object_size (struct object_size_info *osi, const_tree ptr, ...@@ -166,24 +166,19 @@ addr_object_size (struct object_size_info *osi, const_tree ptr,
gcc_assert (TREE_CODE (ptr) == ADDR_EXPR); gcc_assert (TREE_CODE (ptr) == ADDR_EXPR);
pt_var = TREE_OPERAND (ptr, 0); pt_var = TREE_OPERAND (ptr, 0);
if (REFERENCE_CLASS_P (pt_var)) while (handled_component_p (pt_var))
pt_var = get_base_address (pt_var); pt_var = TREE_OPERAND (pt_var, 0);
if (pt_var if (pt_var
&& TREE_CODE (pt_var) == MEM_REF && TREE_CODE (pt_var) == MEM_REF)
&& TREE_CODE (TREE_OPERAND (pt_var, 0)) == SSA_NAME
&& POINTER_TYPE_P (TREE_TYPE (TREE_OPERAND (pt_var, 0))))
{ {
unsigned HOST_WIDE_INT sz; unsigned HOST_WIDE_INT sz;
if (!osi || (object_size_type & 1) != 0) if (!osi || (object_size_type & 1) != 0
|| TREE_CODE (pt_var) != SSA_NAME)
{ {
sz = compute_builtin_object_size (TREE_OPERAND (pt_var, 0), sz = compute_builtin_object_size (TREE_OPERAND (pt_var, 0),
object_size_type & ~1); object_size_type & ~1);
if (host_integerp (TREE_OPERAND (pt_var, 1), 0))
sz -= TREE_INT_CST_LOW (TREE_OPERAND (pt_var, 1));
else
sz = offset_limit;
} }
else else
{ {
...@@ -195,10 +190,17 @@ addr_object_size (struct object_size_info *osi, const_tree ptr, ...@@ -195,10 +190,17 @@ addr_object_size (struct object_size_info *osi, const_tree ptr,
sz = object_sizes[object_size_type][SSA_NAME_VERSION (var)]; sz = object_sizes[object_size_type][SSA_NAME_VERSION (var)];
else else
sz = unknown[object_size_type]; sz = unknown[object_size_type];
if (host_integerp (TREE_OPERAND (pt_var, 1), 0)) }
sz -= TREE_INT_CST_LOW (TREE_OPERAND (pt_var, 1)); if (sz != unknown[object_size_type])
{
double_int dsz = double_int_sub (uhwi_to_double_int (sz),
mem_ref_offset (pt_var));
if (double_int_negative_p (dsz))
sz = 0;
else if (double_int_fits_in_uhwi_p (dsz))
sz = double_int_to_uhwi (dsz);
else else
sz = offset_limit; sz = unknown[object_size_type];
} }
if (sz != unknown[object_size_type] && sz < offset_limit) if (sz != unknown[object_size_type] && sz < offset_limit)
...@@ -211,7 +213,7 @@ addr_object_size (struct object_size_info *osi, const_tree ptr, ...@@ -211,7 +213,7 @@ addr_object_size (struct object_size_info *osi, const_tree ptr,
tree_low_cst (DECL_SIZE_UNIT (pt_var), 1) < offset_limit) tree_low_cst (DECL_SIZE_UNIT (pt_var), 1) < offset_limit)
pt_var_size = DECL_SIZE_UNIT (pt_var); pt_var_size = DECL_SIZE_UNIT (pt_var);
else if (pt_var else if (pt_var
&& (SSA_VAR_P (pt_var) || TREE_CODE (pt_var) == STRING_CST) && TREE_CODE (pt_var) == STRING_CST
&& TYPE_SIZE_UNIT (TREE_TYPE (pt_var)) && TYPE_SIZE_UNIT (TREE_TYPE (pt_var))
&& host_integerp (TYPE_SIZE_UNIT (TREE_TYPE (pt_var)), 1) && host_integerp (TYPE_SIZE_UNIT (TREE_TYPE (pt_var)), 1)
&& (unsigned HOST_WIDE_INT) && (unsigned HOST_WIDE_INT)
......
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