c-convert.c (convert): When converting to a BOOLEAN_TYPE, avoid passing nested NOP_EX...
authorJoseph Myers <jsm28@cam.ac.uk>
Mon, 23 Apr 2001 22:55:32 +0000 (23:55 +0100)
committerJoseph Myers <jsm28@gcc.gnu.org>
Mon, 23 Apr 2001 22:55:32 +0000 (23:55 +0100)
* c-convert.c (convert): When converting to a BOOLEAN_TYPE, avoid
passing nested NOP_EXPRs to fold.

testsuite:
* gcc.c-torture/compile/20010423-1.c: New test.

From-SVN: r41508

gcc/ChangeLog
gcc/c-convert.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.c-torture/compile/20010423-1.c [new file with mode: 0644]

index e3d7ad0d9bb016b06325a44cf2f7a9df603e4f72..fca2bcffc1a1511f9f08902dc2b2144acd1b4102 100644 (file)
@@ -1,3 +1,8 @@
+2001-04-23  Joseph S. Myers  <jsm28@cam.ac.uk>
+
+       * c-convert.c (convert): When converting to a BOOLEAN_TYPE, avoid
+       passing nested NOP_EXPRs to fold.
+
 Mon Apr 23 14:32:12 CEST 2001  Jan Hubicka  <jh@suse.cz>
 
        * reg-stack.c (emit_swap_insn): Do not get pass CALL_INSNs.
index 7f57725b7c16039551a911efcc9d1d7f40c87766..6585f3cb4f638b074d8542949656f3c42c180446 100644 (file)
@@ -89,7 +89,15 @@ convert (type, expr)
   if (code == INTEGER_TYPE || code == ENUMERAL_TYPE)
     return fold (convert_to_integer (type, e));
   if (code == BOOLEAN_TYPE)
-    return fold (build1 (NOP_EXPR, type, truthvalue_conversion (expr)));
+    {
+      tree t = truthvalue_conversion (expr);
+      /* If truthvalue_conversion returns a NOP_EXPR, we must fold it here
+        to avoid infinite recursion between fold () and convert ().  */
+      if (TREE_CODE (t) == NOP_EXPR)
+       return fold (build1 (NOP_EXPR, type, TREE_OPERAND (t, 0)));
+      else
+       return fold (build1 (NOP_EXPR, type, t));
+    }
   if (code == POINTER_TYPE || code == REFERENCE_TYPE)
     return fold (convert_to_pointer (type, e));
   if (code == REAL_TYPE)
index f2c3d70e037d20475ff9471b45a9bef0f0003942..aa168b69cb7713e1404bc0e33ea8d33cffc2a073 100644 (file)
@@ -1,3 +1,7 @@
+2001-04-23  Joseph S. Myers  <jsm28@cam.ac.uk>
+
+       * gcc.c-torture/compile/20010423-1.c: New test.
+
 2001-04-20  Nathan Sidwell  <nathan@codesourcery.com>
 
        * g++.old-deja/g++.pt/typename28.C: New test.
diff --git a/gcc/testsuite/gcc.c-torture/compile/20010423-1.c b/gcc/testsuite/gcc.c-torture/compile/20010423-1.c
new file mode 100644 (file)
index 0000000..ef7771f
--- /dev/null
@@ -0,0 +1,16 @@
+/* Origin: PR c/2618 from Cesar Eduardo Barros <cesarb@nitnet.com.br>,
+   adapted to a testcase by Joseph Myers <jsm28@cam.ac.uk>.
+
+   Boolean conversions were causing infinite recursion between convert
+   and fold in certain cases.  */
+
+#include <stdbool.h>
+
+bool x;
+unsigned char y;
+
+void
+fn (void)
+{
+  x = y & 0x1 ? 1 : 0;
+}