Commit 9be47f57 authored by clemensh's avatar clemensh Committed by Commit bot

[wasm] Do also output WASM frames on detailed stack traces

Till now, they were just skipped. With this patch, they now show up in
the DevTools on uncaught Errors with function name <WASM> and no line
number or file name information (see new test case:
https://chromiumcodereview.appspot.com/1875083002).

R=jfb@chromium.org, titzer@chromium.org
BUG=

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

Cr-Commit-Position: refs/heads/master@{#35615}
parent 9c927d0f
...@@ -1333,6 +1333,16 @@ JSFunction* WasmFrame::function() const { ...@@ -1333,6 +1333,16 @@ JSFunction* WasmFrame::function() const {
return *fun; return *fun;
} }
void WasmFrame::Summarize(List<FrameSummary>* functions) const {
DCHECK(functions->length() == 0);
Code* code = LookupCode();
int offset = static_cast<int>(pc() - code->instruction_start());
AbstractCode* abstract_code = AbstractCode::cast(code);
Handle<JSFunction> fun(function(), isolate());
FrameSummary summary(receiver(), *fun, abstract_code, offset, false);
functions->Add(summary);
}
void WasmFrame::Iterate(ObjectVisitor* v) const { IterateCompiledFrame(v); } void WasmFrame::Iterate(ObjectVisitor* v) const { IterateCompiledFrame(v); }
Address WasmFrame::GetCallerStackPointer() const { Address WasmFrame::GetCallerStackPointer() const {
......
...@@ -976,6 +976,8 @@ class WasmFrame : public StandardFrame { ...@@ -976,6 +976,8 @@ class WasmFrame : public StandardFrame {
JSFunction* function() const override; JSFunction* function() const override;
void Summarize(List<FrameSummary>* frames) const override;
protected: protected:
inline explicit WasmFrame(StackFrameIteratorBase* iterator); inline explicit WasmFrame(StackFrameIteratorBase* iterator);
......
...@@ -547,6 +547,9 @@ class CaptureStackTraceHelper { ...@@ -547,6 +547,9 @@ class CaptureStackTraceHelper {
Handle<JSObject> stack_frame = Handle<JSObject> stack_frame =
factory()->NewJSObject(isolate_->object_function()); factory()->NewJSObject(isolate_->object_function());
// TODO(clemensh): this can be changed to a DCHECK once also WASM frames
// define a script
if (!fun->shared()->script()->IsUndefined()) {
Handle<Script> script(Script::cast(fun->shared()->script())); Handle<Script> script(Script::cast(fun->shared()->script()));
if (!line_key_.is_null()) { if (!line_key_.is_null()) {
...@@ -556,17 +559,20 @@ class CaptureStackTraceHelper { ...@@ -556,17 +559,20 @@ class CaptureStackTraceHelper {
int relative_line_number = line_number - script_line_offset; int relative_line_number = line_number - script_line_offset;
if (!column_key_.is_null() && relative_line_number >= 0) { if (!column_key_.is_null() && relative_line_number >= 0) {
Handle<FixedArray> line_ends(FixedArray::cast(script->line_ends())); Handle<FixedArray> line_ends(FixedArray::cast(script->line_ends()));
int start = (relative_line_number == 0) ? 0 : int start = (relative_line_number == 0)
Smi::cast(line_ends->get(relative_line_number - 1))->value() + 1; ? 0
: Smi::cast(line_ends->get(relative_line_number - 1))
->value() +
1;
int column_offset = position - start; int column_offset = position - start;
if (relative_line_number == 0) { if (relative_line_number == 0) {
// For the case where the code is on the same line as the script // For the case where the code is on the same line as the script
// tag. // tag.
column_offset += script->column_offset(); column_offset += script->column_offset();
} }
JSObject::AddProperty(stack_frame, column_key_, JSObject::AddProperty(
handle(Smi::FromInt(column_offset + 1), isolate_), stack_frame, column_key_,
NONE); handle(Smi::FromInt(column_offset + 1), isolate_), NONE);
} }
JSObject::AddProperty(stack_frame, line_key_, JSObject::AddProperty(stack_frame, line_key_,
handle(Smi::FromInt(line_number + 1), isolate_), handle(Smi::FromInt(line_number + 1), isolate_),
...@@ -575,7 +581,8 @@ class CaptureStackTraceHelper { ...@@ -575,7 +581,8 @@ class CaptureStackTraceHelper {
if (!script_id_key_.is_null()) { if (!script_id_key_.is_null()) {
JSObject::AddProperty(stack_frame, script_id_key_, JSObject::AddProperty(stack_frame, script_id_key_,
handle(Smi::FromInt(script->id()), isolate_), NONE); handle(Smi::FromInt(script->id()), isolate_),
NONE);
} }
if (!script_name_key_.is_null()) { if (!script_name_key_.is_null()) {
...@@ -585,13 +592,8 @@ class CaptureStackTraceHelper { ...@@ -585,13 +592,8 @@ class CaptureStackTraceHelper {
if (!script_name_or_source_url_key_.is_null()) { if (!script_name_or_source_url_key_.is_null()) {
Handle<Object> result = Script::GetNameOrSourceURL(script); Handle<Object> result = Script::GetNameOrSourceURL(script);
JSObject::AddProperty(stack_frame, script_name_or_source_url_key_, result, JSObject::AddProperty(stack_frame, script_name_or_source_url_key_,
NONE); result, NONE);
}
if (!function_key_.is_null()) {
Handle<Object> fun_name = JSFunction::GetDebugName(fun);
JSObject::AddProperty(stack_frame, function_key_, fun_name, NONE);
} }
if (!eval_key_.is_null()) { if (!eval_key_.is_null()) {
...@@ -599,6 +601,12 @@ class CaptureStackTraceHelper { ...@@ -599,6 +601,12 @@ class CaptureStackTraceHelper {
script->compilation_type() == Script::COMPILATION_TYPE_EVAL); script->compilation_type() == Script::COMPILATION_TYPE_EVAL);
JSObject::AddProperty(stack_frame, eval_key_, is_eval, NONE); JSObject::AddProperty(stack_frame, eval_key_, is_eval, NONE);
} }
}
if (!function_key_.is_null()) {
Handle<Object> fun_name = JSFunction::GetDebugName(fun);
JSObject::AddProperty(stack_frame, function_key_, fun_name, NONE);
}
if (!constructor_key_.is_null()) { if (!constructor_key_.is_null()) {
Handle<Object> is_constructor_obj = factory()->ToBoolean(is_constructor); Handle<Object> is_constructor_obj = factory()->ToBoolean(is_constructor);
......
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