Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(181)

Side by Side Diff: runtime/vm/object.cc

Issue 2646443005: Track async causal stack traces (Closed)
Patch Set: initialize async_causal_stack_trace_ to NULL Created 3 years, 10 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 #include "vm/object.h" 5 #include "vm/object.h"
6 6
7 #include "include/dart_api.h" 7 #include "include/dart_api.h"
8 #include "platform/assert.h" 8 #include "platform/assert.h"
9 #include "vm/assembler.h" 9 #include "vm/assembler.h"
10 #include "vm/become.h" 10 #include "vm/become.h"
(...skipping 22686 matching lines...) Expand 10 before | Expand all | Expand 10 after
22697 function_name.ToCString(), url.ToCString()); 22697 function_name.ToCString(), url.ToCString());
22698 } 22698 }
22699 frame_strings->Add(chars); 22699 frame_strings->Add(chars);
22700 return strlen(chars); 22700 return strlen(chars);
22701 } 22701 }
22702 22702
22703 22703
22704 const char* StackTrace::ToCStringInternal(intptr_t* frame_index, 22704 const char* StackTrace::ToCStringInternal(intptr_t* frame_index,
22705 intptr_t max_frames) const { 22705 intptr_t max_frames) const {
22706 Zone* zone = Thread::Current()->zone(); 22706 Zone* zone = Thread::Current()->zone();
22707 Function& function = Function::Handle(); 22707 Function& function = Function::Handle(zone);
22708 Code& code = Code::Handle(); 22708 Code& code = Code::Handle(zone);
22709 // Iterate through the stack frames and create C string description 22709 // Iterate through the stack frames and create C string description
22710 // for each frame. 22710 // for each frame.
22711 intptr_t total_len = 0; 22711 intptr_t total_len = 0;
22712 GrowableArray<char*> frame_strings; 22712 GrowableArray<char*> frame_strings;
22713 for (intptr_t i = 0; (i < Length()) && (*frame_index < max_frames); i++) { 22713 for (intptr_t i = 0; (i < Length()) && (*frame_index < max_frames); i++) {
22714 code = CodeAtFrame(i);
22714 function = FunctionAtFrame(i); 22715 function = FunctionAtFrame(i);
22715 if (function.IsNull()) { 22716 if (code.raw() == StubCode::AsynchronousGapMarker_entry()->code()) {
22717 const char* kAsynchronousGap = "<asynchronous suspension>\n";
22718 intptr_t asynchronous_gap_len = strlen(kAsynchronousGap) + 1;
22719 frame_strings.Add(const_cast<char*>(kAsynchronousGap));
22720 total_len += asynchronous_gap_len;
22721 } else if (function.IsNull()) {
22716 // Check for a null function, which indicates a gap in a StackOverflow or 22722 // Check for a null function, which indicates a gap in a StackOverflow or
22717 // OutOfMemory trace. 22723 // OutOfMemory trace.
22718 if ((i < (Length() - 1)) && 22724 if ((i < (Length() - 1)) &&
22719 (FunctionAtFrame(i + 1) != Function::null())) { 22725 (FunctionAtFrame(i + 1) != Function::null())) {
22720 const char* kTruncated = "...\n...\n"; 22726 const char* kTruncated = "...\n...\n";
22721 intptr_t truncated_len = strlen(kTruncated) + 1; 22727 intptr_t truncated_len = strlen(kTruncated) + 1;
22722 char* chars = zone->Alloc<char>(truncated_len); 22728 frame_strings.Add(const_cast<char*>(kTruncated));
22723 OS::SNPrint(chars, truncated_len, "%s", kTruncated);
22724 frame_strings.Add(chars);
22725 total_len += truncated_len; 22729 total_len += truncated_len;
22726 ASSERT(PcOffsetAtFrame(i) != Smi::null()); 22730 ASSERT(PcOffsetAtFrame(i) != Smi::null());
22727 // To account for gap frames. 22731 // To account for gap frames.
22728 (*frame_index) += Smi::Value(PcOffsetAtFrame(i)); 22732 (*frame_index) += Smi::Value(PcOffsetAtFrame(i));
22729 } 22733 }
22730 } else { 22734 } else {
22731 code = CodeAtFrame(i);
22732 ASSERT(function.raw() == code.function()); 22735 ASSERT(function.raw() == code.function());
22733 uword pc = code.PayloadStart() + Smi::Value(PcOffsetAtFrame(i)); 22736 uword pc = code.PayloadStart() + Smi::Value(PcOffsetAtFrame(i));
22734 if (code.is_optimized() && expand_inlined() && 22737 if (code.is_optimized() && expand_inlined() &&
22735 !FLAG_precompiled_runtime) { 22738 !FLAG_precompiled_runtime) {
22736 // Traverse inlined frames. 22739 // Traverse inlined frames.
22737 for (InlinedFunctionsIterator it(code, pc); 22740 for (InlinedFunctionsIterator it(code, pc);
22738 !it.Done() && (*frame_index < max_frames); it.Advance()) { 22741 !it.Done() && (*frame_index < max_frames); it.Advance()) {
22739 function = it.function(); 22742 function = it.function();
22740 if (function.is_visible() || FLAG_show_invisible_frames) { 22743 if (function.is_visible() || FLAG_show_invisible_frames) {
22741 code = it.code(); 22744 code = it.code();
(...skipping 343 matching lines...) Expand 10 before | Expand all | Expand 10 after
23085 return UserTag::null(); 23088 return UserTag::null();
23086 } 23089 }
23087 23090
23088 23091
23089 const char* UserTag::ToCString() const { 23092 const char* UserTag::ToCString() const {
23090 const String& tag_label = String::Handle(label()); 23093 const String& tag_label = String::Handle(label());
23091 return tag_label.ToCString(); 23094 return tag_label.ToCString();
23092 } 23095 }
23093 23096
23094 } // namespace dart 23097 } // namespace dart
OLDNEW
« runtime/lib/stacktrace.cc ('K') | « runtime/vm/object.h ('k') | runtime/vm/object_store.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698