summaryrefslogtreecommitdiff
path: root/Source
diff options
context:
space:
mode:
authorGravatar qadeer <qadeer@microsoft.com>2015-04-18 17:46:27 -0700
committerGravatar qadeer <qadeer@microsoft.com>2015-04-18 17:46:27 -0700
commit6d56652342dd935f47ce5396d7f7d3a480bbb68e (patch)
tree2dfaf12a8f06dd5a8be3030567bb6413e4ca041b /Source
parent7c950ff9a2444a4664243be1eb9fe744d1f4fc87 (diff)
patched ghost checking
Diffstat (limited to 'Source')
-rw-r--r--Source/Concurrency/TypeCheck.cs25
1 files changed, 23 insertions, 2 deletions
diff --git a/Source/Concurrency/TypeCheck.cs b/Source/Concurrency/TypeCheck.cs
index 907f7397..c407a7b9 100644
--- a/Source/Concurrency/TypeCheck.cs
+++ b/Source/Concurrency/TypeCheck.cs
@@ -474,6 +474,15 @@ namespace Microsoft.Boogie
}
if (errorCount > 0) return;
this.VisitProgram(program);
+ foreach (Procedure proc in program.Procedures)
+ {
+ if (procToActionInfo.ContainsKey(proc)) continue;
+ foreach (var ie in proc.Modifies)
+ {
+ if (!SharedVariables.Contains(ie.Decl)) continue;
+ Error(proc, "A ghost procedure must not modify a global variable with layer annotation");
+ }
+ }
if (errorCount > 0) return;
YieldTypeChecker.PerformYieldSafeCheck(this);
new LayerEraser().VisitProgram(program);
@@ -549,12 +558,24 @@ namespace Microsoft.Boogie
{
Error(node, "The callee is not available in the caller procedure");
}
+ return base.VisitCallCmd(node);
}
else
{
- Error(node, "Yielding procedure can call only a yielding procedure");
+ foreach (var ie in node.Outs)
+ {
+ if (ghostVars.Contains(ie.Decl)) continue;
+ Error(node, "The output of a ghost procedure must be assigned to a ghost variable");
+ }
+ bool savedCanAccessSharedVars = canAccessSharedVars;
+ bool savedCanAccessAuxVars = canAccessGhostVars;
+ canAccessSharedVars = true;
+ canAccessGhostVars = true;
+ var retVal = base.VisitCallCmd(node);
+ canAccessSharedVars = savedCanAccessSharedVars;
+ canAccessGhostVars = savedCanAccessAuxVars;
+ return retVal;
}
- return base.VisitCallCmd(node);
}
public override Cmd VisitParCallCmd(ParCallCmd node)