forked from chipsalliance/caliptra-rtl
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtest_gen.py
executable file
·194 lines (158 loc) · 6.52 KB
/
test_gen.py
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
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
#/usr/local/bin/python3
# SPDX-License-Identifier: Apache-2.0
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
import os
import subprocess
import random
def generate_expected_tag():
f = open("hmac_uvm_test_vector.txt", "r")
g = open("expected_tag.txt", "w")
h = open("expected_tags_all.txt", "a")
msg_str = ""
key_str = ""
seed_str = ""
tag_str = ""
for line in f:
if(line[0:6] == "KEY = "):
key_str = line.strip()[6:]
elif(line[0:7] == "SEED = "):
seed_str = line.strip()[7:]
else:
msg_str = msg_str + line.strip()[8:]
#Generate digest using OpenSSL HMAC SHA384
command = 'echo '+msg_str+' | xxd -r -p | openssl dgst -sha384 -mac hmac -macopt hexkey:'+key_str+' -hex'
tag = subprocess.check_output(command, shell=True)
tag_str = str(tag)
#Chomp extra chars at beginning and end if python 3.6.8 is loaded
if tag_str[1] == "'":
tag_str = tag_str[11:-3]
else:
tag_str = tag_str.rstrip()
tag_str = tag_str[9:]
g.write('TAG = '+tag_str+'\n')
h.write('TAG = '+tag_str+'\n')
h.write("------------------------\n")
f.close()
g.close()
h.close()
#=========================================================
# def calc_pad_chars(num_bits, start_padding):
# pad_bits = (1024 - num_bits)
# pad_bytes = int((pad_bits / 8) - start_padding) #One byte for 'h80 at the start of padding or all 0s based on value of start_padding field
# pad_chars = pad_bytes*2
# return pad_chars
# def calc_msg_len(total_num_bits):
# size_chars = 16*2 #16 bytes = 128 bits
# msg_len = str(hex(1024 + total_num_bits))
# msg_len = msg_len[2:]
# size_chars = size_chars - len(msg_len)
# msg_len = (str(0) * size_chars) + msg_len
# return msg_len
# def generate_test():
# #Open file for logging outputs
# f = open("test_vector.txt", "w")
# g = open("test_vectors_all.txt", "a")
# #Generate 384-bit key
# key = subprocess.check_output('openssl rand -hex 48', shell=True)
# key_str = str(key)
# #Chomp extra chars at beginning and end if python 3.6.8 is loaded
# if key_str[1] == "'":
# key_str = key_str[2:-3]
# else:
# key_str = key_str.rstrip()
# f.write('KEY = '+key_str+'\n')
# g.write('KEY = '+key_str+'\n')
# #Generate random length msg (upper limit of length is 512 bytes)
# num_bytes = random.randrange(1,512)
# command = 'openssl rand -hex '+str(num_bytes)
# msg = subprocess.check_output(command, shell=True)
# msg_str = str(msg)
# #Chomp extra chars at beginning and end if python 3.6.8 is loaded
# if msg_str[1] == "'":
# msg_str = msg_str[2:-3]
# else:
# msg_str = msg_str.rstrip()
# orig_msg_str = msg_str
# #Post process msg to divide into 1024-bit blocks. Last runt msg will get padding + msg length
# #If msg length is <=895 bits, it will be single blk msg
# #If msg length is > 895, it will be multi blk msg
# num_bits = num_bytes * 8
# #Following cases are possible:
# #case 1: msg = 1200 bits --> 1024, 176 + pad + size
# #case 2: msg = 1024 bits --> 1024, pad + size
# #case 3: msg = 1023 bits --> 1023 + pad, pad + size
# #case 4: msg = 896 bits --> 896 + pad, pad + size
# #case 5: msg <= 895 bits --> 895 + pad + size
# total_num_bits = num_bits
# zero = str(0)
# one = str(80)
# while num_bits > 0:
# if num_bits > 1023: #case 1 and 2
# block = msg_str[0:256]
# f.write('BLOCK = '+block+'\n')
# g.write('BLOCK = '+block+'\n')
# msg_str = msg_str[256:]
# num_bits = num_bits - 1024
# if num_bits == 0: #case 2
# #We know here that we don't have space for msg, pad AND msg length, so we just do msg + pad
# pad_chars = calc_pad_chars(num_bits+128, 1)
# pad = one + zero * pad_chars
# msg_len = calc_msg_len(total_num_bits)
# block = pad + msg_len
# f.write('BLOCK = '+block+'\n')
# g.write('BLOCK = '+block+'\n')
# elif num_bits <= 895: #case 5
# pad_chars = calc_pad_chars(num_bits+128, 1) #pad chars = 1024 - (msg + msg_len bits)
# pad = one + zero * pad_chars
# msg_len = calc_msg_len(total_num_bits)
# num_bits = 0
# block = msg_str + pad + msg_len
# f.write('BLOCK = '+block+'\n')
# g.write('BLOCK = '+block+'\n')
# else: #case 3 and 4
# #We know here that we don't have space for msg, pad AND msg length, so we just do msg + pad
# pad_chars = calc_pad_chars(num_bits, 1)
# pad = one + zero * pad_chars
# block = msg_str + pad
# f.write('BLOCK = '+block+'\n')
# g.write('BLOCK = '+block+'\n')
# pad_chars = calc_pad_chars(128, 0) #No msg in this block. Only msg_len and padding is continued (all 0s in padding)
# pad = zero * pad_chars
# msg_len = calc_msg_len(total_num_bits)
# num_bits = 0
# block = pad + msg_len
# f.write('BLOCK = '+block+'\n')
# g.write('BLOCK = '+block+'\n')
# #Generate digest using OpenSSL HMAC SHA384
# command = 'echo '+orig_msg_str+' | xxd -r -p | openssl dgst -sha384 -mac hmac -macopt hexkey:'+key_str+' -hex'
# tag = subprocess.check_output(command, shell=True)
# tag_str = str(tag)
# #Chomp extra chars at beginning and end if python 3.6.8 is loaded
# if tag_str[1] == "'":
# tag_str = tag_str[11:-3]
# else:
# tag_str = tag_str.rstrip()
# tag_str = tag_str[9:]
# f.write('TAG = '+tag_str+'\n')
# g.write('TAG = '+tag_str+'\n')
# g.write('======================================================================================================'+'\n')
# #Close file
# f.close()
# g.close()
#generate_test()
def main():
generate_expected_tag()
#generate_test()
main()