diff --git a/examples/Crypto/SHA-2/Holmakefile b/examples/Crypto/SHA-2/Holmakefile deleted file mode 100644 index 12a3526880..0000000000 --- a/examples/Crypto/SHA-2/Holmakefile +++ /dev/null @@ -1 +0,0 @@ -INCLUDES = $(HOLDIR)/src/num/theories/cv_compute/automation diff --git a/examples/Crypto/SHA-2/sha2Script.sml b/examples/Crypto/SHA-2/sha2Script.sml deleted file mode 100644 index 010599149b..0000000000 --- a/examples/Crypto/SHA-2/sha2Script.sml +++ /dev/null @@ -1,131 +0,0 @@ -open HolKernel boolLib bossLib Parse - listTheory rich_listTheory arithmeticTheory - wordsTheory numposrepTheory byteTheory wordsLib - cv_transLib cv_stdTheory - -(* The SHA-2 Standard: https://nvlpubs.nist.gov/nistpubs/FIPS/NIST.FIPS.180-4.pdf *) -(* SHA-256 in particular (i.e. Section 6.2) *) - -val _ = new_theory"sha2"; - -(* TODO: move *) -Definition bool_to_bit_def: - bool_to_bit b = if b then 1 else 0n -End - -val () = cv_auto_trans bool_to_bit_def; - -(* TODO: move *) -val () = cv_auto_trans numposrepTheory.n2l_n2lA; - -Definition pad_message_def: - pad_message bs = - let l = LENGTH bs in - let n = l + 1 MOD 512 in - let k = if n <= 448 then 448 - n else 512 + 448 - n in - let lb = PAD_LEFT 0 64 $ (if l = 0 then [] else REVERSE $ n2l 2 l) in - let bits = MAP bool_to_bit bs in - bits ++ 1 :: REPLICATE k 0 ++ lb -End - -val () = cv_auto_trans pad_message_def; - -Theorem pad_message_length_multiple: - LENGTH bs < 2 ** 64 ==> - divides 512 $ LENGTH (pad_message bs) -Proof - rw[pad_message_def, PAD_LEFT, LENGTH_n2l, ADD1] - \\ cheat -QED - -Definition parse_block_def: - parse_block acc bits = - if NULL bits then REVERSE acc : word32 list - else parse_block ((word_from_bin_list (TAKE 32 bits))::acc) (DROP 32 bits) -Termination - WF_REL_TAC`measure (LENGTH o SND)` \\ Cases \\ rw[] -QED - -val () = cv_auto_trans parse_block_def; - -Definition parse_message_def: - parse_message acc bits = - if NULL bits then REVERSE acc else - parse_message (parse_block [] (TAKE 512 bits) :: acc) (DROP 512 bits) -Termination - WF_REL_TAC`measure (LENGTH o SND)` \\ Cases \\ rw[] -QED - -val () = cv_auto_trans parse_message_def; - -Definition initial_hash_value_def: - initial_hash_value : word32 list = [ - 0x6a09e667w; - 0xbb67ae85w; - 0x3c6ef372w; - 0xa54ff53aw; - 0x510e527fw; - 0x9b05688cw; - 0x1f83d9abw; - 0x5be0cd19w - ] -End - -val () = cv_trans_deep_embedding EVAL initial_hash_value_def; - -Definition rotr_def: - rotr n (x: 'a word) = x >>> n || x << (dimindex(:'a) - n) -End - -val () = cv_auto_trans (INST_TYPE[alpha |-> ``:32``] rotr_def); - -Definition sigma0_def: - sigma0 (x: word32) = rotr 7 x ?? rotr 18 x ?? x >>> 3 -End - -Definition sigma1_def: - sigma1 (x: word32) = rotr 17 x ?? rotr 19 x ?? x >>> 10 -End - -val () = cv_auto_trans sigma0_def; -val () = cv_auto_trans sigma1_def; - -Definition initial_schedule_loop_def: - initial_schedule_loop Ws t = - if t >= 64 \/ LENGTH Ws < t then - REVERSE Ws - else let - Wt2 = EL 1 Ws; - Wt7 = EL 6 Ws; - Wt15 = EL 14 Ws; - Wt16 = EL 15 Ws; - Wt = sigma1 Wt2 + Wt7 + sigma0 Wt15 + Wt16 - in - initial_schedule_loop (Wt::Ws) (SUC t) -Termination - WF_REL_TAC`measure (λx. 64 - SND x)` -End - -val initial_schedule_loop_pre_def = cv_auto_trans_pre initial_schedule_loop_def; - -(* -Theorem initial_schedule_loop_pre[cv_pre]: - initial_schedule_loop_pre - -Definition initial_schedule_def: - initial_schedule block = - initial_schedule_loop block 16 -End - -val () = cv_auto_trans initial_schedule_def; - -Definition process_block_def: - process_block block - -(* -cv_eval``parse_message [] (pad_message [ - F;T;T;F;F;F;F;T; F;T;T;F;F;F;T;F; F;T;T;F;F;F;T;T -])`` -*) - -val _ = export_theory();