|
|||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.mmtk.plan.MutatorContext org.mmtk.plan.SimpleMutator org.mmtk.plan.StopTheWorldMutator org.mmtk.plan.immix.ImmixMutator org.mmtk.plan.stickyimmix.StickyImmixMutator
public class StickyImmixMutator
This class implements per-mutator thread behavior and state for the StickyImmix plan, which implements a generational mark-sweep collector.
Specifically, this class defines MS mutator-time allocation and per-mutator thread collection semantics (flushing and restoring per-mutator allocator state).
*
StickyImmix
,
StickyImmixCollector
,
MutatorContext
,
Phase
Field Summary | |
---|---|
private ObjectReferenceDeque |
modBuffer
|
Fields inherited from class org.mmtk.plan.immix.ImmixMutator |
---|
immix |
Fields inherited from class org.mmtk.plan.MutatorContext |
---|
immortal, lgcode, log, los, nonmove, smcode |
Constructor Summary | |
---|---|
StickyImmixMutator()
Constructor |
Method Summary | |
---|---|
void |
assertRemsetFlushed()
|
void |
collectionPhase(short phaseId,
boolean primary)
Perform a per-mutator collection phase. |
void |
flushRememberedSets()
Flush per-mutator remembered sets into the global remset pool. |
private static StickyImmix |
global()
|
private void |
logSource(ObjectReference src)
Add an object to the modified objects buffer and mark the object has having been logged. |
boolean |
objectReferenceBulkCopy(ObjectReference src,
Offset srcOffset,
ObjectReference dst,
Offset dstOffset,
int bytes)
A number of references are about to be copied from object src to object dst (as in an array
copy). |
boolean |
objectReferenceTryCompareAndSwap(ObjectReference src,
Address slot,
ObjectReference old,
ObjectReference tgt,
Word metaDataA,
Word metaDataB,
int mode)
Attempt to atomically exchange the value in the given slot with the passed replacement value. |
void |
objectReferenceWrite(ObjectReference src,
Address slot,
ObjectReference tgt,
Word metaDataA,
Word metaDataB,
int mode)
Write an object reference. |
Methods inherited from class org.mmtk.plan.immix.ImmixMutator |
---|
alloc, getAllocatorFromSpace, postAlloc |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait |
Field Detail |
---|
private ObjectReferenceDeque modBuffer
Constructor Detail |
---|
public StickyImmixMutator()
Method Detail |
---|
public final void objectReferenceWrite(ObjectReference src, Address slot, ObjectReference tgt, Word metaDataA, Word metaDataB, int mode)
By default do nothing, override if appropriate.
In this case, we remember the address of the source of the pointer if the new reference points into the nursery from non-nursery space.
objectReferenceWrite
in class MutatorContext
src
- The object into which the new reference will be storedslot
- The address into which the new reference will be
stored.tgt
- The value of the new referencemetaDataA
- A value that assists the host VM in creating a storemetaDataB
- A value that assists the host VM in creating a storemode
- The context in which the store occurredpublic final boolean objectReferenceBulkCopy(ObjectReference src, Offset srcOffset, ObjectReference dst, Offset dstOffset, int bytes)
src
to object dst
(as in an array
copy). Thus, dst
is the mutated object. Take
appropriate write barrier actions.In this case, we remember the mutated source address range and will scan that address range at GC time.
objectReferenceBulkCopy
in class MutatorContext
src
- The source of the values to copiedsrcOffset
- The offset of the first source address, in
bytes, relative to src
(in principle, this could be
negative).dst
- The mutated object, i.e. the destination of the copy.dstOffset
- The offset of the first destination address, in
bytes relative to tgt
(in principle, this could be
negative).bytes
- The size of the region being copied, in bytes.
public boolean objectReferenceTryCompareAndSwap(ObjectReference src, Address slot, ObjectReference old, ObjectReference tgt, Word metaDataA, Word metaDataB, int mode)
MutatorContext
By default do nothing, override if appropriate.
objectReferenceTryCompareAndSwap
in class MutatorContext
src
- The object into which the new reference will be storedslot
- The address into which the new reference will be
stored.old
- The old reference to be swapped outtgt
- The target of the new referencemetaDataA
- A value that assists the host VM in creating a storemetaDataB
- A value that assists the host VM in creating a storemode
- The context in which the store occurred
private void logSource(ObjectReference src)
src
- The object to be loggedpublic final void flushRememberedSets()
MutatorContext
flushRememberedSets
in class MutatorContext
public final void assertRemsetFlushed()
public final void collectionPhase(short phaseId, boolean primary)
collectionPhase
in class ImmixMutator
phaseId
- The unique phase identifierprimary
- Should this thread be used to execute any single-threaded
local operations?private static StickyImmix global()
MSGen
instance.
|
|||||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |