OSDN Git Service

2006-01-26 Andrew Pinski <pinskia@physics.uc.edu>
authorpinskia <pinskia@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 26 Jan 2006 14:59:26 +0000 (14:59 +0000)
committerpinskia <pinskia@138bc75d-0d04-0410-961f-82ee72b054a4>
Thu, 26 Jan 2006 14:59:26 +0000 (14:59 +0000)
        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.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@110256 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/c-common.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.c-torture/compile/pr25861.c [new file with mode: 0644]

index 71144c3..f925b00 100644 (file)
@@ -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
index 60035ea..fe99dfb 100644 (file)
@@ -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;
       }
index dde3de8..0042b36 100644 (file)
@@ -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
diff --git a/gcc/testsuite/gcc.c-torture/compile/pr25861.c b/gcc/testsuite/gcc.c-torture/compile/pr25861.c
new file mode 100644 (file)
index 0000000..cdd8efb
--- /dev/null
@@ -0,0 +1,4 @@
+int f(void *a)
+{
+  return !(&a);
+}