Chromium Code Reviews| Index: src/ia32/lithium-codegen-ia32.cc |
| diff --git a/src/ia32/lithium-codegen-ia32.cc b/src/ia32/lithium-codegen-ia32.cc |
| index 3f003540f1e1ef0042a79bd5de9098b622ae327c..b8a4914f6f4adf0d241a6ae06b75409aa5e562dc 100644 |
| --- a/src/ia32/lithium-codegen-ia32.cc |
| +++ b/src/ia32/lithium-codegen-ia32.cc |
| @@ -4729,6 +4729,86 @@ void LCodeGen::DoIn(LIn* instr) { |
| } |
| +void LCodeGen::DoForInPrepareMap(LForInPrepareMap* instr) { |
| + __ cmp(eax, isolate()->factory()->undefined_value()); |
| + DeoptimizeIf(equal, instr->environment()); |
| + |
| + __ cmp(eax, isolate()->factory()->null_value()); |
| + DeoptimizeIf(equal, instr->environment()); |
| + |
| + __ test(eax, Immediate(kSmiTagMask)); |
| + DeoptimizeIf(zero, instr->environment()); |
| + |
| + __ CmpObjectType(eax, FIRST_SPEC_OBJECT_TYPE, ecx); |
| + DeoptimizeIf(below, instr->environment()); |
| + |
| + STATIC_ASSERT(FIRST_JS_PROXY_TYPE == FIRST_SPEC_OBJECT_TYPE); |
| + __ CmpObjectType(eax, LAST_JS_PROXY_TYPE, ecx); |
| + DeoptimizeIf(below_equal, instr->environment()); |
| + |
| + Label use_cache, call_runtime; |
| + __ CheckEnumCache(&call_runtime); |
| + |
| + __ mov(eax, FieldOperand(eax, HeapObject::kMapOffset)); |
| + __ jmp(&use_cache, Label::kNear); |
| + |
| + // Get the set of properties to enumerate. |
| + __ bind(&call_runtime); |
| + __ push(eax); |
| + CallRuntime(Runtime::kGetPropertyNamesFast, 1, instr); |
| + |
| + __ cmp(FieldOperand(eax, HeapObject::kMapOffset), |
| + isolate()->factory()->meta_map()); |
| + DeoptimizeIf(not_equal, instr->environment()); |
| + __ bind(&use_cache); |
| +} |
| + |
| + |
| +void LCodeGen::DoForInCacheArray(LForInCacheArray* instr) { |
| + Register map = ToRegister(instr->keys()); |
| + Register result = ToRegister(instr->result()); |
| + __ LoadInstanceDescriptors(map, result); |
| + __ mov(result, |
| + FieldOperand(result, DescriptorArray::kEnumerationIndexOffset)); |
| + __ mov(result, |
| + FieldOperand(result, FixedArray::SizeFor(instr->idx()))); |
| + __ test(result, result); |
| + DeoptimizeIf(equal, instr->environment()); |
| +} |
| + |
| + |
| +void LCodeGen::DoCheckMapValue(LCheckMapValue* instr) { |
| + Register object = ToRegister(instr->value()); |
| + __ cmp(ToRegister(instr->map()), |
| + FieldOperand(object, HeapObject::kMapOffset)); |
| + DeoptimizeIf(not_equal, instr->environment()); |
| +} |
| + |
| + |
| +void LCodeGen::DoLoadFieldByIndex(LLoadFieldByIndex* instr) { |
| + Register object = ToRegister(instr->object()); |
| + Register index = ToRegister(instr->index()); |
| + |
| + Label out_of_object, done; |
| + __ cmp(index, Immediate(0)); |
| + __ j(less, &out_of_object); |
| + __ mov(object, Operand(object, |
| + index, |
| + times_half_pointer_size, |
| + JSObject::kHeaderSize - kHeapObjectTag)); |
|
fschneider
2012/02/20 14:56:06
Maybe use FieldOperand instead to avoid having to
|
| + __ jmp(&done, Label::kNear); |
| + |
| + __ bind(&out_of_object); |
| + __ mov(object, FieldOperand(object, JSObject::kPropertiesOffset)); |
| + __ neg(index); |
| + __ mov(object, Operand(object, |
| + index, |
| + times_half_pointer_size, |
| + kPointerSize - kHeapObjectTag)); |
|
fschneider
2012/02/20 14:56:06
Shouldn't this be FixedArray::kHeaderSize - kHeapO
|
| + __ bind(&done); |
| +} |
| + |
| + |
| #undef __ |
| } } // namespace v8::internal |