From: yeom Date: Thu, 24 Sep 2009 00:22:17 +0000 (+0000) Subject: initial commit for method effects analysis. X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=28beee6461cc64f4f487431475339f16e122bb8a;p=IRC.git initial commit for method effects analysis. it captures implementation for last demo. --- diff --git a/Robust/src/Analysis/MLP/AccKey.java b/Robust/src/Analysis/MLP/AccKey.java new file mode 100644 index 00000000..3b02c6f9 --- /dev/null +++ b/Robust/src/Analysis/MLP/AccKey.java @@ -0,0 +1,64 @@ +package Analysis.MLP; + +import IR.TypeDescriptor; + +public class AccKey { + + private String fd; + private TypeDescriptor td; + + // private Integer hrnID; + + public AccKey(String fd, TypeDescriptor td) { + this.fd = fd; + this.td = td; + } + + public String getFieldDescriptor() { + return fd; + } + + public TypeDescriptor getTypeDescriptor() { + return td; + } + + public String toString() { + return "(" + td + ")" + fd ; + } + + public int hashCode() { + + int hash = 1; + + if (fd != null) { + hash = hash * 31 + fd.hashCode(); + } + + if (td != null) { + hash += td.getSymbol().hashCode(); + } + + return hash; + + } + + public boolean equals(Object o) { + + if (o == null) { + return false; + } + + if (!(o instanceof AccKey)) { + return false; + } + + AccKey in = (AccKey) o; + + if (fd.equals(in.getFieldDescriptor()) && td.getSymbol().equals(in.getTypeDescriptor().getSymbol())) { + return true; + } else { + return false; + } + + } +} diff --git a/Robust/src/Analysis/MLP/AccSet.java b/Robust/src/Analysis/MLP/AccSet.java new file mode 100644 index 00000000..673ff244 --- /dev/null +++ b/Robust/src/Analysis/MLP/AccSet.java @@ -0,0 +1,235 @@ +package Analysis.MLP; + +import java.util.HashSet; +import java.util.Hashtable; +import java.util.Iterator; + +import IR.Flat.TempDescriptor; + +public class AccSet { + + private Hashtable> readTable; + private Hashtable> writeTable; + + public AccSet() { + + readTable = new Hashtable>(); + writeTable = new Hashtable>(); + + } + + public void addReadingVar(TempDescriptor td, AccKey access) { + HashSet aSet = readTable.get(td); + if (aSet == null) { + aSet = new HashSet(); + } + + aSet.add(access); + readTable.put(td, aSet); + } + + public void addWritingVar(TempDescriptor td, AccKey access) { + + HashSet aSet = writeTable.get(td); + if (aSet == null) { + aSet = new HashSet(); + } + + aSet.add(access); + writeTable.put(td, aSet); + + } + + public boolean containsParam(TempDescriptor td) { + + Iterator iter = readTable.keySet().iterator(); + + while (iter.hasNext()) { + + TempDescriptor key = iter.next(); + if (key.equals(td)) { + return true; + } + + } + + return false; + + } + + public void addParam(TempDescriptor paramTD) { + + if (!readTable.containsKey(paramTD)) { + HashSet readSet = new HashSet(); + readTable.put(paramTD, readSet); + } + + if (!writeTable.containsKey(paramTD)) { + HashSet writeSet = new HashSet(); + writeTable.put(paramTD, writeSet); + } + + } + + public void addAll(AccSet newAccSet) { + + Hashtable> newReadTable = newAccSet + .getReadTable(); + Hashtable> newWriteTable = newAccSet + .getWriteTable(); + + Iterator iter = newReadTable.keySet().iterator(); + while (iter.hasNext()) { // for each variables + TempDescriptor td = iter.next(); + + HashSet currentSet; + if (!readTable.containsKey(td)) { + currentSet = new HashSet(); + } else { + currentSet = readTable.get(td); + } + + HashSet newSet = newReadTable.get(td); + currentSet.addAll(newSet); + readTable.put(td, currentSet); + } + + iter = newWriteTable.keySet().iterator(); + while (iter.hasNext()) { // for each variables + TempDescriptor td = iter.next(); + + HashSet currentSet; + if (!writeTable.containsKey(td)) { + currentSet = new HashSet(); + } else { + currentSet = writeTable.get(td); + } + + HashSet newSet = newWriteTable.get(td); + currentSet.addAll(newSet); + writeTable.put(td, currentSet); + } + + } + + public Hashtable> getReadTable() { + return readTable; + } + + public Hashtable> getWriteTable() { + return writeTable; + } + + public boolean equals(Object o) { + if (o == null) { + return false; + } + + if (!(o instanceof AccSet)) { + return false; + } + + AccSet in = (AccSet) o; + + if (getReadTable().equals(in.getReadTable()) + && getWriteTable().equals(in.getWriteTable())) { + return true; + } else { + return false; + } + + } + + public void printSet() { + + String readStr = ""; + String writeStr = ""; + + readStr = "#Reading#\r\n"; + Iterator iter = getReadTable().keySet().iterator(); + while (iter.hasNext()) { // for each variables + + TempDescriptor td = iter.next(); + HashSet aSet = readTable.get(td); + + readStr += td.getSymbol() + ":" + "{"; + + Iterator setIter = aSet.iterator(); + while (setIter.hasNext()) { + AccKey element = setIter.next(); + readStr += " " + element; + } + readStr += "}\r\n"; + } + + writeStr = "#Writing#\r\n"; + iter = getWriteTable().keySet().iterator(); + while (iter.hasNext()) { // for each variables + + TempDescriptor td = iter.next(); + HashSet aSet = writeTable.get(td); + + writeStr += td.getSymbol() + ":" + "{"; + + Iterator setIter = aSet.iterator(); + while (setIter.hasNext()) { + AccKey element = setIter.next(); + writeStr += " " + element; + } + writeStr += "}\r\n"; + } + + System.out.println(readStr); + System.out.println(writeStr); + + } + + public String toString() { + + String str = "\n"; + + Iterator iter = getReadTable().keySet().iterator(); + while (iter.hasNext()) { // for each variables + + TempDescriptor td = iter.next(); + + str += "\tParameter " + td.getSymbol() + " reading={"; + + HashSet aSet = readTable.get(td); + Iterator setIter = aSet.iterator(); + boolean first = true; + while (setIter.hasNext()) { + AccKey element = setIter.next(); + if (first) { + str += " " + element; + first = false; + } else { + str += " , " + element; + } + + } + str += " }\n"; + + str += "\tParameter " + td.getSymbol() + " writing={"; + + aSet = writeTable.get(td); + setIter = aSet.iterator(); + first = true; + while (setIter.hasNext()) { + AccKey element = setIter.next(); + if (first) { + str += " " + element; + first = false; + } else { + str += " , " + element; + } + + } + str += " }\n"; + + } + + return str; + } + +} diff --git a/Robust/src/Analysis/MLP/MLPAnalysis.java b/Robust/src/Analysis/MLP/MLPAnalysis.java index 1c9e8eec..4c776dc3 100644 --- a/Robust/src/Analysis/MLP/MLPAnalysis.java +++ b/Robust/src/Analysis/MLP/MLPAnalysis.java @@ -46,6 +46,8 @@ public class MLPAnalysis { private Hashtable< FlatNode, VarSrcTokTable > variableResults; private Hashtable< FlatNode, Set > notAvailableResults; private Hashtable< FlatNode, CodePlan > codePlans; + + private Hashtable effectsResults; private Hashtable< FlatEdge, FlatWriteDynamicVarNode > wdvNodesToSpliceIn; @@ -100,6 +102,8 @@ public class MLPAnalysis { notAvailableResults = new Hashtable< FlatNode, Set >(); codePlans = new Hashtable< FlatNode, CodePlan >(); wdvNodesToSpliceIn = new Hashtable< FlatEdge, FlatWriteDynamicVarNode >(); + + effectsResults = new Hashtable(); FlatMethod fmMain = state.getMethodFlat( typeUtil.getMain() ); @@ -183,7 +187,14 @@ public class MLPAnalysis { // point, in a forward fixed-point pass notAvailableForward( fm ); } - + + // new pass for method effects analysis + methItr = ownAnalysis.descriptorsToAnalyze.iterator(); + while (methItr.hasNext()) { + Descriptor d = methItr.next(); + FlatMethod fm = state.getMethodFlat(d); + effectsForward(fm); + } // 7th pass methItr = ownAnalysis.descriptorsToAnalyze.iterator(); @@ -638,6 +649,292 @@ public class MLPAnalysis { } } + private void effectsForward(FlatMethod fm) { + Set flatNodesToVisit = new HashSet(); + flatNodesToVisit.add(fm); + + while (!flatNodesToVisit.isEmpty()) { + FlatNode fn = (FlatNode) flatNodesToVisit.iterator().next(); + flatNodesToVisit.remove(fn); + + AccSet prev = effectsResults.get(fn); + AccSet curr = new AccSet(); + + // merge phase + for (int i = 0; i < fn.numPrev(); i++) { + FlatNode nn = fn.getPrev(i); + AccSet accSet = effectsResults.get(nn); + if (accSet != null) { + curr.addAll(accSet); + } + } + + effects_nodeActions(fn, curr); + + // if a new result, schedule forward nodes for analysis + if (!curr.equals(prev)) { + effectsResults.put(fn, curr); + for (int i = 0; i < fn.numNext(); i++) { + FlatNode nn = fn.getNext(i); + flatNodesToVisit.add(nn); + } + } + } + + } + + + + + private void effects_nodeActions(FlatNode fn, AccSet curr) { + + OwnershipGraph fnOG = ownAnalysis + .getMappingFlatNodeToOwnershipGraph(fn); + + switch (fn.kind()) { + + case FKind.FlatMethod: { + + FlatMethod fm = (FlatMethod) fn; + int numParam = fm.numParameters(); + + for (int i = 0; i < numParam; i++) { + TempDescriptor paramTD = fm.getParameter(i); + + curr.addParam(paramTD); + } + + // for debug + // OwnershipGraph fnOG = + // ownAnalysis.getMappingFlatNodeToOwnershipGraph(fn); + // try { + // fnOG.writeGraph(fn + "FOOGRAPH", true, true, true, true, false); + // } catch (IOException e) { + // System.out.println("Error writing debug capture."); + // System.exit(0); + // } + + } + break; + + case FKind.FlatSetFieldNode: { + + FlatSetFieldNode fsfn = (FlatSetFieldNode) fn; + + TempDescriptor dstDesc = fsfn.getDst(); + FieldDescriptor fieldDesc = fsfn.getField(); + TempDescriptor srcDesc = fsfn.getSrc(); + + LabelNode ln = fnOG.td2ln.get(dstDesc); + if (ln != null) { + Iterator heapRegionsItr = ln + .iteratorToReferencees(); + + String tempStr = ""; + while (heapRegionsItr.hasNext()) { + HeapRegionNode hrn2 = heapRegionsItr.next().getDst(); + + Set paramSet = fnOG.idSecondary2paramIndexSet + .get(hrn2.getID()); + + String param = null; + if (paramSet != null) { + Iterator paramIter = paramSet.iterator(); + param = ""; + while (paramIter.hasNext()) { + param += paramIter.next() + " "; + } + } + tempStr += " " + hrn2 + "(" + param + ")"; + } + + heapRegionsItr = ln.iteratorToReferencees(); + while (heapRegionsItr.hasNext()) { + ReferenceEdge edge = heapRegionsItr.next(); + HeapRegionNode hrn = edge.getDst(); + + if (hrn.isParameter()) { + // currently, handle this case. otherwise, ignore it. + Iterator iter = hrn + .iteratorToReferencers(); + while (iter.hasNext()) { + ReferenceEdge re = iter.next(); + if (re.getSrc() instanceof LabelNode) { + LabelNode labelNode = (LabelNode) re.getSrc(); + + if (curr.containsParam(labelNode + .getTempDescriptor())) { + + curr.addWritingVar(labelNode + .getTempDescriptor(), new AccKey( + fieldDesc.getSymbol(), dstDesc + .getType())); + + } + + } + } + + // check weather this heap region is parameter + // reachable... + + Set paramSet = fnOG.idSecondary2paramIndexSet + .get(hrn.getID()); + if (paramSet != null) { + Iterator paramIter = paramSet.iterator(); + + while (paramIter.hasNext()) { + Integer paramID = paramIter.next(); + + Integer primaryID = fnOG.paramIndex2idPrimary + .get(paramID); + HeapRegionNode paramHRN = fnOG.id2hrn + .get(primaryID); + + HashSet LNSet = getParameterLabelNodeSet( + fnOG, curr, paramHRN); + + Iterator LNSetIter = LNSet + .iterator(); + while (LNSetIter.hasNext()) { + LabelNode labelNode = LNSetIter.next(); + + curr.addWritingVar(labelNode + .getTempDescriptor(), new AccKey( + fieldDesc.getSymbol(), dstDesc + .getType())); + } + + } + } + + } + + } + } + + } + break; + + case FKind.FlatFieldNode: { + + FlatFieldNode ffn = (FlatFieldNode) fn; + + TempDescriptor srcDesc = ffn.getSrc(); + FieldDescriptor fieldDesc = ffn.getField(); + + LabelNode ln = fnOG.td2ln.get(srcDesc); + if (ln != null) { + + Iterator heapRegionsItr = ln + .iteratorToReferencees(); + String tempStr = ""; + while (heapRegionsItr.hasNext()) { + + HeapRegionNode hrn = heapRegionsItr.next().getDst(); + + Set paramSet = fnOG.idSecondary2paramIndexSet + .get(hrn.getID()); + + String param = null; + if (paramSet != null) { + Iterator paramIter = paramSet.iterator(); + param = ""; + while (paramIter.hasNext()) { + param += paramIter.next() + " "; + } + } + tempStr += " " + hrn + "(" + param + ")"; + } + + heapRegionsItr = ln.iteratorToReferencees(); + while (heapRegionsItr.hasNext()) { + ReferenceEdge edge = heapRegionsItr.next(); + HeapRegionNode hrn = edge.getDst(); + + if (hrn.isParameter()) { + Iterator iter = hrn + .iteratorToReferencers(); + + while (iter.hasNext()) { + ReferenceEdge re = iter.next(); + if (re.getSrc() instanceof LabelNode) { + + LabelNode labelNode = (LabelNode) re.getSrc(); + + if (curr.containsParam(labelNode + .getTempDescriptor())) { + curr.addReadingVar(labelNode + .getTempDescriptor(), new AccKey( + fieldDesc.getSymbol(), srcDesc + .getType())); + } + } + } + + // + // check weather this heap region is parameter + // reachable... + // + + Set paramSet = fnOG.idSecondary2paramIndexSet + .get(hrn.getID()); + if (paramSet != null) { + Iterator paramIter = paramSet.iterator(); + + while (paramIter.hasNext()) { + Integer paramID = paramIter.next(); + + Integer primaryID = fnOG.paramIndex2idPrimary + .get(paramID); + HeapRegionNode paramHRN = fnOG.id2hrn + .get(primaryID); + + HashSet LNSet = getParameterLabelNodeSet( + fnOG, curr, paramHRN); + + Iterator LNSetIter = LNSet + .iterator(); + while (LNSetIter.hasNext()) { + LabelNode labelNode = LNSetIter.next(); + + curr.addReadingVar(labelNode + .getTempDescriptor(), new AccKey( + fieldDesc.getSymbol(), srcDesc + .getType())); + } + } + } + } + } + + } + + } + break; + + } + + } + + // returns the set of parameter label node which are associated with the + // specific heap region node. + private HashSet getParameterLabelNodeSet(OwnershipGraph og, + AccSet curr, HeapRegionNode hrn) { + + HashSet set = new HashSet(); + Iterator iter = hrn.iteratorToReferencers(); + while (iter.hasNext()) { + ReferenceEdge re = iter.next(); + if (re.getSrc() instanceof LabelNode) { + LabelNode labelNode = (LabelNode) re.getSrc(); + if (curr.containsParam(labelNode.getTempDescriptor())) { + set.add(labelNode); + } + } + } + return set; + } private void notAvailableForward( FlatMethod fm ) { diff --git a/Robust/src/Analysis/OwnershipAnalysis/OwnershipAnalysis.java b/Robust/src/Analysis/OwnershipAnalysis/OwnershipAnalysis.java index 5cfdcb59..2ca521d0 100644 --- a/Robust/src/Analysis/OwnershipAnalysis/OwnershipAnalysis.java +++ b/Robust/src/Analysis/OwnershipAnalysis/OwnershipAnalysis.java @@ -334,6 +334,9 @@ public class OwnershipAnalysis { // for controlling DOT file output private boolean writeDOTs; private boolean writeAllDOTs; + + //map each FlatNode to its own internal ownership graph + private Hashtable mappingFlatNodeToOwnershipGraph; @@ -381,6 +384,8 @@ public class OwnershipAnalysis { mapHrnIdToAllocationSite = new Hashtable(); + + mappingFlatNodeToOwnershipGraph = new Hashtable(); if( writeAllDOTs ) { @@ -918,6 +923,8 @@ public class OwnershipAnalysis { setRetNodes.add(frn); break; } + + mappingFlatNodeToOwnershipGraph.put(fn, og); return og; } @@ -1252,6 +1259,10 @@ public class OwnershipAnalysis { return s; } + + public OwnershipGraph getMappingFlatNodeToOwnershipGraph(FlatNode fn) { + return mappingFlatNodeToOwnershipGraph.get(fn); + }