diff options
author | Steve Ellcey <sje@cup.hp.com> | 2010-01-13 22:16:25 +0000 |
---|---|---|
committer | Steve Ellcey <sje@gcc.gnu.org> | 2010-01-13 22:16:25 +0000 |
commit | 9540f5ef923d12c177658f9b742f562c1ad17edc (patch) | |
tree | 158fc70e84b0d2462008c77e210f916e42e5a6b1 /gcc | |
parent | a5859aaf073f326545266b691f5d74fc0f2f0f11 (diff) | |
download | gcc-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/ChangeLog | 7 | ||||
-rw-r--r-- | gcc/config/ia64/ia64.c | 27 |
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; |