| Index: src/compiler/mips64/code-generator-mips64.cc
|
| diff --git a/src/compiler/mips64/code-generator-mips64.cc b/src/compiler/mips64/code-generator-mips64.cc
|
| index 24a3fa6ccd899863e94988ee83b14323564134e5..0795927a859dd8de087d0dce97e1f610aaf39a22 100644
|
| --- a/src/compiler/mips64/code-generator-mips64.cc
|
| +++ b/src/compiler/mips64/code-generator-mips64.cc
|
| @@ -213,6 +213,48 @@ class OutOfLineCeil final : public OutOfLineRound {
|
| };
|
|
|
|
|
| +class OutOfLineRecordWrite final : public OutOfLineCode {
|
| + public:
|
| + OutOfLineRecordWrite(CodeGenerator* gen, Register object, Register index,
|
| + Register value, Register scratch0, Register scratch1,
|
| + RecordWriteMode mode)
|
| + : OutOfLineCode(gen),
|
| + object_(object),
|
| + index_(index),
|
| + value_(value),
|
| + scratch0_(scratch0),
|
| + scratch1_(scratch1),
|
| + mode_(mode) {}
|
| +
|
| + void Generate() final {
|
| + if (mode_ > RecordWriteMode::kValueIsPointer) {
|
| + __ JumpIfSmi(value_, exit());
|
| + }
|
| + if (mode_ > RecordWriteMode::kValueIsMap) {
|
| + __ CheckPageFlag(value_, scratch0_,
|
| + MemoryChunk::kPointersToHereAreInterestingMask, eq,
|
| + exit());
|
| + }
|
| + SaveFPRegsMode const save_fp_mode =
|
| + frame()->DidAllocateDoubleRegisters() ? kSaveFPRegs : kDontSaveFPRegs;
|
| + // TODO(turbofan): Once we get frame elision working, we need to save
|
| + // and restore lr properly here if the frame was elided.
|
| + RecordWriteStub stub(isolate(), object_, scratch0_, scratch1_,
|
| + EMIT_REMEMBERED_SET, save_fp_mode);
|
| + __ Addu(scratch1_, object_, index_);
|
| + __ CallStub(&stub);
|
| + }
|
| +
|
| + private:
|
| + Register const object_;
|
| + Register const index_;
|
| + Register const value_;
|
| + Register const scratch0_;
|
| + Register const scratch1_;
|
| + RecordWriteMode const mode_;
|
| +};
|
| +
|
| +
|
| Condition FlagsConditionToConditionCmp(FlagsCondition condition) {
|
| switch (condition) {
|
| case kEqual:
|
| @@ -518,6 +560,24 @@ void CodeGenerator::AssembleArchInstruction(Instruction* instr) {
|
| case kArchTruncateDoubleToI:
|
| __ TruncateDoubleToI(i.OutputRegister(), i.InputDoubleRegister(0));
|
| break;
|
| + case kArchStoreWithWriteBarrier: {
|
| + RecordWriteMode mode =
|
| + static_cast<RecordWriteMode>(MiscField::decode(instr->opcode()));
|
| + Register object = i.InputRegister(0);
|
| + Register index = i.InputRegister(1);
|
| + Register value = i.InputRegister(2);
|
| + Register scratch0 = i.TempRegister(0);
|
| + Register scratch1 = i.TempRegister(1);
|
| + auto ool = new (zone()) OutOfLineRecordWrite(this, object, index, value,
|
| + scratch0, scratch1, mode);
|
| + __ Daddu(at, object, index);
|
| + __ sd(value, MemOperand(at));
|
| + __ CheckPageFlag(object, scratch0,
|
| + MemoryChunk::kPointersFromHereAreInterestingMask, ne,
|
| + ool->entry());
|
| + __ bind(ool->exit());
|
| + break;
|
| + }
|
| case kMips64Add:
|
| __ Addu(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1));
|
| break;
|
| @@ -967,18 +1027,6 @@ void CodeGenerator::AssembleArchInstruction(Instruction* instr) {
|
| }
|
| break;
|
| }
|
| - case kMips64StoreWriteBarrier: {
|
| - Register object = i.InputRegister(0);
|
| - Register index = i.InputRegister(1);
|
| - Register value = i.InputRegister(2);
|
| - __ daddu(index, object, index);
|
| - __ sd(value, MemOperand(index));
|
| - SaveFPRegsMode mode =
|
| - frame()->DidAllocateDoubleRegisters() ? kSaveFPRegs : kDontSaveFPRegs;
|
| - RAStatus ra_status = kRAHasNotBeenSaved;
|
| - __ RecordWrite(object, index, value, ra_status, mode);
|
| - break;
|
| - }
|
| case kCheckedLoadInt8:
|
| ASSEMBLE_CHECKED_LOAD_INTEGER(lb);
|
| break;
|
|
|