lh-l4v/proof/crefine
Michael McInerney ca589b635c c-parser: add dom_lift_t_heap_update and lemmas for proj_d
Signed-off-by: Michael McInerney <michael.mcinerney@proofcraft.systems>
2023-05-01 15:16:22 +09:30
..
ARM c-parser: add dom_lift_t_heap_update and lemmas for proj_d 2023-05-01 15:16:22 +09:30
ARM_HYP c-parser: add dom_lift_t_heap_update and lemmas for proj_d 2023-05-01 15:16:22 +09:30
RISCV64 c-parser: add dom_lift_t_heap_update and lemmas for proj_d 2023-05-01 15:16:22 +09:30
X64 c-parser: add dom_lift_t_heap_update and lemmas for proj_d 2023-05-01 15:16:22 +09:30
autocorres-test proofs: valid_def moved to NonDetMonadVCG 2023-02-09 11:46:51 +11:00
base crefine: session structure update for Isabelle2020 2020-10-27 15:52:31 +10:00
intermediate crefine: enable intermediate CRefine session for Isabelle2020 2020-10-27 15:52:31 +10:00
lib crefine: simp rules for true and false 2023-04-18 13:23:42 +10:00
Move_C.thy proofs: updates for monad refactor 2023-02-09 11:46:55 +11:00
README.md READMEs: use run_tests consistently in READMEs (#622) 2023-03-30 13:59:18 +11:00

README.md

C Refinement Proof

This proof establishes that seL4's C code, once translated into Isabelle/HOL using Michael Norrish's C parser, is a formal refinement (i.e. a correct implementation) of its design specification and, transitively (using the results of the Design Spec Refinement Proof) seL4's C code is also a formal refinement of its abstract specification. In other words, this proof establishes that seL4's C code correctly implements its abstract specification.

The approach used for the proof is described in the TPHOLS '09 [paper][5].

Building

To build for the ARM architecture from the l4v/ directory, run:

L4V_ARCH=ARM ./run_tests CRefine

Important Theories

The top-level theory where the refinement statement is established over the entire kernel is Refine_C; the state-relation that relates the state-spaces of the two specifications is defined in StateRelation_C.

Note that this proof deals with two C-level semantics of seL4: one produced directly by the C parser from the kernel's C code, and another produced by the C spec's Substitute theory. These proofs largely operate on the latter, proving that it corresponds to the design spec. Refinement between the two C-level specs is proved in the CToCRefine theory. The top-level Refine_C theory quotes both refinement properties.