49#define CMD_STRING L"cmd /c "
61 SIZE_T NumberOfBytesWritten;
64 if (!StandardHandle)
return;
82 &NumberOfBytesWritten);
125 if (ImageMajorVersion > 3 ||
126 (ImageMajorVersion == 3 && ImageMinorVersion >= 10))
132 DPRINT1(
"Accepting image version %lu.%lu, although ReactOS is an NT %hu.%hu OS!\n",
159 DPRINT1(
"Egad! This is a ReactOS Compute Server and we should prevent you from using certain APIs...but we won't.");
163 DPRINT1(
"Gasp! This is a ReactOS Storage Server and we should prevent you from using certain APIs...but we won't.");
167 DPRINT1(
"Golly! This is a ReactOS Web Blade Server and we should prevent you from using certain APIs...but we won't.");
247 sizeof(
L"EmbdTrst.DLL"));
255 "ImageOkToRunOnEmbeddedNT");
331 NextEntry = NextEntry->
Flink;
386 &SaferiReplaceProcessThreadTokens,
431 if (Handles->Section)
438 if (Handles->ViewBase.QuadPart)
497 PWCHAR Remaining, DllPathString, ScanChar;
499 PVOID RemoteAppCompatData;
550 if (StartupInfo->lpDesktop)
558 if (StartupInfo->lpReserved)
566 if (StartupInfo->lpTitle)
580 if (!AppCompatData) AppCompatDataSize = 0;
583 ProcessParameters =
NULL;
587 DPRINT(
"CmdLine : '%wZ'\n", &CommandLine);
591 DPRINT(
"Runtime : '%wZ'\n", &Runtime);
623 ScanChar = lpEnvironment;
627 while (*ScanChar++)
while (*ScanChar++);
661 ProcessParameters->
StartingX = StartupInfo->dwX;
662 ProcessParameters->
StartingY = StartupInfo->dwY;
663 ProcessParameters->
CountX = StartupInfo->dwXSize;
664 ProcessParameters->
CountY = StartupInfo->dwYSize;
665 ProcessParameters->
CountCharsX = StartupInfo->dwXCountChars;
666 ProcessParameters->
CountCharsY = StartupInfo->dwYCountChars;
667 ProcessParameters->
FillAttribute = StartupInfo->dwFillAttribute;
668 ProcessParameters->
WindowFlags = StartupInfo->dwFlags;
672 if (StartupInfo->dwFlags &
699 if (!(StartupInfo->dwFlags &
703 if ((InheritHandles) ||
708 if ((InheritHandles) ||
713 if ((InheritHandles) ||
729 if (ParameterFlags & 1)
735 if (ParameterFlags & 2)
742 RemoteParameters =
NULL;
744 (
PVOID*)&RemoteParameters,
768 ProcessParameters->
Length,
774 &RemotePeb->ProcessParameters,
781 RemoteAppCompatData =
NULL;
785 Size = AppCompatDataSize;
787 &RemoteAppCompatData,
805 &RemotePeb->pShimData,
806 &RemoteAppCompatData,
815 &RemotePeb->ImageSubsystem,
817 sizeof(ImageSubsystem),
831 DPRINT1(
"Failure to create process parameters: %lx\n",
Status);
899 (
PVOID)&dwProcessAffinityMask,
900 sizeof(dwProcessAffinityMask));
927 sizeof(*ShutdownParametersRequest));
958 sizeof(*ShutdownParametersRequest));
1014 lpMinimumWorkingSetSize,
1015 lpMaximumWorkingSetSize,
1039 if ((dwMinimumWorkingSetSize) && (dwMaximumWorkingSetSize))
1053 sizeof(QuotaLimits));
1086 dwMinimumWorkingSetSize,
1087 dwMaximumWorkingSetSize,
1119 lpCreationTime->dwLowDateTime = Kut.
CreateTime.
u.LowPart;
1120 lpCreationTime->dwHighDateTime = Kut.
CreateTime.
u.HighPart;
1121 lpExitTime->dwLowDateTime = Kut.
ExitTime.
u.LowPart;
1122 lpExitTime->dwHighDateTime = Kut.
ExitTime.
u.HighPart;
1123 lpKernelTime->dwLowDateTime = Kut.
KernelTime.
u.LowPart;
1124 lpKernelTime->dwHighDateTime = Kut.
KernelTime.
u.HighPart;
1125 lpUserTime->dwLowDateTime = Kut.
UserTime.
u.LowPart;
1126 lpUserTime->dwHighDateTime = Kut.
UserTime.
u.HighPart;
1175 sizeof(ProcessBasic),
1206 sizeof(ProcessBasic),
1274 lpStartupInfo->lpReserved =
Params->ShellInfo.Buffer;
1275 lpStartupInfo->lpDesktop =
Params->DesktopInfo.Buffer;
1276 lpStartupInfo->lpTitle =
Params->WindowTitle.Buffer;
1277 lpStartupInfo->dwX =
Params->StartingX;
1278 lpStartupInfo->dwY =
Params->StartingY;
1279 lpStartupInfo->dwXSize =
Params->CountX;
1280 lpStartupInfo->dwYSize =
Params->CountY;
1281 lpStartupInfo->dwXCountChars =
Params->CountCharsX;
1282 lpStartupInfo->dwYCountChars =
Params->CountCharsY;
1283 lpStartupInfo->dwFillAttribute =
Params->FillAttribute;
1284 lpStartupInfo->dwFlags =
Params->WindowFlags;
1285 lpStartupInfo->wShowWindow = (
WORD)
Params->ShowWindowFlags;
1286 lpStartupInfo->cbReserved2 =
Params->RuntimeData.Length;
1287 lpStartupInfo->lpReserved2 = (
LPBYTE)
Params->RuntimeData.Buffer;
1292 STARTF_SHELLPRIVATE))
1295 lpStartupInfo->hStdInput =
Params->StandardInput;
1296 lpStartupInfo->hStdOutput =
Params->StandardOutput;
1297 lpStartupInfo->hStdError =
Params->StandardError;
1349 ExitProcessRequest->
uExitCode = uExitCode;
1353 sizeof(*ExitProcessRequest));
1515 sizeof(PriorityClass),
1549 switch (dwPriorityClass)
1654 sizeof(ProcessBasicInfo),
1682 sizeof(VersionData),
1767 IN BOOL bDisablePriorityBoost)
1809 *pdwHandleCount = phc;
1843 *Wow64Process = (
pbi != 0);
1882 (
PVOID)lpBaseAddress,
1888 if (lpNumberOfBytesRead) *lpNumberOfBytesRead =
nSize;
1919 Base = lpBaseAddress;
1951 if (lpNumberOfBytesWritten) *lpNumberOfBytesWritten =
nSize;
1989 if (lpNumberOfBytesWritten) *lpNumberOfBytesWritten =
nSize;
2054 &SessionInformation,
2055 sizeof(SessionInformation),
2063 *pSessionId = SessionInformation.
SessionId;
2074#define AddToHandle(x,y) ((x) = (HANDLE)((ULONG_PTR)(x) | (y)))
2075#define RemoveFromHandle(x,y) ((x) = (HANDLE)((ULONG_PTR)(x) & ~(y)))
2108 ULONG ParameterFlags, PrivilegeValue, HardErrorMode, ErrorResponse;
2110 BOOLEAN InJob, SaferNeeded, UseLargePages, HavePrivilege;
2111 BOOLEAN QuerySection, SkipSaferAndAppCompat;
2121 NTSTATUS Status, AppCompatStatus, SaferStatus, IFEOStatus, ImageDbgStatus;
2139 SIZE_T EnvironmentLength, CmdLineLength;
2144 BOOLEAN SearchRetry, QuotesNeeded, CmdLineIsAppName, HasQuotes;
2150#if _SXS_SUPPORT_ENABLED_
2158 PVOID CapturedStrings[3];
2162 PWCHAR SxsConglomeratedBuffer, StaticBuffer;
2163 ULONG ConglomeratedBufferSizeBytes, StaticBufferSize,
i;
2170 PWCHAR FilePart, PathBuffer, FreeBuffer;
2178 PVOID AppCompatSxsData, AppCompatData;
2179 ULONG AppCompatSxsDataSize, AppCompatDataSize;
2183 ULONG BinarySubType, VdmBinaryType, VdmTask, VdmReserve;
2193 QuerySection =
FALSE;
2195 SkipSaferAndAppCompat =
FALSE;
2202 SectionHandle =
NULL;
2204 ThreadHandle =
NULL;
2209 AppCompatData =
NULL;
2210 AppCompatDataSize = 0;
2211 AppCompatSxsData =
NULL;
2212 AppCompatSxsDataSize = 0;
2213 CaptureBuffer =
NULL;
2214#if _SXS_SUPPORT_ENABLED_
2215 SxsConglomeratedBuffer =
NULL;
2220 DebuggerCmdLine =
NULL;
2230 QuotedCmdLine =
NULL;
2240 VdmWaitObject =
NULL;
2241 UseVdmReserve =
FALSE;
2250#if _SXS_SUPPORT_ENABLED_
2256 RtlZeroMemory(&LocalProcessAttributes,
sizeof(LocalProcessAttributes));
2257 RtlZeroMemory(&LocalThreadAttributes,
sizeof(LocalThreadAttributes));
2260 RtlZeroMemory(lpProcessInformation,
sizeof(*lpProcessInformation));
2261 if (hNewToken) *hNewToken =
NULL;
2265 dwCreationFlags &= ~CREATE_NO_WINDOW;
2267#if _SXS_SUPPORT_ENABLED_
2269 SxsStaticBuffers[0] = &SxsWin32ManifestPath;
2270 SxsStaticBuffers[1] = &SxsWin32PolicyPath;
2271 SxsStaticBuffers[2] = &SxsWin32AssemblyDirectory;
2272 SxsStaticBuffers[3] = &SxsNtManifestPath;
2273 SxsStaticBuffers[4] = &SxsNtPolicyPath;
2274 ExePathPair.
Win32 = &SxsWin32ExePath;
2275 ExePathPair.
Nt = &SxsNtExePath;
2276 ManifestPathPair.
Win32 = &SxsWin32ManifestPath.
String;
2277 ManifestPathPair.
Nt = &SxsNtManifestPath.
String;
2278 PolicyPathPair.
Win32 = &SxsWin32PolicyPath.
String;
2279 PolicyPathPair.
Nt = &SxsNtPolicyPath.
String;
2282 DPRINT(
"CreateProcessInternalW: '%S' '%S' %lx\n", lpApplicationName, lpCommandLine, dwCreationFlags);
2292 DPRINT1(
"Invalid flag combo used\n");
2342 DPRINT1(
"Invalid WOW flags\n");
2358 dwCreationFlags = (dwCreationFlags &~ CREATE_SHARED_WOW_VDM) |
2367 while ((*pcScan) || (*(pcScan + 1))) ++pcScan;
2370 EnvironmentLength = (pcScan +
sizeof(
ANSI_NULL) - (
PCHAR)lpEnvironment);
2413 lpEnvironment = UnicodeEnv.
Buffer;
2417 StartupInfo = *lpStartupInfo;
2424 StartupInfo.
dwFlags &= ~STARTF_USESTDHANDLES;
2453 QuotesNeeded =
FALSE;
2454 CmdLineIsAppName =
FALSE;
2457 if (!lpApplicationName)
2474 lpApplicationName = NullBuffer = ScanString = lpCommandLine;
2477 if (*lpCommandLine ==
L'\"')
2480 SearchRetry =
FALSE;
2482 lpApplicationName = ScanString;
2486 if (*ScanString ==
L'\"')
2489 NullBuffer = ScanString;
2496 NullBuffer = ScanString;
2503 lpApplicationName = lpCommandLine;
2507 if ((*ScanString ==
L' ') || (*ScanString ==
L'\t'))
2510 NullBuffer = ScanString;
2516 NullBuffer = ScanString;
2521 SaveChar = *NullBuffer;
2567 DPRINT(
"Length: %lu Buffer: %S\n",
Length, NameBuffer);
2573 *NullBuffer = SaveChar;
2574 lpApplicationName = NameBuffer;
2618 *NullBuffer = SaveChar;
2619 lpApplicationName = NameBuffer;
2622 if (!(*ScanString) || !(SearchRetry))
2631 NullBuffer = ScanString;
2634 QuotesNeeded =
TRUE;
2639 else if (!(lpCommandLine) || !(*lpCommandLine))
2642 CmdLineIsAppName =
TRUE;
2643 lpCommandLine = (
LPWSTR)lpApplicationName;
2650 &SxsWin32RelativePath);
2651 if (!TranslationStatus)
2654 DPRINT1(
"Path translation for SxS failed\n");
2662 FreeBuffer = PathName.
Buffer;
2673 RtlInitEmptyUnicodeString(&PathBufferString,
NULL, 0);
2692 SxsWin32ExePath = PathBufferString;
2693 PathBuffer = PathBufferString.
Buffer;
2695 DPRINT(
"SxS Path: %S\n", PathBuffer);
2699#if _SXS_SUPPORT_ENABLED_
2700 SxsNtExePath = PathName;
2725 &LocalObjectAttributes,
2735 &LocalObjectAttributes,
2744 DPRINT1(
"Open file failed: %lx (%wZ)\n",
Status, &PathName);
2797 DPRINT1(
"Invalid Blade hashes!\n");
2807 DPRINT1(
"Tampered Blade hashes!\n");
2824 SectionHandle =
NULL;
2840 UseVdmReserve =
TRUE;
2844 SectionHandle =
NULL;
2847 QuerySection =
FALSE;
2852 if (!SkipSaferAndAppCompat)
2864 AppCompatData =
NULL;
2865 AppCompatSxsData =
NULL;
2882 sizeof(ImageInformation),
2890 QuerySection =
TRUE;
2891 ImageMachine = ImageInformation.
Machine;
2903 &AppCompatSxsDataSize,
2908 DPRINT1(
"App compat launch failure: %lx\n", AppCompatStatus);
2925 SectionHandle =
NULL;
2938 if (!(SkipSaferAndAppCompat) &&
2960 SaferNeeded =
FALSE;
2972 (
LPWSTR)lpApplicationName,
2977 if (SaferStatus == 0xFFFFFFFF)
2980 DPRINT1(
"WinSafer blocking process launch\n");
2989 DPRINT1(
"Error checking WinSafer: %lx\n", SaferStatus);
3014 DPRINT1(
"VDM environment for WOW app failed\n");
3022 VdmBinaryType = (dwCreationFlags &
3067 if (UseVdmReserve) VdmReserve = 1;
3077 DPRINT1(
"VDM Configuration failed for WOW\n");
3083 lpCommandLine = VdmString.
Buffer;
3084 lpApplicationName =
NULL;
3105 DPRINT1(
"VDM is not ready for WOW\n");
3118 if (VdmWaitObject)
goto VdmShortCircuit;
3121 bInheritHandles =
FALSE;
3124 if ((lpEnvironment) &&
3131 SkipSaferAndAppCompat =
TRUE;
3159 DPRINT1(
"VDM environment for DOS failed\n");
3195 DPRINT1(
"Detached process but no VDM, not allowed\n");
3208 DPRINT1(
"VDM Configuration failed for DOS\n");
3214 lpCommandLine = VdmString.
Buffer;
3215 lpApplicationName =
NULL;
3228 DPRINT1(
"VDM is not ready for DOS\n");
3241 if (VdmWaitObject)
goto VdmShortCircuit;
3244 bInheritHandles =
FALSE;
3247 if ((lpEnvironment) &&
3254 lpEnvironment = VdmUnicodeEnv.
Buffer;
3266 DPRINT1(
"'%wZ': Invalid EXE, and not a batch or script file\n", &PathName);
3273 CmdQuoteLength = CmdLineIsAppName || HasQuotes;
3274 if (!CmdLineIsAppName)
3276 if (HasQuotes) CmdQuoteLength++;
3284 CmdLineLength =
wcslen(lpCommandLine);
3286 CmdLineLength += CmdQuoteLength +
sizeof(
ANSI_NULL);
3287 CmdLineLength *=
sizeof(
WCHAR);
3293 if (!AnsiCmdCommand)
3302 if ((CmdLineIsAppName) || (HasQuotes))
3304 wcscat(AnsiCmdCommand,
L"\"");
3306 wcscat(AnsiCmdCommand, lpCommandLine);
3307 if ((CmdLineIsAppName) || (HasQuotes))
3309 wcscat(AnsiCmdCommand,
L"\"");
3316 lpCommandLine = DebuggerString.
Buffer;
3317 lpApplicationName =
NULL;
3318 DPRINT1(
"Retrying with: %S\n", lpCommandLine);
3322 SkipSaferAndAppCompat =
TRUE;
3329 DPRINT1(
"64-bit binary, failing\n");
3338 DPRINT1(
"File is offline, failing\n");
3364 dwCreationFlags &= ~CREATE_SEPARATE_WOW_VDM;
3374 sizeof(ImageInformation),
3379 DPRINT1(
"Section query failed\n");
3386 QuerySection =
TRUE;
3393 DPRINT1(
"Trying to launch a DLL, failing\n");
3400 Flags &= ~PROCESS_CREATE_FLAGS_LARGE_PAGES;
3403 ParameterFlags &= ~2;
3419 if (!DebuggerCmdLine)
3425 if (!DebuggerCmdLine)
3446 (ResultSize <
sizeof(
WCHAR)) ||
3450 RtlFreeHeap(RtlGetProcessHeap(), 0, DebuggerCmdLine);
3451 DebuggerCmdLine =
NULL;
3459 sizeof(UseLargePages),
3461 if ((
NT_SUCCESS(IFEOStatus)) && (UseLargePages))
3479 ErrorParameters[0] = (
ULONG_PTR)&PathName;
3498 DPRINT1(
"Invalid image architecture: %lx\n", ImageInformation.
Machine);
3509 SectionHandle =
NULL;
3510 QuerySection =
FALSE;
3529 DPRINT1(
"Subsystem command line failed\n");
3534 lpCommandLine = DebuggerString.
Buffer;
3535 lpApplicationName =
NULL;
3538 SkipSaferAndAppCompat =
TRUE;
3539 DPRINT1(
"Retrying with: %S\n", lpCommandLine);
3549 DPRINT1(
"Invalid subsystem version: %hu.%hu\n",
3557 if (DebuggerCmdLine)
3564 lpCommandLine = (
LPWSTR)lpApplicationName;
3601 if (!DebuggerString.
Buffer)
3609 RtlInitEmptyUnicodeString(&DebuggerString,
3623 DbgPrint(
"BASE: Calling debugger with '%wZ'\n", &DebuggerString);
3626 lpCommandLine = DebuggerString.
Buffer;
3627 lpApplicationName =
NULL;
3631 SectionHandle =
NULL;
3632 QuerySection =
FALSE;
3639 RtlFreeHeap(RtlGetProcessHeap(), 0, DebuggerCmdLine);
3640 DebuggerCmdLine =
NULL;
3641 DPRINT1(
"Retrying with: %S\n", lpCommandLine);
3647 lpProcessAttributes,
3653 LocalProcessAttributes = *lpProcessAttributes;
3656 &LocalProcessAttributes,
3674 DPRINT1(
"Failed to connect to DbgUI!\n");
3695 HavePrivilege =
FALSE;
3696 PrivilegeState =
NULL;
3705 HavePrivilege =
TRUE;
3746 RealTimePrivilegeState =
NULL;
3797 DPRINT1(
"Failed to update VDM with wait object\n");
3798 VdmWaitObject =
NULL;
3836 sizeof(ImageInformation),
3848 QuerySection =
TRUE;
3855 DPRINT(
"Image should receive SxS Fusion Isolation\n");
3862 if (lpCurrentDirectory)
3865 DPRINT(
"Current directory: %S\n", lpCurrentDirectory);
3897 DPRINT1(
"Current directory is invalid\n");
3905 if ((QuotesNeeded) || (CmdLineIsAppName))
3920 SaveChar = *NullBuffer;
3925 wcscat(QuotedCmdLine, lpCommandLine);
3931 *NullBuffer = SaveChar;
3932 wcscat(QuotedCmdLine, NullBuffer);
3938 if (QuotesNeeded) QuotesNeeded =
FALSE;
3939 if (CmdLineIsAppName) CmdLineIsAppName =
FALSE;
3944 if (CreateProcessMsg->
Sxs.
Flags & 1) ParameterFlags |= 1;
3947 if ((QuotesNeeded) || (CmdLineIsAppName)) lpCommandLine = QuotedCmdLine;
3958 dwCreationFlags | NoWindow,
3966 DPRINT1(
"BasePushProcessParameters failed\n");
3975 if (!(VdmBinaryType) &&
3976 !(bInheritHandles) &&
4045 LocalThreadAttributes = *lpThreadAttributes;
4048 &LocalThreadAttributes,
4078 DPRINT(
"TODO: WOW64 is not supported yet\n");
4086 switch (ImageInformation.
Machine)
4101 DbgPrint(
"kernel32: No mapping for ImageInformation.Machine == %04x\n",
4151 CreateProcessMsg->
VdmTask = VdmTask;
4153 else if (VdmReserve)
4163 DPRINT1(
"This is an SxS Message -- should not happen yet\n");
4175 sizeof(*CreateProcessMsg));
4181 CaptureBuffer =
NULL;
4188 DPRINT1(
"Failed to tell csrss about new process\n");
4250 lpProcessInformation->hProcess = VdmWaitObject;
4265 lpProcessInformation->hProcess = VdmWaitObject;
4278 lpProcessInformation->hThread = ThreadHandle;
4284 ThreadHandle =
NULL;
4288 if (DebuggerCmdLine)
RtlFreeHeap(RtlGetProcessHeap(), 0, DebuggerCmdLine);
4294 RtlInitEmptyUnicodeString(&SxsWin32ExePath,
NULL, 0);
4295 SxsWin32ExePath.
Length = 0;
4301#if _SXS_SUPPORT_ENABLED_
4310 if (SxsConglomeratedBuffer)
4313 for (
i = 0;
i < 5;
i++)
4316 ThisBuffer = SxsStaticBuffers[
i];
4321 if ((ThisBuffer != (
PVOID)-8) && (ByteBuffer->
Buffer))
4337 RtlInitEmptyUnicodeString(&ThisBuffer->
String,
4358 lpEnvironment =
NULL;
4362 RtlFreeHeap(RtlGetProcessHeap(), 0, QuotedCmdLine);
4369 if (SectionHandle)
NtClose(SectionHandle);
4383 if (JobHandle)
NtClose(JobHandle);
4425 if (VdmWaitObject)
NtClose(VdmWaitObject);
4445 BOOL bInheritHandles,
4446 DWORD dwCreationFlags,
4456 lpProcessAttributes,
4463 lpProcessInformation,
NTSTATUS NTAPI NtUnmapViewOfSection(IN HANDLE ProcessHandle, IN PVOID BaseAddress)
NTSTATUS NTAPI NtCreateSection(OUT PHANDLE SectionHandle, IN ACCESS_MASK DesiredAccess, IN POBJECT_ATTRIBUTES ObjectAttributes OPTIONAL, IN PLARGE_INTEGER MaximumSize OPTIONAL, IN ULONG SectionPageProtection OPTIONAL, IN ULONG AllocationAttributes, IN HANDLE FileHandle OPTIONAL)
static IN ULONG IN PWSTR OUT PCWSTR OUT PBOOLEAN OUT PATH_TYPE_AND_UNKNOWN * PathType
#define DECLSPEC_HOTPATCH
NTSTATUS WINAPI BasepCheckBadapp(IN HANDLE FileHandle, IN PWCHAR ApplicationName, IN PWCHAR Environment, IN USHORT ExeType, IN PVOID *SdbQueryAppCompatData, IN PULONG SdbQueryAppCompatDataSize, IN PVOID *SxsData, IN PULONG SxsDataSize, OUT PULONG FusionFlags)
VOID WINAPI BasepFreeAppCompatData(IN PVOID AppCompatData, IN PVOID AppCompatSxsData)
#define FILE_NON_DIRECTORY_FILE
WCHAR CurrentDirectory[1024]
@ BasepGetProcessShutdownParam
@ BasepSetProcessShutdownParam
#define BASESRV_SERVERDLL_INDEX
#define UlongToHandle(ul)
PVOID NTAPI RtlAllocateHeap(IN PVOID HeapHandle, IN ULONG Flags, IN SIZE_T Size)
BOOLEAN NTAPI RtlFreeHeap(IN PVOID HeapHandle, IN ULONG Flags, IN PVOID HeapBase)
@ ProcessBasicInformation
@ ProcessWow64Information
IN PUNICODE_STRING IN POBJECT_ATTRIBUTES ObjectAttributes
SIZE_T LPPROCESS_INFORMATION
#define CSR_CREATE_API_NUMBER(ServerId, ApiId)
#define STATUS_NOT_IMPLEMENTED
#define ERROR_NOT_ENOUGH_MEMORY
static CHAR Desktop[MAX_PATH]
#define NT_SUCCESS(StatCode)
NTSYSAPI NTSTATUS NTAPI RtlComputeImportTableHash(IN HANDLE FileHandle, OUT PCHAR Hash, IN ULONG ImportTableHashSize)
#define RTL_CONSTANT_STRING(s)
static const WCHAR Title[]
#define ReadProcessMemory(a, b, c, d, e)
#define ERROR_INVALID_PARAMETER
#define GetProcAddress(x, y)
#define INVALID_HANDLE_VALUE
@ ThreadQuerySetWin32StartAddress
#define GetCurrentProcess()
#define ERROR_INVALID_HANDLE
#define FILE_ATTRIBUTE_NORMAL
#define ERROR_ACCESS_DENIED
PBASE_STATIC_SERVER_DATA BaseStaticServerData
BOOLEAN BaseRunningInServerProcess
LONG WINAPI UnhandledExceptionFilter(IN PEXCEPTION_POINTERS ExceptionInfo)
BOOL NTAPI IsBadWritePtr(IN LPVOID lp, IN UINT_PTR ucb)
DWORD WINAPI GetFileAttributesW(LPCWSTR lpFileName)
LPWSTR WINAPI BaseComputeProcessDllPath(IN LPWSTR FullPath, IN PVOID Environment)
LPWSTR WINAPI BaseComputeProcessExePath(IN LPWSTR FullPath)
DWORD WINAPI SearchPathW(IN LPCWSTR lpPath OPTIONAL, IN LPCWSTR lpFileName, IN LPCWSTR lpExtension OPTIONAL, IN DWORD nBufferLength, OUT LPWSTR lpBuffer, OUT LPWSTR *lpFilePart OPTIONAL)
UINT WINAPI GetSystemDirectoryW(OUT LPWSTR lpBuffer, IN UINT uSize)
DWORD WINAPI GetFullPathNameW(IN LPCWSTR lpFileName, IN DWORD nBufferLength, OUT LPWSTR lpBuffer, OUT LPWSTR *lpFilePart)
BOOL NTAPI WriteProcessMemory(IN HANDLE hProcess, IN LPVOID lpBaseAddress, IN LPCVOID lpBuffer, IN SIZE_T nSize, OUT SIZE_T *lpNumberOfBytesWritten)
VOID WINAPI FatalAppExitA(UINT uAction, LPCSTR lpMessageText)
VOID WINAPI FatalExit(IN int ExitCode)
BOOLEAN WINAPI BasePushProcessParameters(IN ULONG ParameterFlags, IN HANDLE ProcessHandle, IN PPEB RemotePeb, IN LPCWSTR ApplicationPathName, IN LPWSTR lpCurrentDirectory, IN LPWSTR lpCommandLine, IN LPVOID lpEnvironment, IN LPSTARTUPINFOW StartupInfo, IN DWORD CreationFlags, IN BOOL InheritHandles, IN ULONG ImageSubsystem, IN PVOID AppCompatData, IN ULONG AppCompatDataSize)
NTSTATUS NTAPI BasepConfigureAppCertDlls(IN PWSTR ValueName, IN ULONG ValueType, IN PVOID ValueData, IN ULONG ValueLength, IN PVOID Context, IN PVOID EntryContext)
BOOL WINAPI CreateProcessInternalW(IN HANDLE hUserToken, IN LPCWSTR lpApplicationName, IN LPWSTR lpCommandLine, IN LPSECURITY_ATTRIBUTES lpProcessAttributes, IN LPSECURITY_ATTRIBUTES lpThreadAttributes, IN BOOL bInheritHandles, IN DWORD dwCreationFlags, IN LPVOID lpEnvironment, IN LPCWSTR lpCurrentDirectory, IN LPSTARTUPINFOW lpStartupInfo, IN LPPROCESS_INFORMATION lpProcessInformation, OUT PHANDLE hNewToken)
BOOL WINAPI FlushInstructionCache(IN HANDLE hProcess, IN LPCVOID lpBaseAddress, IN SIZE_T nSize)
BOOL WINAPI GetProcessWorkingSetSizeEx(IN HANDLE hProcess, OUT PSIZE_T lpMinimumWorkingSetSize, OUT PSIZE_T lpMaximumWorkingSetSize, OUT PDWORD Flags)
NTSTATUS WINAPI BasepCheckWebBladeHashes(IN HANDLE FileHandle)
PBASEP_APPCERT_EMBEDDED_FUNC fEmbeddedCertFunc
BOOL WINAPI DECLSPEC_HOTPATCH CreateProcessW(LPCWSTR lpApplicationName, LPWSTR lpCommandLine, LPSECURITY_ATTRIBUTES lpProcessAttributes, LPSECURITY_ATTRIBUTES lpThreadAttributes, BOOL bInheritHandles, DWORD dwCreationFlags, LPVOID lpEnvironment, LPCWSTR lpCurrentDirectory, LPSTARTUPINFOW lpStartupInfo, LPPROCESS_INFORMATION lpProcessInformation)
BOOL WINAPI GetExitCodeProcess(IN HANDLE hProcess, IN LPDWORD lpExitCode)
RTL_QUERY_REGISTRY_TABLE BasepAppCertTable[2]
UNICODE_STRING BasePathVariableName
VOID WINAPI ExitProcess(IN UINT uExitCode)
VOID WINAPI StuffStdHandle(IN HANDLE ProcessHandle, IN HANDLE StandardHandle, IN PHANDLE Address)
RTL_CRITICAL_SECTION gcsAppCert
BOOLEAN WINAPI BuildSubSysCommandLine(IN LPCWSTR SubsystemName, IN LPCWSTR ApplicationName, IN LPCWSTR CommandLine, OUT PUNICODE_STRING SubsysCommandLine)
DWORD WINAPI GetProcessVersion(IN DWORD ProcessId)
LIST_ENTRY BasepAppCertDllsList
UNICODE_STRING BaseUnicodeCommandLine
BOOLEAN g_AppCertInitialized
BOOL WINAPI TerminateProcess(IN HANDLE hProcess, IN UINT uExitCode)
NTSTATUS WINAPI BasepIsProcessAllowed(IN LPWSTR ApplicationName)
ANSI_STRING BaseAnsiCommandLine
#define AddToHandle(x, y)
HANDLE WINAPI OpenProcess(IN DWORD dwDesiredAccess, IN BOOL bInheritHandle, IN DWORD dwProcessId)
BOOL WINAPI GetProcessPriorityBoost(IN HANDLE hProcess, OUT PBOOL pDisablePriorityBoost)
BOOL WINAPI GetProcessTimes(IN HANDLE hProcess, IN LPFILETIME lpCreationTime, IN LPFILETIME lpExitTime, IN LPFILETIME lpKernelTime, IN LPFILETIME lpUserTime)
PLDR_DATA_TABLE_ENTRY BasepExeLdrEntry
BOOL WINAPI SetProcessWorkingSetSizeEx(IN HANDLE hProcess, IN SIZE_T dwMinimumWorkingSetSize, IN SIZE_T dwMaximumWorkingSetSize, IN DWORD Flags)
NTSTATUS WINAPI BasepReplaceProcessThreadTokens(IN HANDLE TokenHandle, IN HANDLE ProcessHandle, IN HANDLE ThreadHandle)
BOOL WINAPI SetProcessWorkingSetSize(IN HANDLE hProcess, IN SIZE_T dwMinimumWorkingSetSize, IN SIZE_T dwMaximumWorkingSetSize)
BOOL WINAPI GetProcessHandleCount(IN HANDLE hProcess, OUT PDWORD pdwHandleCount)
BOOL WINAPI SetProcessShutdownParameters(IN DWORD dwLevel, IN DWORD dwFlags)
BOOL WINAPI ProcessIdToSessionId(IN DWORD dwProcessId, OUT PDWORD pSessionId)
VOID WINAPI RegisterWaitForInputIdle(WaitForInputIdleType lpfnRegisterWaitForInputIdle)
DWORD WINAPI GetPriorityClass(IN HANDLE hProcess)
DECLSPEC_NORETURN VOID WINAPI BaseProcessStartup(_In_ PPROCESS_START_ROUTINE lpStartAddress)
BOOL WINAPI GetProcessIoCounters(IN HANDLE hProcess, OUT PIO_COUNTERS lpIoCounters)
VOID WINAPI FatalAppExitW(IN UINT uAction, IN LPCWSTR lpMessageText)
BOOL WINAPI SetProcessPriorityBoost(IN HANDLE hProcess, IN BOOL bDisablePriorityBoost)
VOID WINAPI InitCommandLines(VOID)
BOOL WINAPI GetProcessWorkingSetSize(IN HANDLE hProcess, OUT PSIZE_T lpMinimumWorkingSetSize, OUT PSIZE_T lpMaximumWorkingSetSize)
PSAFER_REPLACE_PROCESS_THREAD_TOKENS g_SaferReplaceProcessThreadTokens
BOOL WINAPI SetPriorityClass(IN HANDLE hProcess, IN DWORD dwPriorityClass)
VOID WINAPI GetStartupInfoW(IN LPSTARTUPINFOW lpStartupInfo)
BOOL WINAPI GetProcessShutdownParameters(OUT LPDWORD lpdwLevel, OUT LPDWORD lpdwFlags)
VOID WINAPI BasepSxsCloseHandles(IN PBASE_MSG_SXS_HANDLES Handles)
#define RemoveFromHandle(x, y)
BOOL WINAPI SetProcessAffinityMask(IN HANDLE hProcess, IN DWORD_PTR dwProcessAffinityMask)
BOOLEAN WINAPI BasepIsImageVersionOk(IN ULONG ImageMajorVersion, IN ULONG ImageMinorVersion)
NTSTATUS NTAPI BasepSaveAppCertRegistryValue(IN PLIST_ENTRY List, IN PWCHAR ComponentName, IN PWCHAR DllName)
BOOL WINAPI GetProcessAffinityMask(IN HANDLE hProcess, OUT PDWORD_PTR lpProcessAffinityMask, OUT PDWORD_PTR lpSystemAffinityMask)
VOID WINAPI ExitThread(IN DWORD uExitCode)
NTSTATUS WINAPI BaseCreateStack(_In_ HANDLE hProcess, _In_opt_ SIZE_T StackCommit, _In_opt_ SIZE_T StackReserve, _Out_ PINITIAL_TEB InitialTeb)
VOID WINAPI BaseInitializeContext(IN PCONTEXT Context, IN PVOID Parameter, IN PVOID StartAddress, IN PVOID StackAddress, IN ULONG ContextType)
POBJECT_ATTRIBUTES WINAPI BaseFormatObjectAttributes(OUT POBJECT_ATTRIBUTES ObjectAttributes, IN PSECURITY_ATTRIBUTES SecurityAttributes OPTIONAL, IN PUNICODE_STRING ObjectName)
NTSTATUS WINAPI BasepCheckWinSaferRestrictions(IN HANDLE UserToken, IN LPWSTR ApplicationName, IN HANDLE FileHandle, OUT PBOOLEAN InJob, OUT PHANDLE NewToken, OUT PHANDLE JobHandle)
PVOID WINAPI BasepIsRealtimeAllowed(IN BOOLEAN Keep)
ULONG WINAPI BaseIsDosApplication(IN PUNICODE_STRING PathName, IN NTSTATUS Status)
BOOL NTAPI BaseDestroyVDMEnvironment(IN PANSI_STRING AnsiEnv, IN PUNICODE_STRING UnicodeEnv)
BOOL WINAPI BaseGetVdmConfigInfo(IN LPCWSTR CommandLineReserved, IN ULONG DosSeqId, IN ULONG BinaryType, IN PUNICODE_STRING CmdLineString, OUT PULONG VdmSize)
BOOL WINAPI BaseCheckForVDM(IN HANDLE ProcessHandle, OUT LPDWORD ExitCode)
BOOL WINAPI BaseUpdateVDMEntry(IN ULONG UpdateIndex, IN OUT PHANDLE WaitHandle, IN ULONG IndexInfo, IN ULONG BinaryType)
BOOL NTAPI BaseCreateVDMEnvironment(IN PWCHAR lpEnvironment, OUT PANSI_STRING AnsiEnv, OUT PUNICODE_STRING UnicodeEnv)
NTSTATUS WINAPI BaseCheckVDM(IN ULONG BinaryType, IN PCWCH ApplicationName, IN PCWCH CommandLine, IN PCWCH CurrentDirectory, IN PANSI_STRING AnsiEnvironment, IN PBASE_API_MESSAGE ApiMessage, IN OUT PULONG iTask, IN DWORD CreationFlags, IN LPSTARTUPINFOW StartupInfo, IN HANDLE hUserToken OPTIONAL)
#define HANDLE_CREATE_NEW_CONSOLE
#define HANDLE_CREATE_NO_WINDOW
#define HANDLE_DETACHED_PROCESS
LPWSTR WINAPI GetCommandLineW(void)
LPSTR WINAPI GetCommandLineA(void)
#define DECLSPEC_ALIGN(x)
#define DECLSPEC_NORETURN
_ACRTIMP size_t __cdecl wcslen(const wchar_t *)
_ACRTIMP int __cdecl _wcsnicmp(const wchar_t *, const wchar_t *, size_t)
static int Hash(const char *)
#define IsListEmpty(ListHead)
NTSTATUS RtlAppendUnicodeToString(IN PUNICODE_STRING Str1, IN PWSTR Str2)
IN PLARGE_INTEGER IN PLARGE_INTEGER PEPROCESS ProcessId
_Must_inspect_result_ _In_opt_ PFLT_INSTANCE _Out_ PHANDLE FileHandle
#define STATUS_ACCESS_VIOLATION
#define FILE_SYNCHRONOUS_IO_NONALERT
_Must_inspect_result_ _In_ PLARGE_INTEGER _In_ PLARGE_INTEGER _In_ ULONG _In_ PFILE_OBJECT _In_ PVOID Process
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
NTSTATUS NTAPI NtRaiseHardError(IN NTSTATUS ErrorStatus, IN ULONG NumberOfParameters, IN ULONG UnicodeStringParameterMask, IN PULONG_PTR Parameters, IN ULONG ValidResponseOptions, OUT PULONG Response)
_In_ GUID _In_ PVOID ValueData
#define PROCESS_CREATE_FLAGS_BREAKAWAY
#define PROCESS_QUERY_INFORMATION
#define PROCESS_PRIORITY_CLASS_IDLE
#define PROCESS_CREATE_FLAGS_INHERIT_HANDLES
#define PROCESS_PRIORITY_CLASS_INVALID
#define PROCESS_PRIORITY_CLASS_NORMAL
#define PROCESS_PRIORITY_CLASS_HIGH
#define PROCESS_PRIORITY_CLASS_ABOVE_NORMAL
#define PROCESS_CREATE_FLAGS_LARGE_PAGES
#define PROCESS_PRIORITY_CLASS_BELOW_NORMAL
#define PROCESS_PRIORITY_CLASS_REALTIME
#define FLG_DISABLE_DEBUG_PROMPTS
#define PROCESS_CREATE_FLAGS_NO_DEBUG_INHERIT
NTSTATUS(NTAPI * PSAFER_REPLACE_PROCESS_THREAD_TOKENS)(IN HANDLE Token, IN HANDLE Process, IN HANDLE Thread)
DWORD(* WaitForInputIdleType)(HANDLE hProcess, DWORD dwMilliseconds)
NTSTATUS(NTAPI * PBASEP_APPCERT_EMBEDDED_FUNC)(IN LPWSTR ApplicationName)
DWORD(WINAPI * PPROCESS_START_ROUTINE)(VOID)
NTSTATUS NTAPI LdrQueryImageFileKeyOption(_In_ HANDLE KeyHandle, _In_ PCWSTR ValueName, _In_ ULONG Type, _Out_ PVOID Buffer, _In_ ULONG BufferSize, _Out_opt_ PULONG ReturnedLength)
NTSTATUS NTAPI LdrOpenImageFileOptionsKey(_In_ PUNICODE_STRING SubKey, _In_ BOOLEAN Wow64, _Out_ PHANDLE NewKeyHandle)
NTSTATUS NTAPI LdrUnloadDll(_In_ PVOID BaseAddress)
NTSTATUS NTAPI LdrGetProcedureAddress(_In_ PVOID BaseAddress, _In_opt_ _When_(Ordinal==0, _Notnull_) PANSI_STRING Name, _In_opt_ _When_(Name==NULL, _In_range_(>, 0)) ULONG Ordinal, _Out_ PVOID *ProcedureAddress)
_In_ BOOL _In_ HANDLE hProcess
PVOID PVOID PWCHAR PVOID USHORT PULONG PVOID PULONG PVOID PULONG PULONG FusionFlags
PVOID PVOID PWCHAR ApplicationName
#define SE_INC_BASE_PRIORITY_PRIVILEGE
#define SE_LOCK_MEMORY_PRIVILEGE
static const char const char * DllPath
static const char * ImageName
#define InitializeObjectAttributes(p, n, a, r, s)
_In_ NDIS_ERROR_CODE ErrorCode
_Must_inspect_result_ _Out_ PNDIS_STATUS _In_ NDIS_HANDLE _In_ ULONG _Out_ PNDIS_STRING _Out_ PNDIS_HANDLE KeyHandle
#define HARDERROR_OVERRIDE_ERRORMODE
#define PROCESSOR_ARCHITECTURE_IA64
#define PROCESSOR_ARCHITECTURE_UNKNOWN
#define PROCESSOR_ARCHITECTURE_AMD64
#define PROCESSOR_ARCHITECTURE_INTEL
_In_ HANDLE ProcessHandle
_In_ HANDLE _Outptr_result_bytebuffer_ ViewSize _Pre_valid_ PVOID * BaseAddress
__kernel_entry _Inout_ _Inout_ PSIZE_T RegionSize
@ SectionImageInformation
#define DUPLICATE_SAME_ATTRIBUTES
_In_ ACCESS_MASK _In_ ULONG _Out_ PHANDLE TokenHandle
NTSYSAPI NTSTATUS NTAPI RtlDestroyProcessParameters(_In_ PRTL_USER_PROCESS_PARAMETERS ProcessParameters)
NTSYSAPI NTSTATUS NTAPI RtlCreateProcessParameters(_Out_ PRTL_USER_PROCESS_PARAMETERS *ProcessParameters, _In_ PUNICODE_STRING ImagePathName, _In_opt_ PUNICODE_STRING DllPath, _In_opt_ PUNICODE_STRING CurrentDirectory, _In_opt_ PUNICODE_STRING CommandLine, _In_opt_ PWSTR Environment, _In_opt_ PUNICODE_STRING WindowTitle, _In_opt_ PUNICODE_STRING DesktopInfo, _In_opt_ PUNICODE_STRING ShellInfo, _In_opt_ PUNICODE_STRING RuntimeInfo)
NTSYSAPI ULONG NTAPI RtlIsDosDeviceName_U(_In_ PCWSTR Name)
NTSYSAPI NTSTATUS NTAPI RtlAcquirePrivilege(_In_ PULONG Privilege, _In_ ULONG NumPriv, _In_ ULONG Flags, _Out_ PVOID *ReturnedState)
_In_ PCWSTR _Inout_ _At_ QueryTable EntryContext
NTSTATUS NTAPI RtlGetFullPathName_UstrEx(_In_ PUNICODE_STRING FileName, _In_opt_ PUNICODE_STRING StaticString, _In_opt_ PUNICODE_STRING DynamicString, _Out_opt_ PUNICODE_STRING *StringUsed, _Out_opt_ PSIZE_T FilePartSize, _Out_opt_ PBOOLEAN NameInvalid, _Out_ RTL_PATH_TYPE *PathType, _Out_opt_ PSIZE_T LengthNeeded)
VOID NTAPI RtlReleaseRelativeName(_In_ PRTL_RELATIVE_NAME_U RelativeName)
NTSYSAPI VOID NTAPI RtlDestroyEnvironment(_In_ PWSTR Environment)
NTSYSAPI RTL_PATH_TYPE NTAPI RtlDetermineDosPathNameType_U(_In_ PCWSTR Path)
NTSYSAPI VOID NTAPI RtlReleasePrivilege(_In_ PVOID ReturnedState)
NTSYSAPI NTSTATUS NTAPI RtlEnterCriticalSection(_In_ PRTL_CRITICAL_SECTION CriticalSection)
NTSYSAPI NTSTATUS NTAPI RtlLeaveCriticalSection(_In_ PRTL_CRITICAL_SECTION CriticalSection)
DECLSPEC_NORETURN NTSYSAPI VOID NTAPI RtlRaiseStatus(_In_ NTSTATUS Status)
NTSYSAPI ULONG NTAPI DbgPrompt(_In_z_ PCCH Prompt, _Out_writes_bytes_(MaximumResponseLength) PCH Response, _In_ ULONG MaximumResponseLength)
NTSYSAPI BOOLEAN NTAPI RtlDosPathNameToRelativeNtPathName_U(_In_ PCWSTR DosName, _Out_ PUNICODE_STRING NtName, _Out_ PCWSTR *PartName, _Out_ PRTL_RELATIVE_NAME_U RelativeName)
#define RTL_USER_PROCESS_PARAMETERS_IMAGE_KEY_MISSING
#define RTL_USER_PROCESS_PARAMETERS_PROFILE_KERNEL
#define RTL_USER_PROCESS_PARAMETERS_PROFILE_SERVER
#define SEM_FAILCRITICALERRORS
#define RTL_USER_PROCESS_PARAMETERS_LOCAL_DLL_PATH
#define RTL_USER_PROCESS_PARAMETERS_PROFILE_USER
@ RtlPathTypeRootLocalDevice
@ RtlPathTypeDriveAbsolute
enum _RTL_PATH_TYPE RTL_PATH_TYPE
#define RTL_USER_PROCESS_PARAMETERS_DISABLE_HEAP_CHECKS
VOID WINAPI FreeString(_In_ LPWSTR pszString)
_In_ LPWSTR _In_ DWORD _In_ DWORD _In_ DWORD dwFlags
#define THREAD_ALL_ACCESS
NTSYSAPI NTSTATUS NTAPI NtOpenFile(OUT PHANDLE phFile, IN ACCESS_MASK DesiredAccess, IN POBJECT_ATTRIBUTES ObjectAttributes, OUT PIO_STATUS_BLOCK pIoStatusBlock, IN ULONG ShareMode, IN ULONG OpenMode)
#define RTL_REGISTRY_CONTROL
NTSYSAPI NTSTATUS NTAPI RtlUnicodeStringToAnsiString(PANSI_STRING DestinationString, PUNICODE_STRING SourceString, BOOLEAN AllocateDestinationString)
NTSYSAPI NTSTATUS NTAPI NtOpenKey(OUT PHANDLE KeyHandle, IN ACCESS_MASK DesiredAccess, IN POBJECT_ATTRIBUTES ObjectAttributes)
NTSYSAPI NTSTATUS NTAPI RtlAppendUnicodeStringToString(PUNICODE_STRING Destination, PUNICODE_STRING Source)
#define SECTION_ALL_ACCESS
#define FILE_READ_ATTRIBUTES
#define PROCESS_ALL_ACCESS
NTSYSAPI NTSTATUS NTAPI RtlAnsiStringToUnicodeString(PUNICODE_STRING DestinationString, PANSI_STRING SourceString, BOOLEAN AllocateDestinationString)
NTSYSAPI VOID NTAPI RtlInitUnicodeString(PUNICODE_STRING DestinationString, PCWSTR SourceString)
NTSTATUS NTAPI NtTerminateProcess(HANDLE ProcessHandle, LONG ExitStatus)
#define NtCurrentProcess()
#define FILE_SHARE_DELETE
NTSTATUS NTAPI NtClose(IN HANDLE Handle)
#define PAGE_EXECUTE_WRITECOPY
#define FILE_ATTRIBUTE_DIRECTORY
NTSYSAPI VOID NTAPI RtlFreeUnicodeString(PUNICODE_STRING UnicodeString)
NTSYSAPI NTSTATUS NTAPI NtCreateThread(OUT PHANDLE phThread, IN ACCESS_MASK AccessMask, IN POBJECT_ATTRIBUTES ObjectAttributes, IN HANDLE hProcess, OUT PCLIENT_ID pClientId, IN PCONTEXT pContext, OUT PSTACKINFO pStackInfo, IN BOOLEAN bSuspended)
NTSYSAPI VOID NTAPI RtlInitAnsiString(PANSI_STRING DestinationString, PCSZ SourceString)
#define PAGE_EXECUTE_READWRITE
#define UNICODE_STRING_MAX_CHARS
#define UNICODE_STRING_MAX_BYTES
#define VER_SUITE_DATACENTER
#define VER_SUITE_STORAGE_SERVER
#define VER_SUITE_COMPUTE_SERVER
#define VER_SUITE_PERSONAL
#define VER_SUITE_EMBEDDEDNT
_In_ ULONG _In_ ULONG _In_ ULONG Length
#define RTL_CONSTANT_OBJECT_ATTRIBUTES(n, a)
static OUT PIO_STATUS_BLOCK IoStatusBlock
static BOOL bInheritHandle
#define IMAGE_SUBSYSTEM_POSIX_CUI
#define IMAGE_SUBSYSTEM_WINDOWS_CUI
#define IMAGE_SUBSYSTEM_WINDOWS_GUI
#define IMAGE_DLLCHARACTERISTICS_NO_ISOLATION
#define IMAGE_FILE_MACHINE_AMD64
#define IMAGE_FILE_MACHINE_IA64
NTSTATUS NTAPI NtFreeVirtualMemory(IN HANDLE ProcessHandle, IN PVOID *UBaseAddress, IN PSIZE_T URegionSize, IN ULONG FreeType)
NTSTATUS NTAPI NtWriteVirtualMemory(IN HANDLE ProcessHandle, IN PVOID BaseAddress, IN PVOID Buffer, IN SIZE_T NumberOfBytesToWrite, OUT PSIZE_T NumberOfBytesWritten OPTIONAL)
NTSTATUS NTAPI NtProtectVirtualMemory(IN HANDLE ProcessHandle, IN OUT PVOID *UnsafeBaseAddress, IN OUT SIZE_T *UnsafeNumberOfBytesToProtect, IN ULONG NewAccessProtection, OUT PULONG UnsafeOldAccessProtection)
NTSTATUS NTAPI NtReadVirtualMemory(IN HANDLE ProcessHandle, IN PVOID BaseAddress, OUT PVOID Buffer, IN SIZE_T NumberOfBytesToRead, OUT PSIZE_T NumberOfBytesRead OPTIONAL)
NTSTATUS NTAPI NtAllocateVirtualMemory(IN HANDLE ProcessHandle, IN OUT PVOID *UBaseAddress, IN ULONG_PTR ZeroBits, IN OUT PSIZE_T URegionSize, IN ULONG AllocationType, IN ULONG Protect)
NTSTATUS NTAPI NtFlushInstructionCache(_In_ HANDLE ProcessHandle, _In_opt_ PVOID BaseAddress, _In_ SIZE_T FlushSize)
NTSTATUS NTAPI NtIsProcessInJob(IN HANDLE ProcessHandle, IN HANDLE JobHandle OPTIONAL)
NTSTATUS NTAPI NtAssignProcessToJobObject(HANDLE JobHandle, HANDLE ProcessHandle)
NTSTATUS NTAPI NtCreateProcessEx(OUT PHANDLE ProcessHandle, IN ACCESS_MASK DesiredAccess, IN POBJECT_ATTRIBUTES ObjectAttributes OPTIONAL, IN HANDLE ParentProcess, IN ULONG Flags, IN HANDLE SectionHandle OPTIONAL, IN HANDLE DebugPort OPTIONAL, IN HANDLE ExceptionPort OPTIONAL, IN BOOLEAN InJob)
NTSTATUS NTAPI NtOpenProcess(OUT PHANDLE ProcessHandle, IN ACCESS_MASK DesiredAccess, IN POBJECT_ATTRIBUTES ObjectAttributes, IN PCLIENT_ID ClientId)
NTSTATUS NTAPI NtSetInformationProcess(_In_ HANDLE ProcessHandle, _In_ PROCESSINFOCLASS ProcessInformationClass, _In_reads_bytes_(ProcessInformationLength) PVOID ProcessInformation, _In_ ULONG ProcessInformationLength)
NTSTATUS NTAPI NtSetInformationThread(_In_ HANDLE ThreadHandle, _In_ THREADINFOCLASS ThreadInformationClass, _In_reads_bytes_(ThreadInformationLength) PVOID ThreadInformation, _In_ ULONG ThreadInformationLength)
NTSTATUS NTAPI NtQueryInformationProcess(_In_ HANDLE ProcessHandle, _In_ PROCESSINFOCLASS ProcessInformationClass, _Out_writes_bytes_to_opt_(ProcessInformationLength, *ReturnLength) PVOID ProcessInformation, _In_ ULONG ProcessInformationLength, _Out_opt_ PULONG ReturnLength)
NTSTATUS NTAPI NtResumeThread(IN HANDLE ThreadHandle, OUT PULONG SuspendCount OPTIONAL)
#define STATUS_INVALID_IMAGE_WIN_64
#define STATUS_INVALID_IMAGE_WIN_16
#define STATUS_INVALID_IMAGE_NE_FORMAT
#define STATUS_IMAGE_MACHINE_TYPE_MISMATCH_EXE
#define STATUS_INVALID_IMAGE_FORMAT
#define STATUS_FATAL_APP_EXIT
#define STATUS_INVALID_IMAGE_NOT_MZ
#define STATUS_INVALID_IMAGE_PROTECT
#define STATUS_VDM_DISALLOWED
#define STATUS_ENTRYPOINT_NOT_FOUND
#define STATUS_FILE_IS_OFFLINE
#define STATUS_NAME_TOO_LONG
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)
#define IMAGE_FILE_MACHINE_I386
struct _STARTUPINFOW STARTUPINFOW
#define OBJ_CASE_INSENSITIVE
#define _SEH2_GetExceptionCode()
#define _SEH2_EXCEPT(...)
#define _SEH2_GetExceptionInformation()
#define _SEH2_YIELD(__stmt)
DWORD BaseSetLastNTError(IN NTSTATUS Status)
VOID NTAPI CsrFreeCaptureBuffer(_In_ _Frees_ptr_ PCSR_CAPTURE_BUFFER CaptureBuffer)
NTSTATUS NTAPI CsrClientCallServer(_Inout_ PCSR_API_MESSAGE ApiMessage, _Inout_opt_ PCSR_CAPTURE_BUFFER CaptureBuffer, _In_ CSR_API_NUMBER ApiNumber, _In_ ULONG DataLength)
#define IsConsoleHandle(h)
#define VDM_UNDO_COMPLETED
#define BINARY_TYPE_WOW_EX
#define BINARY_TYPE_SEPARATE_WOW
NTSTATUS NTAPI NtQuerySection(_In_ HANDLE SectionHandle, _In_ SECTION_INFORMATION_CLASS SectionInformationClass, _Out_ PVOID SectionInformation, _In_ SIZE_T SectionInformationLength, _Out_opt_ PSIZE_T ResultLength)
BASE_CREATE_PROCESS CreateProcessRequest
BASE_EXIT_PROCESS ExitProcessRequest
BASE_GETSET_PROCESS_SHUTDOWN_PARAMS ShutdownParametersRequest
union _BASE_API_MESSAGE::@3833 Data
BASE_CHECK_VDM CheckVDMRequest
HANDLE WaitObjectForParent
BASE_SXS_CREATEPROCESS_MSG Sxs
USHORT ProcessorArchitecture
BOOLEAN DefaultSeparateVDM
SYSTEM_BASIC_INFORMATION SysInfo
struct _LIST_ENTRY * Flink
PVOID ArbitraryUserPointer
BOOLEAN ReadImageFileExecOptions
PRTL_USER_PROCESS_PARAMETERS ProcessParameters
ULONG ImageSubsystemMajorVersion
SIZE_T MaximumWorkingSetSize
SIZE_T MinimumWorkingSetSize
UNICODE_STRING RelativeName
HANDLE ContainingDirectory
UNICODE_STRING DesktopInfo
LPVOID lpSecurityDescriptor
#define RtlCopyMemory(Destination, Source, Length)
#define RtlZeroMemory(Destination, Length)
#define CONTAINING_RECORD(address, type, field)
#define STATUS_ACCESS_DENIED
#define STATUS_INVALID_PARAMETER
#define STATUS_UNSUCCESSFUL
#define STATUS_OBJECT_NAME_NOT_FOUND
struct _LARGE_INTEGER::@2505 u
BOOL Privilege(LPTSTR pszPrivilege, BOOL bEnable)
#define INVALID_FILE_ATTRIBUTES
static int Shell(const char **args)
_Must_inspect_result_ _In_ WDFDEVICE _In_ ULONG _In_ ACCESS_MASK _In_opt_ PWDF_OBJECT_ATTRIBUTES KeyAttributes
_Must_inspect_result_ _In_ WDFDEVICE _In_ PWDF_DEVICE_PROPERTY_DATA _In_ DEVPROPTYPE _In_ ULONG Size
_Must_inspect_result_ _In_ WDFDEVICE _In_ LPCGUID _Out_ PINTERFACE _In_ USHORT _In_ USHORT Version
_In_ WDFIOTARGET _In_ _Strict_type_match_ WDF_IO_TARGET_SENT_IO_ACTION Action
_Must_inspect_result_ _In_ WDFKEY _In_ PCUNICODE_STRING _In_ ULONG _Out_opt_ PULONG _Out_opt_ PULONG ValueType
_Must_inspect_result_ _In_ WDFKEY _In_ PCUNICODE_STRING ValueName
_Must_inspect_result_ _In_ WDFKEY _In_ PCUNICODE_STRING _In_ ULONG ValueLength
_In_ WDFREQUEST _In_ NTSTATUS _In_ CCHAR PriorityBoost
_In_ WDFIOTARGET _In_ PWDF_REQUEST_COMPLETION_PARAMS Params
_Must_inspect_result_ _In_ WDFCMRESLIST List
WDF_EXTERN_C_START typedef _Must_inspect_result_ _In_opt_ PCUNICODE_STRING UnicodeString
#define NORMAL_PRIORITY_CLASS
#define STARTF_FORCEOFFFEEDBACK
DWORD WINAPI GetLastError(void)
HANDLE WINAPI GetCurrentThread(void)
#define REALTIME_PRIORITY_CLASS
#define BELOW_NORMAL_PRIORITY_CLASS
#define CREATE_UNICODE_ENVIRONMENT
#define HIGH_PRIORITY_CLASS
DWORD WINAPI GetCurrentProcessId(void)
#define CREATE_SHARED_WOW_VDM
#define CREATE_DEFAULT_ERROR_MODE
#define CREATE_SEPARATE_WOW_VDM
#define CREATE_NEW_PROCESS_GROUP
#define DEBUG_ONLY_THIS_PROCESS
#define STARTF_USESTDHANDLES
#define CREATE_PRESERVE_CODE_AUTHZ_LEVEL
#define IDLE_PRIORITY_CLASS
#define STARTF_FORCEONFEEDBACK
#define CREATE_NEW_CONSOLE
*nSize LPSTR _Inout_ LPDWORD nSize
#define ABOVE_NORMAL_PRIORITY_CLASS
_Inout_ PERBANDINFO * pbi
NTSYSAPI void WINAPI RtlReleasePebLock(void)
NTSYSAPI NTSTATUS WINAPI DbgUiConnectToDbg(void)
NTSYSAPI void WINAPI RtlAcquirePebLock(void)
NTSYSAPI void WINAPI DbgBreakPoint(void)
NTSYSAPI void WINAPI LdrShutdownProcess(void)
NTSYSAPI HANDLE WINAPI DbgUiGetThreadDebugObject(void)
NTSYSAPI NTSTATUS WINAPI RtlQueryRegistryValues(ULONG, PCWSTR, PRTL_QUERY_REGISTRY_TABLE, PVOID, PVOID)
@ ProcessSessionInformation
@ ProcessDefaultHardErrorMode
#define NtCurrentThread()
NTSYSAPI ULONG WINAPI RtlGetNtGlobalFlags(void)
#define ERROR_PATH_NOT_FOUND
#define ERROR_BAD_EXE_FORMAT
#define ERROR_CHILD_NOT_COMPLETE
#define ERROR_ACCESS_DISABLED_BY_POLICY
#define ERROR_EXE_MACHINE_TYPE_MISMATCH
#define ERROR_ACCESS_DISABLED_WEBBLADE_TAMPER
#define ERROR_ACCESS_DISABLED_WEBBLADE
#define ERROR_FILE_OFFLINE
_At_(*)(_In_ PWSK_CLIENT Client, _In_opt_ PUNICODE_STRING NodeName, _In_opt_ PUNICODE_STRING ServiceName, _In_opt_ ULONG NameSpace, _In_opt_ GUID *Provider, _In_opt_ PADDRINFOEXW Hints, _Outptr_ PADDRINFOEXW *Result, _In_opt_ PEPROCESS OwningProcess, _In_opt_ PETHREAD OwningThread, _Inout_ PIRP Irp Result)(Mem)) NTSTATUS(WSKAPI *PFN_WSK_GET_ADDRESS_INFO
_Must_inspect_result_ _In_ ULONG Flags
_Out_ PCLIENT_ID ClientId
#define DUPLICATE_SAME_ACCESS