-
Notifications
You must be signed in to change notification settings - Fork 0
/
SubMonad_AI.thy
52 lines (45 loc) · 1.74 KB
/
SubMonad_AI.thy
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
(*
* Copyright 2014, General Dynamics C4 Systems
*
* This software may be distributed and modified according to the terms of
* the GNU General Public License version 2. Note that NO WARRANTY is provided.
* See "LICENSE_GPLv2.txt" for details.
*
* @TAG(GD_GPL)
*)
theory SubMonad_AI
imports KHeap_AI
begin
(* SubMonadLib *)
lemma submonad_do_machine_op:
"submonad machine_state (machine_state_update \<circ> K) \<top> do_machine_op"
apply unfold_locales
apply (clarsimp simp: ext stateAssert_def do_machine_op_def o_def gets_def
get_def bind_def return_def submonad_fn_def)+
done
interpretation submonad_do_machine_op:
submonad machine_state "(machine_state_update \<circ> K)" \<top> do_machine_op
by (rule submonad_do_machine_op)
lemma submonad_args_pspace:
"submonad_args kheap (kheap_update o (\<lambda>x _. x)) \<top>"
by (simp add: submonad_args_def)
schematic_lemma assert_get_tcb_pspace:
"gets_the (get_tcb t) = submonad_fn kheap (kheap_update o (\<lambda>x _. x)) \<top> ?f"
apply (unfold gets_the_def)
apply (rule submonad_bind_alt [OF submonad_args_pspace])
apply (rule gets_submonad [OF submonad_args_pspace _ refl])
apply (simp add: get_tcb_def)
apply (rule assert_opt_submonad [OF submonad_args_pspace])
apply simp
apply (rule empty_fail_assert_opt)
done
lemma assert_get_thread_do_machine_op_comm:
"empty_fail m' \<Longrightarrow>
do x \<leftarrow> gets_the (get_tcb t); y \<leftarrow> do_machine_op m'; n x y od =
do y \<leftarrow> do_machine_op m'; x \<leftarrow> gets_the (get_tcb t); n x y od"
apply (rule submonad_comm2 [OF _ _ submonad_do_machine_op])
apply (rule submonad_args_pspace)
apply (rule assert_get_tcb_pspace)
apply simp+
done
end