[CRT] Massively improve performance of rand_s

Cache the pointer to RtlGenRandom instead of loading and unloading advapi32 every single time this function is called.
This commit is contained in:
Timo Kreuzer 2024-04-19 20:53:51 +03:00
parent 3c55252828
commit 1f49173f82

View file

@ -9,12 +9,14 @@
#include <precomp.h> #include <precomp.h>
typedef BOOLEAN (WINAPI *PFN_SystemFunction036)(PVOID, ULONG); // RtlGenRandom
PFN_SystemFunction036 g_pfnSystemFunction036 = NULL;
/********************************************************************* /*********************************************************************
* rand_s (MSVCRT.@) * rand_s (MSVCRT.@)
*/ */
int CDECL rand_s(unsigned int *pval) int CDECL rand_s(unsigned int *pval)
{ {
BOOLEAN (WINAPI *pSystemFunction036)(PVOID, ULONG); // RtlGenRandom
HINSTANCE hadvapi32; HINSTANCE hadvapi32;
if (!pval) if (!pval)
@ -25,32 +27,38 @@ int CDECL rand_s(unsigned int *pval)
} }
*pval = 0; *pval = 0;
hadvapi32 = LoadLibraryA("advapi32.dll");
if (!hadvapi32) if (g_pfnSystemFunction036 == NULL)
{
PFN_SystemFunction036 pSystemFunction036;
hadvapi32 = LoadLibraryA("advapi32.dll");
if (!hadvapi32)
{
_invalid_parameter(NULL,_CRT_WIDE("rand_s"),_CRT_WIDE(__FILE__),__LINE__, 0);
*_errno() = EINVAL;
return EINVAL;
}
pSystemFunction036 = (void*)GetProcAddress(hadvapi32, "SystemFunction036");
if (!pSystemFunction036)
{
_invalid_parameter(NULL,_CRT_WIDE("rand_s"),_CRT_WIDE(__FILE__),__LINE__, 0);
*_errno() = EINVAL;
FreeLibrary(hadvapi32);
return EINVAL;
}
g_pfnSystemFunction036 = pSystemFunction036;
}
if (!g_pfnSystemFunction036(pval, sizeof(*pval)))
{ {
_invalid_parameter(NULL,_CRT_WIDE("rand_s"),_CRT_WIDE(__FILE__),__LINE__, 0); _invalid_parameter(NULL,_CRT_WIDE("rand_s"),_CRT_WIDE(__FILE__),__LINE__, 0);
*_errno() = EINVAL; *_errno() = EINVAL;
return EINVAL; return EINVAL;
} }
pSystemFunction036 = (void*)GetProcAddress(hadvapi32, "SystemFunction036");
if (!pSystemFunction036)
{
_invalid_parameter(NULL,_CRT_WIDE("rand_s"),_CRT_WIDE(__FILE__),__LINE__, 0);
*_errno() = EINVAL;
FreeLibrary(hadvapi32);
return EINVAL;
}
if (!pSystemFunction036(pval, sizeof(*pval)))
{
_invalid_parameter(NULL,_CRT_WIDE("rand_s"),_CRT_WIDE(__FILE__),__LINE__, 0);
*_errno() = EINVAL;
FreeLibrary(hadvapi32);
return EINVAL;
}
FreeLibrary(hadvapi32);
return 0; return 0;
} }