forked from seL4/l4v
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathTcb_AC.thy
557 lines (485 loc) · 25.4 KB
/
Tcb_AC.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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
(*
* Copyright 2020, Data61, CSIRO (ABN 41 687 119 230)
*
* SPDX-License-Identifier: GPL-2.0-only
*)
theory Tcb_AC
imports ArchFinalise_AC
begin
(* FIXME-NTFN: The 'NotificationControl' case of the following definition needs to be changed. *)
definition authorised_tcb_inv :: "'a PAS \<Rightarrow> tcb_invocation \<Rightarrow> bool" where
"authorised_tcb_inv aag ti \<equiv> case ti of
Suspend t \<Rightarrow> is_subject aag t
| Resume t \<Rightarrow> is_subject aag t
| ThreadControl t sl ep mcp priority croot vroot buf \<Rightarrow>
is_subject aag t \<and>
(\<forall>(cap, slot) \<in> set_option croot \<union> set_option vroot \<union>
(case_option {} (set_option \<circ> snd) buf). pas_cap_cur_auth aag cap \<and>
is_subject aag (fst slot))
| NotificationControl t ntfn \<Rightarrow>
is_subject aag t \<and>
case_option True (\<lambda>a. \<forall>auth \<in> {Receive, Reset}. aag_has_auth_to aag auth a) ntfn
| ReadRegisters src susp n arch \<Rightarrow> is_subject aag src
| WriteRegisters dest res values arch \<Rightarrow> is_subject aag dest
| CopyRegisters dest src susp res frame int_regs arch \<Rightarrow> is_subject aag src \<and> is_subject aag dest
| SetTLSBase tcb tls_base \<Rightarrow> is_subject aag tcb"
subsection\<open>invoke\<close>
lemma setup_reply_master_respects:
"\<lbrace>integrity aag X st and K (is_subject aag t)\<rbrace>
setup_reply_master t
\<lbrace>\<lambda>_. integrity aag X st\<rbrace>"
apply (simp add: setup_reply_master_def)
apply (wp get_cap_wp set_cap_integrity_autarch[unfolded K_def pred_conj_def]
set_original_integrity_autarch)+
apply simp
done
crunch eintegrity[wp]: possible_switch_to "integrity aag X st"
(ignore: tcb_sched_action)
lemma restart_integrity_autarch:
"\<lbrace>integrity aag X st and K (is_subject aag t) and einvs and tcb_at t and pas_refined aag\<rbrace>
restart t
\<lbrace>\<lambda>_. integrity aag X st\<rbrace>"
apply (simp add: restart_def)
apply (wp set_thread_state_integrity_autarch setup_reply_master_respects
hoare_drop_imps
| simp add: if_apply_def2)+
done
crunch integrity_autarch: option_update_thread "integrity aag X st"
crunch arch_state [wp]: cap_swap_for_delete "\<lambda>s. P (arch_state s)"
lemmas itr_wps =
restart_integrity_autarch as_user_integrity_autarch thread_set_integrity_autarch
option_update_thread_integrity_autarch thread_set_pas_refined
cap_insert_integrity_autarch cap_insert_pas_refined
hoare_vcg_all_liftE wp_throw_const_impE hoare_weak_lift_imp hoare_vcg_all_lift
check_cap_inv[where P="valid_cap c" for c]
check_cap_inv[where P="tcb_cap_valid c p" for c p]
check_cap_inv[where P="cte_at p0" for p0]
check_cap_inv[where P="tcb_at p0" for p0]
check_cap_inv[where P="ex_cte_cap_wp_to P p" for P p]
check_cap_inv[where P="ex_nonz_cap_to p" for p]
check_cap_inv2[where Q="\<lambda>_. integrity aag X st" for aag X st]
check_cap_inv2[where Q="\<lambda>_. pas_refined aag" for aag]
checked_insert_no_cap_to cap_insert_ex_cap
cap_delete_valid_cap cap_delete_deletes
hoare_case_option_wp thread_set_valid_cap
thread_set_tcb_ipc_buffer_cap_cleared_invs
thread_set_invs_trivial[OF ball_tcb_cap_casesI]
thread_set_cte_wp_at_trivial[where Q="\<lambda>x. x", OF ball_tcb_cap_casesI]
thread_set_no_cap_to_trivial[OF ball_tcb_cap_casesI]
(*FIXME MOVE *)
lemma aag_cap_auth_master_Reply:
"\<lbrakk> pas_refined aag s ; AllowGrant \<in> R \<rbrakk>
\<Longrightarrow> pas_cap_cur_auth aag (ReplyCap tcb True R) = is_subject aag tcb"
unfolding aag_cap_auth_def
by (fastforce intro: aag_wellformed_refl aag_wellformed_control_is_owns[THEN iffD1]
simp: pas_refined_def cli_no_irqs clas_no_asid cap_auth_conferred_def
reply_cap_rights_to_auth_def)
(* FIXME MOVE *)
lemma cdt_NullCap:
"\<lbrakk> valid_mdb s; caps_of_state s src = Some NullCap \<rbrakk>
\<Longrightarrow> cdt s src = None"
by (rule ccontr) (force dest: mdb_cte_atD simp: valid_mdb_def2)
lemma setup_reply_master_pas_refined:
"\<lbrace>pas_refined aag and pspace_aligned and valid_vspace_objs and valid_arch_state
and valid_mdb and K (is_subject aag t)\<rbrace>
setup_reply_master t
\<lbrace>\<lambda>_. pas_refined aag\<rbrace>"
apply (simp add: setup_reply_master_def)
apply (wp get_cap_wp set_cap_pas_refined set_original_wp)+
by (force dest: cdt_NullCap simp: aag_cap_auth_master_Reply cte_wp_at_caps_of_state)
crunches possible_switch_to
for tcb_domain_map_wellformed[wp]: "tcb_domain_map_wellformed aag"
crunches setup_reply_master
for pspace_aligned[wp]: pspace_aligned
lemma restart_pas_refined:
"\<lbrace>pas_refined aag and invs and tcb_at t and K (is_subject aag t)\<rbrace>
restart t
\<lbrace>\<lambda>_. pas_refined aag\<rbrace>"
apply (simp add: restart_def get_thread_state_def)
apply (wp set_thread_state_pas_refined setup_reply_master_pas_refined thread_get_wp'
| strengthen invs_mdb
| fastforce)+
done
lemma option_update_thread_set_safe_lift:
"\<lbrakk> \<And>v. \<lbrace>P\<rbrace> thread_set (f v) t \<lbrace>\<lambda>rv. P\<rbrace> \<rbrakk>
\<Longrightarrow> \<lbrace>P\<rbrace> option_update_thread t f v \<lbrace>\<lambda>rv. P\<rbrace>"
by (simp add: option_update_thread_def split: option.split)
crunch integrity_autarch[wp]: thread_set_priority "integrity aag X st"
(ignore: tcb_sched_action)
lemma set_priority_integrity_autarch[wp]:
"\<lbrace>integrity aag X st and pas_refined aag and K (is_subject aag tptr)\<rbrace>
set_priority tptr prio
\<lbrace>\<lambda>_. integrity aag X st\<rbrace>"
by (simp add: set_priority_def | wp)+
lemma set_priority_pas_refined[wp]:
"\<lbrace>pas_refined aag\<rbrace>
set_priority tptr prio
\<lbrace>\<lambda>_. pas_refined aag\<rbrace>"
apply (simp add: set_priority_def thread_set_priority_def
ethread_set_def set_eobject_def get_etcb_def
| wp hoare_vcg_imp_lift')+
apply (simp add: tcb_sched_action_def | wp)+
apply (clarsimp simp: etcb_at_def pas_refined_def tcb_domain_map_wellformed_aux_def
split: option.splits)
apply (erule_tac x="(a, b)" in ballE)
apply simp
apply (erule domains_of_state_aux.cases)
apply (force intro: domtcbs split: if_split_asm)
done
lemma gts_test[wp]:
"\<lbrace>\<top>\<rbrace> get_thread_state t \<lbrace>\<lambda>rv s. test rv = st_tcb_at test t s\<rbrace>"
apply (simp add: get_thread_state_def thread_get_def)
apply wp
apply (clarsimp simp add: st_tcb_def2)
done
crunch exst[wp]: option_update_thread "\<lambda>s. P (exst s)"
crunch pas_refined[wp]: set_mcpriority "pas_refined aag"
crunch integrity_autarch: set_mcpriority "integrity aag X st"
lemma (in is_extended') valid_cap_syn[wp]: "I (\<lambda>s. valid_cap_syn s a)"
by (rule lift_inv, simp)
lemma (in is_extended') no_cap_to_obj_dr_emp[wp]: "I (no_cap_to_obj_dr_emp a)"
by (rule lift_inv, simp)
lemma (in is_extended') cte_wp_at[wp]: "I (cte_wp_at P a)"
by (rule lift_inv, simp)
lemma checked_insert_pas_refined:
"\<lbrace>pas_refined aag and pspace_aligned and valid_vspace_objs and valid_arch_state and valid_mdb and
K (\<not> is_master_reply_cap new_cap \<and> is_subject aag target \<and>
is_subject aag (fst src_slot) \<and> pas_cap_cur_auth aag new_cap)\<rbrace>
check_cap_at new_cap src_slot
(check_cap_at (ThreadCap target) slot
(cap_insert new_cap src_slot (target, ref)))
\<lbrace>\<lambda>_. pas_refined aag\<rbrace>"
apply (unfold check_cap_at_def)
apply (wp cap_insert_pas_refined_same_object_as get_cap_wp)
by (fastforce simp: cte_wp_at_caps_of_state)
(* FIXME MOVE *)
lemma update_cdt_wp:
"\<lbrace>\<lambda>s. P (s\<lparr>cdt := m (cdt s)\<rparr>)\<rbrace> update_cdt m \<lbrace>\<lambda>_. P\<rbrace>"
by (simp add: update_cdt_def set_cdt_def) wp
(* FIXME MOVE *)
lemma parent_ofD: "m \<Turnstile> src \<leadsto> x \<Longrightarrow> m x = Some src"
by (simp add: cdt_parent_of_def)
crunch tcb_states_of_state[wp]: set_untyped_cap_as_full "\<lambda>s. P (tcb_states_of_state s)"
(* FIXME MOVE *)
lemma map_le_to_rtrancl:
"m \<subseteq>\<^sub>m m' \<Longrightarrow> m \<Turnstile> pptr \<rightarrow>* ptr \<Longrightarrow> m' \<Turnstile> pptr \<rightarrow>* ptr"
apply (erule subsetD[rotated])
apply (rule rtrancl_mono)
apply (fastforce simp:cdt_parent_of_def map_le_def dom_def)
done
lemma map_le_to_cca:
"m \<subseteq>\<^sub>m m' \<Longrightarrow> cdt_change_allowed aag subjects m tcbsts ptr
\<Longrightarrow> cdt_change_allowed aag subjects m' tcbsts ptr"
apply (elim cdt_change_allowedE cdt_change_allowedI[rotated])
by (rule map_le_to_rtrancl)
lemma cap_insert_cdt_change_allowed[wp]:
"\<lbrace>valid_mdb and cdt_change_allowed' aag slot\<rbrace>
cap_insert new_cap src_slot dest_slot
\<lbrace>\<lambda>_. cdt_change_allowed' aag slot\<rbrace>"
apply (rule hoare_pre, unfold cap_insert_def)
apply (wp add: dxo_wp_weak update_cdt_wp | simp)+
apply (rule hoare_post_imp[of
"\<lambda>_. cdt_change_allowed' aag slot and (\<lambda>s. cdt s dest_slot = None)"])
apply (fastforce elim: map_le_to_cca[rotated] simp:map_le_def dom_def)
apply (wps | wp get_cap_wp)+
apply (clarsimp)
apply (drule valid_mdb_mdb_cte_at)
apply (subst not_Some_eq[symmetric])
apply (intro allI notI)
apply (drule(1) mdb_cte_atD[rotated])
apply (simp add:cte_wp_at_caps_of_state)
done
lemma invoke_tcb_unbind_notification_respects:
"\<lbrace>integrity aag X st and pas_refined aag and simple_sched_action and einvs
and tcb_inv_wf (NotificationControl t None)
and K (authorised_tcb_inv aag (NotificationControl t None))\<rbrace>
invoke_tcb (tcb_invocation.NotificationControl t None)
\<lbrace>\<lambda>_. integrity aag X st\<rbrace>"
apply (clarsimp)
apply (wp unbind_notification_respects)
apply (clarsimp simp: authorised_tcb_inv_def tcb_at_def pred_tcb_def2)
apply (clarsimp split: option.split)
apply (frule(1) bound_tcb_at_implies_reset[unfolded pred_tcb_def2, OF _ exI, OF _ conjI])
apply simp
apply simp
done
lemma sbn_bind_respects:
"\<lbrace>integrity aag X st and bound_tcb_at ((=) None) t and
K (aag_has_auth_to aag Receive ntfn \<and> is_subject aag t)\<rbrace>
set_bound_notification t (Some ntfn)
\<lbrace>\<lambda>_. integrity aag X st \<rbrace>"
apply (simp add: set_bound_notification_def)
apply (wpsimp wp: set_object_wp)
apply (erule integrity_trans)
apply (clarsimp simp: integrity_def obj_at_def pred_tcb_at_def)
done
lemma bind_notification_respects:
"\<lbrace>integrity aag X st and pas_refined aag and bound_tcb_at ((=) None) t
and K (aag_has_auth_to aag Receive ntfn \<and> is_subject aag t)\<rbrace>
bind_notification t ntfn
\<lbrace>\<lambda>_. integrity aag X st\<rbrace>"
apply (rule hoare_gen_asm)
apply (clarsimp simp: bind_notification_def)
apply (rule hoare_seq_ext[OF _ get_simple_ko_sp])
apply (wp set_ntfn_respects hoare_vcg_imp_lift sbn_bind_respects | wpc | clarsimp)+
apply fastforce
done
lemma invoke_tcb_bind_notification_respects:
"\<lbrace>integrity aag X st and pas_refined aag and einvs and simple_sched_action
and tcb_inv_wf (NotificationControl t (Some ntfn))
and K (authorised_tcb_inv aag (NotificationControl t (Some ntfn)))\<rbrace>
invoke_tcb (NotificationControl t (Some ntfn))
\<lbrace>\<lambda>_. integrity aag X st\<rbrace>"
apply (rule hoare_gen_asm)
apply (clarsimp)
apply (wp bind_notification_respects)
apply (clarsimp simp: authorised_tcb_inv_def)
done
lemma invoke_tcb_ntfn_control_respects[wp]:
"\<lbrace>integrity aag X st and pas_refined aag and einvs and simple_sched_action
and tcb_inv_wf (NotificationControl t ntfn)
and K (authorised_tcb_inv aag (NotificationControl t ntfn))\<rbrace>
invoke_tcb (NotificationControl t ntfn)
\<lbrace>\<lambda>_. integrity aag X st\<rbrace>"
apply (case_tac ntfn, simp_all del: invoke_tcb.simps Tcb_AI.tcb_inv_wf.simps K_def)
apply (wp invoke_tcb_bind_notification_respects invoke_tcb_unbind_notification_respects | simp)+
done
locale Tcb_AC_1 =
fixes aag :: "'a PAS"
assumes arch_post_modify_registers_invs[wp]:
"arch_post_modify_registers cur t \<lbrace>pas_refined aag\<rbrace>"
and arch_post_modify_registers_respects:
"\<lbrace>integrity aag X st and K (is_subject aag t)\<rbrace>
arch_post_modify_registers cur t
\<lbrace>\<lambda>_ s. integrity aag X st s\<rbrace>"
and arch_get_sanitise_register_info_inv[wp]:
"arch_get_sanitise_register_info t \<lbrace>\<lambda>s :: det_ext state. P s\<rbrace>"
and invoke_tcb_tc_respects_aag:
"\<lbrace>integrity aag X st and pas_refined aag and einvs and simple_sched_action
and tcb_inv_wf (ThreadControl t sl ep mcp priority croot vroot buf)
and K (authorised_tcb_inv aag (ThreadControl t sl ep mcp priority croot vroot buf))\<rbrace>
invoke_tcb (ThreadControl t sl ep mcp priority croot vroot buf)
\<lbrace>\<lambda>rv. integrity aag X st and pas_refined aag\<rbrace>"
begin
lemma invoke_tcb_respects:
"\<lbrace>integrity aag X st and pas_refined aag and einvs and simple_sched_action
and tcb_inv_wf ti and K (authorised_tcb_inv aag ti)\<rbrace>
invoke_tcb ti
\<lbrace>\<lambda>_. integrity aag X st\<rbrace>"
apply (cases ti, simp_all add: hoare_conjD1 [OF invoke_tcb_tc_respects_aag [simplified simp_thms]]
del: invoke_tcb.simps Tcb_AI.tcb_inv_wf.simps K_def)
apply (safe intro!: hoare_gen_asm)
by ((wp itr_wps mapM_x_wp' arch_post_modify_registers_respects
| wpc | clarsimp simp: authorised_tcb_inv_def if_apply_def2
| rule conjI | subst (asm) idle_no_ex_cap)+)
end
subsubsection\<open>@{term "pas_refined"}\<close>
lemmas ita_wps = as_user_pas_refined restart_pas_refined cap_insert_pas_refined
thread_set_pas_refined cap_delete_pas_refined' check_cap_inv2 hoare_vcg_all_liftE
wp_throw_const_impE hoare_weak_lift_imp hoare_vcg_all_lift
lemma hoare_st_refl:
"\<lbrakk> \<And>st. \<lbrace>P st\<rbrace> f \<lbrace>Q st\<rbrace>; \<And>r s st. Q st r s \<Longrightarrow> Q' r s \<rbrakk> \<Longrightarrow> \<lbrace>\<lambda>s. P s s\<rbrace> f \<lbrace>Q'\<rbrace>"
apply (clarsimp simp add: valid_def)
apply (drule_tac x=s in meta_spec)
apply force
done
lemma bind_notification_pas_refined[wp]:
"\<lbrace>pas_refined aag and pspace_aligned and valid_vspace_objs and valid_arch_state and
K (\<forall>auth \<in> {Receive, Reset}. abs_has_auth_to aag auth t ntfn)\<rbrace>
bind_notification t ntfn
\<lbrace>\<lambda>_. pas_refined aag\<rbrace>"
apply (clarsimp simp: bind_notification_def)
apply (wp set_simple_ko_pas_refined | wpc | simp)+
done
lemma invoke_tcb_ntfn_control_pas_refined[wp]:
"\<lbrace>pas_refined aag and tcb_inv_wf (NotificationControl t ntfn) and einvs and simple_sched_action
and K (authorised_tcb_inv aag (NotificationControl t ntfn))\<rbrace>
invoke_tcb (NotificationControl t ntfn)
\<lbrace>\<lambda>_. pas_refined aag\<rbrace>"
apply (case_tac ntfn, simp_all del: K_def)
apply (safe intro!: hoare_gen_asm)
apply (wp | fastforce simp: authorised_tcb_inv_def)+
done
crunches suspend, restart
for pspace_aligned[wp]: "\<lambda>s :: det_ext state. pspace_aligned s"
and valid_vspace_objs[wp]: "\<lambda>s :: det_ext state. valid_vspace_objs s"
and valid_arch_state[wp]: "\<lambda>s :: det_ext state. valid_arch_state s"
(wp: dxo_wp_weak)
context Tcb_AC_1 begin
lemma invoke_tcb_pas_refined:
"\<lbrace>pas_refined aag and tcb_inv_wf ti and einvs and simple_sched_action
and K (authorised_tcb_inv aag ti)\<rbrace>
invoke_tcb ti
\<lbrace>\<lambda>_. pas_refined aag\<rbrace>"
apply (cases "\<exists>t sl ep mcp priority croot vroot buf.
ti = tcb_invocation.ThreadControl t sl ep mcp priority croot vroot buf")
apply safe
apply (rule hoare_chain, rule_tac Q'="\<lambda>_. pas_refined aag" and st1="\<lambda>x. x" in
hoare_st_refl[OF invoke_tcb_tc_respects_aag])
apply force
apply fastforce
apply assumption
apply (rule hoare_gen_asm)
apply (cases ti, simp_all add: authorised_tcb_inv_def)
apply (wp ita_wps hoare_drop_imps
hoare_strengthen_post[where Q="\<lambda>_. pas_refined aag and pspace_aligned
and valid_vspace_objs
and valid_arch_state",
OF mapM_x_wp']
| simp add: emptyable_def if_apply_def2 authorised_tcb_inv_def
| rule ball_tcb_cap_casesI
| wpc
| fastforce intro: notE[rotated,OF idle_no_ex_cap,simplified]
simp: invs_valid_global_refs invs_valid_objs)+
done
end
subsection\<open>TCB / decode\<close>
lemma decode_registers_authorised:
"\<lbrace>K (is_subject aag t)\<rbrace> decode_read_registers msg (ThreadCap t) \<lbrace>\<lambda>rv s. authorised_tcb_inv aag rv\<rbrace>, -"
"\<lbrace>K (is_subject aag t)\<rbrace> decode_write_registers msg (ThreadCap t) \<lbrace>\<lambda>rv s. authorised_tcb_inv aag rv\<rbrace>, -"
"\<lbrace>pas_refined aag and K (is_subject aag t \<and> (\<forall>(cap, slot) \<in> set excaps. pas_cap_cur_auth aag cap
\<and> is_subject aag (fst slot)))\<rbrace>
decode_copy_registers msg (ThreadCap t) (map fst excaps)
\<lbrace>\<lambda>rv _. authorised_tcb_inv aag rv\<rbrace>, -"
unfolding decode_read_registers_def decode_write_registers_def
decode_copy_registers_def authorised_tcb_inv_def
apply (simp_all cong: list.case_cong)
apply wpsimp+
apply (clarsimp simp: cap_auth_conferred_def pas_refined_all_auth_is_owns aag_cap_auth_def)
done
lemma decode_set_ipc_buffer_authorised:
"\<lbrace>K (is_subject aag t \<and> (\<forall>x \<in> set excaps. is_subject aag (fst (snd x)))
\<and> (\<forall>x \<in> set excaps. pas_cap_cur_auth aag (fst x)))\<rbrace>
decode_set_ipc_buffer msg (ThreadCap t) slot excaps
\<lbrace>\<lambda>rv _ :: det_ext state. authorised_tcb_inv aag rv\<rbrace>, -"
unfolding decode_set_ipc_buffer_def authorised_tcb_inv_def
apply (cases "excaps ! 0")
apply (clarsimp cong: list.case_cong split del: if_split)
apply (rule hoare_pre)
apply (clarsimp simp: ball_Un aag_cap_auth_def split del: if_split split: prod.split
| wp (once) derive_cap_obj_refs_auth derive_cap_untyped_range_subset derive_cap_clas
derive_cap_cli hoare_vcg_all_lift_R whenE_throwError_wp slot_long_running_inv
| wpc)+
apply (cases excaps, simp)
apply fastforce
done
lemma decode_set_space_authorised:
"\<lbrace>K (is_subject aag t \<and> (\<forall>x \<in> set excaps. is_subject aag (fst (snd x)))
\<and> (\<forall>x \<in> set excaps. pas_cap_cur_auth aag (fst x)))\<rbrace>
decode_set_space ws (ThreadCap t) slot excaps
\<lbrace>\<lambda>rv _ :: det_ext state. authorised_tcb_inv aag rv\<rbrace>, -"
unfolding decode_set_space_def authorised_tcb_inv_def
apply (rule hoare_pre)
apply (simp cong: list.case_cong split del: if_split)
apply (clarsimp simp: ball_Un split del: if_split
| wp (once) derive_cap_obj_refs_auth derive_cap_untyped_range_subset derive_cap_clas
derive_cap_cli hoare_vcg_const_imp_lift_R hoare_vcg_all_lift_R
whenE_throwError_wp slot_long_running_inv)+
apply (clarsimp simp: not_less all_set_conv_all_nth dest!: P_0_1_spec)
apply (auto simp: aag_cap_auth_def update_cap_cli
intro: update_cap_obj_refs_subset
dest!: update_cap_cap_auth_conferred_subset)
done
(* grot: this is from the bowels of decode_tcb_configure_authorised. *)
lemma decode_tcb_configure_authorised_helper:
"\<lbrace>K True and K (is_subject aag t \<and> (\<forall>x \<in> set excaps. is_subject aag (fst (snd x)))
\<and> (\<forall>x \<in> set excaps. pas_cap_cur_auth aag (fst x))
\<and> authorised_tcb_inv aag set_param
\<and> is_thread_control set_param)\<rbrace>
decode_set_space ws (ThreadCap t) slot excaps
\<lbrace>\<lambda>rv _ :: det_ext state. authorised_tcb_inv aag (ThreadControl t slot (tc_new_fault_ep rv)
None None (tc_new_croot rv)
(tc_new_vroot rv)
(tc_new_buffer set_param))\<rbrace>, -"
apply (rule hoare_gen_asmE)
apply (cases set_param)
apply (simp_all add: is_thread_control_def decode_set_space_def authorised_tcb_inv_def
cong: list.case_cong option.case_cong prod.case_cong
split: prod.split_asm split del: if_split)
apply (cases "excaps!0")
apply (cases "excaps!Suc 0")
apply (rule hoare_pre)
apply (clarsimp simp: ball_Un split del: if_split split: prod.split
| wp (once) derive_cap_obj_refs_auth derive_cap_untyped_range_subset derive_cap_clas derive_cap_cli
hoare_vcg_all_lift_R whenE_throwError_wp slot_long_running_inv)+
apply (clarsimp cong: list.case_cong option.case_cong prod.case_cong split: prod.split_asm)
apply (clarsimp simp: not_less all_set_conv_all_nth dest!: P_0_1_spec)
apply (auto simp: aag_cap_auth_def update_cap_cli
intro: update_cap_obj_refs_subset
dest!: update_cap_cap_auth_conferred_subset)
done
lemma decode_tcb_configure_authorised:
"\<lbrace>K (is_subject aag t \<and> (\<forall>x \<in> set excaps. is_subject aag (fst (snd x)))
\<and> (\<forall>x \<in> set excaps. pas_cap_cur_auth aag (fst x)))\<rbrace>
decode_tcb_configure msg (ThreadCap t) slot excaps
\<lbrace>\<lambda>rv _ :: det_ext state. authorised_tcb_inv aag rv\<rbrace>, -"
apply (wpsimp simp: decode_tcb_configure_def
wp: whenE_throwError_wp decode_tcb_configure_authorised_helper
decode_set_ipc_buffer_authorised)
apply (auto dest: in_set_takeD)
done
lemma decode_set_priority_authorised:
"\<lbrace>K (is_subject aag t)\<rbrace>
decode_set_priority msg (ThreadCap t) slot excs
\<lbrace>\<lambda>rv _. authorised_tcb_inv aag rv\<rbrace>, -"
by (wpsimp simp: decode_set_priority_def check_prio_def authorised_tcb_inv_def)
lemma decode_set_mcpriority_authorised:
"\<lbrace>K (is_subject aag t)\<rbrace>
decode_set_mcpriority msg (ThreadCap t) slot excs
\<lbrace>\<lambda>rv _. authorised_tcb_inv aag rv\<rbrace>, -"
by (wpsimp simp: decode_set_mcpriority_def check_prio_def authorised_tcb_inv_def)
lemma decode_set_sched_params_authorised:
"\<lbrace>K (is_subject aag t)\<rbrace>
decode_set_sched_params msg (ThreadCap t) slot excs
\<lbrace>\<lambda>rv _. authorised_tcb_inv aag rv\<rbrace>, -"
by (wpsimp simp: decode_set_sched_params_def check_prio_def authorised_tcb_inv_def)
lemma decode_unbind_notification_authorised:
"\<lbrace>K (is_subject aag t)\<rbrace>
decode_unbind_notification (ThreadCap t)
\<lbrace>\<lambda>rv _. authorised_tcb_inv aag rv\<rbrace>, -"
unfolding decode_unbind_notification_def authorised_tcb_inv_def
apply clarsimp
apply (wp gbn_wp, clarsimp)
done
lemma decode_bind_notification_authorised:
"\<lbrace>K (is_subject aag t \<and> (\<forall>x \<in> set excaps. is_subject aag (fst (snd x)))
\<and> (\<forall>x \<in> set excaps. pas_cap_cur_auth aag (fst x)) )\<rbrace>
decode_bind_notification (ThreadCap t) excaps
\<lbrace>\<lambda>rv _. authorised_tcb_inv aag rv\<rbrace>, -"
unfolding decode_bind_notification_def authorised_tcb_inv_def
apply clarsimp
apply (wp gbn_wp get_simple_ko_wp whenE_throwError_wp | wpc | simp add:)+
apply (clarsimp dest!: hd_in_set)
apply (drule_tac x="hd excaps" in bspec, simp)+
apply (auto simp: aag_cap_auth_def cap_auth_conferred_def cap_rights_to_auth_def AllowRecv_def)
done
lemma decode_set_tls_base_authorised:
"\<lbrace>K (is_subject aag t)\<rbrace>
decode_set_tls_base msg (ThreadCap t)
\<lbrace>\<lambda>rv _. authorised_tcb_inv aag rv\<rbrace>, -"
unfolding decode_set_tls_base_def authorised_tcb_inv_def
apply clarsimp
apply (wpsimp wp: gbn_wp)
done
lemma decode_tcb_invocation_authorised:
"\<lbrace>invs and pas_refined aag
and K (is_subject aag t \<and> (\<forall>x \<in> set excaps. is_subject aag (fst (snd x)))
\<and> (\<forall>x \<in> set excaps. pas_cap_cur_auth aag (fst x)))\<rbrace>
decode_tcb_invocation label msg (ThreadCap t) slot excaps
\<lbrace>\<lambda>rv _. authorised_tcb_inv aag rv\<rbrace>, -"
unfolding decode_tcb_invocation_def
apply (rule hoare_pre)
apply wpc
apply (wp decode_registers_authorised decode_tcb_configure_authorised
decode_set_priority_authorised decode_set_mcpriority_authorised
decode_set_sched_params_authorised
decode_set_ipc_buffer_authorised decode_set_space_authorised
decode_bind_notification_authorised
decode_unbind_notification_authorised
decode_set_tls_base_authorised)+
by (auto iff: authorised_tcb_inv_def)
text\<open>
@{term "decode_tcb_invocation"} preserves all invariants, so no need
to show @{term "integrity"} or @{term "pas_refined"}.
\<close>
end