/* * This file is part of the Jikes RVM project (http://jikesrvm.org). * * This file is licensed to You under the Eclipse Public License (EPL); * You may not use this file except in compliance with the License. You * may obtain a copy of the License at * * http://www.opensource.org/licenses/eclipse-1.0.php * * See the COPYRIGHT.txt file distributed with this work for information * regarding copyright ownership. */ package org.mmtk.plan.generational.immix; import org.mmtk.plan.generational.Gen; import org.mmtk.plan.Trace; import org.mmtk.plan.TransitiveClosure; import org.mmtk.policy.immix.ImmixSpace; import org.mmtk.policy.immix.ObjectHeader; import org.mmtk.policy.Space; import org.mmtk.utility.heap.VMRequest; import org.vmmagic.pragma.*; import org.vmmagic.unboxed.*; /** * This class implements the functionality of a two-generation copying * collector where <b>the higher generation is an immix space</b>. * * Nursery collections occur when either the heap is full or the nursery * is full. The nursery size is determined by an optional command line * argument. If undefined, the nursery size is "infinite", so nursery * collections only occur when the heap is full (this is known as a * flexible-sized nursery collector). Thus both fixed and flexible * nursery sizes are supported. Full heap collections occur when the * nursery size has dropped to a statically defined threshold, * <code>NURSERY_THRESHOLD</code><p> * * See the PLDI'08 paper by Blackburn and McKinley for a description * of the algorithm: http://doi.acm.org/10.1145/1375581.1375586 * * See the Jones & Lins GC book, chapter 7 for a detailed discussion * of generational collection and section 7.3 for an overview of the * flexible nursery behavior ("The Standard ML of New Jersey * collector"), or go to Appel's paper "Simple generational garbage * collection and fast allocation." SP&E 19(2):171--183, 1989.<p> * * * For general comments about the global/local distinction among classes refer * to Plan.java and PlanLocal.java. */ @Uninterruptible public class GenImmix extends Gen { /***************************************************************************** * * Class fields */ /** The mature space, which for GenImmix uses a mark sweep collection policy. */ public static final ImmixSpace immixSpace = new ImmixSpace("immix", DEFAULT_POLL_FREQUENCY, VMRequest.create()); public static final int IMMIX = immixSpace.getDescriptor(); public static final int SCAN_IMMIX = 1; public static final int SCAN_DEFRAG = 2; /**************************************************************************** * * Instance fields */ /* The trace class for a full-heap collection */ public final Trace matureTrace = new Trace(metaDataSpace); private boolean lastGCWasDefrag = false; /***************************************************************************** * * Collection */ /** * Perform a (global) collection phase. */ @Inline @Override public final void collectionPhase(short phaseId) { if (phaseId == SET_COLLECTION_KIND) { super.collectionPhase(phaseId); if (gcFullHeap) immixSpace.decideWhetherToDefrag(emergencyCollection, true, collectionAttempt, collectionTrigger); return; } if (traceFullHeap()) { if (phaseId == PREPARE) { super.collectionPhase(phaseId); matureTrace.prepare(); immixSpace.prepare(true); return; } if (phaseId == CLOSURE) { matureTrace.prepare(); return; } if (phaseId == RELEASE) { matureTrace.release(); lastGCWasDefrag = immixSpace.release(true); super.collectionPhase(phaseId); return; } } else lastGCWasDefrag = false; super.collectionPhase(phaseId); } /** * @return Whether last GC was an exhaustive attempt to collect the heap. For many collectors this is the same as asking whether the last GC was a full heap collection. */ @Override public boolean lastCollectionWasExhaustive() { return lastGCWasDefrag; } /***************************************************************************** * * Accounting */ /** * Return the number of pages reserved for use given the pending * allocation. * * @return The number of pages reserved given the pending * allocation, excluding space reserved for copying. */ @Inline @Override public int getPagesUsed() { return immixSpace.reservedPages() + super.getPagesUsed(); } /** * Return the number of pages available for allocation into the mature * space. * * @return The number of pages available for allocation into the mature * space. */ public int getMaturePhysicalPagesAvail() { return immixSpace.availablePhysicalPages(); } /***************************************************************************** * * Miscellaneous */ /** * Accessor method to allow the generic generational code in Gen.java * to access the mature space. * * @return The active mature space */ @Inline protected final Space activeMatureSpace() { return immixSpace; } /** * @see org.mmtk.plan.Plan#willNeverMove * * @param object Object in question * @return true if the object will never move */ @Override public boolean willNeverMove(ObjectReference object) { if (Space.isInSpace(IMMIX, object)) { ObjectHeader.pinObject(object); return true; } else return super.willNeverMove(object); } /** * Register specialized methods. */ @Interruptible protected void registerSpecializedMethods() { TransitiveClosure.registerSpecializedScan(SCAN_IMMIX, GenImmixMatureTraceLocal.class); TransitiveClosure.registerSpecializedScan(SCAN_DEFRAG, GenImmixMatureDefragTraceLocal.class); super.registerSpecializedMethods(); } }