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