Commit dc247d4b authored by sreten.kovacevic's avatar sreten.kovacevic Committed by Commit Bot

[mips] Emit trampoline pool after Sdc1 instruction

Since there are some regression tests that use this instruction
many times in a row, trampoline pool can't be emitted. This commit
fixes this issue.

Change-Id: I7b575c4920f7e72a39051dee1ccca4baf9562ff1
Reviewed-on: https://chromium-review.googlesource.com/955696
Commit-Queue: Sreten Kovacevic <sreten.kovacevic@mips.com>
Reviewed-by: 's avatarIvica Bogosavljevic <ivica.bogosavljevic@mips.com>
Cr-Commit-Position: refs/heads/master@{#51846}
parent b19d2851
...@@ -1167,47 +1167,54 @@ void TurboAssembler::Usdc1(FPURegister fd, const MemOperand& rs, ...@@ -1167,47 +1167,54 @@ void TurboAssembler::Usdc1(FPURegister fd, const MemOperand& rs,
void TurboAssembler::Ldc1(FPURegister fd, const MemOperand& src) { void TurboAssembler::Ldc1(FPURegister fd, const MemOperand& src) {
// Workaround for non-8-byte alignment of HeapNumber, convert 64-bit // Workaround for non-8-byte alignment of HeapNumber, convert 64-bit
// load to two 32-bit loads. // load to two 32-bit loads.
BlockTrampolinePoolScope block_trampoline_pool(this); {
DCHECK(Register::kMantissaOffset <= 4 && Register::kExponentOffset <= 4); BlockTrampolinePoolScope block_trampoline_pool(this);
MemOperand tmp = src; DCHECK(Register::kMantissaOffset <= 4 && Register::kExponentOffset <= 4);
AdjustBaseAndOffset(tmp, OffsetAccessType::TWO_ACCESSES); MemOperand tmp = src;
lwc1(fd, MemOperand(tmp.rm(), tmp.offset() + Register::kMantissaOffset)); AdjustBaseAndOffset(tmp, OffsetAccessType::TWO_ACCESSES);
if (IsFp32Mode()) { // fp32 mode. lwc1(fd, MemOperand(tmp.rm(), tmp.offset() + Register::kMantissaOffset));
FPURegister nextfpreg = FPURegister::from_code(fd.code() + 1); if (IsFp32Mode()) { // fp32 mode.
lwc1(nextfpreg, FPURegister nextfpreg = FPURegister::from_code(fd.code() + 1);
lwc1(nextfpreg,
MemOperand(tmp.rm(), tmp.offset() + Register::kExponentOffset));
} else {
DCHECK(IsFp64Mode() || IsFpxxMode());
// Currently we support FPXX and FP64 on Mips32r2 and Mips32r6
DCHECK(IsMipsArchVariant(kMips32r2) || IsMipsArchVariant(kMips32r6));
UseScratchRegisterScope temps(this);
Register scratch = temps.Acquire();
DCHECK(src.rm() != scratch);
lw(scratch,
MemOperand(tmp.rm(), tmp.offset() + Register::kExponentOffset)); MemOperand(tmp.rm(), tmp.offset() + Register::kExponentOffset));
} else { Mthc1(scratch, fd);
DCHECK(IsFp64Mode() || IsFpxxMode()); }
// Currently we support FPXX and FP64 on Mips32r2 and Mips32r6
DCHECK(IsMipsArchVariant(kMips32r2) || IsMipsArchVariant(kMips32r6));
UseScratchRegisterScope temps(this);
Register scratch = temps.Acquire();
DCHECK(src.rm() != scratch);
lw(scratch, MemOperand(tmp.rm(), tmp.offset() + Register::kExponentOffset));
Mthc1(scratch, fd);
} }
CheckTrampolinePoolQuick(1);
} }
void TurboAssembler::Sdc1(FPURegister fd, const MemOperand& src) { void TurboAssembler::Sdc1(FPURegister fd, const MemOperand& src) {
// Workaround for non-8-byte alignment of HeapNumber, convert 64-bit // Workaround for non-8-byte alignment of HeapNumber, convert 64-bit
// store to two 32-bit stores. // store to two 32-bit stores.
BlockTrampolinePoolScope block_trampoline_pool(this); {
DCHECK(Register::kMantissaOffset <= 4 && Register::kExponentOffset <= 4); BlockTrampolinePoolScope block_trampoline_pool(this);
MemOperand tmp = src; DCHECK(Register::kMantissaOffset <= 4 && Register::kExponentOffset <= 4);
AdjustBaseAndOffset(tmp, OffsetAccessType::TWO_ACCESSES); MemOperand tmp = src;
swc1(fd, MemOperand(tmp.rm(), tmp.offset() + Register::kMantissaOffset)); AdjustBaseAndOffset(tmp, OffsetAccessType::TWO_ACCESSES);
if (IsFp32Mode()) { // fp32 mode. swc1(fd, MemOperand(tmp.rm(), tmp.offset() + Register::kMantissaOffset));
FPURegister nextfpreg = FPURegister::from_code(fd.code() + 1); if (IsFp32Mode()) { // fp32 mode.
swc1(nextfpreg, FPURegister nextfpreg = FPURegister::from_code(fd.code() + 1);
MemOperand(tmp.rm(), tmp.offset() + Register::kExponentOffset)); swc1(nextfpreg,
} else { MemOperand(tmp.rm(), tmp.offset() + Register::kExponentOffset));
DCHECK(IsFp64Mode() || IsFpxxMode()); } else {
// Currently we support FPXX and FP64 on Mips32r2 and Mips32r6 DCHECK(IsFp64Mode() || IsFpxxMode());
DCHECK(IsMipsArchVariant(kMips32r2) || IsMipsArchVariant(kMips32r6)); // Currently we support FPXX and FP64 on Mips32r2 and Mips32r6
DCHECK(src.rm() != t8); DCHECK(IsMipsArchVariant(kMips32r2) || IsMipsArchVariant(kMips32r6));
Mfhc1(t8, fd); DCHECK(src.rm() != t8);
sw(t8, MemOperand(tmp.rm(), tmp.offset() + Register::kExponentOffset)); Mfhc1(t8, fd);
sw(t8, MemOperand(tmp.rm(), tmp.offset() + Register::kExponentOffset));
}
} }
CheckTrampolinePoolQuick(1);
} }
void TurboAssembler::Ll(Register rd, const MemOperand& rs) { void TurboAssembler::Ll(Register rd, const MemOperand& rs) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment