windows: Add ntdll and bind to more process listing functions.

db4
Doug Coleman 2013-04-26 21:14:03 -07:00
parent 63050f68e2
commit c95c0fcc98
4 changed files with 106 additions and 5 deletions

View File

@ -1,7 +1,7 @@
! Copyright (C) 2005, 2006 Doug Coleman.
! See http://factorcode.org/license.txt for BSD license.
USING: alien alien.c-types alien.syntax kernel windows.types
math multiline classes.struct alien.data arrays ;
math multiline classes.struct alien.data arrays literals ;
QUALIFIED-WITH: alien.c-types c
IN: windows.kernel32
@ -809,6 +809,21 @@ STRUCT: CONSOLE_SCREEN_BUFFER_INFO
{ srWindow SMALL_RECT }
{ dwMaximumWindowSize COORD } ;
STRUCT: PROCESSENTRY32
{ dwSize DWORD }
{ cntUsage DWORD }
{ th32ProcessID DWORD }
{ th32DefaultHeapID ULONG_PTR }
{ th32ModuleID DWORD }
{ cntThreads DWORD }
{ th32ParentProcessID DWORD }
{ pcPriClassBase LONG }
{ dwFlags DWORD }
{ szExeFile TCHAR[MAX_PATH] } ;
TYPEDEF: PROCESSENTRY32* PPROCESSENTRY32
TYPEDEF: PROCESSENTRY32* LPPROCESSENTRY32
! Resource IDs
: MAKEINTRESOURCE ( int -- resource ) 0xffff bitand <alien> ; inline
@ -1009,7 +1024,16 @@ FUNCTION: HANDLE CreateRemoteThread ( HANDLE hProcess,
! FUNCTION: CreateThread
! FUNCTION: CreateTimerQueue
! FUNCTION: CreateTimerQueueTimer
! FUNCTION: CreateToolhelp32Snapshot
CONSTANT: TH32CS_INHERIT 0x80000000
CONSTANT: TH32CS_SNAPHEAPLIST 1
CONSTANT: TH32CS_SNAPMODULE 8
CONSTANT: TH32CS_SNAPMODULE32 0x10
CONSTANT: TH32CS_SNAPPROCESS 2
CONSTANT: TH32CS_SNAPTHREAD 4
CONSTANT: TH32CS_SNAPALL flags{ TH32CS_SNAPHEAPLIST TH32CS_SNAPMODULE TH32CS_SNAPPROCESS TH32CS_SNAPTHREAD }
FUNCTION: HANDLE CreateToolhelp32Snapshot ( DWORD dwFlags, DWORD th32ProcessID ) ;
! FUNCTION: CreateVirtualBuffer
! FUNCTION: CreateWaitableTimerA
! FUNCTION: CreateWaitableTimerW
@ -1642,7 +1666,7 @@ ALIAS: OpenFileMapping OpenFileMappingW
! FUNCTION: OpenJobObjectA
! FUNCTION: OpenJobObjectW
! FUNCTION: OpenMutexA
! FUNCTION: OpenMutexW
! FUNCTION: OpenMutexW
FUNCTION: HANDLE OpenProcess ( DWORD dwDesiredAccess, BOOL bInheritHandle, DWORD dwProcessId ) ;
! FUNCTION: OpenProfileUserMapping
! FUNCTION: OpenSemaphoreA
@ -1660,9 +1684,11 @@ FUNCTION: HANDLE OpenProcess ( DWORD dwDesiredAccess, BOOL bInheritHandle, DWORD
! FUNCTION: PrivCopyFileExW
! FUNCTION: PrivMoveFileIdentityW
! FUNCTION: Process32First
! FUNCTION: Process32FirstW
FUNCTION: BOOL Process32FirstW ( HANDLE hSnapshot, LPPROCESSENTRY32 lppe ) ;
ALIAS: Process32First Process32FirstW
! FUNCTION: Process32Next
! FUNCTION: Process32NextW
FUNCTION: BOOL Process32NextW ( HANDLE hSnapshot, LPPROCESSENTRY32 lppe ) ;
ALIAS: Process32Next Process32NextW
! FUNCTION: ProcessIdToSessionId
! FUNCTION: PulseEvent
! FUNCTION: PurgeComm

View File

@ -0,0 +1 @@
Doug Coleman

View File

@ -0,0 +1,73 @@
! Copyright (C) 2013 Doug Coleman.
! See http://factorcode.org/license.txt for BSD license.
USING: alien.c-types alien.syntax classes.struct windows.types ;
IN: windows.ntdll
LIBRARY: ntdll
TYPEDEF: uint NTSTATUS
STRUCT: LSA_UNICODE_STRING
{ Length USHORT }
{ MaximumLength USHORT }
{ Buffer void* } ;
TYPEDEF: LSA_UNICODE_STRING* PLSA_UNICODE_STRING
TYPEDEF: LSA_UNICODE_STRING UNICODE_STRING
TYPEDEF: LSA_UNICODE_STRING* PUNICODE_STRING
STRUCT: RTL_USER_PROCESS_PARAMETERS
{ Reserved1 BYTE[16] }
{ Reserved2 PVOID[10] }
{ ImagePathName UNICODE_STRING }
{ CommandLine UNICODE_STRING } ;
TYPEDEF: RTL_USER_PROCESS_PARAMETERS* PRTL_USER_PROCESS_PARAMETERS
STRUCT: LIST_ENTRY
{ Flink LIST_ENTRY* }
{ Blink LIST_ENTRY* } ;
TYPEDEF: LIST_ENTRY* PLIST_ENTRY
STRUCT: PEB_LDR_DATA
{ Reserved1 BYTE[8] }
{ Reserved2 PVOID[3] }
{ InMemoryOrderModuleList LIST_ENTRY } ;
TYPEDEF: PEB_LDR_DATA* PPEB_LDR_DATA
TYPEDEF: void* PPS_POST_PROCESS_INIT_ROUTINE
STRUCT: PEB
{ Reserved1 BYTE[2] }
{ BeingDebugged BYTE }
{ Reserved2 BYTE[1] }
{ Reserved3 BYTE[2] }
{ Ldr PPEB_LDR_DATA }
{ ProcessParameters PRTL_USER_PROCESS_PARAMETERS }
{ Reserved4 BYTE[104] }
{ Reserved5 PVOID[52] }
{ PostProcessInitRoutine PPS_POST_PROCESS_INIT_ROUTINE }
{ Reserved6 BYTE[128] }
{ Reserved7 PVOID[1] }
{ SessionId ULONG } ;
TYPEDEF: PEB* PPEB
! PebBaseAddress is PPEB
STRUCT: PROCESS_BASIC_INFORMATION
{ Reserved1 PVOID }
{ PebBaseAddress void* }
{ Reserved2 PVOID[2] }
{ UniqueProcessId ULONG_PTR }
{ Reserved3 PVOID } ;
ENUM: PROCESSINFOCLASS
{ ProcessBasicInformation 0 }
{ ProcessDebugPort 7 }
{ ProcessWow64Information 26 }
{ ProcessImageFileName 27 } ;
FUNCTION: NTSTATUS NtQueryInformationProcess (
HANDLE ProcessHandle,
PROCESSINFOCLASS ProcessInformationClass,
PVOID ProcessInformation,
ULONG ProcessInformationLength,
PULONG ReturnLength
) ;

View File

@ -23,4 +23,5 @@ CONSTANT: MAX_UNICODE_PATH 32768
{ "usp10" "usp10.dll" stdcall }
{ "psapi" "psapi.dll" stdcall }
{ "winmm" "winmm.dll" stdcall }
{ "ntdll" "ntdll.dll" stdcall }
} [ first3 add-library ] each