combine.c (find_split_point): Sign extend bitmask when changing bitfield assignment...
authorDale Johannesen <dalej@apple.com>
Wed, 30 Nov 2005 18:19:16 +0000 (18:19 +0000)
committerDale Johannesen <dalej@gcc.gnu.org>
Wed, 30 Nov 2005 18:19:16 +0000 (18:19 +0000)
2005-11-30  Dale Johannesen  <dalej@apple.com>
            Andrew Pinski  <pinskia@physics.uc.edu>

* combine.c (find_split_point):  Sign extend bitmask
when changing bitfield assignment to IOR of AND.

2005-11-30  Dale Johannesen  <dalej@apple.com>

* gcc.c-torture/compile/pr24930.c:  New.

Co-Authored-By: Andrew Pinski <pinskia@physics.uc.edu>
From-SVN: r107731

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

index 4b9e14549651a345803feb2cf858947bd0880767..90d2fc892a73e91944b896431198539ea7134622 100644 (file)
@@ -1,3 +1,9 @@
+2005-11-30  Dale Johannesen  <dalej@apple.com>
+            Andrew Pinski  <pinskia@physics.uc.edu>
+
+       * combine.c (find_split_point):  Sign extend bitmask
+       when changing bitfield assignment to IOR of AND.
+
 2005-11-30  Nathan Sidwell  <nathan@codesourcery.com>
 
        * config/ms1/ms1.md (decrement_and_branch_until_zero): Add early
index abd64582d3ee43c6099d84a10dc07a6ad26ecab3..08cacab6f0c9549825cb0d347581d1ff61c2617d 100644 (file)
@@ -3361,13 +3361,15 @@ find_split_point (rtx *loc, rtx insn)
          rtx dest = XEXP (SET_DEST (x), 0);
          enum machine_mode mode = GET_MODE (dest);
          unsigned HOST_WIDE_INT mask = ((HOST_WIDE_INT) 1 << len) - 1;
+         rtx or_mask;
 
          if (BITS_BIG_ENDIAN)
            pos = GET_MODE_BITSIZE (mode) - len - pos;
 
+         or_mask = gen_int_mode (src << pos, mode);
          if (src == mask)
            SUBST (SET_SRC (x),
-                  simplify_gen_binary (IOR, mode, dest, GEN_INT (src << pos)));
+                  simplify_gen_binary (IOR, mode, dest, or_mask));
          else
            {
              rtx negmask = gen_int_mode (~(mask << pos), mode);
@@ -3375,7 +3377,7 @@ find_split_point (rtx *loc, rtx insn)
                     simplify_gen_binary (IOR, mode,
                                          simplify_gen_binary (AND, mode,
                                                               dest, negmask),
-                                         GEN_INT (src << pos)));
+                                         or_mask));
            }
 
          SUBST (SET_DEST (x), dest);
index df3cbed6d930af5a10e53565a658bfa42ec5119c..056b57e924c8695b36e57207fa89f892f0dc9de5 100644 (file)
@@ -1,3 +1,7 @@
+2005-11-30  Dale Johannesen  <dalej@apple.com>
+
+       * gcc.c-torture/compile/pr24930.c:  New.
+
 2005-11-30  Paul Thomas  <pault@gcc.gnu.org>
 
        PR fortran/15809
diff --git a/gcc/testsuite/gcc.c-torture/compile/pr24930.c b/gcc/testsuite/gcc.c-torture/compile/pr24930.c
new file mode 100644 (file)
index 0000000..d52bb5c
--- /dev/null
@@ -0,0 +1,17 @@
+/* PR 24930 */
+extern int foo(int u) __attribute__((noinline));
+int foo(int u) {return 0;}
+int
+main(int argc, char** argv)
+{
+  const char *buf = argv[1];
+  
+  unsigned int data = (((unsigned int) buf[0]) << 8) + (unsigned int) buf[1];
+  if (data & 0x8000) {
+    data &= 0x7fff ;
+    data ^= 0x7fff ;
+    data += 1 ;
+    data *= -1 ;
+  }
+  return foo((int)data);
+}