|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object scale.common.Root scale.score.Note scale.score.expr.Expr scale.score.expr.LoadExpr scale.score.expr.LoadDeclAddressExpr
public final class LoadDeclAddressExpr
This class represents the address of a declaration.
$Id: LoadDeclAddressExpr.java,v 1.74 2007-10-04 19:58:31 burrill Exp $
Copyright 2008 by the
Scale Compiler Group,
Department of Computer Science
University of Massachusetts,
Amherst MA. 01003, USA
All Rights Reserved.
The type of a LoadDeclAddressExpr is always of type pointer-to-declaration-type.
Field Summary |
---|
Fields inherited from class scale.score.expr.Expr |
---|
fpReorder, SE_DOMAIN, SE_NONE, SE_OVERFLOW, SE_STATE |
Constructor Summary | |
---|---|
LoadDeclAddressExpr(Declaration decl)
This method builds an expression node with this operation as the operator. |
Method Summary | |
---|---|
Expr |
copy()
Make a copy of this load expression. |
Expr |
copyNoUD()
Make a copy of this load expression without the use - def information. |
int |
executionCostEstimate()
Return a relative cost estimate for executing the expression. |
int |
findCoefficient()
Return the coefficient value. |
protected Chord |
findCriticalChord(HashMap<Expr,Chord> lMap,
Chord independent)
Return the label of the Chord with the highest label value from the set of Chords that must be executed before this expression. |
java.lang.String |
getDisplayLabel()
Return a String suitable for labeling this node in a graphical display. |
boolean |
isLoopInvariant(LoopHeaderChord loop)
Return true if this expression is loop invariant. |
int |
linearity()
Return linearity of an address. |
boolean |
optimizationCandidate()
Return true if the expression can be moved without problems. |
void |
recordRefs(Chord stmt,
References refs)
Record any variable references in this expression in the table of references. |
void |
removeRefs(Chord stmt,
References refs)
Remove any variable references in this expression from the table of references. |
void |
visit(Predicate p)
Process a node by calling its associated routine. |
Methods inherited from class scale.score.expr.LoadExpr |
---|
addMayUse, canonical, containsDeclaration, dependsOnDeclaration, equivalent, findSubscriptExpr, getAliasAnnote, getDecl, getDeclList, getExprList, getLoadExprList, getMayUse, getName, getObject, getOperandArray, getReference, getReuseLevel, getSubsetDecl, getUseDef, isMemoryDef, isMemRefExpr, loopClean, numOperands, pushOperands, referencesVariableInCommon, removeUseDef, replaceDecl, setCrossloopReuse, setDecl, setSpatialReuse, setStep, setTemporalReuse, setUseDef, setUseMayUse, setUseOriginal, sideEffects, unlinkExpression, validate, validLValue |
Methods inherited from class scale.score.Note |
---|
getChord, getEssentialUse, setAnnotationLevel, setReportLevel, toString |
Methods inherited from class scale.common.Root |
---|
addAnnotation, allAnnotations, allMatchingAnnotations, getAnnotation, getDisplayName, getDisplayString, getNodeCount, getNodeID, hasAnnotation, hasEqualAnnotation, hashCode, removeAnnotation, removeAnnotations, toStringAnnotations, toStringClass, trace, trace, trace |
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, notify, notifyAll, wait, wait, wait |
Constructor Detail |
---|
public LoadDeclAddressExpr(Declaration decl)
Method Detail |
---|
public Expr copy()
copy
in class Expr
public Expr copyNoUD()
copyNoUD
in class LoadExpr
public void visit(Predicate p)
Note
Each class has a visit(Predicate p)
method. For
example, in class ABC
:
public void visit(Predicate p) { p.visitABC(this); }and the class that implements
Predicate
has a method
public void visitABC(Note n) { ABC a = (ABC) n; ... }Thus, the class that implements
Predicate
can call
n.visit(this);where
n
is a Note
sub-class without
determining which specific sub-class n
is.
The visit pattern basically avoids implementing a large
switch
statement or defining different methods
in each class for some purpose.
visit
in class Note
Predicate
public java.lang.String getDisplayLabel()
Expr
getDisplayLabel
in interface DisplayNode
getDisplayLabel
in class Expr
public int linearity()
public int findCoefficient()
protected Chord findCriticalChord(HashMap<Expr,Chord> lMap, Chord independent)
findCriticalChord
in class Expr
lMap
- is used to memoize the expression to critical Chord
informationindependent
- is returned if the expression is not dependent
on anythingpublic boolean optimizationCandidate()
optimizationCandidate
in class Expr
public int executionCostEstimate()
executionCostEstimate
in class Note
public void recordRefs(Chord stmt, References refs)
recordRefs
in class LoadExpr
public void removeRefs(Chord stmt, References refs)
removeRefs
in class LoadExpr
public boolean isLoopInvariant(LoopHeaderChord loop)
isLoopInvariant
in class Expr
loop
- is the loop
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |