Commit 64ae8285 authored by Mike McCormack's avatar Mike McCormack Committed by Alexandre Julliard

advapi32: Implement and test SystemFunction009.

parent 80c3a212
...@@ -603,7 +603,7 @@ ...@@ -603,7 +603,7 @@
@ stdcall SystemFunction006(ptr ptr) @ stdcall SystemFunction006(ptr ptr)
@ stdcall SystemFunction007(ptr ptr) @ stdcall SystemFunction007(ptr ptr)
@ stdcall SystemFunction008(ptr ptr ptr) @ stdcall SystemFunction008(ptr ptr ptr)
@ stub SystemFunction009 @ stdcall SystemFunction009(ptr ptr ptr)
@ stub SystemFunction010 @ stub SystemFunction010
@ stub SystemFunction011 @ stub SystemFunction011
@ stub SystemFunction012 @ stub SystemFunction012
......
...@@ -91,6 +91,16 @@ NTSTATUS WINAPI SystemFunction008(const LPBYTE challenge, const LPBYTE hash, LPB ...@@ -91,6 +91,16 @@ NTSTATUS WINAPI SystemFunction008(const LPBYTE challenge, const LPBYTE hash, LPB
} }
/****************************************************************************** /******************************************************************************
* SystemFunction009 [ADVAPI32.@]
*
* Seems to do the same as SystemFunction008 ...
*/
NTSTATUS WINAPI SystemFunction009(const LPBYTE challenge, const LPBYTE hash, LPBYTE response)
{
return SystemFunction008(challenge, hash, response);
}
/******************************************************************************
* SystemFunction001 [ADVAPI32.@] * SystemFunction001 [ADVAPI32.@]
* *
* Encrypts a single block of data using DES * Encrypts a single block of data using DES
......
...@@ -41,6 +41,7 @@ typedef NTSTATUS (WINAPI *fnSystemFunction004)(const struct ustring *, const str ...@@ -41,6 +41,7 @@ typedef NTSTATUS (WINAPI *fnSystemFunction004)(const struct ustring *, const str
typedef NTSTATUS (WINAPI *fnSystemFunction005)(const struct ustring *, const struct ustring *, struct ustring *); typedef NTSTATUS (WINAPI *fnSystemFunction005)(const struct ustring *, const struct ustring *, struct ustring *);
typedef VOID (WINAPI *fnSystemFunction006)( PCSTR passwd, PSTR lmhash ); typedef VOID (WINAPI *fnSystemFunction006)( PCSTR passwd, PSTR lmhash );
typedef NTSTATUS (WINAPI *fnSystemFunction008)(const LPBYTE, const LPBYTE, LPBYTE); typedef NTSTATUS (WINAPI *fnSystemFunction008)(const LPBYTE, const LPBYTE, LPBYTE);
typedef NTSTATUS (WINAPI *fnSystemFunction009)(const LPBYTE, const LPBYTE, LPBYTE);
typedef NTSTATUS (WINAPI *fnSystemFunction032)(struct ustring *, struct ustring *); typedef NTSTATUS (WINAPI *fnSystemFunction032)(struct ustring *, struct ustring *);
fnSystemFunction001 pSystemFunction001; fnSystemFunction001 pSystemFunction001;
...@@ -50,6 +51,7 @@ fnSystemFunction004 pSystemFunction004; ...@@ -50,6 +51,7 @@ fnSystemFunction004 pSystemFunction004;
fnSystemFunction004 pSystemFunction005; fnSystemFunction004 pSystemFunction005;
fnSystemFunction006 pSystemFunction006; fnSystemFunction006 pSystemFunction006;
fnSystemFunction008 pSystemFunction008; fnSystemFunction008 pSystemFunction008;
fnSystemFunction008 pSystemFunction009;
fnSystemFunction032 pSystemFunction032; fnSystemFunction032 pSystemFunction032;
static void test_SystemFunction006(void) static void test_SystemFunction006(void)
...@@ -333,6 +335,26 @@ static void test_SystemFunction005(void) ...@@ -333,6 +335,26 @@ static void test_SystemFunction005(void)
ok(r == STATUS_INVALID_PARAMETER_2, "function failed\n"); ok(r == STATUS_INVALID_PARAMETER_2, "function failed\n");
} }
static void test_SystemFunction009(void)
{
unsigned char hash[0x10] = {
0xff, 0x37, 0x50, 0xbc, 0xc2, 0xb2, 0x24, 0x12,
0xc2, 0x26, 0x5b, 0x23, 0x73, 0x4e, 0x0d, 0xac };
unsigned char challenge[8] = {
0x01, 0x23, 0x45, 0x67, 0x89, 0xab, 0xcd, 0xef };
unsigned char expected[0x18] = {
0xc3, 0x37, 0xcd, 0x5c, 0xbd, 0x44, 0xfc, 0x97,
0x82, 0xa6, 0x67, 0xaf, 0x6d, 0x42, 0x7c, 0x6d,
0xe6, 0x7c, 0x20, 0xc2, 0xd3, 0xe7, 0x7c, 0x56 };
unsigned char output[0x18];
int r;
memset(output, 0, sizeof output);
r = pSystemFunction009(challenge, hash, output);
ok( r == STATUS_SUCCESS, "wrong error code\n");
ok(!memcmp(output, expected, sizeof expected), "response wrong\n");
}
START_TEST(crypt_lmhash) START_TEST(crypt_lmhash)
{ {
HMODULE module; HMODULE module;
...@@ -367,6 +389,10 @@ START_TEST(crypt_lmhash) ...@@ -367,6 +389,10 @@ START_TEST(crypt_lmhash)
if (pSystemFunction008) if (pSystemFunction008)
test_SystemFunction008(); test_SystemFunction008();
pSystemFunction009 = (fnSystemFunction009)GetProcAddress( module, "SystemFunction009" );
if (pSystemFunction009)
test_SystemFunction009();
pSystemFunction032 = (fnSystemFunction032)GetProcAddress( module, "SystemFunction032" ); pSystemFunction032 = (fnSystemFunction032)GetProcAddress( module, "SystemFunction032" );
if (pSystemFunction032) if (pSystemFunction032)
test_SystemFunction032(); test_SystemFunction032();
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment