-
Notifications
You must be signed in to change notification settings - Fork 2
/
data_create_unknown2.v
84 lines (68 loc) · 4.3 KB
/
data_create_unknown2.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
74
75
76
77
78
79
80
81
82
83
84
Require Import CodeProofDeps.
Require Import Ident.
Require Import Constants.
Require Import RData.
Require Import EventReplay.
Require Import MoverTypes.
Require Import CommonLib.
Require Import TableDataOpsIntro.Spec.
Require Import TableDataOpsRef1.Spec.
Require Import TableDataOpsRef1.Layer.
Require Import TableDataOpsRef2.Code.data_create_unknown2.
Require Import TableDataOpsRef2.LowSpecs.data_create_unknown2.
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) :=
_data_create ↦ gensem data_create_spec
⊕ _data_create_unknown1 ↦ gensem data_create_unknown1_spec
⊕ _data_create_unknown ↦ gensem data_create_unknown_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_data_create: block.
Hypothesis h_data_create_s : Genv.find_symbol ge _data_create = Some b_data_create.
Hypothesis h_data_create_p : Genv.find_funct_ptr ge b_data_create
= Some (External (EF_external _data_create
(signature_of_type (Tcons Tptr (Tcons tulong (Tcons tulong (Tcons Tptr (Tcons Tptr Tnil))))) tulong cc_default))
(Tcons Tptr (Tcons tulong (Tcons tulong (Tcons Tptr (Tcons Tptr Tnil))))) tulong cc_default).
Local Opaque data_create_spec.
Variable b_data_create_unknown1: block.
Hypothesis h_data_create_unknown1_s : Genv.find_symbol ge _data_create_unknown1 = Some b_data_create_unknown1.
Hypothesis h_data_create_unknown1_p : Genv.find_funct_ptr ge b_data_create_unknown1
= Some (External (EF_external _data_create_unknown1
(signature_of_type (Tcons Tptr (Tcons tulong (Tcons tulong (Tcons Tptr Tnil)))) tulong cc_default))
(Tcons Tptr (Tcons tulong (Tcons tulong (Tcons Tptr Tnil)))) tulong cc_default).
Local Opaque data_create_unknown1_spec.
Variable b_data_create_unknown: block.
Hypothesis h_data_create_unknown_s : Genv.find_symbol ge _data_create_unknown = Some b_data_create_unknown.
Hypothesis h_data_create_unknown_p : Genv.find_funct_ptr ge b_data_create_unknown
= Some (External (EF_external _data_create_unknown
(signature_of_type (Tcons Tptr (Tcons tulong (Tcons tulong (Tcons Tptr Tnil)))) tulong cc_default))
(Tcons Tptr (Tcons tulong (Tcons tulong (Tcons Tptr Tnil)))) tulong cc_default).
Local Opaque data_create_unknown_spec.
Lemma data_create_unknown2_body_correct:
forall m d d' env le g_rd_base g_rd_offset data_addr map_addr g_data_base g_data_offset res
(Henv: env = PTree.empty _)
(Hinv: high_level_invariant d)
(HPTg_rd: PTree.get _g_rd le = Some (Vptr g_rd_base (Int.repr g_rd_offset)))
(HPTdata_addr: PTree.get _data_addr le = Some (Vlong data_addr))
(HPTmap_addr: PTree.get _map_addr le = Some (Vlong map_addr))
(HPTg_data: PTree.get _g_data le = Some (Vptr g_data_base (Int.repr g_data_offset)))
(Hspec: data_create_unknown2_spec0 (g_rd_base, g_rd_offset) (VZ64 (Int64.unsigned data_addr)) (VZ64 (Int64.unsigned map_addr)) (g_data_base, g_data_offset) d = Some (d', VZ64 (Int64.unsigned res))),
exists le', (exec_stmt ge env le ((m, d): mem) data_create_unknown2_body E0 le' (m, d') (Out_return (Some (Vlong res, tulong)))).
Proof.
solve_code_proof Hspec data_create_unknown2_body; eexists; solve_proof_low.
Qed.
End BodyProof.
End CodeProof.