 Chromium Code Reviews
 Chromium Code Reviews Issue 2262033003:
  [turbofan] Allow inlining into BytecodeGraphBuilder graph.  (Closed) 
  Base URL: https://chromium.googlesource.com/v8/v8.git@local_interpreter-preserve-bytecode-5
    
  
    Issue 2262033003:
  [turbofan] Allow inlining into BytecodeGraphBuilder graph.  (Closed) 
  Base URL: https://chromium.googlesource.com/v8/v8.git@local_interpreter-preserve-bytecode-5| Index: src/compiler/js-inlining.cc | 
| diff --git a/src/compiler/js-inlining.cc b/src/compiler/js-inlining.cc | 
| index 635daa4d761421e87dd10f7ff060e7598ce91803..43c0ae63271ff5340f84e6cec7311f19bbc362d5 100644 | 
| --- a/src/compiler/js-inlining.cc | 
| +++ b/src/compiler/js-inlining.cc | 
| @@ -10,6 +10,7 @@ | 
| #include "src/compiler.h" | 
| #include "src/compiler/ast-graph-builder.h" | 
| #include "src/compiler/ast-loop-assignment-analyzer.h" | 
| +#include "src/compiler/bytecode-graph-builder.h" | 
| #include "src/compiler/common-operator.h" | 
| #include "src/compiler/graph-reducer.h" | 
| #include "src/compiler/js-operator.h" | 
| @@ -357,8 +358,18 @@ Reduction JSInliner::ReduceJSCall(Node* node, Handle<JSFunction> function) { | 
| CompilationInfo info(&parse_info, function); | 
| if (info_->is_deoptimization_enabled()) info.MarkAsDeoptimizationEnabled(); | 
| if (info_->is_type_feedback_enabled()) info.MarkAsTypeFeedbackEnabled(); | 
| + if (info_->is_optimizing_from_bytecode()) info.MarkAsOptimizeFromBytecode(); | 
| - if (!Compiler::ParseAndAnalyze(info.parse_info())) { | 
| + if (info.is_optimizing_from_bytecode() && !Compiler::EnsureBytecode(&info)) { | 
| + TRACE("Not inlining %s into %s because bytecode generation failed\n", | 
| + shared_info->DebugName()->ToCString().get(), | 
| + info_->shared_info()->DebugName()->ToCString().get()); | 
| + DCHECK(!info_->isolate()->has_pending_exception()); | 
| + return NoChange(); | 
| + } | 
| + | 
| + if (!info.is_optimizing_from_bytecode() && | 
| + !Compiler::ParseAndAnalyze(info.parse_info())) { | 
| TRACE("Not inlining %s into %s because parsing failed\n", | 
| shared_info->DebugName()->ToCString().get(), | 
| info_->shared_info()->DebugName()->ToCString().get()); | 
| @@ -368,7 +379,8 @@ Reduction JSInliner::ReduceJSCall(Node* node, Handle<JSFunction> function) { | 
| return NoChange(); | 
| } | 
| - if (!Compiler::EnsureDeoptimizationSupport(&info)) { | 
| + if (!info.is_optimizing_from_bytecode() && | 
| + !Compiler::EnsureDeoptimizationSupport(&info)) { | 
| TRACE("Not inlining %s into %s because deoptimization support failed\n", | 
| shared_info->DebugName()->ToCString().get(), | 
| info_->shared_info()->DebugName()->ToCString().get()); | 
| @@ -394,7 +406,16 @@ Reduction JSInliner::ReduceJSCall(Node* node, Handle<JSFunction> function) { | 
| // Create the subgraph for the inlinee. | 
| Node* start; | 
| Node* end; | 
| - { | 
| + if (info.is_optimizing_from_bytecode()) { | 
| + // Run the BytecodeGraphBuilder to create the subgraph. | 
| + Graph::SubgraphScope scope(graph()); | 
| + BytecodeGraphBuilder graph_builder(&zone, &info, jsgraph()); | 
| + graph_builder.CreateGraph(); | 
| + | 
| 
rmcilroy
2016/08/25 08:53:26
Do we want todos about the loop analysis and Tyler
 
Michael Starzinger
2016/08/25 09:01:26
The LoopAssignmentAnalyzer is an AST-based analysi
 
rmcilroy
2016/08/25 09:33:06
Makes sense, thanks for the explanation.
 
rmcilroy
2016/08/25 09:33:06
Makes sense, thanks for the explanation.
 | 
| + // Extract the inlinee start/end nodes. | 
| + start = graph()->start(); | 
| + end = graph()->end(); | 
| + } else { | 
| // Run the loop assignment analyzer on the inlinee. | 
| AstLoopAssignmentAnalyzer loop_assignment_analyzer(&zone, &info); | 
| LoopAssignmentAnalysis* loop_assignment = | 
| @@ -475,7 +496,7 @@ Reduction JSInliner::ReduceJSCall(Node* node, Handle<JSFunction> function) { | 
| // in that frame state tho, as the conversion of the receiver can be repeated | 
| // any number of times, it's not observable. | 
| if (node->opcode() == IrOpcode::kJSCallFunction && | 
| - is_sloppy(parse_info.language_mode()) && !shared_info->native()) { | 
| + is_sloppy(shared_info->language_mode()) && !shared_info->native()) { | 
| const CallFunctionParameters& p = CallFunctionParametersOf(node->op()); | 
| Node* frame_state_before = NodeProperties::FindFrameStateBefore(node); | 
| Node* effect = NodeProperties::GetEffectInput(node); | 
| @@ -504,7 +525,7 @@ Reduction JSInliner::ReduceJSCall(Node* node, Handle<JSFunction> function) { | 
| // count (i.e. value outputs of start node minus target, receiver, new target, | 
| // arguments count and context) have to match the number of arguments passed | 
| // to the call. | 
| - int parameter_count = info.literal()->parameter_count(); | 
| + int parameter_count = shared_info->internal_formal_parameter_count(); | 
| DCHECK_EQ(parameter_count, start->op()->ValueOutputCount() - 5); | 
| if (call.formal_arguments() != parameter_count) { | 
| frame_state = CreateArtificialFrameState( |