diff options
author | Hiroshi Yamauchi <yamauchi@google.com> | 2015-01-09 14:03:35 -0800 |
---|---|---|
committer | Hiroshi Yamauchi <yamauchi@google.com> | 2015-01-23 14:07:32 -0800 |
commit | 2cd334ae2d4287216523882f0d298cf3901b7ab1 (patch) | |
tree | b72d3d07e5a04151caca96cae345075b6e4452b0 /runtime/debugger.cc | |
parent | 604e2828896fbb8663897d1e75112da7305ead4c (diff) | |
download | art-2cd334ae2d4287216523882f0d298cf3901b7ab1.tar.gz art-2cd334ae2d4287216523882f0d298cf3901b7ab1.tar.bz2 art-2cd334ae2d4287216523882f0d298cf3901b7ab1.zip |
More of the concurrent copying collector.
Bug: 12687968
Change-Id: I62f70274d47df6d6cab714df95c518b750ce3105
Diffstat (limited to 'runtime/debugger.cc')
-rw-r--r-- | runtime/debugger.cc | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/runtime/debugger.cc b/runtime/debugger.cc index 169aa9c717..1cbaf393d4 100644 --- a/runtime/debugger.cc +++ b/runtime/debugger.cc @@ -4487,6 +4487,18 @@ void Dbg::DdmSendHeapSegments(bool native) { context.SetChunkOverhead(0); space->AsBumpPointerSpace()->Walk(BumpPointerSpaceCallback, &context); HeapChunkContext::HeapChunkJavaCallback(nullptr, nullptr, 0, &context); + } else if (space->IsRegionSpace()) { + heap->IncrementDisableMovingGC(self); + self->TransitionFromRunnableToSuspended(kSuspended); + ThreadList* tl = Runtime::Current()->GetThreadList(); + tl->SuspendAll(); + ReaderMutexLock mu(self, *Locks::heap_bitmap_lock_); + context.SetChunkOverhead(0); + space->AsRegionSpace()->Walk(BumpPointerSpaceCallback, &context); + HeapChunkContext::HeapChunkJavaCallback(nullptr, nullptr, 0, &context); + tl->ResumeAll(); + self->TransitionFromSuspendedToRunnable(); + heap->DecrementDisableMovingGC(self); } else { UNIMPLEMENTED(WARNING) << "Not counting objects in space " << *space; } |