/*
* 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.jikesrvm.compilers.opt.driver;
import org.jikesrvm.VM;
import org.jikesrvm.compilers.opt.OptOptions;
import org.jikesrvm.compilers.opt.ir.IR;
import org.jikesrvm.runtime.Time;
/**
* An element in the opt compiler's optimization plan
* that consists of a single CompilerPhase.
*
* <p> NOTE: Instances of this class are
* held in <code> OptimizationPlanner.masterPlan </code>
* and thus represent global state.
* It is therefore incorrect for any per-compilation
* state to be stored in an instance field of
* one of these objects.
*/
public final class OptimizationPlanAtomicElement extends OptimizationPlanElement {
/**
* The phase to be performed.
*/
private final CompilerPhase myPhase;
/**
* Accumulated nanoseconds spent in the element.
*/
protected long phaseNanos = 0;
/**
* Counters to be used by myPhase to gather phase specific stats.
*/
public double counter1, counter2;
public OptimizationPlanAtomicElement(CompilerPhase p) {
myPhase = p;
p.setContainer(this);
}
/**
* Update this phase to support the measuring of compilation
*/
@Override
public void initializeForMeasureCompilation() {
counter1 = 0;
counter2 = 0;
}
@Override
public boolean shouldPerform(OptOptions options) {
return myPhase.shouldPerform(options);
}
@Override
public void perform(IR ir) {
ir.setIdForNextPhase();
long start = 0;
try {
if (VM.MeasureCompilationPhases && VM.runningVM) {
start = Time.nanoTime();
}
CompilerPhase cmpPhase = myPhase.newExecution(ir);
cmpPhase.setContainer(this);
cmpPhase.performPhase(ir);
} finally {
if (VM.MeasureCompilationPhases && VM.runningVM) {
long end = Time.nanoTime();
phaseNanos += end - start;
}
}
}
@Override
public String getName() {
return myPhase.getName();
}
@Override
public void reportStats(int indent, int timeCol, double totalTime) {
if (phaseNanos == 0) return;
int curCol = 0;
for (curCol = 0; curCol < indent; curCol++) {
VM.sysWrite(" ");
}
String name = myPhase.getName();
int namePtr = 0;
while (curCol < timeCol && namePtr < name.length()) {
VM.sysWrite(name.charAt(namePtr));
namePtr++;
curCol++;
}
while (curCol < timeCol) {
VM.sysWrite(" ");
curCol++;
}
double myTime = Time.nanosToMillis(phaseNanos);
prettyPrintTime(myTime, totalTime);
myPhase.reportAdditionalStats();
VM.sysWriteln();
}
@Override
public double elapsedTime() {
return Time.nanosToMillis(phaseNanos);
}
}