| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 2277 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2288 | 2288 |
| 2289 if (instr->value()->representation().IsDouble()) { | 2289 if (instr->value()->representation().IsDouble()) { |
| 2290 LOperand* object = UseRegisterAtStart(instr->elements()); | 2290 LOperand* object = UseRegisterAtStart(instr->elements()); |
| 2291 LOperand* val = NULL; | 2291 LOperand* val = NULL; |
| 2292 if (CpuFeatures::IsSafeForSnapshot(SSE2)) { | 2292 if (CpuFeatures::IsSafeForSnapshot(SSE2)) { |
| 2293 val = UseRegisterAtStart(instr->value()); | 2293 val = UseRegisterAtStart(instr->value()); |
| 2294 } else if (!instr->IsConstantHoleStore()) { | 2294 } else if (!instr->IsConstantHoleStore()) { |
| 2295 val = UseX87TopOfStack(instr->value()); | 2295 val = UseX87TopOfStack(instr->value()); |
| 2296 } | 2296 } |
| 2297 LOperand* key = UseRegisterOrConstantAtStart(instr->key()); | 2297 LOperand* key = UseRegisterOrConstantAtStart(instr->key()); |
| 2298 | |
| 2299 return new(zone()) LStoreKeyed(object, key, val); | 2298 return new(zone()) LStoreKeyed(object, key, val); |
| 2300 } else { | 2299 } else { |
| 2301 ASSERT(instr->value()->representation().IsTagged()); | 2300 ASSERT(instr->value()->representation().IsTagged()); |
| 2302 bool needs_write_barrier = instr->NeedsWriteBarrier(); | 2301 bool needs_write_barrier = instr->NeedsWriteBarrier(); |
| 2303 | 2302 |
| 2304 LOperand* obj = UseRegister(instr->elements()); | 2303 LOperand* obj = UseRegister(instr->elements()); |
| 2305 LOperand* val = needs_write_barrier | 2304 LOperand* val; |
| 2306 ? UseTempRegister(instr->value()) | 2305 LOperand* key; |
| 2307 : UseRegisterAtStart(instr->value()); | 2306 if (needs_write_barrier) { |
| 2308 LOperand* key = needs_write_barrier | 2307 val = UseTempRegister(instr->value()); |
| 2309 ? UseTempRegister(instr->key()) | 2308 key = UseTempRegister(instr->key()); |
| 2310 : UseRegisterOrConstantAtStart(instr->key()); | 2309 } else { |
| 2310 val = UseRegisterOrConstantAtStart(instr->value()); |
| 2311 key = UseRegisterOrConstantAtStart(instr->key()); |
| 2312 } |
| 2311 return new(zone()) LStoreKeyed(obj, key, val); | 2313 return new(zone()) LStoreKeyed(obj, key, val); |
| 2312 } | 2314 } |
| 2313 } | 2315 } |
| 2314 | 2316 |
| 2315 ElementsKind elements_kind = instr->elements_kind(); | 2317 ElementsKind elements_kind = instr->elements_kind(); |
| 2316 ASSERT( | 2318 ASSERT( |
| 2317 (instr->value()->representation().IsInteger32() && | 2319 (instr->value()->representation().IsInteger32() && |
| 2318 (elements_kind != EXTERNAL_FLOAT_ELEMENTS) && | 2320 (elements_kind != EXTERNAL_FLOAT_ELEMENTS) && |
| 2319 (elements_kind != EXTERNAL_DOUBLE_ELEMENTS)) || | 2321 (elements_kind != EXTERNAL_DOUBLE_ELEMENTS)) || |
| 2320 (instr->value()->representation().IsDouble() && | 2322 (instr->value()->representation().IsDouble() && |
| (...skipping 79 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2400 if (needs_write_barrier) { | 2402 if (needs_write_barrier) { |
| 2401 obj = instr->is_in_object() | 2403 obj = instr->is_in_object() |
| 2402 ? UseRegister(instr->object()) | 2404 ? UseRegister(instr->object()) |
| 2403 : UseTempRegister(instr->object()); | 2405 : UseTempRegister(instr->object()); |
| 2404 } else { | 2406 } else { |
| 2405 obj = needs_write_barrier_for_map | 2407 obj = needs_write_barrier_for_map |
| 2406 ? UseRegister(instr->object()) | 2408 ? UseRegister(instr->object()) |
| 2407 : UseRegisterAtStart(instr->object()); | 2409 : UseRegisterAtStart(instr->object()); |
| 2408 } | 2410 } |
| 2409 | 2411 |
| 2410 LOperand* val = needs_write_barrier | 2412 bool register_or_constant = false; |
| 2411 ? UseTempRegister(instr->value()) | 2413 if (instr->value()->IsConstant()) { |
| 2412 : UseRegister(instr->value()); | 2414 HConstant* constant_value = HConstant::cast(instr->value()); |
| 2415 register_or_constant = constant_value->HasInteger32Value() |
| 2416 || constant_value->HasDoubleValue() |
| 2417 || constant_value->ImmortalImmovable(); |
| 2418 } |
| 2419 |
| 2420 LOperand* val; |
| 2421 if (needs_write_barrier) { |
| 2422 val = UseTempRegister(instr->value()); |
| 2423 } else if (register_or_constant) { |
| 2424 val = UseRegisterOrConstant(instr->value()); |
| 2425 } else { |
| 2426 val = UseRegister(instr->value()); |
| 2427 } |
| 2413 | 2428 |
| 2414 // We only need a scratch register if we have a write barrier or we | 2429 // We only need a scratch register if we have a write barrier or we |
| 2415 // have a store into the properties array (not in-object-property). | 2430 // have a store into the properties array (not in-object-property). |
| 2416 LOperand* temp = (!instr->is_in_object() || needs_write_barrier || | 2431 LOperand* temp = (!instr->is_in_object() || needs_write_barrier || |
| 2417 needs_write_barrier_for_map) ? TempRegister() : NULL; | 2432 needs_write_barrier_for_map) ? TempRegister() : NULL; |
| 2418 | 2433 |
| 2419 // We need a temporary register for write barrier of the map field. | 2434 // We need a temporary register for write barrier of the map field. |
| 2420 LOperand* temp_map = needs_write_barrier_for_map ? TempRegister() : NULL; | 2435 LOperand* temp_map = needs_write_barrier_for_map ? TempRegister() : NULL; |
| 2421 | 2436 |
| 2422 return new(zone()) LStoreNamedField(obj, val, temp, temp_map); | 2437 return new(zone()) LStoreNamedField(obj, val, temp, temp_map); |
| (...skipping 146 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2569 // There are no real uses of the arguments object. | 2584 // There are no real uses of the arguments object. |
| 2570 // arguments.length and element access are supported directly on | 2585 // arguments.length and element access are supported directly on |
| 2571 // stack arguments, and any real arguments object use causes a bailout. | 2586 // stack arguments, and any real arguments object use causes a bailout. |
| 2572 // So this value is never used. | 2587 // So this value is never used. |
| 2573 return NULL; | 2588 return NULL; |
| 2574 } | 2589 } |
| 2575 | 2590 |
| 2576 | 2591 |
| 2577 LInstruction* LChunkBuilder::DoAccessArgumentsAt(HAccessArgumentsAt* instr) { | 2592 LInstruction* LChunkBuilder::DoAccessArgumentsAt(HAccessArgumentsAt* instr) { |
| 2578 LOperand* args = UseRegister(instr->arguments()); | 2593 LOperand* args = UseRegister(instr->arguments()); |
| 2579 LOperand* length = UseTempRegister(instr->length()); | 2594 LOperand* length; |
| 2580 LOperand* index = Use(instr->index()); | 2595 LOperand* index; |
| 2596 if (instr->length()->IsConstant() && instr->index()->IsConstant()) { |
| 2597 length = UseRegisterOrConstant(instr->length()); |
| 2598 index = UseOrConstant(instr->index()); |
| 2599 } else { |
| 2600 length = UseTempRegister(instr->length()); |
| 2601 index = Use(instr->index()); |
| 2602 } |
| 2581 return DefineAsRegister(new(zone()) LAccessArgumentsAt(args, length, index)); | 2603 return DefineAsRegister(new(zone()) LAccessArgumentsAt(args, length, index)); |
| 2582 } | 2604 } |
| 2583 | 2605 |
| 2584 | 2606 |
| 2585 LInstruction* LChunkBuilder::DoToFastProperties(HToFastProperties* instr) { | 2607 LInstruction* LChunkBuilder::DoToFastProperties(HToFastProperties* instr) { |
| 2586 LOperand* object = UseFixed(instr->value(), eax); | 2608 LOperand* object = UseFixed(instr->value(), eax); |
| 2587 LToFastProperties* result = new(zone()) LToFastProperties(object); | 2609 LToFastProperties* result = new(zone()) LToFastProperties(object); |
| 2588 return MarkAsCall(DefineFixed(result, eax), instr); | 2610 return MarkAsCall(DefineFixed(result, eax), instr); |
| 2589 } | 2611 } |
| 2590 | 2612 |
| (...skipping 137 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2728 LInstruction* LChunkBuilder::DoLoadFieldByIndex(HLoadFieldByIndex* instr) { | 2750 LInstruction* LChunkBuilder::DoLoadFieldByIndex(HLoadFieldByIndex* instr) { |
| 2729 LOperand* object = UseRegister(instr->object()); | 2751 LOperand* object = UseRegister(instr->object()); |
| 2730 LOperand* index = UseTempRegister(instr->index()); | 2752 LOperand* index = UseTempRegister(instr->index()); |
| 2731 return DefineSameAsFirst(new(zone()) LLoadFieldByIndex(object, index)); | 2753 return DefineSameAsFirst(new(zone()) LLoadFieldByIndex(object, index)); |
| 2732 } | 2754 } |
| 2733 | 2755 |
| 2734 | 2756 |
| 2735 } } // namespace v8::internal | 2757 } } // namespace v8::internal |
| 2736 | 2758 |
| 2737 #endif // V8_TARGET_ARCH_IA32 | 2759 #endif // V8_TARGET_ARCH_IA32 |
| OLD | NEW |