-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathrvic_set_pending.v
73 lines (58 loc) · 3.04 KB
/
rvic_set_pending.v
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
Require Import CodeProofDeps.
Require Import Ident.
Require Import Constants.
Require Import RData.
Require Import EventReplay.
Require Import MoverTypes.
Require Import CommonLib.
Require Import AbsAccessor.Spec.
Require Import RVIC2.Spec.
Require Import RVIC3.Layer.
Require Import RVIC4.Code.rvic_set_pending.
Require Import RVIC4.LowSpecs.rvic_set_pending.
Local Open Scope Z_scope.
Section CodeProof.
Context `{real_params: RealParams}.
Context {memb} `{Hmemx: Mem.MemoryModelX memb}.
Context `{Hmwd: UseMemWithData memb}.
Let mem := mwd (cdata RData).
Context `{Hstencil: Stencil}.
Context `{make_program_ops: !MakeProgramOps Clight.function type Clight.fundef type}.
Context `{Hmake_program: !MakeProgram Clight.function type Clight.fundef type}.
Let L : compatlayer (cdata RData) :=
_get_rvic_pending_bits ↦ gensem get_rvic_pending_bits_spec
⊕ _rvic_set_flag ↦ gensem rvic_set_flag_spec
.
Local Instance: ExternalCallsOps mem := CompatExternalCalls.compatlayer_extcall_ops L.
Local Instance: CompilerConfigOps mem := CompatExternalCalls.compatlayer_compiler_config_ops L.
Section BodyProof.
Context `{Hwb: WritableBlockOps}.
Variable (sc: stencil).
Variables (ge: genv) (STENCIL_MATCHES: stencil_matches sc ge).
Variable b_get_rvic_pending_bits: block.
Hypothesis h_get_rvic_pending_bits_s : Genv.find_symbol ge _get_rvic_pending_bits = Some b_get_rvic_pending_bits.
Hypothesis h_get_rvic_pending_bits_p : Genv.find_funct_ptr ge b_get_rvic_pending_bits
= Some (External (EF_external _get_rvic_pending_bits
(signature_of_type (Tcons Tptr Tnil) Tptr cc_default))
(Tcons Tptr Tnil) Tptr cc_default).
Local Opaque get_rvic_pending_bits_spec.
Variable b_rvic_set_flag: block.
Hypothesis h_rvic_set_flag_s : Genv.find_symbol ge _rvic_set_flag = Some b_rvic_set_flag.
Hypothesis h_rvic_set_flag_p : Genv.find_funct_ptr ge b_rvic_set_flag
= Some (External (EF_external _rvic_set_flag
(signature_of_type (Tcons tulong (Tcons Tptr Tnil)) tvoid cc_default))
(Tcons tulong (Tcons Tptr Tnil)) tvoid cc_default).
Local Opaque rvic_set_flag_spec.
Lemma rvic_set_pending_body_correct:
forall m d d' env le rvic_base rvic_offset intid
(Henv: env = PTree.empty _)
(Hinv: high_level_invariant d)
(HPTrvic: PTree.get _rvic le = Some (Vptr rvic_base (Int.repr rvic_offset)))
(HPTintid: PTree.get _intid le = Some (Vlong intid))
(Hspec: rvic_set_pending_spec0 (rvic_base, rvic_offset) (VZ64 (Int64.unsigned intid)) d = Some d'),
exists le', (exec_stmt ge env le ((m, d): mem) rvic_set_pending_body E0 le' (m, d') Out_normal).
Proof.
solve_code_proof Hspec rvic_set_pending_body; eexists; solve_proof_low.
Qed.
End BodyProof.
End CodeProof.