mirror of
https://github.com/yuzu-emu/mbedtls.git
synced 2025-01-09 04:05:37 +00:00
Replace Windows API threading with CRT functions
This commit is contained in:
parent
5bcbd4e7f4
commit
7f244a5e36
|
@ -46,6 +46,7 @@
|
||||||
|
|
||||||
#include <windows.h>
|
#include <windows.h>
|
||||||
#include <winbase.h>
|
#include <winbase.h>
|
||||||
|
#include <process.h>
|
||||||
|
|
||||||
struct _hr_time
|
struct _hr_time
|
||||||
{
|
{
|
||||||
|
@ -261,18 +262,16 @@ unsigned long mbedtls_timing_get_timer( struct mbedtls_timing_hr_time *val, int
|
||||||
/* It's OK to use a global because alarm() is supposed to be global anyway */
|
/* It's OK to use a global because alarm() is supposed to be global anyway */
|
||||||
static DWORD alarmMs;
|
static DWORD alarmMs;
|
||||||
|
|
||||||
static DWORD WINAPI TimerProc( LPVOID TimerContext )
|
static void TimerProc( void *TimerContext )
|
||||||
{
|
{
|
||||||
((void) TimerContext);
|
(void)TimerContext;
|
||||||
Sleep( alarmMs );
|
Sleep( alarmMs );
|
||||||
mbedtls_timing_alarmed = 1;
|
mbedtls_timing_alarmed = 1;
|
||||||
return( TRUE );
|
// Implicit call of _endthread() is better (see MS online docs)
|
||||||
}
|
}
|
||||||
|
|
||||||
void mbedtls_set_alarm( int seconds )
|
void mbedtls_set_alarm( int seconds )
|
||||||
{
|
{
|
||||||
DWORD ThreadId;
|
|
||||||
|
|
||||||
if( seconds == 0 )
|
if( seconds == 0 )
|
||||||
{
|
{
|
||||||
/* No need to create a thread for this simple case.
|
/* No need to create a thread for this simple case.
|
||||||
|
@ -283,7 +282,7 @@ void mbedtls_set_alarm( int seconds )
|
||||||
|
|
||||||
mbedtls_timing_alarmed = 0;
|
mbedtls_timing_alarmed = 0;
|
||||||
alarmMs = seconds * 1000;
|
alarmMs = seconds * 1000;
|
||||||
CloseHandle( CreateThread( NULL, 0, TimerProc, NULL, 0, &ThreadId ) );
|
(void)_beginthread( TimerProc, 0, NULL );
|
||||||
}
|
}
|
||||||
|
|
||||||
#else /* _WIN32 && !EFIX64 && !EFI32 */
|
#else /* _WIN32 && !EFIX64 && !EFI32 */
|
||||||
|
|
Loading…
Reference in a new issue