re PR c/25861 (tree check fail at c-common.c:2430)
2006-01-26 Andrew Pinski <pinskia@physics.uc.edu> PR C/25861 * c-common.c (c_common_truthvalue_conversion) <case ADDR_EXPR>: Use a new variable, inner. PARM_DECLs are always non-weak. 2006-01-26 Andrew Pinski <pinskia@physics.uc.edu> PR C/25861 * gcc.c-torture/compile/pr25861.c: New test. From-SVN: r110256
This commit is contained in:
parent
62f3e894c5
commit
f6f083604b
4 changed files with 23 additions and 7 deletions
|
@ -1,3 +1,9 @@
|
|||
2006-01-26 Andrew Pinski <pinskia@physics.uc.edu>
|
||||
|
||||
PR C/25861
|
||||
* c-common.c (c_common_truthvalue_conversion) <case ADDR_EXPR>:
|
||||
Use a new variable, inner. PARM_DECLs are always non-weak.
|
||||
|
||||
2006-01-26 Shantonu Sen <ssen@opendarwin.org>
|
||||
|
||||
* tree.h (OMP_CLAUSE_SUBCODE_CHECK): Add definition for
|
||||
|
|
|
@ -2456,25 +2456,26 @@ c_common_truthvalue_conversion (tree expr)
|
|||
|
||||
case ADDR_EXPR:
|
||||
{
|
||||
if (DECL_P (TREE_OPERAND (expr, 0))
|
||||
&& !DECL_WEAK (TREE_OPERAND (expr, 0)))
|
||||
tree inner = TREE_OPERAND (expr, 0);
|
||||
if (DECL_P (inner)
|
||||
&& (TREE_CODE (inner) == PARM_DECL || !DECL_WEAK (inner)))
|
||||
{
|
||||
/* Common Ada/Pascal programmer's mistake. We always warn
|
||||
about this since it is so bad. */
|
||||
warning (OPT_Walways_true, "the address of %qD, will always evaluate as %<true%>",
|
||||
TREE_OPERAND (expr, 0));
|
||||
inner);
|
||||
return truthvalue_true_node;
|
||||
}
|
||||
|
||||
/* If we are taking the address of an external decl, it might be
|
||||
zero if it is weak, so we cannot optimize. */
|
||||
if (DECL_P (TREE_OPERAND (expr, 0))
|
||||
&& DECL_EXTERNAL (TREE_OPERAND (expr, 0)))
|
||||
if (DECL_P (inner)
|
||||
&& DECL_EXTERNAL (inner))
|
||||
break;
|
||||
|
||||
if (TREE_SIDE_EFFECTS (TREE_OPERAND (expr, 0)))
|
||||
if (TREE_SIDE_EFFECTS (inner))
|
||||
return build2 (COMPOUND_EXPR, truthvalue_type_node,
|
||||
TREE_OPERAND (expr, 0), truthvalue_true_node);
|
||||
inner, truthvalue_true_node);
|
||||
else
|
||||
return truthvalue_true_node;
|
||||
}
|
||||
|
|
|
@ -1,3 +1,8 @@
|
|||
2006-01-26 Andrew Pinski <pinskia@physics.uc.edu>
|
||||
|
||||
PR C/25861
|
||||
* gcc.c-torture/compile/pr25861.c: New test.
|
||||
|
||||
2006-01-26 Paul Brook <paul@codesourcery.com>
|
||||
|
||||
* gcc.dg/compat/struct-layout-1.exp: Pass -e to generator program
|
||||
|
|
4
gcc/testsuite/gcc.c-torture/compile/pr25861.c
Normal file
4
gcc/testsuite/gcc.c-torture/compile/pr25861.c
Normal file
|
@ -0,0 +1,4 @@
|
|||
int f(void *a)
|
||||
{
|
||||
return !(&a);
|
||||
}
|
Loading…
Add table
Reference in a new issue