Commit b935e44c authored by jochen's avatar jochen Committed by Commit bot

Add support for walking stack frames from hydrogen stubs

R=yangguo@chromium.org
BUG=none
LOG=n

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

Cr-Commit-Position: refs/heads/master@{#28984}
parent bd3edf37
...@@ -424,10 +424,27 @@ StackFrame::Type StackFrame::ComputeType(const StackFrameIteratorBase* iterator, ...@@ -424,10 +424,27 @@ StackFrame::Type StackFrame::ComputeType(const StackFrameIteratorBase* iterator,
// into the heap to determine the state. This is safe as long // into the heap to determine the state. This is safe as long
// as nobody tries to GC... // as nobody tries to GC...
if (!iterator->can_access_heap_objects_) return JAVA_SCRIPT; if (!iterator->can_access_heap_objects_) return JAVA_SCRIPT;
Code::Kind kind = GetContainingCode(iterator->isolate(), Code* code_obj =
*(state->pc_address))->kind(); GetContainingCode(iterator->isolate(), *(state->pc_address));
DCHECK(kind == Code::FUNCTION || kind == Code::OPTIMIZED_FUNCTION); switch (code_obj->kind()) {
return (kind == Code::OPTIMIZED_FUNCTION) ? OPTIMIZED : JAVA_SCRIPT; case Code::FUNCTION:
return JAVA_SCRIPT;
case Code::HANDLER:
#ifdef DEBUG
if (!code_obj->is_hydrogen_stub()) {
// There's currently no support for non-hydrogen stub handlers. If
// you this, you'll have to implement it yourself.
UNREACHABLE();
}
#endif
case Code::OPTIMIZED_FUNCTION:
return OPTIMIZED;
default:
UNREACHABLE();
return JAVA_SCRIPT;
}
} }
return static_cast<StackFrame::Type>(Smi::cast(marker)->value()); return static_cast<StackFrame::Type>(Smi::cast(marker)->value());
} }
......
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