| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "src/v8.h" | 5 #include "src/v8.h" |
| 6 | 6 |
| 7 #if V8_TARGET_ARCH_X64 | 7 #if V8_TARGET_ARCH_X64 |
| 8 | 8 |
| 9 #include "src/lithium-allocator-inl.h" | 9 #include "src/lithium-allocator-inl.h" |
| 10 #include "src/x64/lithium-x64.h" | 10 #include "src/x64/lithium-x64.h" |
| (...skipping 2092 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2103 new(zone()) LLoadFunctionPrototype(UseRegister(instr->function())))); | 2103 new(zone()) LLoadFunctionPrototype(UseRegister(instr->function())))); |
| 2104 } | 2104 } |
| 2105 | 2105 |
| 2106 | 2106 |
| 2107 LInstruction* LChunkBuilder::DoLoadRoot(HLoadRoot* instr) { | 2107 LInstruction* LChunkBuilder::DoLoadRoot(HLoadRoot* instr) { |
| 2108 return DefineAsRegister(new(zone()) LLoadRoot); | 2108 return DefineAsRegister(new(zone()) LLoadRoot); |
| 2109 } | 2109 } |
| 2110 | 2110 |
| 2111 | 2111 |
| 2112 void LChunkBuilder::FindDehoistedKeyDefinitions(HValue* candidate) { | 2112 void LChunkBuilder::FindDehoistedKeyDefinitions(HValue* candidate) { |
| 2113 ASSERT(kPointerSize == kInt64Size); |
| 2113 BitVector* dehoisted_key_ids = chunk_->GetDehoistedKeyIds(); | 2114 BitVector* dehoisted_key_ids = chunk_->GetDehoistedKeyIds(); |
| 2114 if (dehoisted_key_ids->Contains(candidate->id())) return; | 2115 if (dehoisted_key_ids->Contains(candidate->id())) return; |
| 2115 dehoisted_key_ids->Add(candidate->id()); | 2116 dehoisted_key_ids->Add(candidate->id()); |
| 2116 if (!candidate->IsPhi()) return; | 2117 if (!candidate->IsPhi()) return; |
| 2117 for (int i = 0; i < candidate->OperandCount(); ++i) { | 2118 for (int i = 0; i < candidate->OperandCount(); ++i) { |
| 2118 FindDehoistedKeyDefinitions(candidate->OperandAt(i)); | 2119 FindDehoistedKeyDefinitions(candidate->OperandAt(i)); |
| 2119 } | 2120 } |
| 2120 } | 2121 } |
| 2121 | 2122 |
| 2122 | 2123 |
| 2123 LInstruction* LChunkBuilder::DoLoadKeyed(HLoadKeyed* instr) { | 2124 LInstruction* LChunkBuilder::DoLoadKeyed(HLoadKeyed* instr) { |
| 2124 ASSERT(instr->key()->representation().IsInteger32()); | 2125 ASSERT(instr->key()->representation().IsInteger32()); |
| 2125 ElementsKind elements_kind = instr->elements_kind(); | 2126 ElementsKind elements_kind = instr->elements_kind(); |
| 2126 LOperand* key = UseRegisterOrConstantAtStart(instr->key()); | 2127 LOperand* key = UseRegisterOrConstantAtStart(instr->key()); |
| 2127 LInstruction* result = NULL; | 2128 LInstruction* result = NULL; |
| 2128 | 2129 |
| 2129 if (instr->IsDehoisted()) { | 2130 if ((kPointerSize == kInt64Size) && instr->IsDehoisted()) { |
| 2130 FindDehoistedKeyDefinitions(instr->key()); | 2131 FindDehoistedKeyDefinitions(instr->key()); |
| 2131 } | 2132 } |
| 2132 | 2133 |
| 2133 if (!instr->is_typed_elements()) { | 2134 if (!instr->is_typed_elements()) { |
| 2134 LOperand* obj = UseRegisterAtStart(instr->elements()); | 2135 LOperand* obj = UseRegisterAtStart(instr->elements()); |
| 2135 result = DefineAsRegister(new(zone()) LLoadKeyed(obj, key)); | 2136 result = DefineAsRegister(new(zone()) LLoadKeyed(obj, key)); |
| 2136 } else { | 2137 } else { |
| 2137 ASSERT( | 2138 ASSERT( |
| 2138 (instr->representation().IsInteger32() && | 2139 (instr->representation().IsInteger32() && |
| 2139 !(IsDoubleOrFloatElementsKind(elements_kind))) || | 2140 !(IsDoubleOrFloatElementsKind(elements_kind))) || |
| (...skipping 24 matching lines...) Expand all Loading... |
| 2164 | 2165 |
| 2165 LLoadKeyedGeneric* result = | 2166 LLoadKeyedGeneric* result = |
| 2166 new(zone()) LLoadKeyedGeneric(context, object, key); | 2167 new(zone()) LLoadKeyedGeneric(context, object, key); |
| 2167 return MarkAsCall(DefineFixed(result, rax), instr); | 2168 return MarkAsCall(DefineFixed(result, rax), instr); |
| 2168 } | 2169 } |
| 2169 | 2170 |
| 2170 | 2171 |
| 2171 LInstruction* LChunkBuilder::DoStoreKeyed(HStoreKeyed* instr) { | 2172 LInstruction* LChunkBuilder::DoStoreKeyed(HStoreKeyed* instr) { |
| 2172 ElementsKind elements_kind = instr->elements_kind(); | 2173 ElementsKind elements_kind = instr->elements_kind(); |
| 2173 | 2174 |
| 2174 if (instr->IsDehoisted()) { | 2175 if ((kPointerSize == kInt64Size) && instr->IsDehoisted()) { |
| 2175 FindDehoistedKeyDefinitions(instr->key()); | 2176 FindDehoistedKeyDefinitions(instr->key()); |
| 2176 } | 2177 } |
| 2177 | 2178 |
| 2178 if (!instr->is_typed_elements()) { | 2179 if (!instr->is_typed_elements()) { |
| 2179 ASSERT(instr->elements()->representation().IsTagged()); | 2180 ASSERT(instr->elements()->representation().IsTagged()); |
| 2180 bool needs_write_barrier = instr->NeedsWriteBarrier(); | 2181 bool needs_write_barrier = instr->NeedsWriteBarrier(); |
| 2181 LOperand* object = NULL; | 2182 LOperand* object = NULL; |
| 2182 LOperand* key = NULL; | 2183 LOperand* key = NULL; |
| 2183 LOperand* val = NULL; | 2184 LOperand* val = NULL; |
| 2184 | 2185 |
| (...skipping 412 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 2597 LOperand* function = UseRegisterAtStart(instr->function()); | 2598 LOperand* function = UseRegisterAtStart(instr->function()); |
| 2598 LAllocateBlockContext* result = | 2599 LAllocateBlockContext* result = |
| 2599 new(zone()) LAllocateBlockContext(context, function); | 2600 new(zone()) LAllocateBlockContext(context, function); |
| 2600 return MarkAsCall(DefineFixed(result, rsi), instr); | 2601 return MarkAsCall(DefineFixed(result, rsi), instr); |
| 2601 } | 2602 } |
| 2602 | 2603 |
| 2603 | 2604 |
| 2604 } } // namespace v8::internal | 2605 } } // namespace v8::internal |
| 2605 | 2606 |
| 2606 #endif // V8_TARGET_ARCH_X64 | 2607 #endif // V8_TARGET_ARCH_X64 |
| OLD | NEW |