diff options
| author | 2014-06-19 21:17:44 +0000 | |
|---|---|---|
| committer | 2014-06-19 20:38:20 +0000 | |
| commit | 7133659eeea45e391aa12affea75e39e8c300eb0 (patch) | |
| tree | 8cfdf007c7e3a1d0de6e06216f60f7185eef2337 | |
| parent | 202e74780054ce2b0d87ddf0591cd83b6506de1d (diff) | |
| parent | 02959eae949f37445c184ae6f3df4d068ff309e0 (diff) | |
Merge "x86_64: Fix neg_double"
| -rw-r--r-- | compiler/dex/quick/x86/fp_x86.cc | 7 | ||||
| -rw-r--r-- | test/112-double-math/expected.txt | 1 | ||||
| -rw-r--r-- | test/112-double-math/info.txt | 1 | ||||
| -rw-r--r-- | test/112-double-math/src/Main.java | 31 |
4 files changed, 38 insertions, 2 deletions
diff --git a/compiler/dex/quick/x86/fp_x86.cc b/compiler/dex/quick/x86/fp_x86.cc index 20bb7bf117..1f05ab9cf4 100644 --- a/compiler/dex/quick/x86/fp_x86.cc +++ b/compiler/dex/quick/x86/fp_x86.cc @@ -568,8 +568,11 @@ void X86Mir2Lir::GenNegDouble(RegLocation rl_dest, RegLocation rl_src) { rl_src = LoadValueWide(rl_src, kCoreReg); rl_result = EvalLocWide(rl_dest, kCoreReg, true); if (Gen64Bit()) { - LoadConstantWide(rl_result.reg, 0x8000000000000000); - OpRegReg(kOpAdd, rl_result.reg, rl_src.reg); + OpRegCopy(rl_result.reg, rl_src.reg); + // Flip sign bit. + NewLIR2(kX86Rol64RI, rl_result.reg.GetReg(), 1); + NewLIR2(kX86Xor64RI, rl_result.reg.GetReg(), 1); + NewLIR2(kX86Ror64RI, rl_result.reg.GetReg(), 1); } else { OpRegRegImm(kOpAdd, rl_result.reg.GetHigh(), rl_src.reg.GetHigh(), 0x80000000); OpRegCopy(rl_result.reg, rl_src.reg); diff --git a/test/112-double-math/expected.txt b/test/112-double-math/expected.txt new file mode 100644 index 0000000000..1e10a952bb --- /dev/null +++ b/test/112-double-math/expected.txt @@ -0,0 +1 @@ +cond_neg_double PASSED diff --git a/test/112-double-math/info.txt b/test/112-double-math/info.txt new file mode 100644 index 0000000000..a32f4e0d85 --- /dev/null +++ b/test/112-double-math/info.txt @@ -0,0 +1 @@ +This checks the neg_double bytecode. diff --git a/test/112-double-math/src/Main.java b/test/112-double-math/src/Main.java new file mode 100644 index 0000000000..8172dfab5a --- /dev/null +++ b/test/112-double-math/src/Main.java @@ -0,0 +1,31 @@ +/* + * Copyright (C) 2007 The Android Open Source Project + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +public class Main { + public static double cond_neg_double(double value, boolean cond) { + return cond ? -value : value; + } + + public static void main(String args[]) { + double result = cond_neg_double(-1.0d, true); + + if (Double.doubleToRawLongBits(result) == 0x3ff0000000000000L) { + System.out.println("cond_neg_double PASSED"); + } else { + System.out.println("cond_neg_double FAILED " + result); + } + } +} |