2017-06-29 21:31:40 +00:00
|
|
|
// Copyright (c) 2017, the Dart project authors. Please see the AUTHORS file
|
|
|
|
// for details. All rights reserved. Use of this source code is governed by a
|
|
|
|
// BSD-style license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
#include "lib/stacktrace.h"
|
2019-09-06 19:25:31 +00:00
|
|
|
#include "vm/heap/safepoint.h"
|
2017-06-29 21:31:40 +00:00
|
|
|
#include "vm/object.h"
|
|
|
|
#include "vm/stack_frame.h"
|
|
|
|
|
|
|
|
namespace dart {
|
|
|
|
|
|
|
|
#if !defined(PRODUCT)
|
|
|
|
|
|
|
|
DART_EXPORT
|
2020-04-25 05:21:27 +00:00
|
|
|
void _printRawObject(ObjectPtr object) {
|
2017-06-29 21:31:40 +00:00
|
|
|
OS::PrintErr("%s\n", Object::Handle(object).ToCString());
|
|
|
|
}
|
|
|
|
|
|
|
|
DART_EXPORT
|
2020-04-25 05:21:27 +00:00
|
|
|
Object* _handle(ObjectPtr object) {
|
2017-06-29 21:31:40 +00:00
|
|
|
return &Object::Handle(object);
|
|
|
|
}
|
|
|
|
|
|
|
|
// An utility method for convenient printing of dart stack traces when
|
|
|
|
// inside 'gdb'. Note: This function will only work when there is a
|
|
|
|
// valid exit frame information. It will not work when a breakpoint is
|
|
|
|
// set in dart code and control is got inside 'gdb' without going through
|
|
|
|
// the runtime or native transition stub.
|
|
|
|
DART_EXPORT
|
|
|
|
void _printDartStackTrace() {
|
|
|
|
const StackTrace& stacktrace = GetCurrentStackTrace(0);
|
|
|
|
OS::PrintErr("=== Current Trace:\n%s===\n", stacktrace.ToCString());
|
|
|
|
}
|
|
|
|
|
|
|
|
// Like _printDartStackTrace, but works in a NoSafepointScope. Use it if you're
|
|
|
|
// in the middle of a GC or interested in stub frames.
|
|
|
|
DART_EXPORT
|
|
|
|
void _printStackTrace() {
|
2019-11-11 23:56:00 +00:00
|
|
|
StackFrame::DumpCurrentTrace();
|
2017-06-29 21:31:40 +00:00
|
|
|
}
|
|
|
|
|
2019-09-06 19:25:31 +00:00
|
|
|
// Like _printDartStackTrace, but works when stopped in generated code.
|
|
|
|
// Must be called with the current fp, sp, and pc.
|
|
|
|
DART_EXPORT
|
|
|
|
void _printGeneratedStackTrace(uword fp, uword sp, uword pc) {
|
|
|
|
StackFrameIterator frames(fp, sp, pc, ValidationPolicy::kDontValidateFrames,
|
|
|
|
Thread::Current(),
|
|
|
|
StackFrameIterator::kNoCrossThreadIteration);
|
|
|
|
StackFrame* frame = frames.NextFrame();
|
|
|
|
while (frame != nullptr) {
|
|
|
|
OS::PrintErr("%s\n", frame->ToCString());
|
|
|
|
frame = frames.NextFrame();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-06-29 21:31:40 +00:00
|
|
|
class PrintObjectPointersVisitor : public ObjectPointerVisitor {
|
|
|
|
public:
|
2020-02-20 21:08:35 +00:00
|
|
|
PrintObjectPointersVisitor()
|
|
|
|
: ObjectPointerVisitor(IsolateGroup::Current()) {}
|
2017-06-29 21:31:40 +00:00
|
|
|
|
2020-04-25 05:21:27 +00:00
|
|
|
void VisitPointers(ObjectPtr* first, ObjectPtr* last) {
|
|
|
|
for (ObjectPtr* p = first; p <= last; p++) {
|
2017-06-29 21:31:40 +00:00
|
|
|
Object& obj = Object::Handle(*p);
|
|
|
|
OS::PrintErr("%p: %s\n", p, obj.ToCString());
|
|
|
|
}
|
|
|
|
}
|
2021-02-16 18:27:39 +00:00
|
|
|
|
|
|
|
void VisitCompressedPointers(uword heap_base,
|
|
|
|
CompressedObjectPtr* first,
|
|
|
|
CompressedObjectPtr* last) {
|
|
|
|
for (CompressedObjectPtr* p = first; p <= last; p++) {
|
|
|
|
Object& obj = Object::Handle(p->Decompress(heap_base));
|
|
|
|
OS::PrintErr("%p: %s\n", p, obj.ToCString());
|
|
|
|
}
|
|
|
|
}
|
2017-06-29 21:31:40 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
DART_EXPORT
|
|
|
|
void _printStackTraceWithLocals() {
|
|
|
|
PrintObjectPointersVisitor visitor;
|
2018-06-04 14:46:26 +00:00
|
|
|
StackFrameIterator frames(ValidationPolicy::kDontValidateFrames,
|
2017-06-29 21:31:40 +00:00
|
|
|
Thread::Current(),
|
|
|
|
StackFrameIterator::kNoCrossThreadIteration);
|
|
|
|
StackFrame* frame = frames.NextFrame();
|
2019-09-06 19:25:31 +00:00
|
|
|
while (frame != nullptr) {
|
2017-06-29 21:31:40 +00:00
|
|
|
OS::PrintErr("%s\n", frame->ToCString());
|
|
|
|
frame->VisitObjectPointers(&visitor);
|
|
|
|
frame = frames.NextFrame();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // !PRODUCT
|
|
|
|
|
|
|
|
} // namespace dart
|