diff options
author | Mathieu Chartier <mathieuc@google.com> | 2015-01-14 14:55:47 -0800 |
---|---|---|
committer | Mathieu Chartier <mathieuc@google.com> | 2015-01-15 12:23:28 -0800 |
commit | e34fa1df67fbe0173b4ea9abddcc3ae3d0537037 (patch) | |
tree | a5148f079b5671a95f60910c41981ebf91db3a02 /runtime/gc/collector/mark_sweep.cc | |
parent | 9f06b1946ae3ef1d2fd75bbf7f0a288bc611fe58 (diff) | |
download | art-e34fa1df67fbe0173b4ea9abddcc3ae3d0537037.tar.gz art-e34fa1df67fbe0173b4ea9abddcc3ae3d0537037.tar.bz2 art-e34fa1df67fbe0173b4ea9abddcc3ae3d0537037.zip |
Print more info in MarkSweep::VerifyRoot
Refactored old root callback to use a new class called RootInfo.
RootInfo contains all the relevant info related to the root
associated with the callback. The MarkSweep::VerifyRoot function
now uses this info to print the StackVisitor's described location
if the GC root is of the type kRootJavaFrame.
Some other cleanup.
Example output:
E/art (12167): Tried to mark 0x123 not contained by any spaces
E/art (12167): Attempting see if it's a bad root
E/art (12167): Found invalid root: 0x123 with type RootJavaFrame
E/art (12167): Location=Visiting method
'void java.lang.Runtime.gc()' at dex PC 0xffffffff (native PC 0x0)
vreg=0
(cherry picked from commit 12f7423a2bb4bfab76700d84eb6d4338d211983a)
Bug: 18588862
Change-Id: Ic5a2781f704e931265ffb3621c2eab4b2e25f60f
Diffstat (limited to 'runtime/gc/collector/mark_sweep.cc')
-rw-r--r-- | runtime/gc/collector/mark_sweep.cc | 25 |
1 files changed, 9 insertions, 16 deletions
diff --git a/runtime/gc/collector/mark_sweep.cc b/runtime/gc/collector/mark_sweep.cc index 6ad44e6a75..80f7968ef9 100644 --- a/runtime/gc/collector/mark_sweep.cc +++ b/runtime/gc/collector/mark_sweep.cc @@ -460,42 +460,35 @@ inline void MarkSweep::MarkObject(Object* obj) { } } -void MarkSweep::MarkRootParallelCallback(Object** root, void* arg, uint32_t /*thread_id*/, - RootType /*root_type*/) { +void MarkSweep::MarkRootParallelCallback(Object** root, void* arg, const RootInfo& /*root_info*/) { reinterpret_cast<MarkSweep*>(arg)->MarkObjectNonNullParallel(*root); } -void MarkSweep::VerifyRootMarked(Object** root, void* arg, uint32_t /*thread_id*/, - RootType /*root_type*/) { +void MarkSweep::VerifyRootMarked(Object** root, void* arg, const RootInfo& /*root_info*/) { CHECK(reinterpret_cast<MarkSweep*>(arg)->IsMarked(*root)); } -void MarkSweep::MarkRootCallback(Object** root, void* arg, uint32_t /*thread_id*/, - RootType /*root_type*/) { +void MarkSweep::MarkRootCallback(Object** root, void* arg, const RootInfo& /*root_info*/) { reinterpret_cast<MarkSweep*>(arg)->MarkObjectNonNull(*root); } -void MarkSweep::VerifyRootCallback(const Object* root, void* arg, size_t vreg, - const StackVisitor* visitor, RootType root_type) { - reinterpret_cast<MarkSweep*>(arg)->VerifyRoot(root, vreg, visitor, root_type); +void MarkSweep::VerifyRootCallback(Object** root, void* arg, const RootInfo& root_info) { + reinterpret_cast<MarkSweep*>(arg)->VerifyRoot(*root, root_info); } -void MarkSweep::VerifyRoot(const Object* root, size_t vreg, const StackVisitor* visitor, - RootType root_type) { +void MarkSweep::VerifyRoot(const Object* root, const RootInfo& root_info) { // See if the root is on any space bitmap. if (heap_->GetLiveBitmap()->GetContinuousSpaceBitmap(root) == nullptr) { space::LargeObjectSpace* large_object_space = GetHeap()->GetLargeObjectsSpace(); if (large_object_space != nullptr && !large_object_space->Contains(root)) { - LOG(ERROR) << "Found invalid root: " << root << " with type " << root_type; - if (visitor != NULL) { - LOG(ERROR) << visitor->DescribeLocation() << " in VReg: " << vreg; - } + LOG(ERROR) << "Found invalid root: " << root << " "; + root_info.Describe(LOG(ERROR)); } } } void MarkSweep::VerifyRoots() { - Runtime::Current()->GetThreadList()->VerifyRoots(VerifyRootCallback, this); + Runtime::Current()->GetThreadList()->VisitRoots(VerifyRootCallback, this); } void MarkSweep::MarkRoots(Thread* self) { |