xref: /illumos-gate/usr/src/test/crypto-tests/tests/hmac/hmac_sha1_data.h (revision 29316b9c834da1aab0c095f56a69bd1e71121080)
1*29316b9cSGordon Ross /*
2*29316b9cSGordon Ross  * This file and its contents are supplied under the terms of the
3*29316b9cSGordon Ross  * Common Development and Distribution License (), version 1.0.
4*29316b9cSGordon Ross  * You may only use this file in accordance with the terms of version
5*29316b9cSGordon Ross  * 1.0 of the CDDL.
6*29316b9cSGordon Ross  *
7*29316b9cSGordon Ross  * A full copy of the text of the CDDL should have accompanied this
8*29316b9cSGordon Ross  * source.  A copy of the CDDL is also available via the Internet at
9*29316b9cSGordon Ross  * http://www.illumos.org/license/CDDL.
10*29316b9cSGordon Ross  */
11*29316b9cSGordon Ross 
12*29316b9cSGordon Ross /*
13*29316b9cSGordon Ross  * Copyright 2019 Joyent, Inc.
14*29316b9cSGordon Ross  */
15*29316b9cSGordon Ross 
16*29316b9cSGordon Ross #include <sys/types.h>
17*29316b9cSGordon Ross 
18*29316b9cSGordon Ross /*
19*29316b9cSGordon Ross  * Test data from RFC2202
20*29316b9cSGordon Ross  */
21*29316b9cSGordon Ross 
22*29316b9cSGordon Ross static uint8_t KEY0[] = {
23*29316b9cSGordon Ross 	0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b,
24*29316b9cSGordon Ross 	0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b,
25*29316b9cSGordon Ross 	0x0b, 0x0b, 0x0b, 0x0b
26*29316b9cSGordon Ross };
27*29316b9cSGordon Ross 
28*29316b9cSGordon Ross /* "Hi There" */
29*29316b9cSGordon Ross static uint8_t DATA0[] = { 0x48, 0x69, 0x20, 0x54, 0x68, 0x65, 0x72, 0x65 };
30*29316b9cSGordon Ross 
31*29316b9cSGordon Ross static uint8_t HMAC0[] = {
32*29316b9cSGordon Ross 	0xb6, 0x17, 0x31, 0x86, 0x55, 0x05, 0x72, 0x64,
33*29316b9cSGordon Ross 	0xe2, 0x8b, 0xc0, 0xb6, 0xfb, 0x37, 0x8c, 0x8e,
34*29316b9cSGordon Ross 	0xf1, 0x46, 0xbe, 0x00
35*29316b9cSGordon Ross };
36*29316b9cSGordon Ross 
37*29316b9cSGordon Ross 
38*29316b9cSGordon Ross /* "Jefe" */
39*29316b9cSGordon Ross static uint8_t KEY1[] = { 0x4a, 0x65, 0x66, 0x65 };
40*29316b9cSGordon Ross 
41*29316b9cSGordon Ross /* "what do ya want for nothing?" */
42*29316b9cSGordon Ross static uint8_t DATA1[] = {
43*29316b9cSGordon Ross 	0x77, 0x68, 0x61, 0x74, 0x20, 0x64, 0x6f, 0x20,
44*29316b9cSGordon Ross 	0x79, 0x61, 0x20, 0x77, 0x61, 0x6e, 0x74, 0x20,
45*29316b9cSGordon Ross 	0x66, 0x6f, 0x72, 0x20, 0x6e, 0x6f, 0x74, 0x68,
46*29316b9cSGordon Ross 	0x69, 0x6e, 0x67, 0x3f
47*29316b9cSGordon Ross };
48*29316b9cSGordon Ross 
49*29316b9cSGordon Ross static uint8_t HMAC1[] = {
50*29316b9cSGordon Ross 	0xef, 0xfc, 0xdf, 0x6a, 0xe5, 0xeb, 0x2f, 0xa2,
51*29316b9cSGordon Ross 	0xd2, 0x74, 0x16, 0xd5, 0xf1, 0x84, 0xdf, 0x9c,
52*29316b9cSGordon Ross 	0x25, 0x9a, 0x7c, 0x79
53*29316b9cSGordon Ross };
54*29316b9cSGordon Ross 
55*29316b9cSGordon Ross 
56*29316b9cSGordon Ross static uint8_t KEY2[] = {
57*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
58*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
59*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa
60*29316b9cSGordon Ross };
61*29316b9cSGordon Ross 
62*29316b9cSGordon Ross static uint8_t DATA2[] = {
63*29316b9cSGordon Ross 	0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd,
64*29316b9cSGordon Ross 	0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd,
65*29316b9cSGordon Ross 	0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd,
66*29316b9cSGordon Ross 	0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd,
67*29316b9cSGordon Ross 	0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd,
68*29316b9cSGordon Ross 	0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd, 0xdd,
69*29316b9cSGordon Ross 	0xdd, 0xdd
70*29316b9cSGordon Ross };
71*29316b9cSGordon Ross 
72*29316b9cSGordon Ross static uint8_t HMAC2[] = {
73*29316b9cSGordon Ross 	0x12, 0x5d, 0x73, 0x42, 0xb9, 0xac, 0x11, 0xcd,
74*29316b9cSGordon Ross 	0x91, 0xa3, 0x9a, 0xf4, 0x8a, 0xa1, 0x7b, 0x4f,
75*29316b9cSGordon Ross 	0x63, 0xf1, 0x75, 0xd3
76*29316b9cSGordon Ross };
77*29316b9cSGordon Ross 
78*29316b9cSGordon Ross 
79*29316b9cSGordon Ross static uint8_t KEY3[] = {
80*29316b9cSGordon Ross 	0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08,
81*29316b9cSGordon Ross 	0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f, 0x10,
82*29316b9cSGordon Ross 	0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18,
83*29316b9cSGordon Ross 	0x19
84*29316b9cSGordon Ross };
85*29316b9cSGordon Ross 
86*29316b9cSGordon Ross static uint8_t DATA3[] = {
87*29316b9cSGordon Ross 	0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd,
88*29316b9cSGordon Ross 	0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd,
89*29316b9cSGordon Ross 	0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd,
90*29316b9cSGordon Ross 	0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd,
91*29316b9cSGordon Ross 	0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd,
92*29316b9cSGordon Ross 	0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd, 0xcd,
93*29316b9cSGordon Ross 	0xcd, 0xcd
94*29316b9cSGordon Ross };
95*29316b9cSGordon Ross 
96*29316b9cSGordon Ross static uint8_t HMAC3[] = {
97*29316b9cSGordon Ross 	0x4c, 0x90, 0x07, 0xf4, 0x02, 0x62, 0x50, 0xc6,
98*29316b9cSGordon Ross 	0xbc, 0x84, 0x14, 0xf9, 0xbf, 0x50, 0xc8, 0x6c,
99*29316b9cSGordon Ross 	0x2d, 0x72, 0x35, 0xda
100*29316b9cSGordon Ross };
101*29316b9cSGordon Ross 
102*29316b9cSGordon Ross 
103*29316b9cSGordon Ross static uint8_t KEY4[] = {
104*29316b9cSGordon Ross 	0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0c,
105*29316b9cSGordon Ross 	0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0c, 0x0c,
106*29316b9cSGordon Ross 	0x0c, 0x0c, 0x0c, 0x0c
107*29316b9cSGordon Ross };
108*29316b9cSGordon Ross 
109*29316b9cSGordon Ross /* "Test With Truncation" */
110*29316b9cSGordon Ross static uint8_t DATA4[] = {
111*29316b9cSGordon Ross 	0x54, 0x65, 0x73, 0x74, 0x20, 0x57, 0x69, 0x74,
112*29316b9cSGordon Ross 	0x68, 0x20, 0x54, 0x72, 0x75, 0x6e, 0x63, 0x61,
113*29316b9cSGordon Ross 	0x74, 0x69, 0x6f, 0x6e
114*29316b9cSGordon Ross };
115*29316b9cSGordon Ross 
116*29316b9cSGordon Ross static uint8_t HMAC4[] = {
117*29316b9cSGordon Ross 	0x4c, 0x1a, 0x03, 0x42, 0x4b, 0x55, 0xe0, 0x7f,
118*29316b9cSGordon Ross 	0xe7, 0xf2, 0x7b, 0xe1, 0xd5, 0x8b, 0xb9, 0x32,
119*29316b9cSGordon Ross 	0x4a, 0x9a, 0x5a, 0x04
120*29316b9cSGordon Ross };
121*29316b9cSGordon Ross 
122*29316b9cSGordon Ross 
123*29316b9cSGordon Ross static uint8_t KEY5[] = {
124*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
125*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
126*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
127*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
128*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
129*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
130*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
131*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
132*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
133*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa
134*29316b9cSGordon Ross };
135*29316b9cSGordon Ross 
136*29316b9cSGordon Ross /* "Test Using Larger Than Block-Size Key - Hash Key First" */
137*29316b9cSGordon Ross static uint8_t DATA5[] = {
138*29316b9cSGordon Ross 	0x54, 0x65, 0x73, 0x74, 0x20, 0x55, 0x73, 0x69,
139*29316b9cSGordon Ross 	0x6e, 0x67, 0x20, 0x4c, 0x61, 0x72, 0x67, 0x65,
140*29316b9cSGordon Ross 	0x72, 0x20, 0x54, 0x68, 0x61, 0x6e, 0x20, 0x42,
141*29316b9cSGordon Ross 	0x6c, 0x6f, 0x63, 0x6b, 0x2d, 0x53, 0x69, 0x7a,
142*29316b9cSGordon Ross 	0x65, 0x20, 0x4b, 0x65, 0x79, 0x20, 0x2d, 0x20,
143*29316b9cSGordon Ross 	0x48, 0x61, 0x73, 0x68, 0x20, 0x4b, 0x65, 0x79,
144*29316b9cSGordon Ross 	0x20, 0x46, 0x69, 0x72, 0x73, 0x74
145*29316b9cSGordon Ross };
146*29316b9cSGordon Ross 
147*29316b9cSGordon Ross static uint8_t HMAC5[] = {
148*29316b9cSGordon Ross 	0xaa, 0x4a, 0xe5, 0xe1, 0x52, 0x72, 0xd0, 0x0e,
149*29316b9cSGordon Ross 	0x95, 0x70, 0x56, 0x37, 0xce, 0x8a, 0x3b, 0x55,
150*29316b9cSGordon Ross 	0xed, 0x40, 0x21, 0x12
151*29316b9cSGordon Ross };
152*29316b9cSGordon Ross 
153*29316b9cSGordon Ross 
154*29316b9cSGordon Ross static uint8_t KEY6[] = {
155*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
156*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
157*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
158*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
159*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
160*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
161*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
162*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
163*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
164*29316b9cSGordon Ross 	0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa
165*29316b9cSGordon Ross };
166*29316b9cSGordon Ross 
167*29316b9cSGordon Ross /*
168*29316b9cSGordon Ross  * "Test Using Larger Than Block-Size Key and Larger Than One Block-Size Data"
169*29316b9cSGordon Ross  */
170*29316b9cSGordon Ross static uint8_t DATA6[] = {
171*29316b9cSGordon Ross 	0x54, 0x65, 0x73, 0x74, 0x20, 0x55, 0x73, 0x69,
172*29316b9cSGordon Ross 	0x6e, 0x67, 0x20, 0x4c, 0x61, 0x72, 0x67, 0x65,
173*29316b9cSGordon Ross 	0x72, 0x20, 0x54, 0x68, 0x61, 0x6e, 0x20, 0x42,
174*29316b9cSGordon Ross 	0x6c, 0x6f, 0x63, 0x6b, 0x2d, 0x53, 0x69, 0x7a,
175*29316b9cSGordon Ross 	0x65, 0x20, 0x4b, 0x65, 0x79, 0x20, 0x61, 0x6e,
176*29316b9cSGordon Ross 	0x64, 0x20, 0x4c, 0x61, 0x72, 0x67, 0x65, 0x72,
177*29316b9cSGordon Ross 	0x20, 0x54, 0x68, 0x61, 0x6e, 0x20, 0x4f, 0x6e,
178*29316b9cSGordon Ross 	0x65, 0x20, 0x42, 0x6c, 0x6f, 0x63, 0x6b, 0x2d,
179*29316b9cSGordon Ross 	0x53, 0x69, 0x7a, 0x65, 0x20, 0x44, 0x61, 0x74,
180*29316b9cSGordon Ross 	0x61
181*29316b9cSGordon Ross };
182*29316b9cSGordon Ross static uint8_t HMAC6[] = {
183*29316b9cSGordon Ross 	0xe8, 0xe9, 0x9d, 0x0f, 0x45, 0x23, 0x7d, 0x78,
184*29316b9cSGordon Ross 	0x6d, 0x6b, 0xba, 0xa7, 0x96, 0x5c, 0x78, 0x08,
185*29316b9cSGordon Ross 	0xbb, 0xff, 0x1a, 0x91
186*29316b9cSGordon Ross };
187