Refactoring only: Extracted a method for finding optimized code.

Review URL: https://codereview.chromium.org/11637036

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@13252 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 9b00a57a
...@@ -477,6 +477,40 @@ void Deoptimizer::ComputeOutputFrames(Deoptimizer* deoptimizer) { ...@@ -477,6 +477,40 @@ void Deoptimizer::ComputeOutputFrames(Deoptimizer* deoptimizer) {
} }
static Code* FindOptimizedCode(Isolate* isolate,
JSFunction* function,
Deoptimizer::BailoutType type,
Address from,
Code* optimized_code) {
switch (type) {
case Deoptimizer::EAGER:
ASSERT(from == NULL);
return function->code();
case Deoptimizer::LAZY: {
Code* compiled_code =
isolate->deoptimizer_data()->FindDeoptimizingCode(from);
return (compiled_code == NULL)
? static_cast<Code*>(isolate->heap()->FindCodeObject(from))
: compiled_code;
}
case Deoptimizer::OSR: {
// The function has already been optimized and we're transitioning
// from the unoptimized shared version to the optimized one in the
// function. The return address (from) points to unoptimized code.
Code* compiled_code = function->code();
ASSERT(compiled_code->kind() == Code::OPTIMIZED_FUNCTION);
ASSERT(!compiled_code->contains(from));
return compiled_code;
}
case Deoptimizer::DEBUGGER:
ASSERT(optimized_code->contains(from));
return optimized_code;
}
UNREACHABLE();
return NULL;
}
Deoptimizer::Deoptimizer(Isolate* isolate, Deoptimizer::Deoptimizer(Isolate* isolate,
JSFunction* function, JSFunction* function,
BailoutType type, BailoutType type,
...@@ -525,28 +559,10 @@ Deoptimizer::Deoptimizer(Isolate* isolate, ...@@ -525,28 +559,10 @@ Deoptimizer::Deoptimizer(Isolate* isolate,
if (function != NULL && function->IsOptimized()) { if (function != NULL && function->IsOptimized()) {
function->shared()->increment_deopt_count(); function->shared()->increment_deopt_count();
} }
// Find the optimized code.
if (type == EAGER) {
ASSERT(from == NULL);
compiled_code_ = function_->code();
if (FLAG_trace_deopt) compiled_code_->PrintDeoptLocation(bailout_id);
} else if (type == LAZY) {
compiled_code_ = isolate->deoptimizer_data()->FindDeoptimizingCode(from);
if (compiled_code_ == NULL) {
compiled_code_ = compiled_code_ =
static_cast<Code*>(isolate->heap()->FindCodeObject(from)); FindOptimizedCode(isolate, function, type, from, optimized_code);
} if (FLAG_trace_deopt && type == EAGER) {
ASSERT(compiled_code_ != NULL); compiled_code_->PrintDeoptLocation(bailout_id);
} else if (type == OSR) {
// The function has already been optimized and we're transitioning
// from the unoptimized shared version to the optimized one in the
// function. The return address (from) points to unoptimized code.
compiled_code_ = function_->code();
ASSERT(compiled_code_->kind() == Code::OPTIMIZED_FUNCTION);
ASSERT(!compiled_code_->contains(from));
} else if (type == DEBUGGER) {
compiled_code_ = optimized_code;
ASSERT(compiled_code_->contains(from));
} }
ASSERT(HEAP->allow_allocation(false)); ASSERT(HEAP->allow_allocation(false));
unsigned size = ComputeInputFrameSize(); unsigned size = ComputeInputFrameSize();
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment