File: DRBG_properties.cry

package info (click to toggle)
aws-crt-python 0.16.8%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 78,328 kB
  • sloc: ansic: 330,743; python: 18,949; makefile: 6,271; sh: 3,712; asm: 754; cpp: 699; ruby: 208; java: 77; perl: 73; javascript: 46; xml: 11
file content (122 lines) | stat: -rw-r--r-- 8,920 bytes parent folder | download | duplicates (3)
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
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
module DRBG_properties where

import AES
import DRBG


nist_aes128_reference_entropy_hex = [
  0x528ccd2d6c143800a34ad33e7f153cfaceaa2411abbaf4bfcfe9796898d0ece6
, 0x478fd1eaa7ed293294d370979b0f0f1948d5a3161b12eeebf2cf6bd1bf059adf
, 0x036bf1173977b323f60c6f0f603d9c50835b2afca8347dfb24e8f66604444951
, 0x53e5783fd27cda264189ff0aa5513dc5903c28e3e260b77b4b4a0b9b76e4aa46
, 0xe04bade7636e72397f8303437cb22be52810dadd768d5cfc9d3269e7ad4bc8bc
, 0xe20dabb9fcaf3aed0ec40c7ef68d78f2bcb5675db2d62ee40d8184b7046f0e0e
, 0xf3b247d0400740d18b795e8e9c04cc43eb138cb9eb6c46862030517d8b3679db
, 0x0603b481bb88d77d6bacf03a64cf82248420a95cca10e3efc012bd770dd5621c
, 0x233b1e550a0d1249a5bd09ccb9a88be9119258feadfc309a6ae3c340918545b9
, 0x9d97ce8452474bc19a4be64efd43484874074779e05ac221f19db3955ce29bc1
, 0x5c0ef27b53eb7903cc9e2bc709f9e885eec139ec687a3444450f0cb079ca5171
, 0x0e26d3e8d2fd18fe0ce2538c2ede5d61574c8227b3f82b333ac42dbdd78b8e19
, 0x12f68f049216e3987860651f6fd13efef184fc8fe05cac459eb3cf97dd957e6c
, 0xccfabc0f847801b342774ce50d80c600af2d1f2016e1aea412fc4c60b2a041b1
, 0x07e192e576bb031bb8baa60b9374dcc1c40cb43ab42035719588e2afd75fc8f0
, 0x6129a163efde5f14067e075c4790029652a56eedf8ea4877a0ffcedd32866166
, 0x356ade73b8ffb38408be0537ca539b633d0afffcf2962b717ac37eb2a06ddf50
, 0x0b857fe137cab149e9195019732a714e25e62c946eba58dd2fa8e6c797172bcb
, 0x310d2e7b249ca8fdf1d4b15612f6e1f5428241c7ad777281171fdcecf7f5ed44
, 0x241e8fe2d6de5efb6509144c8dba00a582d1aebfabd306052747fc311d7c5a56
, 0xa2c100da70d8659d94a4d6a0f10594c8412c977168df242a35d5c2600a47084b
, 0xf5771eeacddef0c6cbfac5ac4285205f110fd6a8174ad45748a8633a28c85ec2
, 0x0621babc5c0ea527ca7c8d42338e16b6113b387ba888a6c12779cc127561a148
, 0x672df1d58510c016913fc6c42771273f7cbaeef1993dbabcd6cca26758bdb7df
, 0x7a9365ebb48fdd83809167cb2bfebc37b69b34595b2f8d81cff2924a70e300d5
, 0x954e64b6f4f1d7e0135eb2a9174612d23111329c00bded4cecf6b2b2fdfad145
, 0xe6495728cb28b8f64b208afa9e1012f061c790d285663f5cf0760c9f7c4bd32f
, 0xbd10e4b282c98b6c2e0451272a332c24f54a2a45244e9889420a48786f662aed
, 0x5a1cf5b5212ae2a776ae4f688ea9e6124f624c817b5e429b8cc2ad730cf29f6e
, 0xfcca996bf011ba139b7bd05e31c594d459685aa143e0ee46d6db0ba8582a6fd6
, 0x9009b2d3b9ef7fd1e925d75d6ad07d42e165310153ed1ef9e1284894e0d16575
, 0x13f8641a1d9cd50966b4fff6f2a5a9f67aefa8d7b5cb527d3b73338aea773ee1
, 0x4645aa5ebb41f27380328161864cca36055c871356316bf3773d35687fe72874
, 0x87e58c3c91ae0935b7935d2d0a855e795327062238180f20b02f9c9c861cbc33
, 0x28c5691d0c0ff0d834cb0c85a82fe561f40803f63beb3e740215e5d5089fc554
, 0xfd22324369fd30e2f47553c012ce2c46fd40df5fcdd737bf266cd20bcdc20a98
, 0xf3291f1d5fa47abf1918416a2cb78b243e614f883bda2afc10ffc1cc7f7f06a8
, 0xc9cbe9f41e2d81f99ca6327ca617caf836b73512d96b1edc5ae5ed56c056cade
, 0x47ebfc4437f769ac299f0d87069e5d6074420113761a9f9e053866581e836701
, 0xbcb51bc0dfae0fb04bf08face7369981d9a78bbcc0d3da2a1442d8fef756c1c0
, 0xb74a392be091fe00eb6a6576f027073a838308f5a5aed7fd0db47d6616cbec98
, 0xd39a307b956d1183f718be7d91a11891dc3fee45652edb89449d9766fc85bb32
, 0x5565457cf60a3aff9ea6f3dc6254a76a085ff87f1dd19127b2aeb3ac50b8c31e
, 0x9dfd31e3adc822b675c0a9c8702df12de4c3354ccdb5389ed481d910b3dbb51a
, 0x2a1b1519d22d40ef4ec23c6d97dc148cfe171fb5f8b1c305ec6d8e83a1ef9064 ]

nist_aes128_reference_personalization_strings_hex = [
  0x07ca7a007b53f014d7f10461d6c97b5c8b0c502d3461d583f99efec69f121cd2
, 0x99f2d501dd183f5657d8b8061bf4f0988de3bc2719f41281cf08d9bcc99f0dcb
, 0x617d6463eaf3849e13b89a7f9805edff3ea1f0aa7ad71e7de7af3481bfeba7f5
, 0x7f7d81a5c72f9e3498de183329d6b2291792ac8c81e690200387305aba8987c7
, 0x0c70a20b690bf5d586b284aa752ec73055e039233089a30efdd6218a1e49f548
, 0x1fe2b0ce3a1896017e30753064e1c0e1341b673569c739a199cd218fe64665d0
, 0x2703e1dca9926995705229cc8a8c9d958bcdbfd5f3e09eeb349b5135686aeed1
, 0x9ca4b8e6cdec1ecd9546508542c84936ff2aa1a4dab969613139c01e35f36d71
, 0x0f533937857dc9f97fefa142c95445b484e1f259a488e9fa38a46e49d693c4b6
, 0x950472ba4b3b6979ba4d2a1ad51db7732eb3337b28270fdb7f99018144734f72
, 0x06bd36977e09cc13d7c9edc9a285043f7c00575610e9b95fd3754a4b7c561fb7
, 0x6dacec09cc407ddf545c4d54c77efd712f65be8ba5ecbc9fa6bdf29243eed72e
, 0x85facc571d2c6eb257437e1d3b77b5fba4a125606440181b8387f9a4fb1a7fbf
, 0x2c4e73ad2597b027dd04c6056db1189b7a0d8e9fece52237cb7fc2511509c4eb
, 0x717c4de30c0ac7b831807cb1fcf4ab37f1734683a723d183fcfe5fc8a4c6c7e5 ]

nist_aes128_reference_values_hex = [
  0x462eaef2ff6d82aec55f451776700e4c, 0x010cd7c293306adbe9798f2f65bdfb01, 0xf6f808dd7e199b3ce8497d63515092df
, 0x1e574e0a9b220668776a109ecec959f5, 0xf47380b9e6d8ce485a5bb9f890331f89, 0xf2b475b29ed8aca7f3a69477212153e3
, 0xd63aa6ddf10dfb6934b7a745456f2056, 0x29c05402d0dd6ff1d171c523e6066b3d, 0xfb15e2dfd607439797e29f9ea9a24788
, 0x601d313b010af1930132417697d9e27e, 0xb17422b4a74cc83de34c7196cd232355, 0xb63cf4e0894e185eb7ef572c2adacf98
, 0xa7ec1f62b063acd9904d2ca4b26e755c, 0xb98e1a708027be7d5f0ff46f775ceece, 0x5b5adf71f7d8c85a011acc778c4e3d6f
, 0x6536d316f19bd244ca1a2deba572face, 0x0ce6ba1487b38261f306c84642338b53, 0xa19af0020f46085ca3caf34b2cb4f1f5
, 0xcac724dc3e214ff8d0ac4f60ee2dfded, 0x67138c2c7a488b2f4449b03192aa54f8, 0xd10073624d73847284c91b46e28b83c3
, 0xedadadc2ad451ea48ab9619d6c89cdcb, 0x24f64c09499b4803a03aadf0e34240ca, 0x8ac5b02284cac91bb39e14bd3d38ae2b
, 0x31f21cce9f11c7e9047e3ebad7c23a1b, 0x6b59014f0e7e8df5f7456017841e9c63, 0x4cfc026d6bc19e9674ec7002bf0baf62
, 0xd871c3f06cdf34c0cebb8b405aa79be7, 0x6af76a8c51f305b88249af9db4eacfe4, 0xff77327ab3761736e40f79ca0a6660e2
, 0x9eedbc9923b20434c175c066ed3584ba, 0x06ebe4bd2ea20c39ef8f4f66796816bb, 0x497b437274f3d7cee04b163c10233aec
, 0x7fca6267fd42102de5baacb7b4409565, 0x1310719710bd2c3468f8000fad5b6f4c, 0x34e5d8e0f7e6c28718a5f27ac086516b
, 0x9948b0263f2c91756050fad1f5d7876f, 0x9aff44fbc0f539186d13e81a9b233786, 0x0a86ad5766efe6d3fa01a9ac4ec9090d
, 0xa022dfed4c805b8f2c15d81693edfb53, 0x9d4f527ab03ff0c4abe7e442572fc0bb, 0x5fc9cb9e3cd694c6b08bb99256062814
, 0xfaa46432da44e336bd782edd85ccfa83, 0xc17b86c7fd8e5a2131f515fb0ab62c9b, 0x619ff6d15579a1cb4bc9c96f6be8f4e5]

nist_aes128_reference_returned_bits_hex  =[
  0xbba1ef50b4bad288897f02ac2706ee1e01488dcbe9b3d8a637921f5e788faed3b23db63d590ceaa7607a2179192bea9aeaa85d048e7e108fee666dc646af5f0e
, 0xb9ecf5521d38f9212578f9dd32af38089b45812ca96e661fc8e1be0b2f4b54215f52c9c93a6f76efee4521cb316378403108a6bf2724fdc93bc4d2db60a2de83
, 0xce4bec8241dd1ce12d7fa18bd1a3188b43892392b7dcae7228a851afef9c9728c587167b6df28c895a67af35b6fd84ad076efcd70d1c59c49fa7c0f7ed87bc82
, 0x94001b011830bc6a911fa23bc1fd0dac8c0acd0e856ab4497ad072e54fe3b47bc06890e7e7babd4912af1e7da96e90523b75dd86d9a4ba4d88107de607e52534
, 0xd0619996c88423a740f04dfdad3bfc131bf3601fc43022e89957bf8b9a1ad8702bc8fbb2004e7ab02550777818e11f03fab48458424ae5c8cc8cb73436657292
, 0xa2613ddb75107ef3fe9fc392061a52ea2304af7aed6dedec3aee626e1ab2bf989ce7d6484555941e9a4013036c4605c564f17d4d1369e1e12d28b877d2125d99
, 0x48460543d08b3331f0c7bcf786be06a276efc757bedce0f428323d54206931f18c3c7c606c0ff8e673f3d1367c7d50db2ed002120ff05623d2deddd037c125a4
, 0x037a0305532b6bd2a51057962f23dbfd4660be8e5b7a448b1168be3bf8598a301fb517a4714b7826162fc0fcdae08800e967f638ff1ad1da39282d3454d93075
, 0x035c19396d603b52222c16af6c6bc1c07a1a518f578b59943ffad73ca14948b7a8dde117e5c571506d57fd08e3a067a2ae3bde2240c2399f160c5cc5a2f5d582
, 0xe17674172397369025d6b7811b69b6e62dfb8ab94852cc96bde1371fcedbe5fe31a11589f4e57183fb46883d93c647e36f70f8d5a536f8fb0d428dcfd7722e4e
, 0xcbedccaa88b22e39fb0e14bf15dc05e4e1b7002fa0cffe7803e3f6bcf6a03f3faa51ce5b3ccb0d341533d335e20f9f71e90f83fef06ecfe93ed056f5d6851306
, 0x116bd7ab4030379cd6f50e85a04182775292fa9619c38b7418a19b8e7855f29efffdf7a2b8b1d9d3d96ea85a6d56302014dd3bcbe401ada5b0e3cf2f66dce9cd
, 0x51e0b54c109884baecd1884f7bafc846ace216b6fd97eb1ca70b563e62c4a2f22b55561152f379326ef2999e9746f25043a02402d3e47b4a58e747c222b7a081
, 0x7c41adf941656cfb9f24409d6cc4d578d43930b3e23ec801a59c53d999401bc0cb3e5b8797b2770a8a8f51ff594b7b17d9e694d5e36644508d16cb2554057adc
, 0xac054570b081cf53b39b0a2faa21ee9b554c05ff9055843ac0eb9031d1de324701ad4cf2875623e0bf4184de4aea20070be1cb586880ac87fbb7e414b4b128d0]

drbg = drbg_instantiate (nist_aes128_reference_entropy_hex @ 0) (nist_aes128_reference_personalization_strings_hex @ 0)

test_drbg : [8] -> Bit
test_drbg n =
  bits_out == nist_aes128_reference_returned_bits_hex @ n /\
  drbg1.v == nist_aes128_reference_values_hex @ (3 * n) /\
  drbg2.v == nist_aes128_reference_values_hex @ (3 * n + 1) /\
  drbg3.v == nist_aes128_reference_values_hex @ (3 * n + 2)
  where
    drbg1 = drbg_instantiate (nist_aes128_reference_entropy_hex @ (3*n))
                             (nist_aes128_reference_personalization_strings_hex @ n)
    ((bits1, drbg2) : ([512], s2n_drbg)) =
      drbg_generate`{blocks=4} drbg1 (nist_aes128_reference_entropy_hex @ (3 * n + 1)) True
    ((bits_out, drbg3) : ([512], s2n_drbg)) =
      drbg_generate`{blocks=4} drbg2 (nist_aes128_reference_entropy_hex @ (3 * n + 2)) True

property drbg_tests_pass =
  ~zero == [ test_drbg n | n <- [0 .. 14] ]