| Index: src/ia32/lithium-codegen-ia32.cc
|
| diff --git a/src/ia32/lithium-codegen-ia32.cc b/src/ia32/lithium-codegen-ia32.cc
|
| index 37b6accc14f0c8a9ae3337737c0e94b79af5360c..e7e032701e2c6c99c0038d614b674d881cbd9e2c 100644
|
| --- a/src/ia32/lithium-codegen-ia32.cc
|
| +++ b/src/ia32/lithium-codegen-ia32.cc
|
| @@ -423,7 +423,6 @@ bool LCodeGen::GenerateDeferredCode() {
|
| if (deferred_.length() > 0) {
|
| for (int i = 0; !is_aborted() && i < deferred_.length(); i++) {
|
| LDeferredCode* code = deferred_[i];
|
| - x87_stack_ = X87Stack(code->x87_stack());
|
|
|
| int pos = instructions_->at(code->instruction_index())->position();
|
| RecordAndUpdatePosition(pos);
|
| @@ -504,7 +503,6 @@ void LCodeGen::X87LoadForUsage(X87Register reg) {
|
|
|
|
|
| void LCodeGen::X87Stack::Fxch(X87Register reg, int other_slot) {
|
| - ASSERT(is_mutable_);
|
| ASSERT(Contains(reg) && stack_depth_ > other_slot);
|
| int i = ArrayIndex(reg);
|
| int st = st2idx(i);
|
| @@ -549,7 +547,6 @@ bool LCodeGen::X87Stack::Contains(X87Register reg) {
|
|
|
|
|
| void LCodeGen::X87Stack::Free(X87Register reg) {
|
| - ASSERT(is_mutable_);
|
| ASSERT(Contains(reg));
|
| int i = ArrayIndex(reg);
|
| int st = st2idx(i);
|
| @@ -609,7 +606,6 @@ void LCodeGen::X87Mov(Operand dst, X87Register src, X87OperandType opts) {
|
|
|
|
|
| void LCodeGen::X87Stack::PrepareToWrite(X87Register reg) {
|
| - ASSERT(is_mutable_);
|
| if (Contains(reg)) {
|
| Free(reg);
|
| }
|
| @@ -619,7 +615,6 @@ void LCodeGen::X87Stack::PrepareToWrite(X87Register reg) {
|
|
|
|
|
| void LCodeGen::X87Stack::CommitWrite(X87Register reg) {
|
| - ASSERT(is_mutable_);
|
| // Assert the reg is prepared to write, but not on the virtual stack yet
|
| ASSERT(!Contains(reg) && stack_[stack_depth_].is(reg) &&
|
| stack_depth_ < X87Register::kNumAllocatableRegisters);
|
| @@ -2846,9 +2841,8 @@ void LCodeGen::DoInstanceOfKnownGlobal(LInstanceOfKnownGlobal* instr) {
|
| class DeferredInstanceOfKnownGlobal V8_FINAL : public LDeferredCode {
|
| public:
|
| DeferredInstanceOfKnownGlobal(LCodeGen* codegen,
|
| - LInstanceOfKnownGlobal* instr,
|
| - const X87Stack& x87_stack)
|
| - : LDeferredCode(codegen, x87_stack), instr_(instr) { }
|
| + LInstanceOfKnownGlobal* instr)
|
| + : LDeferredCode(codegen), instr_(instr) { }
|
| virtual void Generate() V8_OVERRIDE {
|
| codegen()->DoDeferredInstanceOfKnownGlobal(instr_, &map_check_);
|
| }
|
| @@ -2860,7 +2854,7 @@ void LCodeGen::DoInstanceOfKnownGlobal(LInstanceOfKnownGlobal* instr) {
|
| };
|
|
|
| DeferredInstanceOfKnownGlobal* deferred;
|
| - deferred = new(zone()) DeferredInstanceOfKnownGlobal(this, instr, x87_stack_);
|
| + deferred = new(zone()) DeferredInstanceOfKnownGlobal(this, instr);
|
|
|
| Label done, false_result;
|
| Register object = ToRegister(instr->value());
|
| @@ -3814,10 +3808,8 @@ void LCodeGen::DoMathAbs(LMathAbs* instr) {
|
| // Class for deferred case.
|
| class DeferredMathAbsTaggedHeapNumber V8_FINAL : public LDeferredCode {
|
| public:
|
| - DeferredMathAbsTaggedHeapNumber(LCodeGen* codegen,
|
| - LMathAbs* instr,
|
| - const X87Stack& x87_stack)
|
| - : LDeferredCode(codegen, x87_stack), instr_(instr) { }
|
| + DeferredMathAbsTaggedHeapNumber(LCodeGen* codegen, LMathAbs* instr)
|
| + : LDeferredCode(codegen), instr_(instr) { }
|
| virtual void Generate() V8_OVERRIDE {
|
| codegen()->DoDeferredMathAbsTaggedHeapNumber(instr_);
|
| }
|
| @@ -3840,7 +3832,7 @@ void LCodeGen::DoMathAbs(LMathAbs* instr) {
|
| EmitIntegerMathAbs(instr);
|
| } else { // Tagged case.
|
| DeferredMathAbsTaggedHeapNumber* deferred =
|
| - new(zone()) DeferredMathAbsTaggedHeapNumber(this, instr, x87_stack_);
|
| + new(zone()) DeferredMathAbsTaggedHeapNumber(this, instr);
|
| Register input_reg = ToRegister(instr->value());
|
| // Smi check.
|
| __ JumpIfNotSmi(input_reg, deferred->entry());
|
| @@ -4056,18 +4048,15 @@ void LCodeGen::DoPower(LPower* instr) {
|
| void LCodeGen::DoRandom(LRandom* instr) {
|
| class DeferredDoRandom V8_FINAL : public LDeferredCode {
|
| public:
|
| - DeferredDoRandom(LCodeGen* codegen,
|
| - LRandom* instr,
|
| - const X87Stack& x87_stack)
|
| - : LDeferredCode(codegen, x87_stack), instr_(instr) { }
|
| + DeferredDoRandom(LCodeGen* codegen, LRandom* instr)
|
| + : LDeferredCode(codegen), instr_(instr) { }
|
| virtual void Generate() V8_OVERRIDE { codegen()->DoDeferredRandom(instr_); }
|
| virtual LInstruction* instr() V8_OVERRIDE { return instr_; }
|
| private:
|
| LRandom* instr_;
|
| };
|
|
|
| - DeferredDoRandom* deferred =
|
| - new(zone()) DeferredDoRandom(this, instr, x87_stack_);
|
| + DeferredDoRandom* deferred = new(zone()) DeferredDoRandom(this, instr);
|
|
|
| CpuFeatureScope scope(masm(), SSE2);
|
| // Having marked this instruction as a call we can use any
|
| @@ -4802,10 +4791,8 @@ void LCodeGen::DoTransitionElementsKind(LTransitionElementsKind* instr) {
|
| void LCodeGen::DoStringCharCodeAt(LStringCharCodeAt* instr) {
|
| class DeferredStringCharCodeAt V8_FINAL : public LDeferredCode {
|
| public:
|
| - DeferredStringCharCodeAt(LCodeGen* codegen,
|
| - LStringCharCodeAt* instr,
|
| - const X87Stack& x87_stack)
|
| - : LDeferredCode(codegen, x87_stack), instr_(instr) { }
|
| + DeferredStringCharCodeAt(LCodeGen* codegen, LStringCharCodeAt* instr)
|
| + : LDeferredCode(codegen), instr_(instr) { }
|
| virtual void Generate() V8_OVERRIDE {
|
| codegen()->DoDeferredStringCharCodeAt(instr_);
|
| }
|
| @@ -4815,7 +4802,7 @@ void LCodeGen::DoStringCharCodeAt(LStringCharCodeAt* instr) {
|
| };
|
|
|
| DeferredStringCharCodeAt* deferred =
|
| - new(zone()) DeferredStringCharCodeAt(this, instr, x87_stack_);
|
| + new(zone()) DeferredStringCharCodeAt(this, instr);
|
|
|
| StringCharLoadGenerator::Generate(masm(),
|
| factory(),
|
| @@ -4861,10 +4848,8 @@ void LCodeGen::DoDeferredStringCharCodeAt(LStringCharCodeAt* instr) {
|
| void LCodeGen::DoStringCharFromCode(LStringCharFromCode* instr) {
|
| class DeferredStringCharFromCode V8_FINAL : public LDeferredCode {
|
| public:
|
| - DeferredStringCharFromCode(LCodeGen* codegen,
|
| - LStringCharFromCode* instr,
|
| - const X87Stack& x87_stack)
|
| - : LDeferredCode(codegen, x87_stack), instr_(instr) { }
|
| + DeferredStringCharFromCode(LCodeGen* codegen, LStringCharFromCode* instr)
|
| + : LDeferredCode(codegen), instr_(instr) { }
|
| virtual void Generate() V8_OVERRIDE {
|
| codegen()->DoDeferredStringCharFromCode(instr_);
|
| }
|
| @@ -4874,7 +4859,7 @@ void LCodeGen::DoStringCharFromCode(LStringCharFromCode* instr) {
|
| };
|
|
|
| DeferredStringCharFromCode* deferred =
|
| - new(zone()) DeferredStringCharFromCode(this, instr, x87_stack_);
|
| + new(zone()) DeferredStringCharFromCode(this, instr);
|
|
|
| ASSERT(instr->hydrogen()->value()->representation().IsInteger32());
|
| Register char_code = ToRegister(instr->char_code());
|
| @@ -4962,10 +4947,8 @@ void LCodeGen::DoUint32ToDouble(LUint32ToDouble* instr) {
|
| void LCodeGen::DoNumberTagI(LNumberTagI* instr) {
|
| class DeferredNumberTagI V8_FINAL : public LDeferredCode {
|
| public:
|
| - DeferredNumberTagI(LCodeGen* codegen,
|
| - LNumberTagI* instr,
|
| - const X87Stack& x87_stack)
|
| - : LDeferredCode(codegen, x87_stack), instr_(instr) { }
|
| + DeferredNumberTagI(LCodeGen* codegen, LNumberTagI* instr)
|
| + : LDeferredCode(codegen), instr_(instr) { }
|
| virtual void Generate() V8_OVERRIDE {
|
| codegen()->DoDeferredNumberTagI(instr_, instr_->value(), SIGNED_INT32);
|
| }
|
| @@ -4978,8 +4961,7 @@ void LCodeGen::DoNumberTagI(LNumberTagI* instr) {
|
| ASSERT(input->IsRegister() && input->Equals(instr->result()));
|
| Register reg = ToRegister(input);
|
|
|
| - DeferredNumberTagI* deferred =
|
| - new(zone()) DeferredNumberTagI(this, instr, x87_stack_);
|
| + DeferredNumberTagI* deferred = new(zone()) DeferredNumberTagI(this, instr);
|
| __ SmiTag(reg);
|
| __ j(overflow, deferred->entry());
|
| __ bind(deferred->exit());
|
| @@ -4989,10 +4971,8 @@ void LCodeGen::DoNumberTagI(LNumberTagI* instr) {
|
| void LCodeGen::DoNumberTagU(LNumberTagU* instr) {
|
| class DeferredNumberTagU V8_FINAL : public LDeferredCode {
|
| public:
|
| - DeferredNumberTagU(LCodeGen* codegen,
|
| - LNumberTagU* instr,
|
| - const X87Stack& x87_stack)
|
| - : LDeferredCode(codegen, x87_stack), instr_(instr) { }
|
| + DeferredNumberTagU(LCodeGen* codegen, LNumberTagU* instr)
|
| + : LDeferredCode(codegen), instr_(instr) { }
|
| virtual void Generate() V8_OVERRIDE {
|
| codegen()->DoDeferredNumberTagI(instr_, instr_->value(), UNSIGNED_INT32);
|
| }
|
| @@ -5005,8 +4985,7 @@ void LCodeGen::DoNumberTagU(LNumberTagU* instr) {
|
| ASSERT(input->IsRegister() && input->Equals(instr->result()));
|
| Register reg = ToRegister(input);
|
|
|
| - DeferredNumberTagU* deferred =
|
| - new(zone()) DeferredNumberTagU(this, instr, x87_stack_);
|
| + DeferredNumberTagU* deferred = new(zone()) DeferredNumberTagU(this, instr);
|
| __ cmp(reg, Immediate(Smi::kMaxValue));
|
| __ j(above, deferred->entry());
|
| __ SmiTag(reg);
|
| @@ -5095,10 +5074,8 @@ void LCodeGen::DoDeferredNumberTagI(LInstruction* instr,
|
| void LCodeGen::DoNumberTagD(LNumberTagD* instr) {
|
| class DeferredNumberTagD V8_FINAL : public LDeferredCode {
|
| public:
|
| - DeferredNumberTagD(LCodeGen* codegen,
|
| - LNumberTagD* instr,
|
| - const X87Stack& x87_stack)
|
| - : LDeferredCode(codegen, x87_stack), instr_(instr) { }
|
| + DeferredNumberTagD(LCodeGen* codegen, LNumberTagD* instr)
|
| + : LDeferredCode(codegen), instr_(instr) { }
|
| virtual void Generate() V8_OVERRIDE {
|
| codegen()->DoDeferredNumberTagD(instr_);
|
| }
|
| @@ -5116,8 +5093,7 @@ void LCodeGen::DoNumberTagD(LNumberTagD* instr) {
|
| X87LoadForUsage(src);
|
| }
|
|
|
| - DeferredNumberTagD* deferred =
|
| - new(zone()) DeferredNumberTagD(this, instr, x87_stack_);
|
| + DeferredNumberTagD* deferred = new(zone()) DeferredNumberTagD(this, instr);
|
| if (FLAG_inline_new) {
|
| Register tmp = ToRegister(instr->temp());
|
| __ AllocateHeapNumber(reg, tmp, no_reg, deferred->entry());
|
| @@ -5399,10 +5375,8 @@ void LCodeGen::DoDeferredTaggedToI(LTaggedToI* instr) {
|
| void LCodeGen::DoTaggedToI(LTaggedToI* instr) {
|
| class DeferredTaggedToI V8_FINAL : public LDeferredCode {
|
| public:
|
| - DeferredTaggedToI(LCodeGen* codegen,
|
| - LTaggedToI* instr,
|
| - const X87Stack& x87_stack)
|
| - : LDeferredCode(codegen, x87_stack), instr_(instr) { }
|
| + DeferredTaggedToI(LCodeGen* codegen, LTaggedToI* instr)
|
| + : LDeferredCode(codegen), instr_(instr) { }
|
| virtual void Generate() V8_OVERRIDE {
|
| codegen()->DoDeferredTaggedToI(instr_);
|
| }
|
| @@ -5416,8 +5390,7 @@ void LCodeGen::DoTaggedToI(LTaggedToI* instr) {
|
| Register input_reg = ToRegister(input);
|
| ASSERT(input_reg.is(ToRegister(instr->result())));
|
|
|
| - DeferredTaggedToI* deferred =
|
| - new(zone()) DeferredTaggedToI(this, instr, x87_stack_);
|
| + DeferredTaggedToI* deferred = new(zone()) DeferredTaggedToI(this, instr);
|
|
|
| __ JumpIfNotSmi(input_reg, deferred->entry());
|
| __ SmiUntag(input_reg);
|
| @@ -5563,10 +5536,8 @@ void LCodeGen::DoDeferredTaggedToINoSSE2(LTaggedToINoSSE2* instr) {
|
| void LCodeGen::DoTaggedToINoSSE2(LTaggedToINoSSE2* instr) {
|
| class DeferredTaggedToINoSSE2 V8_FINAL : public LDeferredCode {
|
| public:
|
| - DeferredTaggedToINoSSE2(LCodeGen* codegen,
|
| - LTaggedToINoSSE2* instr,
|
| - const X87Stack& x87_stack)
|
| - : LDeferredCode(codegen, x87_stack), instr_(instr) { }
|
| + DeferredTaggedToINoSSE2(LCodeGen* codegen, LTaggedToINoSSE2* instr)
|
| + : LDeferredCode(codegen), instr_(instr) { }
|
| virtual void Generate() V8_OVERRIDE {
|
| codegen()->DoDeferredTaggedToINoSSE2(instr_);
|
| }
|
| @@ -5581,7 +5552,7 @@ void LCodeGen::DoTaggedToINoSSE2(LTaggedToINoSSE2* instr) {
|
| ASSERT(input_reg.is(ToRegister(instr->result())));
|
|
|
| DeferredTaggedToINoSSE2* deferred =
|
| - new(zone()) DeferredTaggedToINoSSE2(this, instr, x87_stack_);
|
| + new(zone()) DeferredTaggedToINoSSE2(this, instr);
|
|
|
| // Smi check.
|
| __ JumpIfNotSmi(input_reg, deferred->entry());
|
| @@ -5861,11 +5832,8 @@ void LCodeGen::DoDeferredInstanceMigration(LCheckMaps* instr, Register object) {
|
| void LCodeGen::DoCheckMaps(LCheckMaps* instr) {
|
| class DeferredCheckMaps V8_FINAL : public LDeferredCode {
|
| public:
|
| - DeferredCheckMaps(LCodeGen* codegen,
|
| - LCheckMaps* instr,
|
| - Register object,
|
| - const X87Stack& x87_stack)
|
| - : LDeferredCode(codegen, x87_stack), instr_(instr), object_(object) {
|
| + DeferredCheckMaps(LCodeGen* codegen, LCheckMaps* instr, Register object)
|
| + : LDeferredCode(codegen), instr_(instr), object_(object) {
|
| SetExit(check_maps());
|
| }
|
| virtual void Generate() V8_OVERRIDE {
|
| @@ -5889,7 +5857,7 @@ void LCodeGen::DoCheckMaps(LCheckMaps* instr) {
|
|
|
| DeferredCheckMaps* deferred = NULL;
|
| if (instr->hydrogen()->has_migration_target()) {
|
| - deferred = new(zone()) DeferredCheckMaps(this, instr, reg, x87_stack_);
|
| + deferred = new(zone()) DeferredCheckMaps(this, instr, reg);
|
| __ bind(deferred->check_maps());
|
| }
|
|
|
| @@ -6087,10 +6055,8 @@ void LCodeGen::DoClampTToUint8NoSSE2(LClampTToUint8NoSSE2* instr) {
|
| void LCodeGen::DoAllocate(LAllocate* instr) {
|
| class DeferredAllocate V8_FINAL : public LDeferredCode {
|
| public:
|
| - DeferredAllocate(LCodeGen* codegen,
|
| - LAllocate* instr,
|
| - const X87Stack& x87_stack)
|
| - : LDeferredCode(codegen, x87_stack), instr_(instr) { }
|
| + DeferredAllocate(LCodeGen* codegen, LAllocate* instr)
|
| + : LDeferredCode(codegen), instr_(instr) { }
|
| virtual void Generate() V8_OVERRIDE {
|
| codegen()->DoDeferredAllocate(instr_);
|
| }
|
| @@ -6100,7 +6066,7 @@ void LCodeGen::DoAllocate(LAllocate* instr) {
|
| };
|
|
|
| DeferredAllocate* deferred =
|
| - new(zone()) DeferredAllocate(this, instr, x87_stack_);
|
| + new(zone()) DeferredAllocate(this, instr);
|
|
|
| Register result = ToRegister(instr->result());
|
| Register temp = ToRegister(instr->temp());
|
| @@ -6440,10 +6406,8 @@ void LCodeGen::DoDeferredStackCheck(LStackCheck* instr) {
|
| void LCodeGen::DoStackCheck(LStackCheck* instr) {
|
| class DeferredStackCheck V8_FINAL : public LDeferredCode {
|
| public:
|
| - DeferredStackCheck(LCodeGen* codegen,
|
| - LStackCheck* instr,
|
| - const X87Stack& x87_stack)
|
| - : LDeferredCode(codegen, x87_stack), instr_(instr) { }
|
| + DeferredStackCheck(LCodeGen* codegen, LStackCheck* instr)
|
| + : LDeferredCode(codegen), instr_(instr) { }
|
| virtual void Generate() V8_OVERRIDE {
|
| codegen()->DoDeferredStackCheck(instr_);
|
| }
|
| @@ -6476,7 +6440,7 @@ void LCodeGen::DoStackCheck(LStackCheck* instr) {
|
| ASSERT(instr->hydrogen()->is_backwards_branch());
|
| // Perform stack overflow check if this goto needs it before jumping.
|
| DeferredStackCheck* deferred_stack_check =
|
| - new(zone()) DeferredStackCheck(this, instr, x87_stack_);
|
| + new(zone()) DeferredStackCheck(this, instr);
|
| ExternalReference stack_limit =
|
| ExternalReference::address_of_stack_limit(isolate());
|
| __ cmp(esp, Operand::StaticVariable(stack_limit));
|
|
|