Blame SOURCES/gcc32-pr19005.patch

6f1b0c
2005-05-13  Jakub Jelinek  <jakub@redhat.com>
6f1b0c
6f1b0c
	PR target/19005
6f1b0c
	* config/i386/i386.md (swapqi): Use +q instead of +r constraints.
6f1b0c
6f1b0c
	* gcc.c-torture/execute/pr19005.c: New test.
6f1b0c
6f1b0c
--- gcc/config/i386/i386.md.jj	2004-07-01 12:40:54.000000000 +0200
6f1b0c
+++ gcc/config/i386/i386.md	2005-05-13 13:56:14.000000000 +0200
6f1b0c
@@ -2107,8 +2107,8 @@
6f1b0c
 })
6f1b0c
 
6f1b0c
 (define_insn "*swapqi"
6f1b0c
-  [(set (match_operand:QI 0 "register_operand" "+r")
6f1b0c
-	(match_operand:QI 1 "register_operand" "+r"))
6f1b0c
+  [(set (match_operand:QI 0 "register_operand" "+q")
6f1b0c
+	(match_operand:QI 1 "register_operand" "+q"))
6f1b0c
    (set (match_dup 1)
6f1b0c
 	(match_dup 0))]
6f1b0c
   ""
6f1b0c
--- gcc/testsuite/gcc.c-torture/execute/pr19005.c.jj	2005-04-07 15:51:53.775361896 +0200
6f1b0c
+++ gcc/testsuite/gcc.c-torture/execute/pr19005.c	2005-05-13 13:33:21.000000000 +0200
6f1b0c
@@ -0,0 +1,38 @@
6f1b0c
+/* PR target/19005 */
6f1b0c
+extern void abort (void);
6f1b0c
+
6f1b0c
+int v, s;
6f1b0c
+
6f1b0c
+void
6f1b0c
+bar (int a, int b)
6f1b0c
+{
6f1b0c
+  unsigned char x = v;
6f1b0c
+
6f1b0c
+  if (!s)
6f1b0c
+    {
6f1b0c
+      if (a != x || b != (unsigned char) (x + 1))
6f1b0c
+        abort ();
6f1b0c
+    }
6f1b0c
+  else if (a != (unsigned char) (x + 1) || b != x)
6f1b0c
+    abort ();
6f1b0c
+  s ^= 1;
6f1b0c
+}
6f1b0c
+
6f1b0c
+int
6f1b0c
+foo (int x)
6f1b0c
+{
6f1b0c
+  unsigned char a = x, b = x + 1;
6f1b0c
+
6f1b0c
+  bar (a, b);
6f1b0c
+  a ^= b; b ^= a; a ^= b;
6f1b0c
+  bar (a, b);
6f1b0c
+  return 0;
6f1b0c
+}
6f1b0c
+
6f1b0c
+int
6f1b0c
+main (void)
6f1b0c
+{
6f1b0c
+  for (v = -10; v < 266; v++)
6f1b0c
+    foo (v);
6f1b0c
+  return 0;
6f1b0c
+}