gcc/
authormatz <matz@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 5 Oct 2007 17:56:52 +0000 (17:56 +0000)
committermatz <matz@138bc75d-0d04-0410-961f-82ee72b054a4>
Fri, 5 Oct 2007 17:56:52 +0000 (17:56 +0000)
 PR middle-end/33667
 * lower-subreg.c (decompose_multiword_subregs): Use
 validate_unshare_change().

testsuite/
 * gcc.dg/pr33667.c: New testcase.

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

gcc/ChangeLog
gcc/lower-subreg.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/pr33667.c [new file with mode: 0644]

index c8d1beb..e6cdebf 100644 (file)
@@ -1,3 +1,9 @@
+2007-10-05  Michael Matz  <matz@suse.de>
+
+       PR middle-end/33667
+       * lower-subreg.c (decompose_multiword_subregs): Use
+       validate_unshare_change().
+
 2007-10-05  Peter Bergner  <bergner@vnet.ibm.com>
 
        * ra-conflict.c: Include "sparseset.h".
index b8e2eb6..fa3a2c8 100644 (file)
@@ -1339,7 +1339,7 @@ decompose_multiword_subregs (void)
                          int dup_num = recog_data.dup_num[i];
                          rtx *px = recog_data.operand_loc[dup_num];
 
-                         validate_change (insn, pl, *px, 1);
+                         validate_unshare_change (insn, pl, *px, 1);
                        }
 
                      i = apply_change_group ();
index d73bde3..b9d2e75 100644 (file)
@@ -1,3 +1,8 @@
+2007-10-05  Michael Matz  <matz@suse.de>
+
+       PR middle-end/33667
+       * gcc.dg/pr33667.c: New testcase.
+
 2007-10-05  Richard Guenther  <rguenther@suse.de>
 
        PR middle-end/33666
diff --git a/gcc/testsuite/gcc.dg/pr33667.c b/gcc/testsuite/gcc.dg/pr33667.c
new file mode 100644 (file)
index 0000000..d3c039b
--- /dev/null
@@ -0,0 +1,21 @@
+/* { dg-do compile } */
+/* { dg-options "-O2" } */
+
+typedef unsigned int size_t;
+typedef unsigned char uint8_t;
+typedef unsigned short int uint16_t;
+typedef unsigned long long int uint64_t;
+struct magic {
+  uint8_t mask_op;
+  union {
+   uint64_t _mask;
+  } _u;
+  union VALUETYPE {
+   uint16_t h;
+  } value;
+};
+void cvt_16(union VALUETYPE *p, const struct magic *m)
+{
+  if (m->_u._mask)
+    p->h %= (uint16_t) m->_u._mask;
+}