summaryrefslogtreecommitdiff
path: root/src/state.ml
diff options
context:
space:
mode:
authorJon French2018-05-15 17:50:05 +0100
committerJon French2018-05-15 17:50:05 +0100
commite2d8fe4d847b6e8f71eecd7aa6d15799bd2a2e11 (patch)
treeaf5ca7ac35244a706f9631ab8f1a4dada172f27d /src/state.ml
parented3bb9702bd1f76041a3798f453714b0636a1b6b (diff)
parent77b393e4f53d14955d301cbd16e22d2e7b026ede (diff)
Merge branch 'sail2' into mappings
Diffstat (limited to 'src/state.ml')
-rw-r--r--src/state.ml15
1 files changed, 14 insertions, 1 deletions
diff --git a/src/state.ml b/src/state.ml
index 5a360456..ab63747c 100644
--- a/src/state.ml
+++ b/src/state.ml
@@ -286,7 +286,7 @@ let register_refs_lem mwords registers =
"";
"val option_of_regval : forall 'a. (register_value -> maybe 'a) -> register_value -> maybe (maybe 'a)";
"let option_of_regval of_regval = function";
- " | Regval_option v -> Maybe.map of_regval v";
+ " | Regval_option v -> Just (Maybe.bind v of_regval)";
" | _ -> Nothing";
"end";
"";
@@ -388,6 +388,19 @@ let generate_isa_lemmas mwords (Defs defs : tannot defs) =
"proof -";
" from assms have \"of_rv \\<circ> rv_of = Some\" by auto";
" then show ?thesis by (auto simp: vector_of_regval_def regval_of_vector_def)";
+ "qed";
+ "";
+ "lemma option_of_rv_rv_of_option[simp]:";
+ " assumes \"\\<And>v. of_rv (rv_of v) = Some v\"";
+ " shows \"option_of_regval of_rv (regval_of_option rv_of v) = Some v\"";
+ " using assms by (cases v) (auto simp: option_of_regval_def regval_of_option_def)";
+ "";
+ "lemma list_of_rv_rv_of_list[simp]:";
+ " assumes \"\\<And>v. of_rv (rv_of v) = Some v\"";
+ " shows \"list_of_regval of_rv (regval_of_list rv_of v) = Some v\"";
+ "proof -";
+ " from assms have \"of_rv \\<circ> rv_of = Some\" by auto";
+ " with assms show ?thesis by (induction v) (auto simp: list_of_regval_def regval_of_list_def)";
"qed"] ^^
hardline ^^ hardline ^^
separate_map (hardline ^^ hardline) register_lemmas registers