mirror of
https://github.com/reactos/reactos.git
synced 2024-09-15 07:05:04 +00:00
f2cae03a42
- add KeEvent test (part 1/x) - add ExFastMutex test (part 1/2) svn path=/branches/GSoC_2011/KMTestSuite/; revision=53090
117 lines
4 KiB
C
117 lines
4 KiB
C
/*
|
|
* PROJECT: ReactOS kernel-mode tests
|
|
* LICENSE: GPLv2+ - See COPYING in the top level directory
|
|
* PURPOSE: Kernel-Mode Test Suite Event test
|
|
* PROGRAMMER: Thomas Faber <thfabba@gmx.de>
|
|
*/
|
|
|
|
#include <kmt_test.h>
|
|
|
|
/* TODO: thread testing, exports vs macros */
|
|
|
|
#define CheckEvent(Event, ExpectedType, State, ExpectedWaitNext, Irql) do \
|
|
{ \
|
|
ok_eq_uint((Event)->Header.Type, ExpectedType); \
|
|
ok_eq_uint((Event)->Header.Hand, sizeof *(Event) / sizeof(ULONG)); \
|
|
ok_eq_long((Event)->Header.Lock & 0xFF00FF00L, 0x55005500L); \
|
|
ok_eq_long((Event)->Header.SignalState, State); \
|
|
ok_eq_pointer((Event)->Header.WaitListHead.Flink, \
|
|
&(Event)->Header.WaitListHead); \
|
|
ok_eq_pointer((Event)->Header.WaitListHead.Blink, \
|
|
&(Event)->Header.WaitListHead); \
|
|
ok_eq_long(KeReadStateEvent(Event), State); \
|
|
ok_eq_bool(Thread->WaitNext, ExpectedWaitNext); \
|
|
ok_irql(Irql); \
|
|
} while (0)
|
|
|
|
static
|
|
VOID
|
|
TestEventFunctional(
|
|
IN PKEVENT Event,
|
|
IN EVENT_TYPE Type,
|
|
IN KIRQL OriginalIrql)
|
|
{
|
|
LONG State;
|
|
PKTHREAD Thread = KeGetCurrentThread();
|
|
|
|
memset(Event, 0x55, sizeof *Event);
|
|
KeInitializeEvent(Event, Type, FALSE);
|
|
CheckEvent(Event, Type, 0L, FALSE, OriginalIrql);
|
|
|
|
memset(Event, 0x55, sizeof *Event);
|
|
KeInitializeEvent(Event, Type, TRUE);
|
|
CheckEvent(Event, Type, 1L, FALSE, OriginalIrql);
|
|
|
|
Event->Header.SignalState = 0x12345678L;
|
|
CheckEvent(Event, Type, 0x12345678L, FALSE, OriginalIrql);
|
|
|
|
State = KePulseEvent(Event, 0, FALSE);
|
|
CheckEvent(Event, Type, 0L, FALSE, OriginalIrql);
|
|
ok_eq_long(State, 0x12345678L);
|
|
|
|
Event->Header.SignalState = 0x12345678L;
|
|
KeClearEvent(Event);
|
|
CheckEvent(Event, Type, 0L, FALSE, OriginalIrql);
|
|
|
|
State = KeSetEvent(Event, 0, FALSE);
|
|
CheckEvent(Event, Type, 1L, FALSE, OriginalIrql);
|
|
ok_eq_long(State, 0L);
|
|
|
|
State = KeResetEvent(Event);
|
|
CheckEvent(Event, Type, 0L, FALSE, OriginalIrql);
|
|
ok_eq_long(State, 1L);
|
|
|
|
Event->Header.SignalState = 0x23456789L;
|
|
State = KeSetEvent(Event, 0, FALSE);
|
|
CheckEvent(Event, Type, 1L, FALSE, OriginalIrql);
|
|
ok_eq_long(State, 0x23456789L);
|
|
|
|
Event->Header.SignalState = 0x3456789AL;
|
|
State = KeResetEvent(Event);
|
|
CheckEvent(Event, Type, 0L, FALSE, OriginalIrql);
|
|
ok_eq_long(State, 0x3456789AL);
|
|
|
|
if (OriginalIrql <= DISPATCH_LEVEL || !KmtIsCheckedBuild)
|
|
{
|
|
Event->Header.SignalState = 0x456789ABL;
|
|
State = KeSetEvent(Event, 0, TRUE);
|
|
CheckEvent(Event, Type, 1L, TRUE, DISPATCH_LEVEL);
|
|
ok_eq_long(State, 0x456789ABL);
|
|
ok_eq_uint(Thread->WaitIrql, OriginalIrql);
|
|
/* repair the "damage" */
|
|
Thread->WaitNext = FALSE;
|
|
KmtSetIrql(OriginalIrql);
|
|
|
|
Event->Header.SignalState = 0x56789ABCL;
|
|
State = KePulseEvent(Event, 0, TRUE);
|
|
CheckEvent(Event, Type, 0L, TRUE, DISPATCH_LEVEL);
|
|
ok_eq_long(State, 0x56789ABCL);
|
|
ok_eq_uint(Thread->WaitIrql, OriginalIrql);
|
|
/* repair the "damage" */
|
|
Thread->WaitNext = FALSE;
|
|
KmtSetIrql(OriginalIrql);
|
|
}
|
|
|
|
ok_irql(OriginalIrql);
|
|
KmtSetIrql(OriginalIrql);
|
|
}
|
|
|
|
START_TEST(KeEvent)
|
|
{
|
|
KEVENT Event;
|
|
KIRQL Irql;
|
|
KIRQL Irqls[] = { PASSIVE_LEVEL, APC_LEVEL, DISPATCH_LEVEL, HIGH_LEVEL };
|
|
int i;
|
|
|
|
for (i = 0; i < sizeof Irqls / sizeof Irqls[0]; ++i)
|
|
{
|
|
KeRaiseIrql(Irqls[i], &Irql);
|
|
TestEventFunctional(&Event, NotificationEvent, Irqls[i]);
|
|
TestEventFunctional(&Event, SynchronizationEvent, Irqls[i]);
|
|
KeLowerIrql(Irql);
|
|
}
|
|
|
|
ok_irql(PASSIVE_LEVEL);
|
|
KmtSetIrql(PASSIVE_LEVEL);
|
|
}
|