summaryrefslogtreecommitdiffstats
path: root/compiler
diff options
context:
space:
mode:
authorbuzbee <buzbee@google.com>2014-04-08 04:47:11 +0000
committerGerrit Code Review <noreply-gerritcodereview@google.com>2014-04-08 04:47:11 +0000
commit1512ea155cbe0a4b33776b0320c1ce38583ab09b (patch)
tree84c235566f72c3e383786e81534fa1182976cb28 /compiler
parent476fe7c81c0d6b060be5cde4c44a2bb8b0b8ffd2 (diff)
parenta1983d4dab10b0cc51e9d1b6bcafa9a723fabcd9 (diff)
downloadart-1512ea155cbe0a4b33776b0320c1ce38583ab09b.tar.gz
art-1512ea155cbe0a4b33776b0320c1ce38583ab09b.tar.bz2
art-1512ea155cbe0a4b33776b0320c1ce38583ab09b.zip
Merge "Quick compiler: fix CmpLong pair handling"
Diffstat (limited to 'compiler')
-rw-r--r--compiler/dex/quick/arm/int_arm.cc5
1 files changed, 2 insertions, 3 deletions
diff --git a/compiler/dex/quick/arm/int_arm.cc b/compiler/dex/quick/arm/int_arm.cc
index c80297bc0..8b4171de1 100644
--- a/compiler/dex/quick/arm/int_arm.cc
+++ b/compiler/dex/quick/arm/int_arm.cc
@@ -90,8 +90,7 @@ void ArmMir2Lir::OpEndIT(LIR* it) {
* neg rX
* done:
*/
-void ArmMir2Lir::GenCmpLong(RegLocation rl_dest, RegLocation rl_src1,
- RegLocation rl_src2) {
+void ArmMir2Lir::GenCmpLong(RegLocation rl_dest, RegLocation rl_src1, RegLocation rl_src2) {
LIR* target1;
LIR* target2;
rl_src1 = LoadValueWide(rl_src1, kCoreReg);
@@ -101,7 +100,7 @@ void ArmMir2Lir::GenCmpLong(RegLocation rl_dest, RegLocation rl_src1,
OpRegReg(kOpCmp, rl_src1.reg.GetHigh(), rl_src2.reg.GetHigh());
LIR* branch1 = OpCondBranch(kCondLt, NULL);
LIR* branch2 = OpCondBranch(kCondGt, NULL);
- OpRegRegReg(kOpSub, t_reg, rl_src1.reg, rl_src2.reg);
+ OpRegRegReg(kOpSub, t_reg, rl_src1.reg.GetLow(), rl_src2.reg.GetLow());
LIR* branch3 = OpCondBranch(kCondEq, NULL);
LIR* it = OpIT(kCondHi, "E");