aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorSteve Ellcey <sje@cup.hp.com>2010-01-13 22:16:25 +0000
committerSteve Ellcey <sje@gcc.gnu.org>2010-01-13 22:16:25 +0000
commit9540f5ef923d12c177658f9b742f562c1ad17edc (patch)
tree158fc70e84b0d2462008c77e210f916e42e5a6b1 /gcc
parenta5859aaf073f326545266b691f5d74fc0f2f0f11 (diff)
downloadgcc-9540f5ef923d12c177658f9b742f562c1ad17edc.zip
gcc-9540f5ef923d12c177658f9b742f562c1ad17edc.tar.gz
gcc-9540f5ef923d12c177658f9b742f562c1ad17edc.tar.bz2
PR target/pr42542
2010-01-13 Steve Ellcey <sje@cup.hp.com> PR target/pr42542 * config/ia64/ia64.c (ia64_expand_vecint_compare): Convert GTU to GT for V2SI by subtracting (-(INT MAX) - 1) from both operands to make them signed. From-SVN: r155870
Diffstat (limited to 'gcc')
-rw-r--r--gcc/ChangeLog7
-rw-r--r--gcc/config/ia64/ia64.c27
2 files changed, 17 insertions, 17 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index 6b2df35..68edaec 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,10 @@
+2010-01-13 Steve Ellcey <sje@cup.hp.com>
+
+ PR target/pr42542
+ * config/ia64/ia64.c (ia64_expand_vecint_compare): Convert GTU to GT
+ for V2SI by subtracting (-(INT MAX) - 1) from both operands to make
+ them signed.
+
2010-01-13 Bernd Schmidt <bernd.schmidt@analog.com>
* config/bfin/libgcc-bfin.ver: Regenerate based on current
diff --git a/gcc/config/ia64/ia64.c b/gcc/config/ia64/ia64.c
index 52107df..384de6d 100644
--- a/gcc/config/ia64/ia64.c
+++ b/gcc/config/ia64/ia64.c
@@ -1733,25 +1733,18 @@ ia64_expand_vecint_compare (enum rtx_code code, enum machine_mode mode,
{
rtx t1, t2, mask;
- /* Perform a parallel modulo subtraction. */
- t1 = gen_reg_rtx (V2SImode);
- emit_insn (gen_subv2si3 (t1, op0, op1));
-
- /* Extract the original sign bit of op0. */
- mask = GEN_INT (-0x80000000);
+ /* Subtract (-(INT MAX) - 1) from both operands to make
+ them signed. */
+ mask = GEN_INT (0x80000000);
mask = gen_rtx_CONST_VECTOR (V2SImode, gen_rtvec (2, mask, mask));
- mask = force_reg (V2SImode, mask);
- t2 = gen_reg_rtx (V2SImode);
- emit_insn (gen_andv2si3 (t2, op0, mask));
-
- /* XOR it back into the result of the subtraction. This results
- in the sign bit set iff we saw unsigned underflow. */
- x = gen_reg_rtx (V2SImode);
- emit_insn (gen_xorv2si3 (x, t1, t2));
-
+ mask = force_reg (mode, mask);
+ t1 = gen_reg_rtx (mode);
+ emit_insn (gen_subv2si3 (t1, op0, mask));
+ t2 = gen_reg_rtx (mode);
+ emit_insn (gen_subv2si3 (t2, op1, mask));
+ op0 = t1;
+ op1 = t2;
code = GT;
- op0 = x;
- op1 = CONST0_RTX (mode);
}
break;