| Index: src/compiler/arm/code-generator-arm.cc
|
| diff --git a/src/compiler/arm/code-generator-arm.cc b/src/compiler/arm/code-generator-arm.cc
|
| index 6247f1f8022b46578c85270ca4e6b7df263d570e..77fb70e3b90ef59a5db6e0f244fd85c4544f5d0b 100644
|
| --- a/src/compiler/arm/code-generator-arm.cc
|
| +++ b/src/compiler/arm/code-generator-arm.cc
|
| @@ -2822,7 +2822,6 @@ void CodeGenerator::AssembleMove(InstructionOperand* source,
|
| __ add(kScratchReg, dst.rn(), Operand(dst.offset()));
|
| __ vst1(Neon8, NeonListOperand(kScratchQuadReg.low(), 2),
|
| NeonMemOperand(kScratchReg));
|
| - __ veor(kDoubleRegZero, kDoubleRegZero, kDoubleRegZero);
|
| }
|
| }
|
| } else {
|
| @@ -2905,40 +2904,41 @@ void CodeGenerator::AssembleSwap(InstructionOperand* source,
|
| NeonMemOperand(kScratchReg));
|
| __ vst1(Neon8, NeonListOperand(kScratchQuadReg.low(), 2),
|
| NeonMemOperand(kScratchReg));
|
| - __ veor(kDoubleRegZero, kDoubleRegZero, kDoubleRegZero);
|
| }
|
| }
|
| } else if (source->IsFPStackSlot()) {
|
| DCHECK(destination->IsFPStackSlot());
|
| - MemOperand src = g.ToMemOperand(source);
|
| - MemOperand dst = g.ToMemOperand(destination);
|
| + Register temp_0 = kScratchReg;
|
| + LowDwVfpRegister temp_1 = kScratchDoubleReg;
|
| + MemOperand src0 = g.ToMemOperand(source);
|
| + MemOperand dst0 = g.ToMemOperand(destination);
|
| MachineRepresentation rep = LocationOperand::cast(source)->representation();
|
| if (rep == MachineRepresentation::kFloat64) {
|
| - __ vldr(kScratchDoubleReg, dst);
|
| - __ vldr(kDoubleRegZero, src);
|
| - __ vstr(kScratchDoubleReg, src);
|
| - __ vstr(kDoubleRegZero, dst);
|
| - // Restore the 0 register.
|
| - __ veor(kDoubleRegZero, kDoubleRegZero, kDoubleRegZero);
|
| + MemOperand src1(src0.rn(), src0.offset() + kPointerSize);
|
| + MemOperand dst1(dst0.rn(), dst0.offset() + kPointerSize);
|
| + __ vldr(temp_1, dst0); // Save destination in temp_1.
|
| + __ ldr(temp_0, src0); // Then use temp_0 to copy source to destination.
|
| + __ str(temp_0, dst0);
|
| + __ ldr(temp_0, src1);
|
| + __ str(temp_0, dst1);
|
| + __ vstr(temp_1, src0);
|
| } else if (rep == MachineRepresentation::kFloat32) {
|
| - __ vldr(kScratchDoubleReg.low(), dst);
|
| - __ vldr(kScratchDoubleReg.high(), src);
|
| - __ vstr(kScratchDoubleReg.low(), src);
|
| - __ vstr(kScratchDoubleReg.high(), dst);
|
| + __ vldr(temp_1.low(), dst0); // Save destination in temp_1.
|
| + __ ldr(temp_0, src0); // Then use temp_0 to copy source to destination.
|
| + __ str(temp_0, dst0);
|
| + __ vstr(temp_1.low(), src0);
|
| } else {
|
| DCHECK_EQ(MachineRepresentation::kSimd128, rep);
|
| - __ vldr(kScratchDoubleReg, dst);
|
| - __ vldr(kDoubleRegZero, src);
|
| - __ vstr(kScratchDoubleReg, src);
|
| - __ vstr(kDoubleRegZero, dst);
|
| - src.set_offset(src.offset() + kDoubleSize);
|
| - dst.set_offset(dst.offset() + kDoubleSize);
|
| - __ vldr(kScratchDoubleReg, dst);
|
| - __ vldr(kDoubleRegZero, src);
|
| - __ vstr(kScratchDoubleReg, src);
|
| - __ vstr(kDoubleRegZero, dst);
|
| - // Restore the 0 register.
|
| - __ veor(kDoubleRegZero, kDoubleRegZero, kDoubleRegZero);
|
| + MemOperand src1(src0.rn(), src0.offset() + kDoubleSize);
|
| + MemOperand dst1(dst0.rn(), dst0.offset() + kDoubleSize);
|
| + __ vldr(kScratchQuadReg.low(), dst0);
|
| + __ vldr(kScratchQuadReg.high(), src0);
|
| + __ vstr(kScratchQuadReg.low(), src0);
|
| + __ vstr(kScratchQuadReg.high(), dst0);
|
| + __ vldr(kScratchQuadReg.low(), dst1);
|
| + __ vldr(kScratchQuadReg.high(), src1);
|
| + __ vstr(kScratchQuadReg.low(), src1);
|
| + __ vstr(kScratchQuadReg.high(), dst1);
|
| }
|
| } else {
|
| // No other combinations are possible.
|
|
|