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);
624 ScanChar = lpEnvironment;
628 while (*ScanChar++)
while (*ScanChar++);
662 ProcessParameters->
StartingX = StartupInfo->dwX;
663 ProcessParameters->
StartingY = StartupInfo->dwY;
664 ProcessParameters->
CountX = StartupInfo->dwXSize;
665 ProcessParameters->
CountY = StartupInfo->dwYSize;
666 ProcessParameters->
CountCharsX = StartupInfo->dwXCountChars;
667 ProcessParameters->
CountCharsY = StartupInfo->dwYCountChars;
668 ProcessParameters->
FillAttribute = StartupInfo->dwFillAttribute;
669 ProcessParameters->
WindowFlags = StartupInfo->dwFlags;
673 if (StartupInfo->dwFlags &
700 if (!(StartupInfo->dwFlags &
704 if ((InheritHandles) ||
709 if ((InheritHandles) ||
714 if ((InheritHandles) ||
730 if (ParameterFlags & 1)
736 if (ParameterFlags & 2)
743 RemoteParameters =
NULL;
745 (
PVOID*)&RemoteParameters,
769 ProcessParameters->
Length,
775 &RemotePeb->ProcessParameters,
782 RemoteAppCompatData =
NULL;
786 Size = AppCompatDataSize;
788 &RemoteAppCompatData,
806 &RemotePeb->pShimData,
807 &RemoteAppCompatData,
816 &RemotePeb->ImageSubsystem,
818 sizeof(ImageSubsystem),
832 DPRINT1(
"Failure to create process parameters: %lx\n",
Status);
900 (
PVOID)&dwProcessAffinityMask,
901 sizeof(dwProcessAffinityMask));
928 sizeof(*ShutdownParametersRequest));
959 sizeof(*ShutdownParametersRequest));
1015 lpMinimumWorkingSetSize,
1016 lpMaximumWorkingSetSize,
1040 if ((dwMinimumWorkingSetSize) && (dwMaximumWorkingSetSize))
1054 sizeof(QuotaLimits));
1087 dwMinimumWorkingSetSize,
1088 dwMaximumWorkingSetSize,
1120 lpCreationTime->dwLowDateTime = Kut.
CreateTime.
u.LowPart;
1121 lpCreationTime->dwHighDateTime = Kut.
CreateTime.
u.HighPart;
1122 lpExitTime->dwLowDateTime = Kut.
ExitTime.
u.LowPart;
1123 lpExitTime->dwHighDateTime = Kut.
ExitTime.
u.HighPart;
1124 lpKernelTime->dwLowDateTime = Kut.
KernelTime.
u.LowPart;
1125 lpKernelTime->dwHighDateTime = Kut.
KernelTime.
u.HighPart;
1126 lpUserTime->dwLowDateTime = Kut.
UserTime.
u.LowPart;
1127 lpUserTime->dwHighDateTime = Kut.
UserTime.
u.HighPart;
1176 sizeof(ProcessBasic),
1207 sizeof(ProcessBasic),
1275 lpStartupInfo->lpReserved =
Params->ShellInfo.Buffer;
1276 lpStartupInfo->lpDesktop =
Params->DesktopInfo.Buffer;
1277 lpStartupInfo->lpTitle =
Params->WindowTitle.Buffer;
1278 lpStartupInfo->dwX =
Params->StartingX;
1279 lpStartupInfo->dwY =
Params->StartingY;
1280 lpStartupInfo->dwXSize =
Params->CountX;
1281 lpStartupInfo->dwYSize =
Params->CountY;
1282 lpStartupInfo->dwXCountChars =
Params->CountCharsX;
1283 lpStartupInfo->dwYCountChars =
Params->CountCharsY;
1284 lpStartupInfo->dwFillAttribute =
Params->FillAttribute;
1285 lpStartupInfo->dwFlags =
Params->WindowFlags;
1286 lpStartupInfo->wShowWindow = (
WORD)
Params->ShowWindowFlags;
1287 lpStartupInfo->cbReserved2 =
Params->RuntimeData.Length;
1288 lpStartupInfo->lpReserved2 = (
LPBYTE)
Params->RuntimeData.Buffer;
1293 STARTF_SHELLPRIVATE))
1296 lpStartupInfo->hStdInput =
Params->StandardInput;
1297 lpStartupInfo->hStdOutput =
Params->StandardOutput;
1298 lpStartupInfo->hStdError =
Params->StandardError;
1350 ExitProcessRequest->
uExitCode = uExitCode;
1354 sizeof(*ExitProcessRequest));
1516 sizeof(PriorityClass),
1550 switch (dwPriorityClass)
1655 sizeof(ProcessBasicInfo),
1683 sizeof(VersionData),
1768 IN BOOL bDisablePriorityBoost)
1810 *pdwHandleCount = phc;
1844 *Wow64Process = (
pbi != 0);
1883 (
PVOID)lpBaseAddress,
1889 if (lpNumberOfBytesRead) *lpNumberOfBytesRead =
nSize;
1920 Base = lpBaseAddress;
1952 if (lpNumberOfBytesWritten) *lpNumberOfBytesWritten =
nSize;
1990 if (lpNumberOfBytesWritten) *lpNumberOfBytesWritten =
nSize;
2055 &SessionInformation,
2056 sizeof(SessionInformation),
2064 *pSessionId = SessionInformation.
SessionId;
2075#define AddToHandle(x,y) ((x) = (HANDLE)((ULONG_PTR)(x) | (y)))
2076#define RemoveFromHandle(x,y) ((x) = (HANDLE)((ULONG_PTR)(x) & ~(y)))
2109 ULONG ParameterFlags, PrivilegeValue, HardErrorMode, ErrorResponse;
2111 BOOLEAN InJob, SaferNeeded, UseLargePages, HavePrivilege;
2112 BOOLEAN QuerySection, SkipSaferAndAppCompat;
2122 NTSTATUS Status, AppCompatStatus, SaferStatus, IFEOStatus, ImageDbgStatus;
2140 SIZE_T EnvironmentLength, CmdLineLength;
2145 BOOLEAN SearchRetry, QuotesNeeded, CmdLineIsAppName, HasQuotes;
2151#if _SXS_SUPPORT_ENABLED_
2159 PVOID CapturedStrings[3];
2163 PWCHAR SxsConglomeratedBuffer, StaticBuffer;
2164 ULONG ConglomeratedBufferSizeBytes, StaticBufferSize,
i;
2171 PWCHAR FilePart, PathBuffer, FreeBuffer;
2179 PVOID AppCompatSxsData, AppCompatData;
2180 ULONG AppCompatSxsDataSize, AppCompatDataSize;
2184 ULONG BinarySubType, VdmBinaryType, VdmTask, VdmReserve;
2194 QuerySection =
FALSE;
2196 SkipSaferAndAppCompat =
FALSE;
2203 SectionHandle =
NULL;
2205 ThreadHandle =
NULL;
2210 AppCompatData =
NULL;
2211 AppCompatDataSize = 0;
2212 AppCompatSxsData =
NULL;
2213 AppCompatSxsDataSize = 0;
2214 CaptureBuffer =
NULL;
2215#if _SXS_SUPPORT_ENABLED_
2216 SxsConglomeratedBuffer =
NULL;
2221 DebuggerCmdLine =
NULL;
2231 QuotedCmdLine =
NULL;
2241 VdmWaitObject =
NULL;
2242 UseVdmReserve =
FALSE;
2251#if _SXS_SUPPORT_ENABLED_
2257 RtlZeroMemory(&LocalProcessAttributes,
sizeof(LocalProcessAttributes));
2258 RtlZeroMemory(&LocalThreadAttributes,
sizeof(LocalThreadAttributes));
2261 RtlZeroMemory(lpProcessInformation,
sizeof(*lpProcessInformation));
2262 if (hNewToken) *hNewToken =
NULL;
2266 dwCreationFlags &= ~CREATE_NO_WINDOW;
2268#if _SXS_SUPPORT_ENABLED_
2270 SxsStaticBuffers[0] = &SxsWin32ManifestPath;
2271 SxsStaticBuffers[1] = &SxsWin32PolicyPath;
2272 SxsStaticBuffers[2] = &SxsWin32AssemblyDirectory;
2273 SxsStaticBuffers[3] = &SxsNtManifestPath;
2274 SxsStaticBuffers[4] = &SxsNtPolicyPath;
2275 ExePathPair.
Win32 = &SxsWin32ExePath;
2276 ExePathPair.
Nt = &SxsNtExePath;
2277 ManifestPathPair.
Win32 = &SxsWin32ManifestPath.
String;
2278 ManifestPathPair.
Nt = &SxsNtManifestPath.
String;
2279 PolicyPathPair.
Win32 = &SxsWin32PolicyPath.
String;
2280 PolicyPathPair.
Nt = &SxsNtPolicyPath.
String;
2283 DPRINT(
"CreateProcessInternalW: '%S' '%S' %lx\n", lpApplicationName, lpCommandLine, dwCreationFlags);
2293 DPRINT1(
"Invalid flag combo used\n");
2343 DPRINT1(
"Invalid WOW flags\n");
2359 dwCreationFlags = (dwCreationFlags &~ CREATE_SHARED_WOW_VDM) |
2368 while ((*pcScan) || (*(pcScan + 1))) ++pcScan;
2371 EnvironmentLength = (pcScan +
sizeof(
ANSI_NULL) - (
PCHAR)lpEnvironment);
2414 lpEnvironment = UnicodeEnv.
Buffer;
2418 StartupInfo = *lpStartupInfo;
2425 StartupInfo.
dwFlags &= ~STARTF_USESTDHANDLES;
2454 QuotesNeeded =
FALSE;
2455 CmdLineIsAppName =
FALSE;
2458 if (!lpApplicationName)
2475 lpApplicationName = NullBuffer = ScanString = lpCommandLine;
2478 if (*lpCommandLine ==
L'\"')
2481 SearchRetry =
FALSE;
2483 lpApplicationName = ScanString;
2487 if (*ScanString ==
L'\"')
2490 NullBuffer = ScanString;
2497 NullBuffer = ScanString;
2504 lpApplicationName = lpCommandLine;
2508 if ((*ScanString ==
L' ') || (*ScanString ==
L'\t'))
2511 NullBuffer = ScanString;
2517 NullBuffer = ScanString;
2522 SaveChar = *NullBuffer;
2568 DPRINT(
"Length: %lu Buffer: %S\n",
Length, NameBuffer);
2574 *NullBuffer = SaveChar;
2575 lpApplicationName = NameBuffer;
2619 *NullBuffer = SaveChar;
2620 lpApplicationName = NameBuffer;
2623 if (!(*ScanString) || !(SearchRetry))
2632 NullBuffer = ScanString;
2635 QuotesNeeded =
TRUE;
2640 else if (!(lpCommandLine) || !(*lpCommandLine))
2643 CmdLineIsAppName =
TRUE;
2644 lpCommandLine = (
LPWSTR)lpApplicationName;
2651 &SxsWin32RelativePath);
2652 if (!TranslationStatus)
2655 DPRINT1(
"Path translation for SxS failed\n");
2663 FreeBuffer = PathName.
Buffer;
2674 RtlInitEmptyUnicodeString(&PathBufferString,
NULL, 0);
2693 SxsWin32ExePath = PathBufferString;
2694 PathBuffer = PathBufferString.
Buffer;
2696 DPRINT(
"SxS Path: %S\n", PathBuffer);
2700#if _SXS_SUPPORT_ENABLED_
2701 SxsNtExePath = PathName;
2726 &LocalObjectAttributes,
2736 &LocalObjectAttributes,
2745 DPRINT1(
"Open file failed: %lx (%wZ)\n",
Status, &PathName);
2798 DPRINT1(
"Invalid Blade hashes!\n");
2808 DPRINT1(
"Tampered Blade hashes!\n");
2825 SectionHandle =
NULL;
2841 UseVdmReserve =
TRUE;
2845 SectionHandle =
NULL;
2848 QuerySection =
FALSE;
2853 if (!SkipSaferAndAppCompat)
2865 AppCompatData =
NULL;
2866 AppCompatSxsData =
NULL;
2883 sizeof(ImageInformation),
2891 QuerySection =
TRUE;
2892 ImageMachine = ImageInformation.
Machine;
2904 &AppCompatSxsDataSize,
2909 DPRINT1(
"App compat launch failure: %lx\n", AppCompatStatus);
2926 SectionHandle =
NULL;
2939 if (!(SkipSaferAndAppCompat) &&
2961 SaferNeeded =
FALSE;
2973 (
LPWSTR)lpApplicationName,
2978 if (SaferStatus == 0xFFFFFFFF)
2981 DPRINT1(
"WinSafer blocking process launch\n");
2990 DPRINT1(
"Error checking WinSafer: %lx\n", SaferStatus);
3015 DPRINT1(
"VDM environment for WOW app failed\n");
3023 VdmBinaryType = (dwCreationFlags &
3068 if (UseVdmReserve) VdmReserve = 1;
3078 DPRINT1(
"VDM Configuration failed for WOW\n");
3084 lpCommandLine = VdmString.
Buffer;
3085 lpApplicationName =
NULL;
3106 DPRINT1(
"VDM is not ready for WOW\n");
3119 if (VdmWaitObject)
goto VdmShortCircuit;
3122 bInheritHandles =
FALSE;
3125 if ((lpEnvironment) &&
3132 SkipSaferAndAppCompat =
TRUE;
3160 DPRINT1(
"VDM environment for DOS failed\n");
3196 DPRINT1(
"Detached process but no VDM, not allowed\n");
3209 DPRINT1(
"VDM Configuration failed for DOS\n");
3215 lpCommandLine = VdmString.
Buffer;
3216 lpApplicationName =
NULL;
3229 DPRINT1(
"VDM is not ready for DOS\n");
3242 if (VdmWaitObject)
goto VdmShortCircuit;
3245 bInheritHandles =
FALSE;
3248 if ((lpEnvironment) &&
3255 lpEnvironment = VdmUnicodeEnv.
Buffer;
3267 DPRINT1(
"'%wZ': Invalid EXE, and not a batch or script file\n", &PathName);
3274 CmdQuoteLength = CmdLineIsAppName || HasQuotes;
3275 if (!CmdLineIsAppName)
3277 if (HasQuotes) CmdQuoteLength++;
3285 CmdLineLength =
wcslen(lpCommandLine);
3287 CmdLineLength += CmdQuoteLength +
sizeof(
ANSI_NULL);
3288 CmdLineLength *=
sizeof(
WCHAR);
3294 if (!AnsiCmdCommand)
3303 if ((CmdLineIsAppName) || (HasQuotes))
3305 wcscat(AnsiCmdCommand,
L"\"");
3307 wcscat(AnsiCmdCommand, lpCommandLine);
3308 if ((CmdLineIsAppName) || (HasQuotes))
3310 wcscat(AnsiCmdCommand,
L"\"");
3317 lpCommandLine = DebuggerString.
Buffer;
3318 lpApplicationName =
NULL;
3319 DPRINT1(
"Retrying with: %S\n", lpCommandLine);
3323 SkipSaferAndAppCompat =
TRUE;
3330 DPRINT1(
"64-bit binary, failing\n");
3339 DPRINT1(
"File is offline, failing\n");
3365 dwCreationFlags &= ~CREATE_SEPARATE_WOW_VDM;
3375 sizeof(ImageInformation),
3380 DPRINT1(
"Section query failed\n");
3387 QuerySection =
TRUE;
3394 DPRINT1(
"Trying to launch a DLL, failing\n");
3401 Flags &= ~PROCESS_CREATE_FLAGS_LARGE_PAGES;
3404 ParameterFlags &= ~2;
3420 if (!DebuggerCmdLine)
3426 if (!DebuggerCmdLine)
3447 (ResultSize <
sizeof(
WCHAR)) ||
3451 RtlFreeHeap(RtlGetProcessHeap(), 0, DebuggerCmdLine);
3452 DebuggerCmdLine =
NULL;
3460 sizeof(UseLargePages),
3462 if ((
NT_SUCCESS(IFEOStatus)) && (UseLargePages))
3480 ErrorParameters[0] = (
ULONG_PTR)&PathName;
3499 DPRINT1(
"Invalid image architecture: %lx\n", ImageInformation.
Machine);
3510 SectionHandle =
NULL;
3511 QuerySection =
FALSE;
3530 DPRINT1(
"Subsystem command line failed\n");
3535 lpCommandLine = DebuggerString.
Buffer;
3536 lpApplicationName =
NULL;
3539 SkipSaferAndAppCompat =
TRUE;
3540 DPRINT1(
"Retrying with: %S\n", lpCommandLine);
3550 DPRINT1(
"Invalid subsystem version: %hu.%hu\n",
3558 if (DebuggerCmdLine)
3565 lpCommandLine = (
LPWSTR)lpApplicationName;
3602 if (!DebuggerString.
Buffer)
3610 RtlInitEmptyUnicodeString(&DebuggerString,
3624 DbgPrint(
"BASE: Calling debugger with '%wZ'\n", &DebuggerString);
3627 lpCommandLine = DebuggerString.
Buffer;
3628 lpApplicationName =
NULL;
3632 SectionHandle =
NULL;
3633 QuerySection =
FALSE;
3640 RtlFreeHeap(RtlGetProcessHeap(), 0, DebuggerCmdLine);
3641 DebuggerCmdLine =
NULL;
3642 DPRINT1(
"Retrying with: %S\n", lpCommandLine);
3648 lpProcessAttributes,
3654 LocalProcessAttributes = *lpProcessAttributes;
3657 &LocalProcessAttributes,
3675 DPRINT1(
"Failed to connect to DbgUI!\n");
3696 HavePrivilege =
FALSE;
3697 PrivilegeState =
NULL;
3706 HavePrivilege =
TRUE;
3747 RealTimePrivilegeState =
NULL;
3798 DPRINT1(
"Failed to update VDM with wait object\n");
3799 VdmWaitObject =
NULL;
3837 sizeof(ImageInformation),
3849 QuerySection =
TRUE;
3856 DPRINT(
"Image should receive SxS Fusion Isolation\n");
3863 if (lpCurrentDirectory)
3866 DPRINT(
"Current directory: %S\n", lpCurrentDirectory);
3898 DPRINT1(
"Current directory is invalid\n");
3906 if ((QuotesNeeded) || (CmdLineIsAppName))
3921 SaveChar = *NullBuffer;
3926 wcscat(QuotedCmdLine, lpCommandLine);
3932 *NullBuffer = SaveChar;
3933 wcscat(QuotedCmdLine, NullBuffer);
3939 if (QuotesNeeded) QuotesNeeded =
FALSE;
3940 if (CmdLineIsAppName) CmdLineIsAppName =
FALSE;
3945 if (CreateProcessMsg->
Sxs.
Flags & 1) ParameterFlags |= 1;
3948 if ((QuotesNeeded) || (CmdLineIsAppName)) lpCommandLine = QuotedCmdLine;
3959 dwCreationFlags | NoWindow,
3967 DPRINT1(
"BasePushProcessParameters failed\n");
3976 if (!(VdmBinaryType) &&
3977 !(bInheritHandles) &&
4046 LocalThreadAttributes = *lpThreadAttributes;
4049 &LocalThreadAttributes,
4079 DPRINT(
"TODO: WOW64 is not supported yet\n");
4087 switch (ImageInformation.
Machine)
4102 DbgPrint(
"kernel32: No mapping for ImageInformation.Machine == %04x\n",
4152 CreateProcessMsg->
VdmTask = VdmTask;
4154 else if (VdmReserve)
4164 DPRINT1(
"This is an SxS Message -- should not happen yet\n");
4176 sizeof(*CreateProcessMsg));
4182 CaptureBuffer =
NULL;
4189 DPRINT1(
"Failed to tell csrss about new process\n");
4251 lpProcessInformation->hProcess = VdmWaitObject;
4266 lpProcessInformation->hProcess = VdmWaitObject;
4279 lpProcessInformation->hThread = ThreadHandle;
4285 ThreadHandle =
NULL;
4289 if (DebuggerCmdLine)
RtlFreeHeap(RtlGetProcessHeap(), 0, DebuggerCmdLine);
4295 RtlInitEmptyUnicodeString(&SxsWin32ExePath,
NULL, 0);
4296 SxsWin32ExePath.
Length = 0;
4302#if _SXS_SUPPORT_ENABLED_
4311 if (SxsConglomeratedBuffer)
4314 for (
i = 0;
i < 5;
i++)
4317 ThisBuffer = SxsStaticBuffers[
i];
4322 if ((ThisBuffer != (
PVOID)-8) && (ByteBuffer->
Buffer))
4338 RtlInitEmptyUnicodeString(&ThisBuffer->
String,
4359 lpEnvironment =
NULL;
4363 RtlFreeHeap(RtlGetProcessHeap(), 0, QuotedCmdLine);
4370 if (SectionHandle)
NtClose(SectionHandle);
4384 if (JobHandle)
NtClose(JobHandle);
4426 if (VdmWaitObject)
NtClose(VdmWaitObject);
4446 BOOL bInheritHandles,
4447 DWORD dwCreationFlags,
4457 lpProcessAttributes,
4464 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
#define NT_SUCCESS(StatCode)
NTSYSAPI NTSTATUS NTAPI RtlComputeImportTableHash(IN HANDLE FileHandle, OUT PCHAR Hash, IN ULONG ImportTableHashSize)
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
#define OBJ_CASE_INSENSITIVE
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)
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 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 _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 of all file and directory entries
BASE_CREATE_PROCESS CreateProcessRequest
BASE_EXIT_PROCESS ExitProcessRequest
BASE_GETSET_PROCESS_SHUTDOWN_PARAMS ShutdownParametersRequest
BASE_CHECK_VDM CheckVDMRequest
union _BASE_API_MESSAGE::@3712 Data
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 RTL_CONSTANT_STRING(s)
#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::@2450 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
#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
#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