From 9d8abb8cfe4ef3b0a4cc993f90b721f8d66344d0 Mon Sep 17 00:00:00 2001 From: yeom Date: Mon, 29 Aug 2011 18:28:58 +0000 Subject: [PATCH] changes: have a better way to keep the set of reading shared variables to verify their clearance. --- .../SSJava/DefinitelyWrittenCheck.java | 93 ++++++++++++++++--- 1 file changed, 78 insertions(+), 15 deletions(-) diff --git a/Robust/src/Analysis/SSJava/DefinitelyWrittenCheck.java b/Robust/src/Analysis/SSJava/DefinitelyWrittenCheck.java index 684dc337..9ee6bcce 100644 --- a/Robust/src/Analysis/SSJava/DefinitelyWrittenCheck.java +++ b/Robust/src/Analysis/SSJava/DefinitelyWrittenCheck.java @@ -84,7 +84,6 @@ public class DefinitelyWrittenCheck { // maps shared location to the set of descriptors which belong to the shared // location - private Hashtable> mapSharedLocation2DescriptorSet; // keep current descriptors to visit in fixed-point interprocedural analysis, private Stack methodDescriptorsToVisitStack; @@ -92,6 +91,11 @@ public class DefinitelyWrittenCheck { // when analyzing flatcall, need to re-schedule set of callee private Set calleesToEnqueue; + // maps heap path to the mapping of a shared location and the set of reading + // descriptors + // it is for setting clearance flag when all read set is overwritten + private Hashtable, Hashtable>> mapHeapPathToLocSharedDescReadSet; + public static final String arrayElementFieldName = "___element_"; static protected Hashtable mapTypeToArrayField; @@ -131,13 +135,14 @@ public class DefinitelyWrittenCheck { new Hashtable(); this.mapMethodDescriptorToInitialClearingSummary = new Hashtable(); - this.mapSharedLocation2DescriptorSet = new Hashtable>(); this.methodDescriptorsToVisitStack = new Stack(); this.calleesToEnqueue = new HashSet(); this.possibleCalleeCompleteSummarySetToCaller = new HashSet(); this.mapTypeToArrayField = new Hashtable(); this.LOCAL = new TempDescriptor("LOCAL"); this.mapDescToLocation = new Hashtable(); + this.mapHeapPathToLocSharedDescReadSet = + new Hashtable, Hashtable>>(); } public void definitelyWrittenCheck() { @@ -157,6 +162,8 @@ public class DefinitelyWrittenCheck { ClearingSummary result = mapMethodDescriptorToCompleteClearingSummary.get(methodContainingSSJavaLoop); + System.out.println("\n\n#RESULT=" + result); + Set> hpKeySet = result.keySet(); for (Iterator iterator = hpKeySet.iterator(); iterator.hasNext();) { NTuple hpKey = (NTuple) iterator.next(); @@ -165,9 +172,30 @@ public class DefinitelyWrittenCheck { for (Iterator iterator2 = locKeySet.iterator(); iterator2.hasNext();) { Location locKey = (Location) iterator2.next(); if (!state.getFlag(locKey)) { + printNotClearedResult(result); throw new Error( - "Some concrete locations of the shared abstract location are not cleared at the same time:" - + state); + "Some concrete locations of the shared abstract location are not cleared at the same time:"); + } + } + } + + } + + private void printNotClearedResult(ClearingSummary result) { + Set> keySet = result.keySet(); + + for (Iterator iterator = keySet.iterator(); iterator.hasNext();) { + NTuple hpKey = (NTuple) iterator.next(); + SharedStatus status = result.get(hpKey); + Hashtable, Boolean>> map = status.getMap(); + Set locKeySet = map.keySet(); + for (Iterator iterator2 = locKeySet.iterator(); iterator2.hasNext();) { + Location locKey = (Location) iterator2.next(); + Pair, Boolean> pair = map.get(locKey); + if (!pair.getSecond().booleanValue()) { + // not cleared! + System.out.println("Concrete locations of the shared location '" + locKey + + "' are not cleared out, which are reachable through the heap path '" + hpKey + "'"); } } } @@ -180,6 +208,9 @@ public class DefinitelyWrittenCheck { computeReadSharedDescriptorSet(); + System.out.println("###"); + System.out.println("READ SHARED=" + mapHeapPathToLocSharedDescReadSet); + // methodDescriptorsToVisitStack.clear(); // methodDescriptorsToVisitStack.add(sortedDescriptors.peekFirst()); @@ -249,7 +280,7 @@ public class DefinitelyWrittenCheck { boolean onlyVisitSSJavaLoop) { if (state.SSJAVADEBUG) { - System.out.println("Definitely written for shared locations Analyzing: " + md + " " + System.out.println("Definite clearance for shared locations Analyzing: " + md + " " + onlyVisitSSJavaLoop); } @@ -833,23 +864,37 @@ public class DefinitelyWrittenCheck { } private boolean hasReadingEffectOnSharedLocation(NTuple hp, Location loc, Descriptor d) { - if (!mapSharedLocation2DescriptorSet.containsKey(loc)) { + + Hashtable> mapLocToDescSet = + mapHeapPathToLocSharedDescReadSet.get(hp); + if (mapLocToDescSet == null) { return false; } else { - return mapSharedLocation2DescriptorSet.get(loc).contains(d); + Set setDesc = mapLocToDescSet.get(loc); + if (setDesc == null) { + return false; + } else { + return setDesc.contains(d); + } } + } private void addReadDescriptor(NTuple hp, Location loc, Descriptor d) { - // Location loc = getLocation(d); if (loc != null && ssjava.isSharedLocation(loc)) { - Set set = mapSharedLocation2DescriptorSet.get(loc); - if (set == null) { - set = new HashSet(); - mapSharedLocation2DescriptorSet.put(loc, set); + Hashtable> mapLocToDescSet = + mapHeapPathToLocSharedDescReadSet.get(hp); + if (mapLocToDescSet == null) { + mapLocToDescSet = new Hashtable>(); + mapHeapPathToLocSharedDescReadSet.put(hp, mapLocToDescSet); + } + Set descSet = mapLocToDescSet.get(loc); + if (descSet == null) { + descSet = new HashSet(); + mapLocToDescSet.put(loc, descSet); } - set.add(d); + descSet.add(d); } } @@ -884,6 +929,7 @@ public class DefinitelyWrittenCheck { 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); @@ -891,8 +937,7 @@ public class DefinitelyWrittenCheck { // 3. if the set v contains all of variables belonging to the shared // location, set flag to true - Set sharedVarSet = mapSharedLocation2DescriptorSet.get(loc); - if (state.getVarSet(loc).containsAll(sharedVarSet)) { + if (overwrittenAllSharedConcreteLocation(hp, loc, state.getVarSet(loc))) { state.updateFlag(loc, true); } } @@ -900,6 +945,24 @@ public class DefinitelyWrittenCheck { } + private boolean overwrittenAllSharedConcreteLocation(NTuple hp, Location loc, + Set writtenSet) { + + Hashtable> mapLocToDescSet = + mapHeapPathToLocSharedDescReadSet.get(hp); + + if (mapLocToDescSet != null) { + Set descSet = mapLocToDescSet.get(loc); + if (writtenSet.containsAll(descSet)) { + return true; + } else { + return false; + } + } else { + return false; + } + } + private void readLocation(ClearingSummary curr, NTuple hp, Descriptor d) { // remove reading var x from written set Location loc = getLocation(d); -- 2.34.1