33 if (ConsoleRecord ==
NULL)
104 if (CurrentRecord->
SessionId == TaskId)
break;
200 if (!VdmAllowed)
return FALSE;
263 if (ServerEvent)
NtClose(ServerEvent);
390 if (CheckVdmRequest->
PifLen != 0)
617 sizeof(*CheckVdmRequest->
CmdLine))
621 sizeof(*CheckVdmRequest->
AppName))
625 sizeof(*CheckVdmRequest->
PifFile))
633 sizeof(*CheckVdmRequest->
Desktop))
637 sizeof(*CheckVdmRequest->
Title))
641 sizeof(*CheckVdmRequest->
Reserved)))
663 if (ConsoleRecord ==
NULL)
683 NewConsoleRecord =
TRUE;
686 if (!NewConsoleRecord)
698 if (DosRecord ==
NULL)
714 if (DosRecord ==
NULL)
742 if (!NewConsoleRecord)
759 if (NewConsoleRecord)
793 if (NewConsoleRecord)
798 ConsoleRecord =
NULL;
826 if (UpdateVdmEntryRequest->
iTask != 0)
907 DPRINT1(
"BaseSrvUpdateVDMEntry: VdmEntryUpdateControlCHandler not implemented!");
947 GetNextVdmCommandRequest->
CmdLen,
948 sizeof(*GetNextVdmCommandRequest->
CmdLine))
951 GetNextVdmCommandRequest->
AppLen,
952 sizeof(*GetNextVdmCommandRequest->
AppName))
955 GetNextVdmCommandRequest->
PifLen,
956 sizeof(*GetNextVdmCommandRequest->
PifFile))
962 (
PVOID*)&GetNextVdmCommandRequest->
Env,
963 GetNextVdmCommandRequest->
EnvLen,
964 sizeof(*GetNextVdmCommandRequest->
Env))
968 sizeof(*GetNextVdmCommandRequest->
Desktop))
972 sizeof(*GetNextVdmCommandRequest->
Title))
976 sizeof(*GetNextVdmCommandRequest->
Reserved))
1001 if (GetNextVdmCommandRequest->
iTask != 0)
1053 if (!(GetNextVdmCommandRequest->
VDMState
#define DUPLICATE_CLOSE_SOURCE
#define CsrGetClientThread()
IN PLARGE_INTEGER IN PLARGE_INTEGER PEPROCESS ProcessId
#define VDM_POLICY_KEY_NAME
NTSTATUS BaseSrvGetConsoleRecord(HANDLE ConsoleHandle, PVDM_CONSOLE_RECORD *Record)
#define OBJ_CASE_INSENSITIVE
_Must_inspect_result_ _Out_ PNDIS_STATUS _In_ NDIS_HANDLE _In_ ULONG _Out_ PNDIS_STRING _Out_ PNDIS_HANDLE KeyHandle
static VDM_COMMAND_INFO CommandInfo
IN BOOLEAN OUT PSTR Buffer
struct _VDM_DOS_RECORD * PVDM_DOS_RECORD
#define STATUS_INVALID_PARAMETER
FORCEINLINE VOID InsertHeadList(_Inout_ PLIST_ENTRY ListHead, _Inout_ __drv_aliasesMem PLIST_ENTRY Entry)
BOOLEAN NTAPI RtlFreeHeap(IN PVOID HeapHandle, IN ULONG Flags, IN PVOID HeapBase)
BOOLEAN NTAPI CsrValidateMessageBuffer(IN PCSR_API_MESSAGE ApiMessage, IN PVOID *Buffer, IN ULONG ElementCount, IN ULONG ElementSize)
BOOLEAN NTAPI CsrRevertToSelf(VOID)
NTSTATUS NTAPI NtCreateEvent(OUT PHANDLE EventHandle, IN ACCESS_MASK DesiredAccess, IN POBJECT_ATTRIBUTES ObjectAttributes OPTIONAL, IN EVENT_TYPE EventType, IN BOOLEAN InitialState)
NTSYSAPI NTSTATUS NTAPI RtlEnterCriticalSection(_In_ PRTL_CRITICAL_SECTION CriticalSection)
VOID BaseSrvFreeVDMInfo(PVDM_COMMAND_INFO CommandInfo)
#define InsertTailList(ListHead, Entry)
#define STATUS_VDM_DISALLOWED
_Must_inspect_result_ FORCEINLINE BOOLEAN IsListEmpty(_In_ const LIST_ENTRY *ListHead)
NTSTATUS NTAPI NtResetEvent(IN HANDLE EventHandle, OUT PLONG PreviousState OPTIONAL)
NTSTATUS BaseSrvFillCommandInfo(PVDM_COMMAND_INFO CommandInfo, PBASE_GET_NEXT_VDM_COMMAND Message)
#define RtlMoveMemory(Destination, Source, Length)
#define STATUS_BUFFER_TOO_SMALL
#define VDM_GET_ENVIRONMENT
FORCEINLINE BOOLEAN RemoveEntryList(_In_ PLIST_ENTRY Entry)
_In_ struct _KBUGCHECK_REASON_CALLBACK_RECORD * Record
return STATUS_NOT_IMPLEMENTED
#define DUPLICATE_SAME_ACCESS
NTSYSAPI NTSTATUS NTAPI RtlLeaveCriticalSection(_In_ PRTL_CRITICAL_SECTION CriticalSection)
RTL_CRITICAL_SECTION WowCriticalSection
NTSTATUS GetConsoleRecordBySessionId(ULONG TaskId, PVDM_CONSOLE_RECORD *Record)
HANDLE WaitObjectForParent
CRITICAL_SECTION CriticalSection
struct _BASE_API_MESSAGE * PBASE_API_MESSAGE
#define VDM_GET_FIRST_COMMAND
struct VDM_COMMAND_INFO * PVDM_COMMAND_INFO
#define VDM_DEC_REENTER_COUNT
_Must_inspect_result_ _In_ WDFDEVICE _In_ PCUNICODE_STRING KeyName
LIST_ENTRY VDMConsoleListHead
HANDLE WaitObjectForParent
PFLT_MESSAGE_WAITER_QUEUE CONTAINING_RECORD(Csq, DEVICE_EXTENSION, IrpQueue)) -> WaiterQ.mLock) _IRQL_raises_(DISPATCH_LEVEL) VOID NTAPI FltpAcquireMessageWaiterLock(_In_ PIO_CSQ Csq, _Out_ PKIRQL Irql)
#define VDM_FLAG_NESTED_TASK
#define NtCurrentProcess()
PVOID NTAPI RtlAllocateHeap(IN PVOID HeapHandle, IN ULONG Flags, IN SIZE_T Size)
BOOLEAN BaseSrvIsVdmAllowed(VOID)
VOID BaseInitializeVDM(VOID)
struct _LIST_ENTRY * Flink
LPSTARTUPINFOA StartupInfo
NTSYSAPI NTSTATUS NTAPI NtQueryValueKey(IN HANDLE KeyHandle, IN PUNICODE_STRING ValueName, IN KEY_VALUE_INFORMATION_CLASS KeyValueInformationClass, IN PVOID KeyValueInformation, IN ULONG Length, IN PULONG ResultLength)
PVDM_COMMAND_INFO CommandInfo
RTL_CRITICAL_SECTION DosCriticalSection
NTSTATUS NTAPI NtSetEvent(IN HANDLE EventHandle, OUT PLONG PreviousState OPTIONAL)
NTSYSAPI NTSTATUS NTAPI RtlInitializeCriticalSection(_In_ PRTL_CRITICAL_SECTION CriticalSection)
#define NT_SUCCESS(StatCode)
struct _KEY_VALUE_PARTIAL_INFORMATION * PKEY_VALUE_PARTIAL_INFORMATION
#define BINARY_TYPE_SEPARATE_WOW
VOID BaseSrvDestroyConsoleRecord(PVDM_CONSOLE_RECORD ConsoleRecord)
NTSTATUS NTAPI NtClose(IN HANDLE Handle)
_Must_inspect_result_ _In_ WDFKEY _In_ PCUNICODE_STRING ValueName
NTSYSAPI NTSTATUS NTAPI RtlOpenCurrentUser(_In_ ACCESS_MASK DesiredAccess, _Out_ PHANDLE KeyHandle)
static const WCHAR Cleanup[]
LPSTARTUPINFOA StartupInfo
ULONG GetNextDosSesId(VOID)
PVDM_CONSOLE_RECORD BaseSrvCreateConsoleRecord(VOID)
#define STATUS_BUFFER_OVERFLOW
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
struct _KEY_VALUE_PARTIAL_INFORMATION KEY_VALUE_PARTIAL_INFORMATION
#define InitializeListHead(ListHead)
#define DUPLICATE_SAME_ATTRIBUTES
NTSTATUS BaseSrvCreatePairWaitHandles(PHANDLE ServerEvent, PHANDLE ClientEvent)
NTSYSAPI NTSTATUS NTAPI NtOpenKey(OUT PHANDLE KeyHandle, IN ACCESS_MASK DesiredAccess, IN POBJECT_ATTRIBUTES ObjectAttributes)
#define VDM_DISALLOWED_VALUE_NAME
_Must_inspect_result_ _In_ PLARGE_INTEGER _In_ PLARGE_INTEGER _In_ ULONG _In_ PFILE_OBJECT _In_ PVOID Process
#define VDM_INC_REENTER_COUNT
NTSTATUS NTAPI NtDuplicateObject(IN HANDLE SourceProcessHandle, IN HANDLE SourceHandle, IN HANDLE TargetProcessHandle OPTIONAL, OUT PHANDLE TargetHandle OPTIONAL, IN ACCESS_MASK DesiredAccess, IN ULONG HandleAttributes, IN ULONG Options)
VOID BaseSrvCleanupVDMResources(IN PCSR_PROCESS CsrProcess)
#define VDM_FLAG_FIRST_TASK
NTSYSAPI VOID NTAPI RtlInitUnicodeString(PUNICODE_STRING DestinationString, PCWSTR SourceString)
BOOLEAN NTAPI CsrImpersonateClient(IN PCSR_THREAD CsrThread)
NTSYSAPI PVOID WINAPI RtlReAllocateHeap(HANDLE, ULONG, PVOID, SIZE_T)
#define InitializeObjectAttributes(p, n, a, r, s)
base of all file and directory entries
#define VDM_FLAG_DONT_WAIT
BOOLEAN BaseSrvCopyCommand(PBASE_CHECK_VDM CheckVdmRequest, PVDM_DOS_RECORD DosRecord)
_Must_inspect_result_ _In_ WDFDMAENABLER _In_ _In_opt_ PWDF_OBJECT_ATTRIBUTES Attributes
VOID BaseSrvDestroyPairWaitHandles(HANDLE ServerEvent, HANDLE ClientEvent)