From c85ad40214743c4c9aea1a2f73547ffe3dfb62ad Mon Sep 17 00:00:00 2001 From: yeom Date: Mon, 29 Aug 2011 08:47:00 +0000 Subject: [PATCH] fixes on the definite clearance for shared locations. --- .../SSJava/DefinitelyWrittenCheck.java | 111 +++++++++++------- 1 file changed, 68 insertions(+), 43 deletions(-) diff --git a/Robust/src/Analysis/SSJava/DefinitelyWrittenCheck.java b/Robust/src/Analysis/SSJava/DefinitelyWrittenCheck.java index 3ab04e36..684dc337 100644 --- a/Robust/src/Analysis/SSJava/DefinitelyWrittenCheck.java +++ b/Robust/src/Analysis/SSJava/DefinitelyWrittenCheck.java @@ -107,6 +107,8 @@ public class DefinitelyWrittenCheck { private Set> calleeIntersectBoundOverWriteSet; private Set> calleeBoundWriteSet; + private Hashtable mapDescToLocation; + private TempDescriptor LOCAL; public DefinitelyWrittenCheck(SSJavaAnalysis ssjava, State state) { @@ -135,6 +137,7 @@ public class DefinitelyWrittenCheck { this.possibleCalleeCompleteSummarySetToCaller = new HashSet(); this.mapTypeToArrayField = new Hashtable(); this.LOCAL = new TempDescriptor("LOCAL"); + this.mapDescToLocation = new Hashtable(); } public void definitelyWrittenCheck() { @@ -154,8 +157,6 @@ public class DefinitelyWrittenCheck { ClearingSummary result = mapMethodDescriptorToCompleteClearingSummary.get(methodContainingSSJavaLoop); - System.out.println("###RESULT=" + result); - Set> hpKeySet = result.keySet(); for (Iterator iterator = hpKeySet.iterator(); iterator.hasNext();) { NTuple hpKey = (NTuple) iterator.next(); @@ -179,7 +180,6 @@ public class DefinitelyWrittenCheck { computeReadSharedDescriptorSet(); - // methodDescriptorsToVisitStack.clear(); // methodDescriptorsToVisitStack.add(sortedDescriptors.peekFirst()); @@ -211,10 +211,10 @@ public class DefinitelyWrittenCheck { if (!completeSummary.equals(prevCompleteSummary)) { ClearingSummary summaryFromCaller = mapMethodDescriptorToInitialClearingSummary.get(md); -// System.out.println("# summaryFromCaller=" + summaryFromCaller); -// System.out.println("# completeSummary=" + completeSummary); -// System.out.println("# prev=" + prevCompleteSummary); -// System.out.println("# changed!\n"); + // System.out.println("# summaryFromCaller=" + summaryFromCaller); + // System.out.println("# completeSummary=" + completeSummary); + // System.out.println("# prev=" + prevCompleteSummary); + // System.out.println("# changed!\n"); mapMethodDescriptorToCompleteClearingSummary.put(md, completeSummary); @@ -392,11 +392,6 @@ public class DefinitelyWrittenCheck { fld = getArrayField(td); } - // FlatFieldNode ffn = (FlatFieldNode) fn; - // lhs = ffn.getDst(); - // rhs = ffn.getSrc(); - // fld = ffn.getField(); - // read field NTuple srcHeapPath = mapHeapPath.get(rhs); @@ -405,16 +400,13 @@ public class DefinitelyWrittenCheck { // callee's parameters. so just ignore it NTuple fldHeapPath = new NTuple(srcHeapPath.getList()); - if (fld.getType().isImmutable()) { + if (!fld.getType().isArray() && fld.getType().isImmutable()) { readLocation(curr, fldHeapPath, fld); - }else{ + } else { fldHeapPath.add(fld); mapHeapPath.put(lhs, fldHeapPath); } - - - } // } @@ -443,7 +435,6 @@ public class DefinitelyWrittenCheck { NTuple fldHeapPath = new NTuple(lhsHeapPath.getList()); if (fld.getType().isImmutable()) { writeLocation(curr, fldHeapPath, fld); - fldHeapPath.add(fld); } else { // updates reference field case: // 2. if there exists a tuple t in sharing summary that starts with @@ -469,7 +460,7 @@ public class DefinitelyWrittenCheck { // ssjava util case! // have write effects on the first argument NTuple argHeapPath = computePath(fc.getArg(0)); - // writeLocation(curr, argHeapPath, fc.getArg(0)); + writeLocation(curr, argHeapPath, fc.getArg(0)); } else { // find out the set of callees MethodDescriptor mdCallee = fc.getMethod(); @@ -480,7 +471,6 @@ public class DefinitelyWrittenCheck { possibleCalleeCompleteSummarySetToCaller.clear(); - for (Iterator iterator = setPossibleCallees.iterator(); iterator.hasNext();) { MethodDescriptor mdPossibleCallee = (MethodDescriptor) iterator.next(); FlatMethod calleeFlatMethod = state.getMethodFlat(mdPossibleCallee); @@ -507,10 +497,10 @@ public class DefinitelyWrittenCheck { // if changes, update the init summary // and reschedule the callee for analysis if (!calleeInitSummary.equals(prevCalleeInitSummary)) { -// System.out.println("#CALLEE INIT CHANGED=" + mdPossibleCallee); -// System.out.println("# prev=" + prevCalleeInitSummary); -// System.out.println("# current=" + calleeInitSummary); -// System.out.println("#"); + // System.out.println("#CALLEE INIT CHANGED=" + mdPossibleCallee); + // System.out.println("# prev=" + prevCalleeInitSummary); + // System.out.println("# current=" + calleeInitSummary); + // System.out.println("#"); if (!methodDescriptorsToVisitStack.contains(mdPossibleCallee)) { methodDescriptorsToVisitStack.add(mdPossibleCallee); @@ -520,7 +510,8 @@ public class DefinitelyWrittenCheck { } } -// System.out.println("callee " + fc + " summary=" + possibleCalleeCompleteSummarySetToCaller); + // System.out.println("callee " + fc + " summary=" + + // possibleCalleeCompleteSummarySetToCaller); // contribute callee's writing effects to the caller mergeSharedLocationAnaylsis(curr, possibleCalleeCompleteSummarySetToCaller); } @@ -739,7 +730,8 @@ public class DefinitelyWrittenCheck { NTuple rhsHeapPath = new NTuple(); NTuple lhsHeapPath = new NTuple(); rhsHeapPath.add(LOCAL); - addReadDescriptor(rhsHeapPath, rhs); + Location loc = getLocation(rhs); + addReadDescriptor(rhsHeapPath, loc, rhs); } } @@ -754,18 +746,16 @@ public class DefinitelyWrittenCheck { lhs = ffn.getDst(); rhs = ffn.getSrc(); fld = ffn.getField(); - if (fld.isStatic() && fld.isFinal()) { - break; - } } else { FlatElementNode fen = (FlatElementNode) fn; lhs = fen.getDst(); rhs = fen.getSrc(); TypeDescriptor td = rhs.getType().dereference(); fld = getArrayField(td); - if (fld.isStatic() && fld.isFinal()) { - break; - } + } + + if (fld.isStatic() && fld.isFinal()) { + break; } // read field @@ -775,14 +765,28 @@ public class DefinitelyWrittenCheck { // callee's parameters. so just ignore it NTuple fldHeapPath = new NTuple(srcHeapPath.getList()); - // fldHeapPath.add(fld); - if (fld.getType().isImmutable()) { - addReadDescriptor(fldHeapPath, fld); + if (!fld.getType().isArray() && fld.getType().isImmutable()) { + + Location loc; + if (fn.kind() == FKind.FlatElementNode) { + loc = mapDescToLocation.get(rhs); + } else { + loc = getLocation(fld); + } + + addReadDescriptor(fldHeapPath, loc, fld); + } else { + // propagate rhs's heap path to the lhs + + if (fn.kind() == FKind.FlatElementNode) { + mapDescToLocation.put(lhs, getLocation(rhs)); + } + + fldHeapPath.add(fld); + mapHeapPath.put(lhs, fldHeapPath); } - // propagate rhs's heap path to the lhs - mapHeapPath.put(lhs, fldHeapPath); } } @@ -811,6 +815,20 @@ public class DefinitelyWrittenCheck { } break; + case FKind.FlatCall: { + + FlatCall fc = (FlatCall) fn; + + if (ssjava.isSSJavaUtil(fc.getMethod().getClassDesc())) { + // ssjava util case! + // have write effects on the first argument + NTuple argHeapPath = computePath(fc.getArg(0)); + Location loc = getLocation(fc.getArg(0)); + addReadDescriptor(argHeapPath, loc, fc.getArg(0)); + } + } + break; + } } @@ -822,9 +840,9 @@ public class DefinitelyWrittenCheck { } } - private void addReadDescriptor(NTuple hp, Descriptor d) { + private void addReadDescriptor(NTuple hp, Location loc, Descriptor d) { - Location loc = getLocation(d); + // Location loc = getLocation(d); if (loc != null && ssjava.isSharedLocation(loc)) { Set set = mapSharedLocation2DescriptorSet.get(loc); if (set == null) { @@ -832,7 +850,6 @@ public class DefinitelyWrittenCheck { mapSharedLocation2DescriptorSet.put(loc, set); } set.add(d); - } } @@ -840,7 +857,10 @@ public class DefinitelyWrittenCheck { private Location getLocation(Descriptor d) { if (d instanceof FieldDescriptor) { - return (Location) ((FieldDescriptor) d).getType().getExtension(); + TypeExtension te = ((FieldDescriptor) d).getType().getExtension(); + if (te != null) { + return (Location) te; + } } else { assert d instanceof TempDescriptor; TempDescriptor td = (TempDescriptor) d; @@ -857,12 +877,13 @@ public class DefinitelyWrittenCheck { } } - return null; + return mapDescToLocation.get(d); } private void writeLocation(ClearingSummary curr, NTuple hp, Descriptor d) { Location loc = getLocation(d); + // System.out.println("# WRITE LOC hp=" + hp + " d=" + d); if (loc != null && hasReadingEffectOnSharedLocation(hp, loc, d)) { // 1. add field x to the clearing set SharedStatus state = getState(curr, hp); @@ -875,15 +896,19 @@ public class DefinitelyWrittenCheck { state.updateFlag(loc, true); } } + // System.out.println("# WRITE CURR=" + curr); + } private void readLocation(ClearingSummary curr, NTuple hp, Descriptor d) { // remove reading var x from written set Location loc = getLocation(d); + // System.out.println("# READ LOC hp="+hp+" d="+d); if (loc != null && hasReadingEffectOnSharedLocation(hp, loc, d)) { SharedStatus state = getState(curr, hp); state.removeVar(loc, d); } + // System.out.println("# READ CURR="+curr); } private SharedStatus getState(ClearingSummary curr, NTuple hp) { @@ -1618,7 +1643,6 @@ public class DefinitelyWrittenCheck { if (inSet.size() == 0) { return; } - Hashtable, Location>, Boolean> mapHeapPathLoc2Flag = new Hashtable, Location>, Boolean>(); @@ -1636,6 +1660,7 @@ public class DefinitelyWrittenCheck { currState = new SharedStatus(); curr.put(hpKey, currState); } + currState.merge(inState); Set locSet = inState.getMap().keySet(); -- 2.34.1