2014-01-25 03:08:06 +04:00
|
|
|
|
|
|
|
#include <winpr/crt.h>
|
|
|
|
#include <winpr/synch.h>
|
2014-01-25 07:44:23 +04:00
|
|
|
#include <winpr/sysinfo.h>
|
2014-01-25 03:08:06 +04:00
|
|
|
|
2014-01-25 07:44:23 +04:00
|
|
|
static int g_Count = 0;
|
|
|
|
static HANDLE g_Event = NULL;
|
|
|
|
|
|
|
|
struct apc_data
|
|
|
|
{
|
|
|
|
UINT32 StartTime;
|
|
|
|
};
|
|
|
|
typedef struct apc_data APC_DATA;
|
2014-01-25 03:08:06 +04:00
|
|
|
|
|
|
|
VOID CALLBACK TimerAPCProc(LPVOID lpArg, DWORD dwTimerLowValue, DWORD dwTimerHighValue)
|
|
|
|
{
|
2014-01-25 07:44:23 +04:00
|
|
|
APC_DATA* apcData;
|
|
|
|
UINT32 CurrentTime = GetTickCount();
|
2014-01-25 03:08:06 +04:00
|
|
|
|
|
|
|
if (!lpArg)
|
|
|
|
return;
|
|
|
|
|
2014-01-25 07:44:23 +04:00
|
|
|
apcData = (APC_DATA*) lpArg;
|
|
|
|
|
|
|
|
printf("TimerAPCProc: time: %d\n", CurrentTime - apcData->StartTime);
|
2014-01-25 03:08:06 +04:00
|
|
|
|
2014-01-25 07:44:23 +04:00
|
|
|
g_Count++;
|
2014-01-25 03:08:06 +04:00
|
|
|
|
2014-01-25 07:44:23 +04:00
|
|
|
if (g_Count >= 5)
|
|
|
|
{
|
|
|
|
SetEvent(g_Event);
|
|
|
|
}
|
2014-01-25 03:08:06 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
int TestSynchWaitableTimerAPC(int argc, char* argv[])
|
|
|
|
{
|
2014-11-17 01:10:33 +03:00
|
|
|
int status = -1;
|
|
|
|
HANDLE hTimer = NULL;
|
2014-01-25 03:08:06 +04:00
|
|
|
BOOL bSuccess;
|
2014-01-25 07:44:23 +04:00
|
|
|
LARGE_INTEGER due;
|
2014-11-17 01:10:33 +03:00
|
|
|
APC_DATA* apcData = NULL;
|
2014-01-25 03:08:06 +04:00
|
|
|
|
2014-01-25 07:44:23 +04:00
|
|
|
apcData = (APC_DATA*) malloc(sizeof(APC_DATA));
|
|
|
|
g_Event = CreateEvent(NULL, TRUE, FALSE, NULL);
|
2014-01-25 03:08:06 +04:00
|
|
|
hTimer = CreateWaitableTimer(NULL, FALSE, NULL);
|
|
|
|
|
|
|
|
if (!hTimer)
|
2014-11-17 01:10:33 +03:00
|
|
|
goto cleanup;
|
2014-01-25 03:08:06 +04:00
|
|
|
|
2014-01-25 07:44:23 +04:00
|
|
|
due.QuadPart = -15000000LL; /* 1.5 seconds */
|
2014-01-25 03:08:06 +04:00
|
|
|
|
2014-01-25 07:44:23 +04:00
|
|
|
apcData->StartTime = GetTickCount();
|
|
|
|
bSuccess = SetWaitableTimer(hTimer, &due, 2000, TimerAPCProc, apcData, FALSE);
|
2014-01-25 03:08:06 +04:00
|
|
|
|
|
|
|
if (!bSuccess)
|
2014-11-17 01:10:33 +03:00
|
|
|
goto cleanup;
|
2014-01-25 03:08:06 +04:00
|
|
|
|
2014-01-25 07:44:23 +04:00
|
|
|
if (WaitForSingleObject(g_Event, INFINITE) != WAIT_OBJECT_0)
|
2014-01-25 03:08:06 +04:00
|
|
|
{
|
|
|
|
printf("WaitForSingleObject failed (%d)\n", GetLastError());
|
2014-11-17 01:10:33 +03:00
|
|
|
goto cleanup;
|
2014-01-25 03:08:06 +04:00
|
|
|
}
|
|
|
|
|
2014-11-17 01:10:33 +03:00
|
|
|
status = 0;
|
|
|
|
|
|
|
|
cleanup:
|
2014-11-17 01:52:22 +03:00
|
|
|
if (hTimer)
|
2014-11-17 01:10:33 +03:00
|
|
|
CloseHandle(hTimer);
|
|
|
|
if (g_Event)
|
|
|
|
CloseHandle(g_Event);
|
|
|
|
if (apcData)
|
|
|
|
free(apcData);
|
2014-01-25 03:08:06 +04:00
|
|
|
|
2014-11-17 01:10:33 +03:00
|
|
|
return status;
|
2014-01-25 03:08:06 +04:00
|
|
|
}
|
|
|
|
|