xref: /aoo4110/main/sal/workben/t_digest.c (revision b1cdbd2c)
1*b1cdbd2cSJim Jagielski /**************************************************************
2*b1cdbd2cSJim Jagielski  *
3*b1cdbd2cSJim Jagielski  * Licensed to the Apache Software Foundation (ASF) under one
4*b1cdbd2cSJim Jagielski  * or more contributor license agreements.  See the NOTICE file
5*b1cdbd2cSJim Jagielski  * distributed with this work for additional information
6*b1cdbd2cSJim Jagielski  * regarding copyright ownership.  The ASF licenses this file
7*b1cdbd2cSJim Jagielski  * to you under the Apache License, Version 2.0 (the
8*b1cdbd2cSJim Jagielski  * "License"); you may not use this file except in compliance
9*b1cdbd2cSJim Jagielski  * with the License.  You may obtain a copy of the License at
10*b1cdbd2cSJim Jagielski  *
11*b1cdbd2cSJim Jagielski  *   http://www.apache.org/licenses/LICENSE-2.0
12*b1cdbd2cSJim Jagielski  *
13*b1cdbd2cSJim Jagielski  * Unless required by applicable law or agreed to in writing,
14*b1cdbd2cSJim Jagielski  * software distributed under the License is distributed on an
15*b1cdbd2cSJim Jagielski  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16*b1cdbd2cSJim Jagielski  * KIND, either express or implied.  See the License for the
17*b1cdbd2cSJim Jagielski  * specific language governing permissions and limitations
18*b1cdbd2cSJim Jagielski  * under the License.
19*b1cdbd2cSJim Jagielski  *
20*b1cdbd2cSJim Jagielski  *************************************************************/
21*b1cdbd2cSJim Jagielski 
22*b1cdbd2cSJim Jagielski 
23*b1cdbd2cSJim Jagielski 
24*b1cdbd2cSJim Jagielski #include <stdio.h>
25*b1cdbd2cSJim Jagielski #include <string.h>
26*b1cdbd2cSJim Jagielski #include <stdlib.h>
27*b1cdbd2cSJim Jagielski 
28*b1cdbd2cSJim Jagielski #include <rtl/digest.h>
29*b1cdbd2cSJim Jagielski 
30*b1cdbd2cSJim Jagielski static const char *digest_in_MD[] =
31*b1cdbd2cSJim Jagielski {
32*b1cdbd2cSJim Jagielski 	"",
33*b1cdbd2cSJim Jagielski 	"a",
34*b1cdbd2cSJim Jagielski 	"abc",
35*b1cdbd2cSJim Jagielski 	"message digest",
36*b1cdbd2cSJim Jagielski 	"abcdefghijklmnopqrstuvwxyz",
37*b1cdbd2cSJim Jagielski 	"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789",
38*b1cdbd2cSJim Jagielski 	"12345678901234567890123456789012345678901234567890123456789012345678901234567890",
39*b1cdbd2cSJim Jagielski 	NULL,
40*b1cdbd2cSJim Jagielski };
41*b1cdbd2cSJim Jagielski 
42*b1cdbd2cSJim Jagielski static const char *digest_out_MD2[]=
43*b1cdbd2cSJim Jagielski {
44*b1cdbd2cSJim Jagielski 	"8350e5a3e24c153df2275c9f80692773",
45*b1cdbd2cSJim Jagielski 	"32ec01ec4a6dac72c0ab96fb34c0b5d1",
46*b1cdbd2cSJim Jagielski 	"da853b0d3f88d99b30283a69e6ded6bb",
47*b1cdbd2cSJim Jagielski 	"ab4f496bfb2a530b219ff33031fe06b0",
48*b1cdbd2cSJim Jagielski 	"4e8ddff3650292ab5a4108c3aa47940b",
49*b1cdbd2cSJim Jagielski 	"da33def2a42df13975352846c30338cd",
50*b1cdbd2cSJim Jagielski 	"d5976f79d83d3a0dc9806c3c66f3efd8",
51*b1cdbd2cSJim Jagielski };
52*b1cdbd2cSJim Jagielski 
53*b1cdbd2cSJim Jagielski static const char *digest_out_MD5[]=
54*b1cdbd2cSJim Jagielski {
55*b1cdbd2cSJim Jagielski 	"d41d8cd98f00b204e9800998ecf8427e",
56*b1cdbd2cSJim Jagielski 	"0cc175b9c0f1b6a831c399e269772661",
57*b1cdbd2cSJim Jagielski 	"900150983cd24fb0d6963f7d28e17f72",
58*b1cdbd2cSJim Jagielski 	"f96b697d7cb7938d525a2f31aaf161d0",
59*b1cdbd2cSJim Jagielski 	"c3fcd3d76192e4007dfb496cca67e13b",
60*b1cdbd2cSJim Jagielski 	"d174ab98d277d9f5a5611c2c9f419d9f",
61*b1cdbd2cSJim Jagielski 	"57edf4a22be3c955ac49da2e2107b67a",
62*b1cdbd2cSJim Jagielski };
63*b1cdbd2cSJim Jagielski 
64*b1cdbd2cSJim Jagielski static const char *digest_in_SHA[]=
65*b1cdbd2cSJim Jagielski {
66*b1cdbd2cSJim Jagielski 	"abc",
67*b1cdbd2cSJim Jagielski 	"abcdbcdecdefdefgefghfghighijhijkijkljklmklmnlmnomnopnopq",
68*b1cdbd2cSJim Jagielski 	NULL,
69*b1cdbd2cSJim Jagielski };
70*b1cdbd2cSJim Jagielski 
71*b1cdbd2cSJim Jagielski static const char *digest_out_SHA_0[]=
72*b1cdbd2cSJim Jagielski {
73*b1cdbd2cSJim Jagielski 	"0164b8a914cd2a5e74c4f7ff082c4d97f1edf880",
74*b1cdbd2cSJim Jagielski 	"d2516ee1acfa5baf33dfc1c471e438449ef134c8",
75*b1cdbd2cSJim Jagielski };
76*b1cdbd2cSJim Jagielski 
77*b1cdbd2cSJim Jagielski static const char *digest_out_SHA_1[]=
78*b1cdbd2cSJim Jagielski {
79*b1cdbd2cSJim Jagielski 	"a9993e364706816aba3e25717850c26c9cd0d89d",
80*b1cdbd2cSJim Jagielski 	"84983e441c3bd26ebaae4aa1f95129e5e54670f1",
81*b1cdbd2cSJim Jagielski };
82*b1cdbd2cSJim Jagielski 
83*b1cdbd2cSJim Jagielski static const char *digest_bigout_SHA_0=
84*b1cdbd2cSJim Jagielski 	"3232affa48628a26653b5aaa44541fd90d690603";
85*b1cdbd2cSJim Jagielski 
86*b1cdbd2cSJim Jagielski static const char *digest_bigout_SHA_1=
87*b1cdbd2cSJim Jagielski 	"34aa973cd4c4daa4f61eeb2bdbad27316534016f";
88*b1cdbd2cSJim Jagielski 
89*b1cdbd2cSJim Jagielski 
90*b1cdbd2cSJim Jagielski static const char digest_key_HMAC_MD5_1[] =
91*b1cdbd2cSJim Jagielski {
92*b1cdbd2cSJim Jagielski 	0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b,
93*b1cdbd2cSJim Jagielski 	0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b, 0x0b,
94*b1cdbd2cSJim Jagielski 	0x00
95*b1cdbd2cSJim Jagielski };
96*b1cdbd2cSJim Jagielski static const char digest_key_HMAC_MD5_2[] =
97*b1cdbd2cSJim Jagielski {
98*b1cdbd2cSJim Jagielski 	/* "Jefe" */
99*b1cdbd2cSJim Jagielski 	'J', 'e', 'f', 'e',
100*b1cdbd2cSJim Jagielski 	0x00
101*b1cdbd2cSJim Jagielski };
102*b1cdbd2cSJim Jagielski static const unsigned char digest_key_HMAC_MD5_3[] =
103*b1cdbd2cSJim Jagielski {
104*b1cdbd2cSJim Jagielski 	0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA,
105*b1cdbd2cSJim Jagielski 	0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA, 0xAA,
106*b1cdbd2cSJim Jagielski 	0x00
107*b1cdbd2cSJim Jagielski };
108*b1cdbd2cSJim Jagielski static const char *digest_key_HMAC_MD5[] =
109*b1cdbd2cSJim Jagielski {
110*b1cdbd2cSJim Jagielski 	(const char*)&digest_key_HMAC_MD5_1,
111*b1cdbd2cSJim Jagielski 	(const char*)&digest_key_HMAC_MD5_2, /* "Jefe", */
112*b1cdbd2cSJim Jagielski 	(const char*)&digest_key_HMAC_MD5_3,
113*b1cdbd2cSJim Jagielski 	NULL
114*b1cdbd2cSJim Jagielski };
115*b1cdbd2cSJim Jagielski 
116*b1cdbd2cSJim Jagielski static const unsigned char digest_in_HMAC_MD5_3[] =
117*b1cdbd2cSJim Jagielski {
118*b1cdbd2cSJim Jagielski 	0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD,
119*b1cdbd2cSJim Jagielski 	0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD,
120*b1cdbd2cSJim Jagielski 	0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD,
121*b1cdbd2cSJim Jagielski 	0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD,
122*b1cdbd2cSJim Jagielski 	0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD,
123*b1cdbd2cSJim Jagielski 	0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD, 0xDD,
124*b1cdbd2cSJim Jagielski 	0xDD, 0xDD,
125*b1cdbd2cSJim Jagielski 	0x00
126*b1cdbd2cSJim Jagielski };
127*b1cdbd2cSJim Jagielski static const char *digest_in_HMAC_MD5[] =
128*b1cdbd2cSJim Jagielski {
129*b1cdbd2cSJim Jagielski 	"Hi There",
130*b1cdbd2cSJim Jagielski 	"what do ya want for nothing?",
131*b1cdbd2cSJim Jagielski 	(const char*)&digest_in_HMAC_MD5_3,
132*b1cdbd2cSJim Jagielski 	NULL
133*b1cdbd2cSJim Jagielski };
134*b1cdbd2cSJim Jagielski 
135*b1cdbd2cSJim Jagielski static const char *digest_out_HMAC_MD5[] =
136*b1cdbd2cSJim Jagielski {
137*b1cdbd2cSJim Jagielski 	"9294727a3638bb1c13f48ef8158bfc9d",
138*b1cdbd2cSJim Jagielski 	"750c783e6ab0b503eaa86e310a5db738",
139*b1cdbd2cSJim Jagielski 	"56be34521d144c88dbb8c733f0e8b3f6",
140*b1cdbd2cSJim Jagielski 	NULL
141*b1cdbd2cSJim Jagielski };
142*b1cdbd2cSJim Jagielski static const char *digest_out_HMAC_SHA1[] =
143*b1cdbd2cSJim Jagielski {
144*b1cdbd2cSJim Jagielski 	/* unofficial, i.e. not verified */
145*b1cdbd2cSJim Jagielski 	"675b0b3a1b4ddf4e124872da6c2f632bfed957e9",
146*b1cdbd2cSJim Jagielski 	"effcdf6ae5eb2fa2d27416d5f184df9c259a7c79",
147*b1cdbd2cSJim Jagielski 	"d730594d167e35d5956fd8003d0db3d3f46dc7bb",
148*b1cdbd2cSJim Jagielski 	NULL
149*b1cdbd2cSJim Jagielski };
150*b1cdbd2cSJim Jagielski 
151*b1cdbd2cSJim Jagielski 
pt(unsigned char * md,int length)152*b1cdbd2cSJim Jagielski static char *pt (unsigned char *md, int length)
153*b1cdbd2cSJim Jagielski {
154*b1cdbd2cSJim Jagielski 	int i;
155*b1cdbd2cSJim Jagielski 	static char buf[80];
156*b1cdbd2cSJim Jagielski 
157*b1cdbd2cSJim Jagielski 	for (i=0; i<length; i++)
158*b1cdbd2cSJim Jagielski 		sprintf(&(buf[i*2]),"%02x",md[i]);
159*b1cdbd2cSJim Jagielski 
160*b1cdbd2cSJim Jagielski 	return(buf);
161*b1cdbd2cSJim Jagielski }
162*b1cdbd2cSJim Jagielski 
main(int argc,char ** argv)163*b1cdbd2cSJim Jagielski int SAL_CALL main (int argc, char **argv)
164*b1cdbd2cSJim Jagielski {
165*b1cdbd2cSJim Jagielski 	const char **P,**R, **Q;
166*b1cdbd2cSJim Jagielski 	char *p;
167*b1cdbd2cSJim Jagielski 	int i=1, err=0;
168*b1cdbd2cSJim Jagielski 
169*b1cdbd2cSJim Jagielski 	unsigned char md[80];
170*b1cdbd2cSJim Jagielski 	unsigned char buffer[1000];
171*b1cdbd2cSJim Jagielski 
172*b1cdbd2cSJim Jagielski 	rtlDigest Digest;
173*b1cdbd2cSJim Jagielski 
174*b1cdbd2cSJim Jagielski 	P=digest_in_MD;
175*b1cdbd2cSJim Jagielski 	R=digest_out_MD2;
176*b1cdbd2cSJim Jagielski 	i = 1;
177*b1cdbd2cSJim Jagielski 	while (*P)
178*b1cdbd2cSJim Jagielski 	{
179*b1cdbd2cSJim Jagielski 		rtl_digest_MD2 (*P, strlen(*P), md, sizeof(md));
180*b1cdbd2cSJim Jagielski 
181*b1cdbd2cSJim Jagielski 		p=pt (md, RTL_DIGEST_LENGTH_MD2);
182*b1cdbd2cSJim Jagielski 		if (strcmp (p, *R))
183*b1cdbd2cSJim Jagielski 		{
184*b1cdbd2cSJim Jagielski 			printf("error calculating MD2 on '%s'\n",*P);
185*b1cdbd2cSJim Jagielski 			printf("got %s instead of %s\n",p,*R);
186*b1cdbd2cSJim Jagielski 			err++;
187*b1cdbd2cSJim Jagielski 		}
188*b1cdbd2cSJim Jagielski 		else
189*b1cdbd2cSJim Jagielski 			printf("test (MD2) %d ok\n",i);
190*b1cdbd2cSJim Jagielski 		i++;
191*b1cdbd2cSJim Jagielski 		R++;
192*b1cdbd2cSJim Jagielski 		P++;
193*b1cdbd2cSJim Jagielski 	}
194*b1cdbd2cSJim Jagielski 
195*b1cdbd2cSJim Jagielski 	P=digest_in_MD;
196*b1cdbd2cSJim Jagielski 	R=digest_out_MD5;
197*b1cdbd2cSJim Jagielski 	i=1;
198*b1cdbd2cSJim Jagielski 	while (*P)
199*b1cdbd2cSJim Jagielski 	{
200*b1cdbd2cSJim Jagielski 		rtl_digest_MD5 (*P, strlen(*P), md, sizeof(md));
201*b1cdbd2cSJim Jagielski 
202*b1cdbd2cSJim Jagielski 		p=pt (md, RTL_DIGEST_LENGTH_MD5);
203*b1cdbd2cSJim Jagielski 		if (strcmp (p, *R))
204*b1cdbd2cSJim Jagielski 		{
205*b1cdbd2cSJim Jagielski 			printf("error calculating MD5 on '%s'\n",*P);
206*b1cdbd2cSJim Jagielski 			printf("got %s instead of %s\n",p,*R);
207*b1cdbd2cSJim Jagielski 			err++;
208*b1cdbd2cSJim Jagielski 		}
209*b1cdbd2cSJim Jagielski 		else
210*b1cdbd2cSJim Jagielski 			printf("test (MD5) %d ok\n",i);
211*b1cdbd2cSJim Jagielski 		i++;
212*b1cdbd2cSJim Jagielski 		R++;
213*b1cdbd2cSJim Jagielski 		P++;
214*b1cdbd2cSJim Jagielski 	}
215*b1cdbd2cSJim Jagielski 
216*b1cdbd2cSJim Jagielski 	P=digest_in_SHA;
217*b1cdbd2cSJim Jagielski 	R=digest_out_SHA_0;
218*b1cdbd2cSJim Jagielski 	i=1;
219*b1cdbd2cSJim Jagielski 	while (*P)
220*b1cdbd2cSJim Jagielski 	{
221*b1cdbd2cSJim Jagielski 		rtl_digest_SHA (*P, strlen(*P), md, sizeof(md));
222*b1cdbd2cSJim Jagielski 
223*b1cdbd2cSJim Jagielski 		p=pt (md, RTL_DIGEST_LENGTH_SHA);
224*b1cdbd2cSJim Jagielski 		if (strcmp (p, *R))
225*b1cdbd2cSJim Jagielski 		{
226*b1cdbd2cSJim Jagielski 			printf("error calculating SHA-0 on '%s'\n",*P);
227*b1cdbd2cSJim Jagielski 			printf("got %s instead of %s\n",p,*R);
228*b1cdbd2cSJim Jagielski 			err++;
229*b1cdbd2cSJim Jagielski 		}
230*b1cdbd2cSJim Jagielski 		else
231*b1cdbd2cSJim Jagielski 			printf("test (SHA-0) %d ok\n",i);
232*b1cdbd2cSJim Jagielski 		i++;
233*b1cdbd2cSJim Jagielski 		R++;
234*b1cdbd2cSJim Jagielski 		P++;
235*b1cdbd2cSJim Jagielski 	}
236*b1cdbd2cSJim Jagielski 
237*b1cdbd2cSJim Jagielski 	memset (buffer, 'a', sizeof(buffer));
238*b1cdbd2cSJim Jagielski 	R = &digest_bigout_SHA_0;
239*b1cdbd2cSJim Jagielski 
240*b1cdbd2cSJim Jagielski 	Digest = rtl_digest_createSHA();
241*b1cdbd2cSJim Jagielski 	for (i=0; i<1000; i++)
242*b1cdbd2cSJim Jagielski 		rtl_digest_updateSHA (Digest, buffer, sizeof(buffer));
243*b1cdbd2cSJim Jagielski 
244*b1cdbd2cSJim Jagielski 	rtl_digest_getSHA (Digest, md, sizeof(md));
245*b1cdbd2cSJim Jagielski 	rtl_digest_destroySHA (Digest);
246*b1cdbd2cSJim Jagielski 
247*b1cdbd2cSJim Jagielski 	p=pt (md, RTL_DIGEST_LENGTH_SHA);
248*b1cdbd2cSJim Jagielski 	if (strcmp (p, *R))
249*b1cdbd2cSJim Jagielski 	{
250*b1cdbd2cSJim Jagielski 		printf("error calculating SHA-0 on '%s'\n",p);
251*b1cdbd2cSJim Jagielski 		printf("got %s instead of %s\n",p,*R);
252*b1cdbd2cSJim Jagielski 		err++;
253*b1cdbd2cSJim Jagielski 	}
254*b1cdbd2cSJim Jagielski 	else
255*b1cdbd2cSJim Jagielski 		printf("test (SHA-0) n ok\n");
256*b1cdbd2cSJim Jagielski 
257*b1cdbd2cSJim Jagielski 	P=digest_in_SHA;
258*b1cdbd2cSJim Jagielski 	R=digest_out_SHA_1;
259*b1cdbd2cSJim Jagielski 	i=1;
260*b1cdbd2cSJim Jagielski 	while (*P)
261*b1cdbd2cSJim Jagielski 	{
262*b1cdbd2cSJim Jagielski 		rtl_digest_SHA1 (*P, strlen(*P), md, sizeof(md));
263*b1cdbd2cSJim Jagielski 
264*b1cdbd2cSJim Jagielski 		p=pt (md, RTL_DIGEST_LENGTH_SHA1);
265*b1cdbd2cSJim Jagielski 		if (strcmp (p, *R))
266*b1cdbd2cSJim Jagielski 		{
267*b1cdbd2cSJim Jagielski 			printf("error calculating SHA-1 on '%s'\n",*P);
268*b1cdbd2cSJim Jagielski 			printf("got %s instead of %s\n",p,*R);
269*b1cdbd2cSJim Jagielski 			err++;
270*b1cdbd2cSJim Jagielski 		}
271*b1cdbd2cSJim Jagielski 		else
272*b1cdbd2cSJim Jagielski 			printf("test (SHA-1) %d ok\n",i);
273*b1cdbd2cSJim Jagielski 		i++;
274*b1cdbd2cSJim Jagielski 		R++;
275*b1cdbd2cSJim Jagielski 		P++;
276*b1cdbd2cSJim Jagielski 	}
277*b1cdbd2cSJim Jagielski 
278*b1cdbd2cSJim Jagielski 	memset (buffer, 'a', sizeof(buffer));
279*b1cdbd2cSJim Jagielski 	R = &digest_bigout_SHA_1;
280*b1cdbd2cSJim Jagielski 
281*b1cdbd2cSJim Jagielski 	Digest = rtl_digest_createSHA1();
282*b1cdbd2cSJim Jagielski 	for (i=0; i<1000; i++)
283*b1cdbd2cSJim Jagielski 		rtl_digest_updateSHA1 (Digest, buffer, sizeof(buffer));
284*b1cdbd2cSJim Jagielski 
285*b1cdbd2cSJim Jagielski 	rtl_digest_getSHA1 (Digest, md, sizeof(md));
286*b1cdbd2cSJim Jagielski 	rtl_digest_destroySHA1 (Digest);
287*b1cdbd2cSJim Jagielski 
288*b1cdbd2cSJim Jagielski 	p=pt (md, RTL_DIGEST_LENGTH_SHA1);
289*b1cdbd2cSJim Jagielski 	if (strcmp (p, *R))
290*b1cdbd2cSJim Jagielski 	{
291*b1cdbd2cSJim Jagielski 		printf("error calculating SHA-1 on '%s'\n",p);
292*b1cdbd2cSJim Jagielski 		printf("got %s instead of %s\n",p,*R);
293*b1cdbd2cSJim Jagielski 		err++;
294*b1cdbd2cSJim Jagielski 	}
295*b1cdbd2cSJim Jagielski 	else
296*b1cdbd2cSJim Jagielski 		printf("test (SHA-1) n ok\n");
297*b1cdbd2cSJim Jagielski 
298*b1cdbd2cSJim Jagielski 
299*b1cdbd2cSJim Jagielski 	P=digest_in_HMAC_MD5;
300*b1cdbd2cSJim Jagielski 	Q=digest_key_HMAC_MD5;
301*b1cdbd2cSJim Jagielski 	R=digest_out_HMAC_MD5;
302*b1cdbd2cSJim Jagielski 	Digest = rtl_digest_createHMAC_MD5();
303*b1cdbd2cSJim Jagielski 	i = 1;
304*b1cdbd2cSJim Jagielski 	while (*P)
305*b1cdbd2cSJim Jagielski 	{
306*b1cdbd2cSJim Jagielski 		rtl_digest_initHMAC_MD5 (Digest, *Q, strlen(*Q));
307*b1cdbd2cSJim Jagielski 		rtl_digest_updateHMAC_MD5 (Digest, *P, strlen(*P));
308*b1cdbd2cSJim Jagielski 		rtl_digest_getHMAC_MD5 (Digest, md, sizeof(md));
309*b1cdbd2cSJim Jagielski 
310*b1cdbd2cSJim Jagielski 		p=pt (md, RTL_DIGEST_LENGTH_HMAC_MD5);
311*b1cdbd2cSJim Jagielski 		if (strcmp (p, *R))
312*b1cdbd2cSJim Jagielski 		{
313*b1cdbd2cSJim Jagielski 			printf("error calculating HMAC-MD5 on '%s'\n",*P);
314*b1cdbd2cSJim Jagielski 			printf("got %s instead of %s\n",p,*R);
315*b1cdbd2cSJim Jagielski 			err++;
316*b1cdbd2cSJim Jagielski 		}
317*b1cdbd2cSJim Jagielski 		else
318*b1cdbd2cSJim Jagielski 			printf("test (HMAC-MD5) %d ok\n",i);
319*b1cdbd2cSJim Jagielski 		i++;
320*b1cdbd2cSJim Jagielski 		R++;
321*b1cdbd2cSJim Jagielski 		P++;
322*b1cdbd2cSJim Jagielski 		Q++;
323*b1cdbd2cSJim Jagielski 	}
324*b1cdbd2cSJim Jagielski 	rtl_digest_destroyHMAC_MD5 (Digest);
325*b1cdbd2cSJim Jagielski 
326*b1cdbd2cSJim Jagielski 
327*b1cdbd2cSJim Jagielski 	P=digest_in_HMAC_MD5;
328*b1cdbd2cSJim Jagielski 	Q=digest_key_HMAC_MD5;
329*b1cdbd2cSJim Jagielski 	R=digest_out_HMAC_SHA1;
330*b1cdbd2cSJim Jagielski 	Digest = rtl_digest_createHMAC_SHA1();
331*b1cdbd2cSJim Jagielski 	i = 1;
332*b1cdbd2cSJim Jagielski 	while (*P)
333*b1cdbd2cSJim Jagielski 	{
334*b1cdbd2cSJim Jagielski 		rtl_digest_initHMAC_SHA1 (Digest, *Q, strlen(*Q));
335*b1cdbd2cSJim Jagielski 		rtl_digest_updateHMAC_SHA1 (Digest, *P, strlen(*P));
336*b1cdbd2cSJim Jagielski 		rtl_digest_getHMAC_SHA1 (Digest, md, sizeof(md));
337*b1cdbd2cSJim Jagielski 
338*b1cdbd2cSJim Jagielski 		p=pt (md, RTL_DIGEST_LENGTH_HMAC_SHA1);
339*b1cdbd2cSJim Jagielski 		if (strcmp (p, *R))
340*b1cdbd2cSJim Jagielski 		{
341*b1cdbd2cSJim Jagielski 			printf("error calculating HMAC-SHA-1 on '%s'\n",*P);
342*b1cdbd2cSJim Jagielski 			printf("got %s instead of %s\n",p,*R);
343*b1cdbd2cSJim Jagielski 			err++;
344*b1cdbd2cSJim Jagielski 		}
345*b1cdbd2cSJim Jagielski 		else
346*b1cdbd2cSJim Jagielski 			printf("test (HMAC-SHA-1) %d ok\n",i);
347*b1cdbd2cSJim Jagielski 		i++;
348*b1cdbd2cSJim Jagielski 		P++;
349*b1cdbd2cSJim Jagielski 		Q++;
350*b1cdbd2cSJim Jagielski 		R++;
351*b1cdbd2cSJim Jagielski 	}
352*b1cdbd2cSJim Jagielski 	rtl_digest_destroyHMAC_SHA1 (Digest);
353*b1cdbd2cSJim Jagielski 
354*b1cdbd2cSJim Jagielski 
355*b1cdbd2cSJim Jagielski 	P=digest_in_HMAC_MD5;
356*b1cdbd2cSJim Jagielski 	Q=digest_key_HMAC_MD5;
357*b1cdbd2cSJim Jagielski 	rtl_digest_PBKDF2 (
358*b1cdbd2cSJim Jagielski 		md, RTL_DIGEST_LENGTH_MD5, /* [out] derived key     */
359*b1cdbd2cSJim Jagielski 		Q[1], strlen(Q[1]),        /* [in]  password        */
360*b1cdbd2cSJim Jagielski 		P[1], strlen(P[1]),        /* [in]  salt            */
361*b1cdbd2cSJim Jagielski 		1000);                     /* [in]  iteration count */
362*b1cdbd2cSJim Jagielski 
363*b1cdbd2cSJim Jagielski 	p=pt (md, RTL_DIGEST_LENGTH_MD5);
364*b1cdbd2cSJim Jagielski 	if (strcmp (p, "6349e09cb6b8c1485cfa9780ee3264df"))
365*b1cdbd2cSJim Jagielski 	{
366*b1cdbd2cSJim Jagielski 		printf("error calculating PBKDF2 on '%s'\n", P[1]);
367*b1cdbd2cSJim Jagielski 		err++;
368*b1cdbd2cSJim Jagielski 	}
369*b1cdbd2cSJim Jagielski 	else
370*b1cdbd2cSJim Jagielski 		printf("test (PBKDF2) %d ok\n", 1);
371*b1cdbd2cSJim Jagielski 
372*b1cdbd2cSJim Jagielski 	return (err);
373*b1cdbd2cSJim Jagielski }
374*b1cdbd2cSJim Jagielski 
375