1 /*
2  * Unit tests for SystemFunctionXXX (LMHash?)
3  *
4  * Copyright 2004 Hans Leidekker
5  * Copyright 2006 Mike McCormack
6  *
7  * This library is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2.1 of the License, or (at your option) any later version.
11  *
12  * This library is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU Lesser General Public
18  * License along with this library; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
20  */
21 
22 #include <stdio.h>
23 
24 #include "ntstatus.h"
25 #define WIN32_NO_STATUS
26 #include "wine/test.h"
27 #include "windef.h"
28 #include "winbase.h"
29 #include "wine/winternl.h"
30 
31 struct ustring {
32     DWORD Length;
33     DWORD MaximumLength;
34     unsigned char *Buffer;
35 };
36 
37 typedef int (WINAPI *descrypt)(unsigned char *, unsigned char *, unsigned char *);
38 static NTSTATUS (WINAPI *pSystemFunction001)(const BYTE *, const BYTE *, LPBYTE);
39 static NTSTATUS (WINAPI *pSystemFunction002)(const BYTE *, const BYTE *, LPBYTE);
40 static NTSTATUS (WINAPI *pSystemFunction003)(const BYTE *, LPBYTE);
41 static NTSTATUS (WINAPI *pSystemFunction004)(const struct ustring *, const struct ustring *, struct ustring *);
42 static NTSTATUS (WINAPI *pSystemFunction005)(const struct ustring *, const struct ustring *, struct ustring *);
43 static VOID (WINAPI *pSystemFunction006)( PCSTR passwd, PSTR lmhash );
44 static NTSTATUS (WINAPI *pSystemFunction008)(const BYTE *, const BYTE *, LPBYTE);
45 static NTSTATUS (WINAPI *pSystemFunction009)(const BYTE *, const BYTE *, LPBYTE);
46 static NTSTATUS (WINAPI *pSystemFunction032)(struct ustring *, const struct ustring *);
47 
48 /* encrypt two blocks */
49 static descrypt pSystemFunction012;
50 static descrypt pSystemFunction014;
51 static descrypt pSystemFunction016;
52 static descrypt pSystemFunction018;
53 static descrypt pSystemFunction020;
54 static descrypt pSystemFunction022;
55 
56 /* decrypt two blocks */
57 static descrypt pSystemFunction013;
58 static descrypt pSystemFunction015;
59 static descrypt pSystemFunction017;
60 static descrypt pSystemFunction019;
61 static descrypt pSystemFunction021;
62 static descrypt pSystemFunction023;
63 
64 /* encrypt two blocks with a 32bit key */
65 static descrypt pSystemFunction024;
66 static descrypt pSystemFunction025;
67 
68 /* decrypt two blocks with a 32bit key */
69 static descrypt pSystemFunction026;
70 static descrypt pSystemFunction027;
71 
72 typedef int (WINAPI *memcmpfunc)(unsigned char *, unsigned char *);
73 static memcmpfunc pSystemFunction030;
74 static memcmpfunc pSystemFunction031;
75 
76 static void test_SystemFunction006(void)
77 {
78     char lmhash[16 + 1];
79 
80     char passwd[] = { 's','e','c','r','e','t', 0, 0, 0, 0, 0, 0, 0, 0 };
81     unsigned char expect[] =
82         { 0x85, 0xf5, 0x28, 0x9f, 0x09, 0xdc, 0xa7, 0xeb,
83           0xaa, 0xd3, 0xb4, 0x35, 0xb5, 0x14, 0x04, 0xee };
84 
85     pSystemFunction006( passwd, lmhash );
86 
87     ok( !memcmp( lmhash, expect, sizeof(expect) ),
88         "lmhash: %02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x%02x\n",
89         lmhash[0], lmhash[1], lmhash[2], lmhash[3], lmhash[4], lmhash[5],
90         lmhash[6], lmhash[7], lmhash[8], lmhash[9], lmhash[10], lmhash[11],
91         lmhash[12], lmhash[13], lmhash[14], lmhash[15] );
92 }
93 
94 static void test_SystemFunction008(void)
95 {
96     /* example data from http://davenport.sourceforge.net/ntlm.html */
97     unsigned char hash[0x40] = {
98         0xff, 0x37, 0x50, 0xbc, 0xc2, 0xb2, 0x24, 0x12,
99         0xc2, 0x26, 0x5b, 0x23, 0x73, 0x4e, 0x0d, 0xac };
100     unsigned char challenge[0x40] = {
101         0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef };
102     unsigned char expected[0x18] = {
103         0xc3, 0x37, 0xcd, 0x5c, 0xbd, 0x44, 0xfc, 0x97,
104         0x82, 0xa6, 0x67, 0xaf, 0x6d, 0x42, 0x7c, 0x6d,
105         0xe6, 0x7c, 0x20, 0xc2, 0xd3, 0xe7, 0x7c, 0x56 };
106     unsigned char output[0x18];
107     NTSTATUS r;
108 
109     r = pSystemFunction008(0,0,0);
110     ok( r == STATUS_UNSUCCESSFUL, "wrong error code\n");
111 
112     r = pSystemFunction008(challenge,0,0);
113     ok( r == STATUS_UNSUCCESSFUL, "wrong error code\n");
114 
115     r = pSystemFunction008(challenge, hash, 0);
116     ok( r == STATUS_UNSUCCESSFUL, "wrong error code\n");
117 
118     /* crashes */
119     if (0)
120     {
121         r = pSystemFunction008(challenge, 0, output);
122         ok( r == STATUS_UNSUCCESSFUL, "wrong error code\n");
123     }
124 
125     r = pSystemFunction008(0, 0, output);
126     ok( r == STATUS_UNSUCCESSFUL, "wrong error code\n");
127 
128     memset(output, 0, sizeof output);
129     r = pSystemFunction008(challenge, hash, output);
130     ok( r == STATUS_SUCCESS, "wrong error code\n");
131 
132     ok( !memcmp(output, expected, sizeof expected), "response wrong\n");
133 }
134 
135 static void test_SystemFunction001(void)
136 {
137     unsigned char key[8] = { 0xff, 0x37, 0x50, 0xbc, 0xc2, 0xb2, 0x24, 0 };
138     unsigned char data[8] = { 0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef };
139     unsigned char expected[8] = { 0xc3, 0x37, 0xcd, 0x5c, 0xbd, 0x44, 0xfc, 0x97 };
140     unsigned char output[16];
141     NTSTATUS r;
142 
143     r = pSystemFunction001(0,0,0);
144     ok( r == STATUS_UNSUCCESSFUL, "wrong error code\n");
145 
146     memset(output, 0, sizeof output);
147 
148     r = pSystemFunction001(data,key,output);
149     ok( r == STATUS_SUCCESS, "wrong error code\n");
150 
151     ok(!memcmp(output, expected, sizeof expected), "response wrong\n");
152 }
153 
154 static void test_SystemFunction002(void)
155 {
156     /* reverse of SystemFunction001 */
157     unsigned char key[8] = { 0xff, 0x37, 0x50, 0xbc, 0xc2, 0xb2, 0x24, 0 };
158     unsigned char expected[8] = { 0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef };
159     unsigned char data[8] = { 0xc3, 0x37, 0xcd, 0x5c, 0xbd, 0x44, 0xfc, 0x97 };
160     unsigned char output[8];
161     int r;
162 
163     memset(output, 0, sizeof output);
164     r = pSystemFunction002(data, key, output);
165     ok(r == STATUS_SUCCESS, "function failed\n");
166     ok(!memcmp(output, expected, sizeof expected), "response wrong\n");
167 }
168 
169 static void test_SystemFunction032(void)
170 {
171     struct ustring key, data;
172     unsigned char szKey[] = { 'f','o','o',0 };
173     unsigned char szData[8] = { 'b','a','r',0 };
174     unsigned char expected[] = {0x28, 0xb9, 0xf8, 0xe1};
175     int r;
176 
177     /* crashes:    pSystemFunction032(NULL,NULL); */
178 
179     key.Buffer = szKey;
180     key.Length = sizeof szKey;
181     key.MaximumLength = key.Length;
182 
183     data.Buffer = szData;
184     data.Length = 4;
185     data.MaximumLength = 8;
186 
187     r = pSystemFunction032(&data, &key);
188     ok(r == STATUS_SUCCESS, "function failed\n");
189 
190     ok(!memcmp(expected, data.Buffer, data.Length), "wrong result\n");
191 }
192 
193 static void test_SystemFunction003(void)
194 {
195     unsigned char output[8], data[8];
196     unsigned char key[7] = { 0xff, 0x37, 0x50, 0xbc, 0xc2, 0xb2, 0x24 };
197     unsigned char exp1[8] = { 0x9d, 0x21, 0xc8, 0x86, 0x6c, 0x21, 0xcf, 0x43 };
198     char exp2[] = "KGS!@#$%";
199     int r;
200 
201     r = pSystemFunction003(NULL, NULL);
202     ok(r == STATUS_UNSUCCESSFUL, "function failed\n");
203 
204     r = pSystemFunction003(key, NULL);
205     ok(r == STATUS_UNSUCCESSFUL, "function failed\n");
206 
207     memset(data, 0, sizeof data);
208     r = pSystemFunction003(key, data);
209     ok(r == STATUS_SUCCESS, "function failed\n");
210     ok( !memcmp(exp1, data, sizeof data), "decrypted message wrong\n");
211 
212     memset(output, 0, sizeof output);
213     r = pSystemFunction002(data, key, output);
214     ok(r == STATUS_SUCCESS, "function failed\n");
215 
216     ok( !memcmp(exp2, output, sizeof output), "decrypted message wrong\n");
217 }
218 
219 static void test_SystemFunction004(void)
220 {
221     unsigned char inbuf[0x100], keybuf[0x100], resbuf[0x100];
222     unsigned char output[8];
223     int r;
224     struct ustring in, key, out;
225 
226     /* crash
227     r = pSystemFunction004(NULL, NULL, NULL);
228     ok(r == STATUS_UNSUCCESSFUL, "function failed\n");
229     */
230 
231     memset(inbuf, 0, sizeof inbuf);
232     memset(keybuf, 0, sizeof keybuf);
233     memset(resbuf, 0, sizeof resbuf);
234 
235     in.Buffer = NULL;
236     in.Length = in.MaximumLength = 0;
237 
238     key.Buffer = NULL;
239     key.Length = key.MaximumLength = 0;
240 
241     out.Buffer = NULL;
242     out.Length = out.MaximumLength = 0;
243 
244     r = pSystemFunction004(&in, &key, &out);
245     ok(r == STATUS_INVALID_PARAMETER_2, "function failed\n");
246 
247     key.Buffer = keybuf;
248     key.Length = 0x100;
249     key.MaximumLength = 0x100;
250 
251     r = pSystemFunction004(&in, &key, &out);
252     ok(r == STATUS_BUFFER_TOO_SMALL, "function failed\n");
253 
254     in.Buffer = inbuf;
255     in.Length = 0x0c;
256     in.MaximumLength = 0;
257 
258     /* add two identical blocks... */
259     inbuf[0] = 1;
260     inbuf[1] = 2;
261     inbuf[2] = 3;
262     inbuf[3] = 4;
263 
264     inbuf[8] = 1;
265     inbuf[9] = 2;
266     inbuf[10] = 3;
267     inbuf[11] = 4;
268 
269     /* check that the Length field is really obeyed */
270     keybuf[6] = 1;
271 
272     key.Buffer = keybuf;
273     key.Length = 6;
274     key.MaximumLength = 0;
275 
276     keybuf[1] = 0x33;
277 
278     out.Buffer = resbuf;
279     out.Length = 0;
280     out.MaximumLength = 0x40;
281     r = pSystemFunction004(&in, &key, &out);
282     ok(r == STATUS_SUCCESS, "function failed\n");
283 
284     keybuf[6] = 0;
285 
286     memset(output, 0, sizeof output);
287     r = pSystemFunction002(out.Buffer, key.Buffer, output);
288     ok(r == STATUS_SUCCESS, "function failed\n");
289 
290     ok(((unsigned int*)output)[0] == in.Length, "crypted length wrong\n");
291     ok(((unsigned int*)output)[1] == 1, "crypted value wrong\n");
292 
293     memset(output, 0, sizeof output);
294     r = pSystemFunction002(out.Buffer+8, key.Buffer, output);
295     ok(r == STATUS_SUCCESS, "function failed\n");
296     ok(!memcmp(output, inbuf, sizeof output), "crypted data wrong\n");
297 
298     memset(output, 0, sizeof output);
299     r = pSystemFunction002(out.Buffer+16, key.Buffer, output);
300     ok(r == STATUS_SUCCESS, "function failed\n");
301     ok(!memcmp(output, inbuf, sizeof output), "crypted data wrong\n");
302 }
303 
304 static void test_SystemFunction005(void)
305 {
306     char output[0x40], result[0x40];
307     int r;
308     struct ustring in, key, out, res;
309     static char datastr[] = "twinkle twinkle little star";
310     static char keystr[]  = "byolnim";
311 
312     in.Buffer = (unsigned char *)datastr;
313     in.Length = strlen(datastr);
314     in.MaximumLength = 0;
315 
316     key.Buffer = (unsigned char *)keystr;
317     key.Length = strlen(keystr);
318     key.MaximumLength = 0;
319 
320     out.Buffer = (unsigned char *)output;
321     out.Length = out.MaximumLength = sizeof output;
322 
323     r = pSystemFunction004(&in, &key, &out);
324     ok(r == STATUS_SUCCESS, "function failed\n");
325 
326     memset(result, 0, sizeof result);
327     res.Buffer = (unsigned char *)result;
328     res.Length = 0;
329     res.MaximumLength = sizeof result;
330 
331     r = pSystemFunction005(&out, &key, &res);
332     ok(r == STATUS_SUCCESS, "function failed\n");
333 
334     r = pSystemFunction005(&out, &key, &res);
335     ok(r == STATUS_SUCCESS, "function failed\n");
336 
337     ok(res.Length == in.Length, "Length wrong\n");
338     ok(!memcmp(res.Buffer, in.Buffer, in.Length), "data wrong\n");
339 
340     out.Length = 0;
341     out.MaximumLength = 0;
342     r = pSystemFunction005(&out, &key, &res);
343     ok(r == STATUS_SUCCESS ||
344        r == STATUS_INVALID_PARAMETER_1, /* Vista */
345        "Expected STATUS_SUCCESS or STATUS_INVALID_PARAMETER_1, got %08x\n", r);
346 
347     ok(res.Length == in.Length, "Length wrong\n");
348     ok(!memcmp(res.Buffer, in.Buffer, in.Length), "data wrong\n");
349 
350     res.MaximumLength = 0;
351     r = pSystemFunction005(&out, &key, &res);
352     ok(r == STATUS_BUFFER_TOO_SMALL ||
353        r == STATUS_INVALID_PARAMETER_1, /* Vista */
354        "Expected STATUS_BUFFER_TOO_SMALL or STATUS_INVALID_PARAMETER_1, got %08x\n", r);
355 
356     key.Length = 1;
357     r = pSystemFunction005(&out, &key, &res);
358     ok(r == STATUS_UNKNOWN_REVISION ||
359        r == STATUS_INVALID_PARAMETER_1, /* Vista */
360        "Expected STATUS_UNKNOWN_REVISION or STATUS_INVALID_PARAMETER_1, got %08x\n", r);
361 
362     key.Length = 0;
363     r = pSystemFunction005(&out, &key, &res);
364     ok(r == STATUS_INVALID_PARAMETER_2, "function failed\n");
365 }
366 
367 static void test_SystemFunction009(void)
368 {
369     unsigned char hash[0x10] = {
370         0xff, 0x37, 0x50, 0xbc, 0xc2, 0xb2, 0x24, 0x12,
371         0xc2, 0x26, 0x5b, 0x23, 0x73, 0x4e, 0x0d, 0xac };
372     unsigned char challenge[8] = {
373         0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef };
374     unsigned char expected[0x18] = {
375         0xc3, 0x37, 0xcd, 0x5c, 0xbd, 0x44, 0xfc, 0x97,
376         0x82, 0xa6, 0x67, 0xaf, 0x6d, 0x42, 0x7c, 0x6d,
377         0xe6, 0x7c, 0x20, 0xc2, 0xd3, 0xe7, 0x7c, 0x56 };
378     unsigned char output[0x18];
379     int r;
380 
381     memset(output, 0, sizeof output);
382     r = pSystemFunction009(challenge, hash, output);
383     ok( r == STATUS_SUCCESS, "wrong error code\n");
384     ok(!memcmp(output, expected, sizeof expected), "response wrong\n");
385 }
386 
387 static unsigned char des_key[] = {
388     0xff, 0x37, 0x50, 0xbc, 0xc2, 0xb2, 0x24,
389     0xff, 0x37, 0x50, 0xbc, 0xc2, 0xb2, 0x24,
390 };
391 static unsigned char des_plaintext[] = {
392     0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef,
393     0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef, 0
394 };
395 static unsigned char des_ciphertext[] = {
396     0xc3, 0x37, 0xcd, 0x5c, 0xbd, 0x44, 0xfc, 0x97,
397     0xc3, 0x37, 0xcd, 0x5c, 0xbd, 0x44, 0xfc, 0x97, 0
398 };
399 
400 /* test functions that encrypt two DES blocks */
401 static void test_SystemFunction_encrypt(descrypt func, int num)
402 {
403     unsigned char output[0x11];
404     int r;
405 
406     if (!func)
407     {
408         win_skip("SystemFunction%03d is not available\n", num);
409         return;
410     }
411 
412     r = func(NULL, NULL, NULL);
413     ok( r == STATUS_UNSUCCESSFUL, "wrong error code\n");
414 
415     memset(output, 0, sizeof output);
416     r = func(des_plaintext, des_key, output);
417     ok( r == STATUS_SUCCESS, "wrong error code\n");
418     ok( !memcmp(des_ciphertext, output, sizeof des_ciphertext), "ciphertext wrong (%d)\n", num);
419 }
420 
421 /* test functions that decrypt two DES blocks */
422 static void test_SystemFunction_decrypt(descrypt func, int num)
423 {
424     unsigned char output[0x11];
425     int r;
426 
427     if (!func)
428     {
429         win_skip("SystemFunction%03d is not available\n", num);
430         return;
431     }
432 
433     r = func(NULL, NULL, NULL);
434     ok( r == STATUS_UNSUCCESSFUL, "wrong error code\n");
435 
436     memset(output, 0, sizeof output);
437 
438     r = func(des_ciphertext, des_key, output);
439     ok( r == STATUS_SUCCESS, "wrong error code\n");
440     ok( !memcmp(des_plaintext, output, sizeof des_plaintext), "plaintext wrong (%d)\n", num);
441 }
442 
443 static unsigned char des_ciphertext32[] = {
444     0x69, 0x51, 0x35, 0x69, 0x0d, 0x29, 0x24, 0xad,
445     0x23, 0x6d, 0xfd, 0x43, 0x0d, 0xd3, 0x25, 0x81, 0
446 };
447 
448 static void test_SystemFunction_enc32(descrypt func, int num)
449 {
450     unsigned char key[4], output[0x11];
451     int r;
452 
453     if (!func)
454     {
455         win_skip("SystemFunction%03d is not available\n", num);
456         return;
457     }
458 
459     memset(output, 0, sizeof output);
460 
461     /* two keys are generated using 4 bytes, repeated 4 times ... */
462     memcpy(key, "foo", 4);
463 
464     r = func(des_plaintext, key, output);
465     ok( r == STATUS_SUCCESS, "wrong error code (%d)\n", num);
466 
467     ok( !memcmp( output, des_ciphertext32, sizeof des_ciphertext32), "ciphertext wrong (%d)\n", num);
468 }
469 
470 static void test_SystemFunction_dec32(descrypt func, int num)
471 {
472     unsigned char key[4], output[0x11];
473     int r;
474 
475     if (!func)
476     {
477         win_skip("SystemFunction%03d is not available\n", num);
478         return;
479     }
480 
481     memset(output, 0, sizeof output);
482 
483     /* two keys are generated using 4 bytes, repeated 4 times ... */
484     memcpy(key, "foo", 4);
485 
486     r = func(des_ciphertext32, key, output);
487     ok( r == STATUS_SUCCESS, "wrong error code (%d)\n", num);
488 
489     ok( !memcmp( output, des_plaintext, sizeof des_plaintext), "plaintext wrong (%d)\n", num);
490 }
491 
492 static void test_memcmpfunc(memcmpfunc fn)
493 {
494     unsigned char arg1[0x20], arg2[0x20];
495     int r;
496 
497     if (!fn)
498     {
499         win_skip("function is not available\n");
500         return;
501     }
502 
503     memset(arg1, 0, sizeof arg1);
504     memset(arg2, 0, sizeof arg2);
505     arg1[0x10] = 1;
506 
507     r = fn(arg1, arg2);
508     ok( r == 1, "wrong error code\n");
509 
510     memset(arg1, 1, sizeof arg1);
511     memset(arg2, 1, sizeof arg2);
512     arg1[0x10] = 0;
513 
514     r = fn(arg1, arg2);
515     ok( r == 1, "wrong error code\n");
516 
517     memset(arg1, 0, sizeof arg1);
518     memset(arg2, 1, sizeof arg2);
519 
520     r = fn(arg1, arg2);
521     ok( r == 0, "wrong error code\n");
522 
523     memset(arg1, 1, sizeof arg1);
524     memset(arg2, 0, sizeof arg2);
525 
526     r = fn(arg1, arg2);
527     ok( r == 0, "wrong error code\n");
528 }
529 
530 START_TEST(crypt_lmhash)
531 {
532     HMODULE module = GetModuleHandleA("advapi32.dll");
533 
534     pSystemFunction001 = (void *)GetProcAddress( module, "SystemFunction001" );
535     if (pSystemFunction001)
536         test_SystemFunction001();
537     else
538         win_skip("SystemFunction001 is not available\n");
539 
540     pSystemFunction002 = (void *)GetProcAddress( module, "SystemFunction002" );
541     if (pSystemFunction002)
542         test_SystemFunction002();
543     else
544         win_skip("SystemFunction002 is not available\n");
545 
546     pSystemFunction003 = (void *)GetProcAddress( module, "SystemFunction003" );
547     if (pSystemFunction003)
548         test_SystemFunction003();
549     else
550         win_skip("SystemFunction002 is not available\n");
551 
552     pSystemFunction004 = (void *)GetProcAddress( module, "SystemFunction004" );
553     if (pSystemFunction004)
554         test_SystemFunction004();
555     else
556         win_skip("SystemFunction004 is not available\n");
557 
558     pSystemFunction005 = (void *)GetProcAddress( module, "SystemFunction005" );
559     if (pSystemFunction005)
560         test_SystemFunction005();
561     else
562         win_skip("SystemFunction005 is not available\n");
563 
564     pSystemFunction006 = (void *)GetProcAddress( module, "SystemFunction006" );
565     if (pSystemFunction006)
566         test_SystemFunction006();
567     else
568         win_skip("SystemFunction006 is not available\n");
569 
570     pSystemFunction008 = (void *)GetProcAddress( module, "SystemFunction008" );
571     if (pSystemFunction008)
572         test_SystemFunction008();
573     else
574         win_skip("SystemFunction008 is not available\n");
575 
576     pSystemFunction009 = (void *)GetProcAddress( module, "SystemFunction009" );
577     if (pSystemFunction009)
578         test_SystemFunction009();
579     else
580         win_skip("SystemFunction009 is not available\n");
581 
582     pSystemFunction012 = (descrypt) GetProcAddress( module, "SystemFunction012");
583     pSystemFunction013 = (descrypt) GetProcAddress( module, "SystemFunction013");
584     pSystemFunction014 = (descrypt) GetProcAddress( module, "SystemFunction014");
585     pSystemFunction015 = (descrypt) GetProcAddress( module, "SystemFunction015");
586     pSystemFunction016 = (descrypt) GetProcAddress( module, "SystemFunction016");
587     pSystemFunction017 = (descrypt) GetProcAddress( module, "SystemFunction017");
588     pSystemFunction018 = (descrypt) GetProcAddress( module, "SystemFunction018");
589     pSystemFunction019 = (descrypt) GetProcAddress( module, "SystemFunction019");
590     pSystemFunction020 = (descrypt) GetProcAddress( module, "SystemFunction020");
591     pSystemFunction021 = (descrypt) GetProcAddress( module, "SystemFunction021");
592     pSystemFunction022 = (descrypt) GetProcAddress( module, "SystemFunction022");
593     pSystemFunction023 = (descrypt) GetProcAddress( module, "SystemFunction023");
594 
595     /* these all encrypt two DES blocks */
596     test_SystemFunction_encrypt(pSystemFunction012, 12);
597     test_SystemFunction_encrypt(pSystemFunction014, 14);
598     test_SystemFunction_encrypt(pSystemFunction016, 16);
599     test_SystemFunction_encrypt(pSystemFunction018, 18);
600     test_SystemFunction_encrypt(pSystemFunction020, 20);
601     test_SystemFunction_encrypt(pSystemFunction022, 22);
602 
603     /* these all decrypt two DES blocks */
604     test_SystemFunction_decrypt(pSystemFunction013, 13);
605     test_SystemFunction_decrypt(pSystemFunction015, 15);
606     test_SystemFunction_decrypt(pSystemFunction017, 17);
607     test_SystemFunction_decrypt(pSystemFunction019, 19);
608     test_SystemFunction_decrypt(pSystemFunction021, 21);
609     test_SystemFunction_decrypt(pSystemFunction023, 23);
610 
611     pSystemFunction024 = (descrypt) GetProcAddress( module, "SystemFunction024");
612     pSystemFunction025 = (descrypt) GetProcAddress( module, "SystemFunction025");
613     pSystemFunction026 = (descrypt) GetProcAddress( module, "SystemFunction026");
614     pSystemFunction027 = (descrypt) GetProcAddress( module, "SystemFunction027");
615 
616     /* these encrypt two DES blocks with a short key */
617     test_SystemFunction_enc32(pSystemFunction024, 24);
618     test_SystemFunction_enc32(pSystemFunction026, 26);
619 
620     /* these descrypt two DES blocks with a short key */
621     test_SystemFunction_dec32(pSystemFunction025, 25);
622     test_SystemFunction_dec32(pSystemFunction027, 27);
623 
624     pSystemFunction030 = (memcmpfunc) GetProcAddress( module, "SystemFunction030" );
625     pSystemFunction031 = (memcmpfunc) GetProcAddress( module, "SystemFunction031" );
626 
627     test_memcmpfunc(pSystemFunction030);
628     test_memcmpfunc(pSystemFunction031);
629 
630     pSystemFunction032 = (void *)GetProcAddress( module, "SystemFunction032" );
631     if (pSystemFunction032)
632         test_SystemFunction032();
633     else
634         win_skip("SystemFunction032 is not available\n");
635 }
636