diff options
author | Mathieu Chartier <mathieuc@google.com> | 2015-03-31 23:20:41 +0000 |
---|---|---|
committer | Gerrit Code Review <noreply-gerritcodereview@google.com> | 2015-03-31 23:20:41 +0000 |
commit | bf143069fc5b7526ea79d4283293878a2ebe99ee (patch) | |
tree | 4692631472d1a112fbee2ca7a0c94708b46cce84 /runtime/runtime.cc | |
parent | 38d3b133dcb5968a69ffbcda58990fcdca5b56a1 (diff) | |
parent | 461687d898dfd91253f242072849a9fe43e5f523 (diff) | |
download | art-bf143069fc5b7526ea79d4283293878a2ebe99ee.zip art-bf143069fc5b7526ea79d4283293878a2ebe99ee.tar.gz art-bf143069fc5b7526ea79d4283293878a2ebe99ee.tar.bz2 |
Merge "Visit image roots for hprof"
Diffstat (limited to 'runtime/runtime.cc')
-rw-r--r-- | runtime/runtime.cc | 19 |
1 files changed, 18 insertions, 1 deletions
diff --git a/runtime/runtime.cc b/runtime/runtime.cc index 23a7db6..b5d2e15 100644 --- a/runtime/runtime.cc +++ b/runtime/runtime.cc @@ -62,7 +62,7 @@ #include "gc/accounting/card_table-inl.h" #include "gc/heap.h" #include "gc/space/image_space.h" -#include "gc/space/space.h" +#include "gc/space/space-inl.h" #include "handle_scope-inl.h" #include "image.h" #include "instrumentation.h" @@ -1355,6 +1355,23 @@ void Runtime::VisitRoots(RootCallback* callback, void* arg, VisitRootFlags flags VisitConcurrentRoots(callback, arg, flags); } +void Runtime::VisitImageRoots(RootCallback* callback, void* arg) { + for (auto* space : GetHeap()->GetContinuousSpaces()) { + if (space->IsImageSpace()) { + auto* image_space = space->AsImageSpace(); + const auto& image_header = image_space->GetImageHeader(); + for (size_t i = 0; i < ImageHeader::kImageRootsMax; ++i) { + auto* obj = image_header.GetImageRoot(static_cast<ImageHeader::ImageRoot>(i)); + if (obj != nullptr) { + auto* after_obj = obj; + callback(&after_obj, arg, RootInfo(kRootStickyClass)); + CHECK_EQ(after_obj, obj); + } + } + } + } +} + mirror::ObjectArray<mirror::ArtMethod>* Runtime::CreateDefaultImt(ClassLinker* cl) { Thread* self = Thread::Current(); StackHandleScope<1> hs(self); |