| Index: src/ia32/lithium-codegen-ia32.cc
|
| ===================================================================
|
| --- src/ia32/lithium-codegen-ia32.cc (revision 7563)
|
| +++ src/ia32/lithium-codegen-ia32.cc (working copy)
|
| @@ -466,7 +466,7 @@
|
| }
|
|
|
|
|
| -void LCodeGen::CallRuntime(Runtime::Function* fun,
|
| +void LCodeGen::CallRuntime(const Runtime::Function* fun,
|
| int argc,
|
| LInstruction* instr,
|
| bool adjusted) {
|
| @@ -586,14 +586,14 @@
|
| if (length == 0) return;
|
| ASSERT(FLAG_deopt);
|
| Handle<DeoptimizationInputData> data =
|
| - Factory::NewDeoptimizationInputData(length, TENURED);
|
| + factory()->NewDeoptimizationInputData(length, TENURED);
|
|
|
| Handle<ByteArray> translations = translations_.CreateByteArray();
|
| data->SetTranslationByteArray(*translations);
|
| data->SetInlinedFunctionCount(Smi::FromInt(inlined_function_count_));
|
|
|
| Handle<FixedArray> literals =
|
| - Factory::NewFixedArray(deoptimization_literals_.length(), TENURED);
|
| + factory()->NewFixedArray(deoptimization_literals_.length(), TENURED);
|
| for (int i = 0; i < deoptimization_literals_.length(); i++) {
|
| literals->set(i, *deoptimization_literals_[i]);
|
| }
|
| @@ -1095,7 +1095,7 @@
|
| uint64_t int_val = BitCast<uint64_t, double>(v);
|
| int32_t lower = static_cast<int32_t>(int_val);
|
| int32_t upper = static_cast<int32_t>(int_val >> (kBitsPerInt));
|
| - if (CpuFeatures::IsSupported(SSE4_1)) {
|
| + if (isolate()->cpu_features()->IsSupported(SSE4_1)) {
|
| CpuFeatures::Scope scope(SSE4_1);
|
| if (lower != 0) {
|
| __ Set(temp, Immediate(lower));
|
| @@ -1298,17 +1298,17 @@
|
| ASSERT(r.IsTagged());
|
| Register reg = ToRegister(instr->InputAt(0));
|
| if (instr->hydrogen()->type().IsBoolean()) {
|
| - __ cmp(reg, Factory::true_value());
|
| + __ cmp(reg, factory()->true_value());
|
| EmitBranch(true_block, false_block, equal);
|
| } else {
|
| Label* true_label = chunk_->GetAssemblyLabel(true_block);
|
| Label* false_label = chunk_->GetAssemblyLabel(false_block);
|
|
|
| - __ cmp(reg, Factory::undefined_value());
|
| + __ cmp(reg, factory()->undefined_value());
|
| __ j(equal, false_label);
|
| - __ cmp(reg, Factory::true_value());
|
| + __ cmp(reg, factory()->true_value());
|
| __ j(equal, true_label);
|
| - __ cmp(reg, Factory::false_value());
|
| + __ cmp(reg, factory()->false_value());
|
| __ j(equal, false_label);
|
| __ test(reg, Operand(reg));
|
| __ j(equal, false_label);
|
| @@ -1318,7 +1318,7 @@
|
| // Test for double values. Zero is false.
|
| NearLabel call_stub;
|
| __ cmp(FieldOperand(reg, HeapObject::kMapOffset),
|
| - Factory::heap_number_map());
|
| + factory()->heap_number_map());
|
| __ j(not_equal, &call_stub);
|
| __ fldz();
|
| __ fld_d(FieldOperand(reg, HeapNumber::kValueOffset));
|
| @@ -1441,11 +1441,11 @@
|
|
|
| NearLabel done;
|
| Condition cc = TokenToCondition(instr->op(), instr->is_double());
|
| - __ mov(ToRegister(result), Factory::true_value());
|
| + __ mov(ToRegister(result), factory()->true_value());
|
| __ j(cc, &done);
|
|
|
| __ bind(&unordered);
|
| - __ mov(ToRegister(result), Factory::false_value());
|
| + __ mov(ToRegister(result), factory()->false_value());
|
| __ bind(&done);
|
| }
|
|
|
| @@ -1476,10 +1476,10 @@
|
| Register result = ToRegister(instr->result());
|
|
|
| __ cmp(left, Operand(right));
|
| - __ mov(result, Factory::true_value());
|
| + __ mov(result, factory()->true_value());
|
| NearLabel done;
|
| __ j(equal, &done);
|
| - __ mov(result, Factory::false_value());
|
| + __ mov(result, factory()->false_value());
|
| __ bind(&done);
|
| }
|
|
|
| @@ -1502,17 +1502,17 @@
|
| // TODO(fsc): If the expression is known to be a smi, then it's
|
| // definitely not null. Materialize false.
|
|
|
| - __ cmp(reg, Factory::null_value());
|
| + __ cmp(reg, factory()->null_value());
|
| if (instr->is_strict()) {
|
| - __ mov(result, Factory::true_value());
|
| + __ mov(result, factory()->true_value());
|
| NearLabel done;
|
| __ j(equal, &done);
|
| - __ mov(result, Factory::false_value());
|
| + __ mov(result, factory()->false_value());
|
| __ bind(&done);
|
| } else {
|
| NearLabel true_value, false_value, done;
|
| __ j(equal, &true_value);
|
| - __ cmp(reg, Factory::undefined_value());
|
| + __ cmp(reg, factory()->undefined_value());
|
| __ j(equal, &true_value);
|
| __ test(reg, Immediate(kSmiTagMask));
|
| __ j(zero, &false_value);
|
| @@ -1524,10 +1524,10 @@
|
| __ test(scratch, Immediate(1 << Map::kIsUndetectable));
|
| __ j(not_zero, &true_value);
|
| __ bind(&false_value);
|
| - __ mov(result, Factory::false_value());
|
| + __ mov(result, factory()->false_value());
|
| __ jmp(&done);
|
| __ bind(&true_value);
|
| - __ mov(result, Factory::true_value());
|
| + __ mov(result, factory()->true_value());
|
| __ bind(&done);
|
| }
|
| }
|
| @@ -1542,14 +1542,14 @@
|
| int true_block = chunk_->LookupDestination(instr->true_block_id());
|
| int false_block = chunk_->LookupDestination(instr->false_block_id());
|
|
|
| - __ cmp(reg, Factory::null_value());
|
| + __ cmp(reg, factory()->null_value());
|
| if (instr->is_strict()) {
|
| EmitBranch(true_block, false_block, equal);
|
| } else {
|
| Label* true_label = chunk_->GetAssemblyLabel(true_block);
|
| Label* false_label = chunk_->GetAssemblyLabel(false_block);
|
| __ j(equal, true_label);
|
| - __ cmp(reg, Factory::undefined_value());
|
| + __ cmp(reg, factory()->undefined_value());
|
| __ j(equal, true_label);
|
| __ test(reg, Immediate(kSmiTagMask));
|
| __ j(zero, false_label);
|
| @@ -1576,7 +1576,7 @@
|
| __ test(input, Immediate(kSmiTagMask));
|
| __ j(equal, is_not_object);
|
|
|
| - __ cmp(input, Factory::null_value());
|
| + __ cmp(input, isolate()->factory()->null_value());
|
| __ j(equal, is_object);
|
|
|
| __ mov(temp1, FieldOperand(input, HeapObject::kMapOffset));
|
| @@ -1603,11 +1603,11 @@
|
| __ j(true_cond, &is_true);
|
|
|
| __ bind(&is_false);
|
| - __ mov(result, Factory::false_value());
|
| + __ mov(result, factory()->false_value());
|
| __ jmp(&done);
|
|
|
| __ bind(&is_true);
|
| - __ mov(result, Factory::true_value());
|
| + __ mov(result, factory()->true_value());
|
|
|
| __ bind(&done);
|
| }
|
| @@ -1635,10 +1635,10 @@
|
|
|
| ASSERT(instr->hydrogen()->value()->representation().IsTagged());
|
| __ test(input, Immediate(kSmiTagMask));
|
| - __ mov(result, Factory::true_value());
|
| + __ mov(result, factory()->true_value());
|
| NearLabel done;
|
| __ j(zero, &done);
|
| - __ mov(result, Factory::false_value());
|
| + __ mov(result, factory()->false_value());
|
| __ bind(&done);
|
| }
|
|
|
| @@ -1684,10 +1684,10 @@
|
| __ j(zero, &is_false);
|
| __ CmpObjectType(input, TestType(instr->hydrogen()), result);
|
| __ j(NegateCondition(BranchCondition(instr->hydrogen())), &is_false);
|
| - __ mov(result, Factory::true_value());
|
| + __ mov(result, factory()->true_value());
|
| __ jmp(&done);
|
| __ bind(&is_false);
|
| - __ mov(result, Factory::false_value());
|
| + __ mov(result, factory()->false_value());
|
| __ bind(&done);
|
| }
|
|
|
| @@ -1727,12 +1727,12 @@
|
| Register result = ToRegister(instr->result());
|
|
|
| ASSERT(instr->hydrogen()->value()->representation().IsTagged());
|
| - __ mov(result, Factory::true_value());
|
| + __ mov(result, factory()->true_value());
|
| __ test(FieldOperand(input, String::kHashFieldOffset),
|
| Immediate(String::kContainsCachedArrayIndexMask));
|
| NearLabel done;
|
| __ j(zero, &done);
|
| - __ mov(result, Factory::false_value());
|
| + __ mov(result, factory()->false_value());
|
| __ bind(&done);
|
| }
|
|
|
| @@ -1821,11 +1821,11 @@
|
| __ j(not_equal, &is_false);
|
|
|
| __ bind(&is_true);
|
| - __ mov(result, Factory::true_value());
|
| + __ mov(result, factory()->true_value());
|
| __ jmp(&done);
|
|
|
| __ bind(&is_false);
|
| - __ mov(result, Factory::false_value());
|
| + __ mov(result, factory()->false_value());
|
| __ bind(&done);
|
| }
|
|
|
| @@ -1873,10 +1873,10 @@
|
| NearLabel true_value, done;
|
| __ test(eax, Operand(eax));
|
| __ j(zero, &true_value);
|
| - __ mov(ToRegister(instr->result()), Factory::false_value());
|
| + __ mov(ToRegister(instr->result()), factory()->false_value());
|
| __ jmp(&done);
|
| __ bind(&true_value);
|
| - __ mov(ToRegister(instr->result()), Factory::true_value());
|
| + __ mov(ToRegister(instr->result()), factory()->true_value());
|
| __ bind(&done);
|
| }
|
|
|
| @@ -1928,16 +1928,16 @@
|
| Register map = ToRegister(instr->TempAt(0));
|
| __ mov(map, FieldOperand(object, HeapObject::kMapOffset));
|
| __ bind(deferred->map_check()); // Label for calculating code patching.
|
| - __ cmp(map, Factory::the_hole_value()); // Patched to cached map.
|
| + __ cmp(map, factory()->the_hole_value()); // Patched to cached map.
|
| __ j(not_equal, &cache_miss, not_taken);
|
| - __ mov(eax, Factory::the_hole_value()); // Patched to either true or false.
|
| + __ mov(eax, factory()->the_hole_value()); // Patched to either true or false.
|
| __ jmp(&done);
|
|
|
| // The inlined call site cache did not match. Check for null and string
|
| // before calling the deferred code.
|
| __ bind(&cache_miss);
|
| // Null is not an instance of anything.
|
| - __ cmp(object, Factory::null_value());
|
| + __ cmp(object, factory()->null_value());
|
| __ j(equal, &false_result);
|
|
|
| // String values are not instances of anything.
|
| @@ -1948,7 +1948,7 @@
|
| __ jmp(deferred->entry());
|
|
|
| __ bind(&false_result);
|
| - __ mov(ToRegister(instr->result()), Factory::false_value());
|
| + __ mov(ToRegister(instr->result()), factory()->false_value());
|
|
|
| // Here result has either true or false. Deferred code also produces true or
|
| // false object.
|
| @@ -2020,10 +2020,10 @@
|
| NearLabel true_value, done;
|
| __ test(eax, Operand(eax));
|
| __ j(condition, &true_value);
|
| - __ mov(ToRegister(instr->result()), Factory::false_value());
|
| + __ mov(ToRegister(instr->result()), factory()->false_value());
|
| __ jmp(&done);
|
| __ bind(&true_value);
|
| - __ mov(ToRegister(instr->result()), Factory::true_value());
|
| + __ mov(ToRegister(instr->result()), factory()->true_value());
|
| __ bind(&done);
|
| }
|
|
|
| @@ -2067,7 +2067,7 @@
|
| Register result = ToRegister(instr->result());
|
| __ mov(result, Operand::Cell(instr->hydrogen()->cell()));
|
| if (instr->hydrogen()->check_hole_value()) {
|
| - __ cmp(result, Factory::the_hole_value());
|
| + __ cmp(result, factory()->the_hole_value());
|
| DeoptimizeIf(equal, instr->environment());
|
| }
|
| }
|
| @@ -2084,7 +2084,7 @@
|
| // to update the property details in the property dictionary to mark
|
| // it as no longer deleted. We deoptimize in that case.
|
| if (instr->hydrogen()->check_hole_value()) {
|
| - __ cmp(Operand::Cell(cell_handle), Factory::the_hole_value());
|
| + __ cmp(Operand::Cell(cell_handle), factory()->the_hole_value());
|
| DeoptimizeIf(equal, instr->environment());
|
| }
|
|
|
| @@ -2136,7 +2136,7 @@
|
| ASSERT(ToRegister(instr->result()).is(eax));
|
|
|
| __ mov(ecx, instr->name());
|
| - Handle<Code> ic(Builtins::builtin(Builtins::LoadIC_Initialize));
|
| + Handle<Code> ic(isolate()->builtins()->builtin(Builtins::LoadIC_Initialize));
|
| CallCode(ic, RelocInfo::CODE_TARGET, instr);
|
| }
|
|
|
| @@ -2161,7 +2161,7 @@
|
| FieldOperand(function, JSFunction::kPrototypeOrInitialMapOffset));
|
|
|
| // Check that the function has a prototype or an initial map.
|
| - __ cmp(Operand(result), Immediate(Factory::the_hole_value()));
|
| + __ cmp(Operand(result), Immediate(factory()->the_hole_value()));
|
| DeoptimizeIf(equal, instr->environment());
|
|
|
| // If the function does not have an initial map, we're done.
|
| @@ -2190,13 +2190,13 @@
|
| if (FLAG_debug_code) {
|
| NearLabel done;
|
| __ cmp(FieldOperand(result, HeapObject::kMapOffset),
|
| - Immediate(Factory::fixed_array_map()));
|
| + Immediate(factory()->fixed_array_map()));
|
| __ j(equal, &done);
|
| __ cmp(FieldOperand(result, HeapObject::kMapOffset),
|
| - Immediate(Factory::external_pixel_array_map()));
|
| + Immediate(factory()->external_pixel_array_map()));
|
| __ j(equal, &done);
|
| __ cmp(FieldOperand(result, HeapObject::kMapOffset),
|
| - Immediate(Factory::fixed_cow_array_map()));
|
| + Immediate(factory()->fixed_cow_array_map()));
|
| __ Check(equal, "Check for fast elements or pixel array failed.");
|
| __ bind(&done);
|
| }
|
| @@ -2240,7 +2240,7 @@
|
| FixedArray::kHeaderSize));
|
|
|
| // Check for the hole value.
|
| - __ cmp(result, Factory::the_hole_value());
|
| + __ cmp(result, factory()->the_hole_value());
|
| DeoptimizeIf(equal, instr->environment());
|
| }
|
|
|
| @@ -2261,7 +2261,8 @@
|
| ASSERT(ToRegister(instr->object()).is(edx));
|
| ASSERT(ToRegister(instr->key()).is(eax));
|
|
|
| - Handle<Code> ic(Builtins::builtin(Builtins::KeyedLoadIC_Initialize));
|
| + Handle<Code> ic(isolate()->builtins()->builtin(
|
| + Builtins::KeyedLoadIC_Initialize));
|
| CallCode(ic, RelocInfo::CODE_TARGET, instr);
|
| }
|
|
|
| @@ -2326,9 +2327,9 @@
|
| // If the receiver is null or undefined, we have to pass the global object
|
| // as a receiver.
|
| NearLabel global_object, receiver_ok;
|
| - __ cmp(receiver, Factory::null_value());
|
| + __ cmp(receiver, factory()->null_value());
|
| __ j(equal, &global_object);
|
| - __ cmp(receiver, Factory::undefined_value());
|
| + __ cmp(receiver, factory()->undefined_value());
|
| __ j(equal, &global_object);
|
|
|
| // The receiver should be a JS object.
|
| @@ -2466,7 +2467,7 @@
|
| void LCodeGen::DoDeferredMathAbsTaggedHeapNumber(LUnaryMathOperation* instr) {
|
| Register input_reg = ToRegister(instr->InputAt(0));
|
| __ cmp(FieldOperand(input_reg, HeapObject::kMapOffset),
|
| - Factory::heap_number_map());
|
| + factory()->heap_number_map());
|
| DeoptimizeIf(not_equal, instr->environment());
|
|
|
| Label done;
|
| @@ -2761,7 +2762,8 @@
|
| ASSERT(ToRegister(instr->result()).is(eax));
|
|
|
| int arity = instr->arity();
|
| - Handle<Code> ic = StubCache::ComputeKeyedCallInitialize(arity, NOT_IN_LOOP);
|
| + Handle<Code> ic = isolate()->stub_cache()->
|
| + ComputeKeyedCallInitialize(arity, NOT_IN_LOOP);
|
| CallCode(ic, RelocInfo::CODE_TARGET, instr);
|
| }
|
|
|
| @@ -2771,7 +2773,8 @@
|
| ASSERT(ToRegister(instr->result()).is(eax));
|
|
|
| int arity = instr->arity();
|
| - Handle<Code> ic = StubCache::ComputeCallInitialize(arity, NOT_IN_LOOP);
|
| + Handle<Code> ic = isolate()->stub_cache()->
|
| + ComputeCallInitialize(arity, NOT_IN_LOOP);
|
| __ mov(ecx, instr->name());
|
| CallCode(ic, RelocInfo::CODE_TARGET, instr);
|
| }
|
| @@ -2793,7 +2796,8 @@
|
| ASSERT(ToRegister(instr->result()).is(eax));
|
|
|
| int arity = instr->arity();
|
| - Handle<Code> ic = StubCache::ComputeCallInitialize(arity, NOT_IN_LOOP);
|
| + Handle<Code> ic = isolate()->stub_cache()->
|
| + ComputeCallInitialize(arity, NOT_IN_LOOP);
|
| __ mov(ecx, instr->name());
|
| CallCode(ic, RelocInfo::CODE_TARGET_CONTEXT, instr);
|
| }
|
| @@ -2811,7 +2815,8 @@
|
| ASSERT(ToRegister(instr->constructor()).is(edi));
|
| ASSERT(ToRegister(instr->result()).is(eax));
|
|
|
| - Handle<Code> builtin(Builtins::builtin(Builtins::JSConstructCall));
|
| + Handle<Code> builtin(isolate()->builtins()->builtin(
|
| + Builtins::JSConstructCall));
|
| __ Set(eax, Immediate(instr->arity()));
|
| CallCode(builtin, RelocInfo::CONSTRUCT_CALL, instr);
|
| }
|
| @@ -2858,7 +2863,7 @@
|
| ASSERT(ToRegister(instr->value()).is(eax));
|
|
|
| __ mov(ecx, instr->name());
|
| - Handle<Code> ic(Builtins::builtin(
|
| + Handle<Code> ic(isolate()->builtins()->builtin(
|
| info_->is_strict() ? Builtins::StoreIC_Initialize_Strict
|
| : Builtins::StoreIC_Initialize));
|
| CallCode(ic, RelocInfo::CODE_TARGET, instr);
|
| @@ -2928,7 +2933,7 @@
|
| ASSERT(ToRegister(instr->key()).is(ecx));
|
| ASSERT(ToRegister(instr->value()).is(eax));
|
|
|
| - Handle<Code> ic(Builtins::builtin(
|
| + Handle<Code> ic(isolate()->builtins()->builtin(
|
| info_->is_strict() ? Builtins::KeyedStoreIC_Initialize_Strict
|
| : Builtins::KeyedStoreIC_Initialize));
|
| CallCode(ic, RelocInfo::CODE_TARGET, instr);
|
| @@ -2990,7 +2995,7 @@
|
| // the case we would rather go to the runtime system now to flatten
|
| // the string.
|
| __ cmp(FieldOperand(string, ConsString::kSecondOffset),
|
| - Immediate(Factory::empty_string()));
|
| + Immediate(factory()->empty_string()));
|
| __ j(not_equal, deferred->entry());
|
| // Get the first of the two strings and load its instance type.
|
| __ mov(string, FieldOperand(string, ConsString::kFirstOffset));
|
| @@ -3095,11 +3100,11 @@
|
|
|
| __ cmp(char_code, String::kMaxAsciiCharCode);
|
| __ j(above, deferred->entry());
|
| - __ Set(result, Immediate(Factory::single_character_string_cache()));
|
| + __ Set(result, Immediate(factory()->single_character_string_cache()));
|
| __ mov(result, FieldOperand(result,
|
| char_code, times_pointer_size,
|
| FixedArray::kHeaderSize));
|
| - __ cmp(result, Factory::undefined_value());
|
| + __ cmp(result, factory()->undefined_value());
|
| __ j(equal, deferred->entry());
|
| __ bind(deferred->exit());
|
| }
|
| @@ -3277,10 +3282,10 @@
|
|
|
| // Heap number map check.
|
| __ cmp(FieldOperand(input_reg, HeapObject::kMapOffset),
|
| - Factory::heap_number_map());
|
| + factory()->heap_number_map());
|
| __ j(equal, &heap_number);
|
|
|
| - __ cmp(input_reg, Factory::undefined_value());
|
| + __ cmp(input_reg, factory()->undefined_value());
|
| DeoptimizeIf(not_equal, env);
|
|
|
| // Convert undefined to NaN.
|
| @@ -3318,19 +3323,19 @@
|
|
|
| // Heap number map check.
|
| __ cmp(FieldOperand(input_reg, HeapObject::kMapOffset),
|
| - Factory::heap_number_map());
|
| + factory()->heap_number_map());
|
|
|
| if (instr->truncating()) {
|
| __ j(equal, &heap_number);
|
| // Check for undefined. Undefined is converted to zero for truncating
|
| // conversions.
|
| - __ cmp(input_reg, Factory::undefined_value());
|
| + __ cmp(input_reg, factory()->undefined_value());
|
| DeoptimizeIf(not_equal, instr->environment());
|
| __ mov(input_reg, 0);
|
| __ jmp(&done);
|
|
|
| __ bind(&heap_number);
|
| - if (CpuFeatures::IsSupported(SSE3)) {
|
| + if (isolate()->cpu_features()->IsSupported(SSE3)) {
|
| CpuFeatures::Scope scope(SSE3);
|
| NearLabel convert;
|
| // Use more powerful conversion when sse3 is available.
|
| @@ -3440,7 +3445,7 @@
|
| // the JS bitwise operations.
|
| __ cvttsd2si(result_reg, Operand(input_reg));
|
| __ cmp(result_reg, 0x80000000u);
|
| - if (CpuFeatures::IsSupported(SSE3)) {
|
| + if (isolate()->cpu_features()->IsSupported(SSE3)) {
|
| // This will deoptimize if the exponent of the input in out of range.
|
| CpuFeatures::Scope scope(SSE3);
|
| NearLabel convert, done;
|
| @@ -3607,9 +3612,9 @@
|
|
|
|
|
| void LCodeGen::LoadHeapObject(Register result, Handle<HeapObject> object) {
|
| - if (Heap::InNewSpace(*object)) {
|
| + if (isolate()->heap()->InNewSpace(*object)) {
|
| Handle<JSGlobalPropertyCell> cell =
|
| - Factory::NewJSGlobalPropertyCell(object);
|
| + isolate()->factory()->NewJSGlobalPropertyCell(object);
|
| __ mov(result, Operand::Cell(cell));
|
| } else {
|
| __ mov(result, object);
|
| @@ -3702,7 +3707,7 @@
|
| int literal_offset = FixedArray::kHeaderSize +
|
| instr->hydrogen()->literal_index() * kPointerSize;
|
| __ mov(ebx, FieldOperand(ecx, literal_offset));
|
| - __ cmp(ebx, Factory::undefined_value());
|
| + __ cmp(ebx, factory()->undefined_value());
|
| __ j(not_equal, &materialized);
|
|
|
| // Create regexp literal using runtime function
|
| @@ -3756,8 +3761,8 @@
|
| __ push(Operand(ebp, StandardFrameConstants::kContextOffset));
|
| __ push(Immediate(shared_info));
|
| __ push(Immediate(pretenure
|
| - ? Factory::true_value()
|
| - : Factory::false_value()));
|
| + ? factory()->true_value()
|
| + : factory()->false_value()));
|
| CallRuntime(Runtime::kNewClosure, 3, instr, false);
|
| }
|
| }
|
| @@ -3787,11 +3792,11 @@
|
| instr->type_literal());
|
| __ j(final_branch_condition, &true_label);
|
| __ bind(&false_label);
|
| - __ mov(result, Factory::false_value());
|
| + __ mov(result, factory()->false_value());
|
| __ jmp(&done);
|
|
|
| __ bind(&true_label);
|
| - __ mov(result, Factory::true_value());
|
| + __ mov(result, factory()->true_value());
|
|
|
| __ bind(&done);
|
| }
|
| @@ -3818,13 +3823,13 @@
|
| Register input,
|
| Handle<String> type_name) {
|
| Condition final_branch_condition = no_condition;
|
| - if (type_name->Equals(Heap::number_symbol())) {
|
| + if (type_name->Equals(heap()->number_symbol())) {
|
| __ JumpIfSmi(input, true_label);
|
| __ cmp(FieldOperand(input, HeapObject::kMapOffset),
|
| - Factory::heap_number_map());
|
| + factory()->heap_number_map());
|
| final_branch_condition = equal;
|
|
|
| - } else if (type_name->Equals(Heap::string_symbol())) {
|
| + } else if (type_name->Equals(heap()->string_symbol())) {
|
| __ JumpIfSmi(input, false_label);
|
| __ CmpObjectType(input, FIRST_NONSTRING_TYPE, input);
|
| __ j(above_equal, false_label);
|
| @@ -3832,14 +3837,14 @@
|
| 1 << Map::kIsUndetectable);
|
| final_branch_condition = zero;
|
|
|
| - } else if (type_name->Equals(Heap::boolean_symbol())) {
|
| - __ cmp(input, Factory::true_value());
|
| + } else if (type_name->Equals(heap()->boolean_symbol())) {
|
| + __ cmp(input, factory()->true_value());
|
| __ j(equal, true_label);
|
| - __ cmp(input, Factory::false_value());
|
| + __ cmp(input, factory()->false_value());
|
| final_branch_condition = equal;
|
|
|
| - } else if (type_name->Equals(Heap::undefined_symbol())) {
|
| - __ cmp(input, Factory::undefined_value());
|
| + } else if (type_name->Equals(heap()->undefined_symbol())) {
|
| + __ cmp(input, factory()->undefined_value());
|
| __ j(equal, true_label);
|
| __ JumpIfSmi(input, false_label);
|
| // Check for undetectable objects => true.
|
| @@ -3848,7 +3853,7 @@
|
| 1 << Map::kIsUndetectable);
|
| final_branch_condition = not_zero;
|
|
|
| - } else if (type_name->Equals(Heap::function_symbol())) {
|
| + } else if (type_name->Equals(heap()->function_symbol())) {
|
| __ JumpIfSmi(input, false_label);
|
| __ CmpObjectType(input, JS_FUNCTION_TYPE, input);
|
| __ j(equal, true_label);
|
| @@ -3856,9 +3861,9 @@
|
| __ CmpInstanceType(input, JS_REGEXP_TYPE);
|
| final_branch_condition = equal;
|
|
|
| - } else if (type_name->Equals(Heap::object_symbol())) {
|
| + } else if (type_name->Equals(heap()->object_symbol())) {
|
| __ JumpIfSmi(input, false_label);
|
| - __ cmp(input, Factory::null_value());
|
| + __ cmp(input, factory()->null_value());
|
| __ j(equal, true_label);
|
| // Regular expressions => 'function', not 'object'.
|
| __ CmpObjectType(input, FIRST_JS_OBJECT_TYPE, input);
|
| @@ -3889,11 +3894,11 @@
|
| EmitIsConstructCall(result);
|
| __ j(equal, &true_label);
|
|
|
| - __ mov(result, Factory::false_value());
|
| + __ mov(result, factory()->false_value());
|
| __ jmp(&done);
|
|
|
| __ bind(&true_label);
|
| - __ mov(result, Factory::true_value());
|
| + __ mov(result, factory()->true_value());
|
|
|
| __ bind(&done);
|
| }
|
|
|