diff options
author | Mathieu Chartier <mathieuc@google.com> | 2014-03-04 11:07:42 -0800 |
---|---|---|
committer | Mathieu Chartier <mathieuc@google.com> | 2014-03-04 14:21:58 -0800 |
commit | 893263b7d5bc2ca43a91ecb8071867f5134fc60a (patch) | |
tree | a99238843a9caad00122c8f7d13e031f5d81bc38 /runtime/runtime.h | |
parent | 2fece5941f12395a94e742313e7059a9e419994d (diff) | |
download | art-893263b7d5bc2ca43a91ecb8071867f5134fc60a.zip art-893263b7d5bc2ca43a91ecb8071867f5134fc60a.tar.gz art-893263b7d5bc2ca43a91ecb8071867f5134fc60a.tar.bz2 |
Avoid marking old class linker and intern table roots during pause.
The new root visiting logic has a concept of a root log which holds
new roots which were added since the start of the GC. This is an
optimization since it lets us only mark these newly added roots
during the pause (or pre-cleaning) since the other roots intern table
and class linker roots were marked concurrently at the start of the
GC.
Before (EvaluateAndApplyChanges):
MarkConcurrentRoots: Sum: 605.193ms
After:
MarkConcurrentRoots: Sum: 271.858ms
This should also reduce pathological GC pauses which used to be able
to happen when the intern table or class linker became "dirty"
during the concurrent GC.
Change-Id: I433fab021f2c339d50c35aaae7161a50a0901dec
Diffstat (limited to 'runtime/runtime.h')
-rw-r--r-- | runtime/runtime.h | 18 |
1 files changed, 16 insertions, 2 deletions
diff --git a/runtime/runtime.h b/runtime/runtime.h index 2b3f100..f12c3d8 100644 --- a/runtime/runtime.h +++ b/runtime/runtime.h @@ -68,6 +68,14 @@ class ThreadList; class Trace; class Transaction; +enum VisitRootFlags : uint8_t { + kVisitRootFlagAllRoots = 0x1, + kVisitRootFlagNewRoots = 0x2, + kVisitRootFlagStartLoggingNewRoots = 0x4, + kVisitRootFlagStopLoggingNewRoots = 0x8, + kVisitRootFlagClearRootLog = 0x10, +}; + class Runtime { public: typedef std::vector<std::pair<std::string, const void*> > Options; @@ -222,11 +230,12 @@ class Runtime { // Visit all the roots. If only_dirty is true then non-dirty roots won't be visited. If // clean_dirty is true then dirty roots will be marked as non-dirty after visiting. - void VisitRoots(RootCallback* visitor, void* arg, bool only_dirty, bool clean_dirty) + void VisitRoots(RootCallback* visitor, void* arg, VisitRootFlags flags = kVisitRootFlagAllRoots) SHARED_LOCKS_REQUIRED(Locks::mutator_lock_); // Visit all of the roots we can do safely do concurrently. - void VisitConcurrentRoots(RootCallback* visitor, void* arg, bool only_dirty, bool clean_dirty) + void VisitConcurrentRoots(RootCallback* visitor, void* arg, + VisitRootFlags flags = kVisitRootFlagAllRoots) SHARED_LOCKS_REQUIRED(Locks::mutator_lock_); // Visit all of the non thread roots, we can do this with mutators unpaused. @@ -242,6 +251,11 @@ class Runtime { void SweepSystemWeaks(IsMarkedCallback* visitor, void* arg) SHARED_LOCKS_REQUIRED(Locks::mutator_lock_); + // Constant roots are the roots which never change after the runtime is initialized, they only + // need to be visited once per GC cycle. + void VisitConstantRoots(RootCallback* callback, void* arg) + SHARED_LOCKS_REQUIRED(Locks::mutator_lock_); + // Returns a special method that calls into a trampoline for runtime method resolution mirror::ArtMethod* GetResolutionMethod() const { CHECK(HasResolutionMethod()); |