coins.ssa
Class GlobalReassociation

java.lang.Object
  extended bycoins.ssa.GlobalReassociation
All Implemented Interfaces:
LocalTransformer, Transformer

class GlobalReassociation
extends java.lang.Object
implements LocalTransformer

Global Reassociation.
The technique to address the code shape probrems. Originaly, global reassociation has 3 steps, but this module has only 2 steps becouse of keeping SSA form. (Forward Propagation is excluded)

Refer:

Preston Briggs and Keith D. Cooper, "Effective Partial Redundancy Elimination," ACM PLDI, pp. 159-170, June 1994.


Nested Class Summary
(package private)  class GlobalReassociation.SortData
          Private data for global reassociation.
 
Field Summary
static int THR
          The threshold of the debug print
 
Constructor Summary
GlobalReassociation(SsaEnvironment e)
          Constructor
 
Method Summary
 boolean doIt(Data data, ImList args)
          Transform the DATA component.
 boolean doIt(Function function, ImList args)
          Do global reassociation.
 java.lang.String name()
          Return the name of the transforming engine.
 java.lang.String subject()
          Return brief description of the tranformation.
 
Methods inherited from class java.lang.Object
clone, equals, finalize, getClass, hashCode, notify, notifyAll, toString, wait, wait, wait
 

Field Detail

THR

public static final int THR
The threshold of the debug print

See Also:
Constant Field Values
Constructor Detail

GlobalReassociation

public GlobalReassociation(SsaEnvironment e)
Constructor

Parameters:
e - The environment of the SSA module
Method Detail

doIt

public boolean doIt(Data data,
                    ImList args)
Description copied from interface: LocalTransformer
Transform the DATA component.

Specified by:
doIt in interface LocalTransformer
Parameters:
data - DATA to be transformed.
args - list of optional arguments.
Returns:
true if transformation suceeded.

name

public java.lang.String name()
Description copied from interface: Transformer
Return the name of the transforming engine. Used for trace tag name.

Specified by:
name in interface Transformer
Returns:
the name of the transforming engine.

subject

public java.lang.String subject()
Description copied from interface: Transformer
Return brief description of the tranformation.

Specified by:
subject in interface Transformer
Returns:
brief description of the tranformation.

doIt

public boolean doIt(Function function,
                    ImList args)
Do global reassociation.

Specified by:
doIt in interface LocalTransformer
Parameters:
function - The current function
args - The list of options
Returns:
true if transformation suceeded.