Skip to content

Commit

Permalink
Cleanup of instr cloning before rebuild
Browse files Browse the repository at this point in the history
* This looks a bit better and handles both interp and JIT
  identically.
  • Loading branch information
subbuss committed Feb 22, 2015
1 parent aa01ace commit dd12f21
Showing 1 changed file with 15 additions and 23 deletions.
38 changes: 15 additions & 23 deletions core/src/main/java/org/jruby/ir/IRScope.java
Original file line number Diff line number Diff line change
Expand Up @@ -455,13 +455,6 @@ public CFG buildCFG() {
return getCFG();
}

// If the scope has already been interpreted once,
// the scope can be on the call stack right now.
// So, clone instructions before building the CFG.
if (state == ScopeState.INTERPED) {
cloneInstrs();
}

CFG newCFG = new CFG(this);
newCFG.build(getInstrs());
// Clear out instruction list after CFG has been built.
Expand Down Expand Up @@ -616,6 +609,19 @@ private void optimizeSimpleScopes() {
}

protected void initScope(boolean jitMode) {
// FIXME: This is messy and prepareForInterpretation and prepareForCompilation need to
// clean up the lifecycle aspects of creating CFG from instrList and running passes in
// a consistent and predictable way. This is a hack atm to unbreak the fact JIT
// may happen before IC.build count and thus not have cloned the instrs (which then
// modifies instrs IC is using causing weird blowups.
//
// If the scope has already been interpreted once,
// the scope can be on the call stack right now.
// So, clone instructions before modifying them!
if (state != ScopeState.INIT && getCFG() == null) {
cloneInstrs();
}

runCompilerPasses(getManager().getCompilerPasses(this));

if (!jitMode && RubyInstanceConfig.IR_COMPILER_PASSES == null) {
Expand Down Expand Up @@ -672,14 +678,9 @@ protected void cloneInstrs(SimpleCloneInfo cloneInfo) {
public synchronized InterpreterContext prepareForInterpretation(boolean rebuild) {
if (interpreterContext == null) {
this.state = ScopeState.INTERPED;
} else if (!rebuild || getCFG() != null) {
return interpreterContext; // Already prepared/rebuilt
} else {
if (!rebuild || getCFG() != null) {
return interpreterContext; // Already prepared/rebuilt
}

// If rebuilding, clone instrs before building cfg, running passes, etc.
this.cloneInstrs();

// Build CFG, run passes, etc.
initScope(false);

Expand All @@ -698,15 +699,6 @@ public synchronized InterpreterContext prepareForInterpretation(boolean rebuild)

/** Run any necessary passes to get the IR ready for compilation */
public synchronized List<BasicBlock> prepareForCompilation() {
// FIXME: This is messy and prepareForInterpretation and prepareForCompilation need to
// clean up the lifecycle aspects of creating CFG from instrList and running passes in
// a consistent and predictable way. This is a hack atm to unbreak the fact JIT
// may happen before IC.build count and thus not have cloned the instrs (which then
// modifies instrs IC is using causing weird blowups.
if (getCFG() == null) {
cloneInstrs();
}

// Reset linearization, if any exists
resetLinearizationData();

Expand Down

0 comments on commit dd12f21

Please sign in to comment.