prio/Paper/Paper.thy
changeset 328 41da10da16a5
parent 327 cb46d2e06803
child 329 c62db88ab197
--- a/prio/Paper/Paper.thy	Tue Feb 14 02:55:47 2012 +0000
+++ b/prio/Paper/Paper.thy	Tue Feb 14 03:26:18 2012 +0000
@@ -784,7 +784,7 @@
 
   \noindent
   Since @{text "th'"} is not able to run at state @{text "s' @ s"}, it is not able to 
-  issue a {text "P"} or @{text "V"} event. Therefore if @{text "s' @ s"} is extended
+  issue a @{text "P"} or @{text "V"} event. Therefore if @{text "s' @ s"} is extended
   one step further, @{text "th'"} still cannot hold any resource. The situation will 
   not change in further extensions as long as @{text "th"} holds the highest precedence.
 
@@ -801,12 +801,29 @@
   @{term "cp (s' @ s) th' = prec th s"}.
   \end{theorem}
 
+  \noindent
   We show this theorem by induction on @{text "s'"} using Lemma~\ref{mainlem}.
   This theorem gives a stricter bound on the processes that can block @{text th}:
   only threads that were alive in state @{text s} and moreover held a resource.
   Finally, the theorem establishes that the blocking threads have the
   current precedence raised to the precedence of @{text th}.
 
+  We can furthermore prove that no deadlock exists in the state @{text "s' @ s"}
+  by showing that @{text "running (s' @ s)"} is not empty.
+
+  \begin{lemma}
+  Given the assumptions about states @{text "s"} and @{text "s' @ s"},
+  the thread @{text th} and the events in @{text "s'"},
+  @{term "running (s' @ s) \<noteq> {}"}.
+  \end{lemma}
+
+  \begin{proof}
+  If @{text th} is blocked, then by following its dependants graph, we can always 
+  reach a ready thread @{text th'}, and that thread must have inherited the 
+  precedence of @{text th}.\qed
+  \end{proof}
+
+
   %The following lemmas show how every node in RAG can be chased to ready threads:
   %\begin{enumerate}
   %\item Every node in RAG can be chased to a ready thread (@{text "chain_building"}):