mirror of
https://github.com/reactos/reactos.git
synced 2024-12-29 10:35:28 +00:00
165 lines
3.8 KiB
C
165 lines
3.8 KiB
C
/*
|
|
* PROJECT: ReactOS Video Port Driver
|
|
* LICENSE: BSD - See COPYING.ARM in the top level directory
|
|
* FILE: win32ss/drivers/videoprt/event.c
|
|
* PURPOSE: Event Support Routines
|
|
* PROGRAMMERS: ReactOS Portable Systems Group
|
|
*/
|
|
|
|
/* INCLUDES *******************************************************************/
|
|
|
|
#include "videoprt.h"
|
|
#include "../../gdi/eng/engevent.h"
|
|
|
|
#define NDEBUG
|
|
#include <debug.h>
|
|
|
|
/* PUBLIC FUNCTIONS ***********************************************************/
|
|
|
|
/*
|
|
* @implemented
|
|
*/
|
|
VP_STATUS
|
|
NTAPI
|
|
VideoPortCreateEvent(
|
|
_In_ PVOID HwDeviceExtension,
|
|
_In_ ULONG EventFlag,
|
|
_In_ PVOID Unused,
|
|
_Out_ PEVENT* pEvent)
|
|
{
|
|
VP_STATUS Result = NO_ERROR;
|
|
PVIDEO_PORT_EVENT EngEvent;
|
|
|
|
/* Allocate memory for the event structure */
|
|
EngEvent = ExAllocatePoolWithTag(NonPagedPool,
|
|
sizeof(VIDEO_PORT_EVENT) + sizeof(KEVENT),
|
|
TAG_VIDEO_PORT);
|
|
if (EngEvent)
|
|
{
|
|
/* Zero flags */
|
|
EngEvent->fFlags = 0;
|
|
|
|
/* Set KEVENT pointer */
|
|
EngEvent->pKEvent = EngEvent + 1;
|
|
|
|
/* Initialize the kernel event */
|
|
KeInitializeEvent(EngEvent->pKEvent,
|
|
(EventFlag & EVENT_TYPE_MASK) ?
|
|
NotificationEvent : SynchronizationEvent,
|
|
EventFlag & INITIAL_EVENT_STATE_MASK);
|
|
|
|
/* Pass pointer to our structure to the caller */
|
|
*pEvent = (PEVENT)EngEvent;
|
|
DPRINT("VideoPortCreateEvent() created %p\n", EngEvent);
|
|
}
|
|
else
|
|
{
|
|
/* Out of memory */
|
|
DPRINT("VideoPortCreateEvent() failed\n");
|
|
Result = ERROR_NOT_ENOUGH_MEMORY;
|
|
}
|
|
|
|
/* Return result */
|
|
return Result;
|
|
}
|
|
|
|
/*
|
|
* @implemented
|
|
*/
|
|
VP_STATUS
|
|
NTAPI
|
|
VideoPortDeleteEvent(
|
|
_In_ PVOID HwDeviceExtension,
|
|
_In_ PEVENT Event)
|
|
{
|
|
/* Handle error cases */
|
|
if (!Event) return ERROR_INVALID_PARAMETER;
|
|
if (Event->fFlags & ENG_EVENT_USERMAPPED) return ERROR_INVALID_PARAMETER;
|
|
if (!Event->pKEvent) return ERROR_INVALID_PARAMETER;
|
|
|
|
/* Free storage */
|
|
ExFreePoolWithTag(Event, TAG_VIDEO_PORT);
|
|
|
|
/* Indicate success */
|
|
return NO_ERROR;
|
|
}
|
|
|
|
/*
|
|
* @implemented
|
|
*/
|
|
LONG
|
|
NTAPI
|
|
VideoPortSetEvent(
|
|
_In_ PVOID HwDeviceExtension,
|
|
_In_ PEVENT Event)
|
|
{
|
|
ASSERT(Event);
|
|
return KeSetEvent(Event->pKEvent, IO_NO_INCREMENT, FALSE);
|
|
}
|
|
|
|
/*
|
|
* @implemented
|
|
*/
|
|
VOID
|
|
NTAPI
|
|
VideoPortClearEvent(
|
|
_In_ PVOID HwDeviceExtension,
|
|
_In_ PEVENT Event)
|
|
{
|
|
ASSERT(Event);
|
|
KeClearEvent(Event->pKEvent);
|
|
}
|
|
|
|
/*
|
|
* @implemented
|
|
*/
|
|
LONG
|
|
NTAPI
|
|
VideoPortReadStateEvent(
|
|
_In_ PVOID HwDeviceExtension,
|
|
_In_ PEVENT Event)
|
|
{
|
|
ASSERT(Event);
|
|
return KeReadStateEvent(Event->pKEvent);
|
|
}
|
|
|
|
/*
|
|
* @implemented
|
|
*/
|
|
VP_STATUS
|
|
NTAPI
|
|
VideoPortWaitForSingleObject(
|
|
_In_ PVOID HwDeviceExtension,
|
|
_In_ PVOID Event,
|
|
_In_opt_ PLARGE_INTEGER Timeout)
|
|
{
|
|
PVIDEO_PORT_EVENT EngEvent = Event;
|
|
NTSTATUS Status;
|
|
|
|
/* Handle error cases */
|
|
if (!EngEvent) return ERROR_INVALID_PARAMETER;
|
|
if (!EngEvent->pKEvent) return ERROR_INVALID_PARAMETER;
|
|
if (EngEvent->fFlags & ENG_EVENT_USERMAPPED) return ERROR_INVALID_PARAMETER;
|
|
|
|
/* Do the actual wait */
|
|
Status = KeWaitForSingleObject(EngEvent->pKEvent,
|
|
Executive,
|
|
KernelMode,
|
|
FALSE,
|
|
Timeout);
|
|
if (Status == STATUS_TIMEOUT)
|
|
{
|
|
/* Convert to wait timeout, otherwise NT_SUCCESS would return NO_ERROR */
|
|
return WAIT_TIMEOUT;
|
|
}
|
|
else if (NT_SUCCESS(Status))
|
|
{
|
|
/* All other success codes are Win32 success */
|
|
return NO_ERROR;
|
|
}
|
|
|
|
/* Otherwise, return default Win32 failure */
|
|
return ERROR_INVALID_PARAMETER;
|
|
}
|
|
|
|
/* EOF */
|