/* * Process Hacker Extra Plugins - * Terminator Plugin * * Copyright (C) 2016 dmex * * This file is part of Process Hacker. * * Process Hacker is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * Process Hacker is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Process Hacker. If not, see . */ #pragma once NTSTATUS Ph2OpenProcess( _Out_ PHANDLE ProcessHandle, _In_ ACCESS_MASK DesiredAccess, _In_ HANDLE ProcessId ); NTSTATUS Ph2OpenThread( _Out_ PHANDLE ThreadHandle, _In_ ACCESS_MASK DesiredAccess, _In_ HANDLE ThreadId ); NTSTATUS Ph2DuplicateObject( _In_ HANDLE SourceProcessHandle, _In_ HANDLE SourceHandle, _In_opt_ HANDLE TargetProcessHandle, _Out_opt_ PHANDLE TargetHandle, _In_ ACCESS_MASK DesiredAccess, _In_ ULONG HandleAttributes, _In_ ULONG Options ); NTSTATUS Ph2TerminateThread( _In_ HANDLE ThreadHandle, _In_ NTSTATUS ExitStatus ); NTSTATUS Ph2GetThreadContext( _In_ HANDLE ThreadHandle, _Inout_ PCONTEXT Context ); NTSTATUS Ph2SetThreadContext( _In_ HANDLE ThreadHandle, _In_ PCONTEXT Context ); NTSTATUS Ph2WriteVirtualMemory( _In_ HANDLE ProcessHandle, _In_ PVOID BaseAddress, _In_reads_bytes_(BufferSize) PVOID Buffer, _In_ SIZE_T BufferSize, _Out_opt_ PSIZE_T NumberOfBytesWritten ); NTSTATUS Ph2TerminateProcess( _In_ HANDLE ProcessHandle, _In_ NTSTATUS ExitStatus );