diff --git a/lib/Corres_UL.thy b/lib/Corres_UL.thy index 395a327b04..c919ae8874 100644 --- a/lib/Corres_UL.thy +++ b/lib/Corres_UL.thy @@ -1298,6 +1298,16 @@ lemmas corres_split_noop_rhs2 lemmas corres_split_dc = corres_split[where r'=dc, simplified] +lemma corres_add_noop_rhs: + "corres_underlying sr nf nf' r P P' f (do _ \ return (); g od) + \ corres_underlying sr nf nf' r P P' f g" + by simp + +lemma corres_add_noop_rhs2: + "corres_underlying sr nf nf' r P P' f (do _ \ g; return () od) + \ corres_underlying sr nf nf' r P P' f g" + by simp + lemma isLeft_case_sum: "isLeft v \ (case v of Inl v' \ f v' | Inr v' \ g v') = f (theLeft v)" by (clarsimp split: sum.splits) diff --git a/proof/crefine/autocorres-test/AutoCorresTest.thy b/proof/crefine/autocorres-test/AutoCorresTest.thy index 01ee243362..bb83ea0a7d 100644 --- a/proof/crefine/autocorres-test/AutoCorresTest.thy +++ b/proof/crefine/autocorres-test/AutoCorresTest.thy @@ -132,11 +132,6 @@ local_setup \AutoCorresModifiesProofs.new_modifies_rules "../c/build/$L4V_ text \Extra corres_underlying rules.\ -lemma corres_add_noop_rhs2: - "corres_underlying sr nf nf' r P P' f (do _ \ g; return () od) - \ corres_underlying sr nf nf' r P P' f g" - by simp - (* Use termination (nf=True) to avoid exs_valid *) lemma corres_noop2_no_exs: assumes x: "\s. P s \ \(=) s\ f \\r. (=) s\ \ empty_fail f" diff --git a/proof/drefine/Arch_DR.thy b/proof/drefine/Arch_DR.thy index b0450bbbd3..ab45a0f247 100644 --- a/proof/drefine/Arch_DR.thy +++ b/proof/drefine/Arch_DR.thy @@ -1082,11 +1082,6 @@ lemma pde_opt_cap_eq: apply (clarsimp simp: valid_idle_def st_tcb_at_def obj_at_def pred_tcb_at_def) done -lemma corres_add_noop_rhs: - "corres_underlying sr fl fl' r P P' f (do _ \ return (); g od) - \ corres_underlying sr fl fl' r P P' f g" - by simp - lemma gets_the_noop_dcorres: "dcorres dc (\s. f s \ None) \ (gets_the f) (return x)" by (clarsimp simp: gets_the_def corres_underlying_def exec_gets