dssenh: Only fill hash buffer when it's provided.
Wine-Bug: https://bugs.winehq.org/show_bug.cgi?id=30244
Signed-off-by: Rémi Bernon <rbernon@codeweavers.com>
Signed-off-by: Hans Leidekker <hans@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
(cherry picked from commit 9b19a110ea
)
Signed-off-by: Michael Stefaniuc <mstefani@winehq.org>
This commit is contained in:
parent
e83cd0e70f
commit
f9bca7ed42
|
@ -942,7 +942,7 @@ BOOL WINAPI CPGetHashParam( HCRYPTPROV hprov, HCRYPTHASH hhash, DWORD param, BYT
|
||||||
SetLastError( ERROR_MORE_DATA );
|
SetLastError( ERROR_MORE_DATA );
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
memcpy( data, hash->value, hash->len );
|
if (data) memcpy( data, hash->value, hash->len );
|
||||||
*len = hash->len;
|
*len = hash->len;
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
|
||||||
|
|
|
@ -472,9 +472,16 @@ static void test_hash(const struct hash_test *tests, int testLen)
|
||||||
ok(result && (hashLen == tests[i].hashLen), "Expected %d hash len, got %d.Error: %x\n",
|
ok(result && (hashLen == tests[i].hashLen), "Expected %d hash len, got %d.Error: %x\n",
|
||||||
tests[i].hashLen, hashLen, GetLastError());
|
tests[i].hashLen, hashLen, GetLastError());
|
||||||
|
|
||||||
|
dataLen = 0xdeadbeef;
|
||||||
|
result = CryptGetHashParam(hHash, HP_HASHVAL, 0, &dataLen, 0);
|
||||||
|
ok(result, "Expected hash value return.\n");
|
||||||
|
ok(dataLen == hashLen, "Expected hash length to match.\n");
|
||||||
|
|
||||||
|
hashLen = 0xdeadbeef;
|
||||||
result = CryptGetHashParam(hHash, HP_HASHVAL, hashValue, &hashLen, 0);
|
result = CryptGetHashParam(hHash, HP_HASHVAL, hashValue, &hashLen, 0);
|
||||||
ok(result, "Expected hash value return.\n");
|
ok(result, "Expected hash value return.\n");
|
||||||
|
|
||||||
|
ok(dataLen == hashLen, "Expected hash length to match.\n");
|
||||||
ok(!memcmp(hashValue, tests[i].hash, tests[i].hashLen), "Incorrect hash output.\n");
|
ok(!memcmp(hashValue, tests[i].hash, tests[i].hashLen), "Incorrect hash output.\n");
|
||||||
|
|
||||||
result = CryptHashData(hHash, data, dataLen, 0);
|
result = CryptHashData(hHash, data, dataLen, 0);
|
||||||
|
|
Loading…
Reference in New Issue