| OLD | NEW |
| 1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 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/code-stubs.h" | 5 #include "src/code-stubs.h" |
| 6 #include "src/compiler/common-operator.h" | 6 #include "src/compiler/common-operator.h" |
| 7 #include "src/compiler/graph-inl.h" | 7 #include "src/compiler/graph-inl.h" |
| 8 #include "src/compiler/js-generic-lowering.h" | 8 #include "src/compiler/js-generic-lowering.h" |
| 9 #include "src/compiler/machine-operator.h" | 9 #include "src/compiler/machine-operator.h" |
| 10 #include "src/compiler/node-aux-data-inl.h" | 10 #include "src/compiler/node-aux-data-inl.h" |
| (...skipping 137 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 148 | 148 |
| 149 private: | 149 private: |
| 150 virtual Major MajorKey() const V8_OVERRIDE { return NoCache; } | 150 virtual Major MajorKey() const V8_OVERRIDE { return NoCache; } |
| 151 virtual int NotMissMinorKey() const V8_OVERRIDE { return 0; } | 151 virtual int NotMissMinorKey() const V8_OVERRIDE { return 0; } |
| 152 virtual bool UseSpecialCache() V8_OVERRIDE { return true; } | 152 virtual bool UseSpecialCache() V8_OVERRIDE { return true; } |
| 153 | 153 |
| 154 StrictMode strict_mode_; | 154 StrictMode strict_mode_; |
| 155 }; | 155 }; |
| 156 | 156 |
| 157 | 157 |
| 158 JSGenericLowering::JSGenericLowering(CompilationInfo* info, JSGraph* jsgraph, | 158 JSGenericLowering::JSGenericLowering(JSGraph* jsgraph, |
| 159 JSContextSpecializer* spec, |
| 160 Linkage* linkage, |
| 159 MachineOperatorBuilder* machine) | 161 MachineOperatorBuilder* machine) |
| 160 : info_(info), | 162 : jsgraph_(jsgraph), spec_(spec), linkage_(linkage), machine_(machine) {} |
| 161 jsgraph_(jsgraph), | |
| 162 linkage_(new (jsgraph->zone()) Linkage(info)), | |
| 163 machine_(machine) {} | |
| 164 | 163 |
| 165 | 164 |
| 166 void JSGenericLowering::PatchOperator(Node* node, Operator* op) { | 165 void JSGenericLowering::PatchOperator(Node* node, Operator* op) { |
| 167 node->set_op(op); | 166 node->set_op(op); |
| 168 } | 167 } |
| 169 | 168 |
| 170 | 169 |
| 171 void JSGenericLowering::PatchInsertInput(Node* node, int index, Node* input) { | 170 void JSGenericLowering::PatchInsertInput(Node* node, int index, Node* input) { |
| 172 node->InsertInput(zone(), index, input); | 171 node->InsertInput(zone(), index, input); |
| 173 } | 172 } |
| (...skipping 159 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 333 PatchOperator(node, common()->Call(desc)); | 332 PatchOperator(node, common()->Call(desc)); |
| 334 } | 333 } |
| 335 | 334 |
| 336 | 335 |
| 337 void JSGenericLowering::ReplaceWithBuiltinCall(Node* node, | 336 void JSGenericLowering::ReplaceWithBuiltinCall(Node* node, |
| 338 Builtins::JavaScript id, | 337 Builtins::JavaScript id, |
| 339 int nargs) { | 338 int nargs) { |
| 340 CallFunctionStub stub(isolate(), nargs - 1, NO_CALL_FUNCTION_FLAGS); | 339 CallFunctionStub stub(isolate(), nargs - 1, NO_CALL_FUNCTION_FLAGS); |
| 341 CodeStubInterfaceDescriptor* d = GetInterfaceDescriptor(isolate(), &stub); | 340 CodeStubInterfaceDescriptor* d = GetInterfaceDescriptor(isolate(), &stub); |
| 342 CallDescriptor* desc = linkage()->GetStubCallDescriptor(d, nargs); | 341 CallDescriptor* desc = linkage()->GetStubCallDescriptor(d, nargs); |
| 343 // TODO(mstarzinger): Accessing the builtins object this way prevents sharing | 342 |
| 344 // of code across native contexts. Fix this by loading from given context. | 343 Node* function_node = spec_->InsertBuiltinLoadBefore(node, id); |
| 345 Handle<JSFunction> function( | |
| 346 JSFunction::cast(info()->context()->builtins()->javascript_builtin(id))); | |
| 347 Node* stub_code = CodeConstant(stub.GetCode()); | 344 Node* stub_code = CodeConstant(stub.GetCode()); |
| 348 Node* function_node = FunctionConstant(function); | |
| 349 PatchInsertInput(node, 0, stub_code); | 345 PatchInsertInput(node, 0, stub_code); |
| 350 PatchInsertInput(node, 1, function_node); | 346 PatchInsertInput(node, 1, function_node); |
| 351 PatchOperator(node, common()->Call(desc)); | 347 PatchOperator(node, common()->Call(desc)); |
| 352 } | 348 } |
| 353 | 349 |
| 354 | 350 |
| 355 void JSGenericLowering::ReplaceWithRuntimeCall(Node* node, | 351 void JSGenericLowering::ReplaceWithRuntimeCall(Node* node, |
| 356 Runtime::FunctionId f, | 352 Runtime::FunctionId f, |
| 357 int nargs_override) { | 353 int nargs_override) { |
| 358 Operator::Property props = node->op()->properties(); | 354 Operator::Property props = node->op()->properties(); |
| (...skipping 51 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 410 Node* JSGenericLowering::LowerJSLoadNamed(Node* node) { | 406 Node* JSGenericLowering::LowerJSLoadNamed(Node* node) { |
| 411 LoadNamedParameters p = OpParameter<LoadNamedParameters>(node); | 407 LoadNamedParameters p = OpParameter<LoadNamedParameters>(node); |
| 412 LoadICStubShim stub(isolate(), p.contextual_mode); | 408 LoadICStubShim stub(isolate(), p.contextual_mode); |
| 413 PatchInsertInput(node, 1, jsgraph()->HeapConstant(p.name)); | 409 PatchInsertInput(node, 1, jsgraph()->HeapConstant(p.name)); |
| 414 ReplaceWithICStubCall(node, &stub); | 410 ReplaceWithICStubCall(node, &stub); |
| 415 return node; | 411 return node; |
| 416 } | 412 } |
| 417 | 413 |
| 418 | 414 |
| 419 Node* JSGenericLowering::LowerJSStoreProperty(Node* node) { | 415 Node* JSGenericLowering::LowerJSStoreProperty(Node* node) { |
| 420 // TODO(mstarzinger): The strict_mode needs to be carried along in the | 416 StrictMode strict_mode = OpParameter<StrictMode>(node); |
| 421 // operator so that graphs are fully compositional for inlining. | |
| 422 StrictMode strict_mode = info()->strict_mode(); | |
| 423 KeyedStoreICStubShim stub(isolate(), strict_mode); | 417 KeyedStoreICStubShim stub(isolate(), strict_mode); |
| 424 ReplaceWithICStubCall(node, &stub); | 418 ReplaceWithICStubCall(node, &stub); |
| 425 return node; | 419 return node; |
| 426 } | 420 } |
| 427 | 421 |
| 428 | 422 |
| 429 Node* JSGenericLowering::LowerJSStoreNamed(Node* node) { | 423 Node* JSGenericLowering::LowerJSStoreNamed(Node* node) { |
| 430 PrintableUnique<Name> key = OpParameter<PrintableUnique<Name> >(node); | 424 StoreNamedParameters params = OpParameter<StoreNamedParameters>(node); |
| 431 // TODO(mstarzinger): The strict_mode needs to be carried along in the | 425 StoreICStubShim stub(isolate(), params.strict_mode); |
| 432 // operator so that graphs are fully compositional for inlining. | 426 PatchInsertInput(node, 1, jsgraph()->HeapConstant(params.name)); |
| 433 StrictMode strict_mode = info()->strict_mode(); | |
| 434 StoreICStubShim stub(isolate(), strict_mode); | |
| 435 PatchInsertInput(node, 1, jsgraph()->HeapConstant(key)); | |
| 436 ReplaceWithICStubCall(node, &stub); | 427 ReplaceWithICStubCall(node, &stub); |
| 437 return node; | 428 return node; |
| 438 } | 429 } |
| 439 | 430 |
| 440 | 431 |
| 441 Node* JSGenericLowering::LowerJSDeleteProperty(Node* node) { | 432 Node* JSGenericLowering::LowerJSDeleteProperty(Node* node) { |
| 442 StrictMode strict_mode = OpParameter<StrictMode>(node); | 433 StrictMode strict_mode = OpParameter<StrictMode>(node); |
| 443 PatchInsertInput(node, 2, SmiConstant(strict_mode)); | 434 PatchInsertInput(node, 2, SmiConstant(strict_mode)); |
| 444 ReplaceWithBuiltinCall(node, Builtins::DELETE, 3); | 435 ReplaceWithBuiltinCall(node, Builtins::DELETE, 3); |
| 445 return node; | 436 return node; |
| (...skipping 89 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 535 | 526 |
| 536 Node* JSGenericLowering::LowerJSCallRuntime(Node* node) { | 527 Node* JSGenericLowering::LowerJSCallRuntime(Node* node) { |
| 537 Runtime::FunctionId function = OpParameter<Runtime::FunctionId>(node); | 528 Runtime::FunctionId function = OpParameter<Runtime::FunctionId>(node); |
| 538 int arity = OperatorProperties::GetValueInputCount(node->op()); | 529 int arity = OperatorProperties::GetValueInputCount(node->op()); |
| 539 ReplaceWithRuntimeCall(node, function, arity); | 530 ReplaceWithRuntimeCall(node, function, arity); |
| 540 return node; | 531 return node; |
| 541 } | 532 } |
| 542 } | 533 } |
| 543 } | 534 } |
| 544 } // namespace v8::internal::compiler | 535 } // namespace v8::internal::compiler |
| OLD | NEW |