 Chromium Code Reviews
 Chromium Code Reviews Issue 9425045:
  Support fast case for-in in Crankshaft.  (Closed) 
  Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
    
  
    Issue 9425045:
  Support fast case for-in in Crankshaft.  (Closed) 
  Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge| 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 |