From 8481c1fa105172e71517334bcfa085da87b85258 Mon Sep 17 00:00:00 2001 From: Alex Ionescu Date: Wed, 10 May 2006 17:47:44 +0000 Subject: [PATCH] - NDK 0.98, now with versionned headers. Too many changes to list, see the TinyKRNL SVN Logs for more detailed information. Thanks to Andrew (Wax), Thomas and Aleksey for testing. svn path=/trunk/; revision=21880 --- reactos/ReactOS.rbuild | 14 +- reactos/base/applications/taskmgr/perfdata.c | 6 +- reactos/base/services/umpnpmgr/umpnpmgr.c | 5 +- reactos/boot/bootdata/txtsetup.sif | 4 +- .../boot/freeldr/freeldr/arch/i386/loader.c | 2 +- .../boot/freeldr/freeldr/include/freeldr.h | 5 +- .../boot/freeldr/freeldr/include/reactos.h | 5 +- .../boot/freeldr/freeldr/reactos/reactos.c | 2 +- .../boot/freeldr/freeldr/reactos/setupldr.c | 2 +- reactos/dll/ntdll/def/ntdll.def | 4 +- reactos/dll/ntdll/ldr/startup.c | 4 +- reactos/dll/ntdll/ldr/utils.c | 75 +- reactos/dll/ntdll/ntdll.rbuild | 2 +- reactos/dll/win32/advapi32/sec/ac.c | 2 + reactos/dll/win32/kernel32/file/create.c | 20 +- reactos/dll/win32/kernel32/file/file.c | 4 + reactos/dll/win32/kernel32/kernel32.rbuild | 6 +- reactos/dll/win32/kernel32/misc/console.c | 4 + reactos/dll/win32/kernel32/misc/ldr.c | 8 +- reactos/dll/win32/kernel32/misc/profile.c | 2 +- reactos/dll/win32/kernel32/misc/recovery.c | 4 + reactos/dll/win32/kernel32/misc/toolhelp.c | 44 +- reactos/dll/win32/kernel32/misc/utils.c | 1 + reactos/dll/win32/kernel32/process/create.c | 2 +- reactos/dll/win32/kernel32/thread/tls.c | 2 - reactos/dll/win32/psapi/psapi.c | 12 +- reactos/drivers/base/blue/blue.c | 9 +- reactos/drivers/filesystems/ms/msfs.h | 2 +- reactos/drivers/filesystems/vfat/vfat.h | 1 - reactos/drivers/multimedia/audio/sound/wave.c | 1 - .../drivers/network/tcpip/include/precomp.h | 2 +- reactos/drivers/storage/diskdump/diskdump.c | 3 +- reactos/drivers/video/videoprt/int10.c | 6 +- reactos/drivers/video/videoprt/videoprt.h | 8 + reactos/hal/hal/hal.c | 8 +- reactos/hal/halx86/generic/display.c | 2 +- reactos/hal/halx86/generic/halinit.c | 6 +- reactos/hal/halx86/generic/irql.c | 44 +- reactos/hal/halx86/generic/spinlock.c | 2 +- reactos/hal/halx86/generic/timer.c | 12 +- reactos/hal/halx86/include/hal.h | 9 +- reactos/hal/halx86/include/halp.h | 15 +- reactos/hal/halx86/include/mps.h | 19 + reactos/hal/halx86/mp/apic.c | 15 +- reactos/hal/halx86/mp/halinit_mp.c | 2 +- reactos/hal/halx86/mp/mpsirql.c | 14 +- reactos/hal/halx86/up/halinit_up.c | 2 +- reactos/hal/halx86/xbox/display_xbox.c | 2 +- reactos/hal/halx86/xbox/halinit_xbox.c | 2 +- reactos/include/ddk/winddk.h | 17 +- reactos/include/ndk/asm.h | 27 +- reactos/include/ndk/cctypes.h | 4 +- reactos/include/ndk/cmfuncs.h | 4 +- reactos/include/ndk/cmtypes.h | 19 +- reactos/include/ndk/dbgkfuncs.h | 10 +- reactos/include/ndk/dbgktypes.h | 4 +- reactos/include/ndk/exfuncs.h | 42 +- reactos/include/ndk/extypes.h | 322 +++-- reactos/include/ndk/fixmes.txt | 88 -- reactos/include/ndk/halfuncs.h | 53 +- reactos/include/ndk/haltypes.h | 283 ++--- reactos/include/ndk/i386/ketypes.h | 299 +++-- reactos/include/ndk/i386/mmtypes.h | 117 ++ reactos/include/ndk/ifssupp.h | 4 +- reactos/include/ndk/inbvfuncs.h | 6 +- reactos/include/ndk/iofuncs.h | 80 +- reactos/include/ndk/iotypes.h | 69 +- reactos/include/ndk/kdfuncs.h | 104 +- reactos/include/ndk/kdtypes.h | 119 +- reactos/include/ndk/kefuncs.h | 58 +- reactos/include/ndk/ketypes.h | 665 ++++++---- reactos/include/ndk/ldrfuncs.h | 33 +- reactos/include/ndk/ldrtypes.h | 101 +- reactos/include/ndk/lpcfuncs.h | 38 +- reactos/include/ndk/lpctypes.h | 6 +- reactos/include/ndk/mmfuncs.h | 35 +- reactos/include/ndk/mmtypes.h | 247 +++- reactos/include/ndk/ntndk.h | 28 +- reactos/include/ndk/obfuncs.h | 4 +- reactos/include/ndk/obtypes.h | 94 +- reactos/include/ndk/pofuncs.h | 4 +- reactos/include/ndk/potypes.h | 4 +- reactos/include/ndk/psfuncs.h | 8 +- reactos/include/ndk/pstypes.h | 1125 ++++++++++++----- reactos/include/ndk/readme.txt | 23 +- reactos/include/ndk/rtlfuncs.h | 443 ++++++- reactos/include/ndk/rtltypes.h | 330 ++++- reactos/include/ndk/sefuncs.h | 6 +- reactos/include/ndk/setypes.h | 4 +- reactos/include/ndk/umfuncs.h | 12 +- reactos/include/reactos/arc/arc.h | 223 +++- .../reactos/drivers/diskdump/diskdump.h | 2 +- reactos/include/reactos/libs/epsapi/epsapi.h | 14 +- reactos/include/reactos/win32k/callout.h | 19 + reactos/include/winnt.h | 4 +- reactos/include/winsock2.h | 8 +- reactos/include/ws2tcpip.h | 6 - reactos/lib/epsapi/enum/drivers.c | 32 +- reactos/lib/epsapi/enum/modules.c | 8 +- reactos/lib/epsapi/enum/processes.c | 6 +- reactos/lib/rtl/bootdata.c | 2 +- reactos/lib/rtl/crc32.c | 2 +- reactos/lib/rtl/dbgbuffer.c | 105 +- reactos/lib/rtl/debug.c | 2 +- reactos/lib/rtl/image.c | 14 +- reactos/lib/rtl/network.c | 240 ++-- reactos/lib/rtl/path.c | 50 +- reactos/lib/rtl/process.c | 8 +- reactos/lib/rtl/sd.c | 5 - reactos/lib/rtl/thread.c | 1 + reactos/lib/rtl/unicode.c | 2 +- reactos/ntoskrnl/cm/cm.h | 1 + reactos/ntoskrnl/cm/registry.c | 2 +- reactos/ntoskrnl/cm/regobj.c | 1 + reactos/ntoskrnl/ex/dbgctrl.c | 16 +- reactos/ntoskrnl/ex/init.c | 7 +- reactos/ntoskrnl/ex/power.c | 10 +- reactos/ntoskrnl/ex/profile.c | 60 +- reactos/ntoskrnl/ex/rundown.c | 8 +- reactos/ntoskrnl/ex/sysinfo.c | 43 +- reactos/ntoskrnl/ex/win32k.c | 10 +- reactos/ntoskrnl/inbv/inbv.c | 7 + reactos/ntoskrnl/include/internal/ex.h | 4 +- reactos/ntoskrnl/include/internal/i386/ke.h | 77 +- reactos/ntoskrnl/include/internal/i386/v86m.h | 126 ++ reactos/ntoskrnl/include/internal/io.h | 10 +- reactos/ntoskrnl/include/internal/kd.h | 52 + reactos/ntoskrnl/include/internal/ke.h | 21 - reactos/ntoskrnl/include/internal/lpc.h | 7 +- reactos/ntoskrnl/include/internal/mm.h | 93 +- reactos/ntoskrnl/include/internal/ntoskrnl.h | 5 +- reactos/ntoskrnl/include/internal/ob.h | 55 +- reactos/ntoskrnl/include/internal/po.h | 2 +- reactos/ntoskrnl/include/internal/ps.h | 203 ++- reactos/ntoskrnl/include/ntoskrnl.h | 2 + reactos/ntoskrnl/io/disk.c | 23 +- reactos/ntoskrnl/io/driver.c | 2 - reactos/ntoskrnl/io/efi.c | 27 +- reactos/ntoskrnl/io/file.c | 8 +- reactos/ntoskrnl/io/iomgr.c | 2 +- reactos/ntoskrnl/io/plugplay.c | 8 +- reactos/ntoskrnl/kd/kdinit.c | 4 +- reactos/ntoskrnl/kdbg/kdb.c | 111 +- reactos/ntoskrnl/kdbg/kdb_cli.c | 2 +- reactos/ntoskrnl/kdbg/kdb_symbols.c | 6 +- reactos/ntoskrnl/ke/bug.c | 10 +- reactos/ntoskrnl/ke/clock.c | 6 +- reactos/ntoskrnl/ke/device.c | 12 +- reactos/ntoskrnl/ke/dpc.c | 10 +- reactos/ntoskrnl/ke/i386/bios.c | 3 +- reactos/ntoskrnl/ke/i386/exp.c | 2 +- reactos/ntoskrnl/ke/i386/irq.c | 1 + reactos/ntoskrnl/ke/i386/kernel.c | 8 +- reactos/ntoskrnl/ke/i386/usertrap.c | 2 +- reactos/ntoskrnl/ke/ipi.c | 4 +- reactos/ntoskrnl/ke/kthread.c | 6 +- reactos/ntoskrnl/ke/main.c | 8 +- reactos/ntoskrnl/ke/process.c | 8 +- reactos/ntoskrnl/ldr/loader.c | 52 +- reactos/ntoskrnl/lpc/close.c | 6 +- reactos/ntoskrnl/mm/anonmem.c | 8 +- reactos/ntoskrnl/mm/aspace.c | 4 +- reactos/ntoskrnl/mm/i386/page.c | 64 +- reactos/ntoskrnl/mm/marea.c | 4 +- reactos/ntoskrnl/mm/mdl.c | 14 +- reactos/ntoskrnl/mm/mm.c | 12 +- reactos/ntoskrnl/mm/process.c | 18 +- reactos/ntoskrnl/mm/rmap.c | 30 +- reactos/ntoskrnl/mm/section.c | 81 +- reactos/ntoskrnl/mm/virtual.c | 4 +- reactos/ntoskrnl/ntoskrnl.def | 4 +- reactos/ntoskrnl/ntoskrnl.rbuild | 28 - reactos/ntoskrnl/ob/dirobj.c | 4 +- reactos/ntoskrnl/ob/handle.c | 28 +- reactos/ntoskrnl/ob/namespc.c | 28 +- reactos/ntoskrnl/ob/ntobj.c | 6 +- reactos/ntoskrnl/ob/object.c | 35 +- reactos/ntoskrnl/ob/security.c | 6 +- reactos/ntoskrnl/ob/symlink.c | 2 +- reactos/ntoskrnl/ob/wait.c | 2 +- reactos/ntoskrnl/po/power.c | 2 +- reactos/ntoskrnl/ps/job.c | 4 +- reactos/ntoskrnl/ps/kill.c | 20 +- reactos/ntoskrnl/ps/process.c | 18 +- reactos/ntoskrnl/ps/psmgr.c | 20 +- reactos/ntoskrnl/ps/query.c | 12 +- reactos/ntoskrnl/ps/thread.c | 2 +- reactos/ntoskrnl/ps/win32.c | 20 +- reactos/ntoskrnl/se/semgr.c | 2 +- .../subsystems/win32/win32k/include/winsta.h | 10 +- .../subsystems/win32/win32k/main/dllmain.c | 11 +- .../subsystems/win32/win32k/ntuser/winsta.c | 6 +- reactos/subsystems/win32/win32k/objects/dc.c | 8 + reactos/subsystems/win32/win32k/w32k.h | 4 +- 194 files changed, 5175 insertions(+), 2618 deletions(-) create mode 100644 reactos/include/reactos/win32k/callout.h create mode 100644 reactos/ntoskrnl/include/internal/i386/v86m.h diff --git a/reactos/ReactOS.rbuild b/reactos/ReactOS.rbuild index d5ab7c4b995..d03f0f01287 100644 --- a/reactos/ReactOS.rbuild +++ b/reactos/ReactOS.rbuild @@ -24,14 +24,12 @@ - - - -Os - -Wno-strict-aliasing - -ftracer - -momit-leaf-frame-pointer - -mpreferred-stack-boundary=2 - + -O3 + -fno-optimize-sibling-calls + -Wno-strict-aliasing + -ftracer + -momit-leaf-frame-pointer + -mpreferred-stack-boundary=2 -Wpointer-arith . diff --git a/reactos/base/applications/taskmgr/perfdata.c b/reactos/base/applications/taskmgr/perfdata.c index 8a5b13d9b6f..9becdcfcc45 100644 --- a/reactos/base/applications/taskmgr/perfdata.c +++ b/reactos/base/applications/taskmgr/perfdata.c @@ -35,7 +35,7 @@ double OldKernelTime = 0; LARGE_INTEGER liOldSystemTime = {{0,0}}; SYSTEM_PERFORMANCE_INFORMATION SystemPerfInfo; SYSTEM_BASIC_INFORMATION SystemBasicInfo; -SYSTEM_CACHE_INFORMATION SystemCacheInfo; +SYSTEM_FILECACHE_INFORMATION SystemCacheInfo; SYSTEM_HANDLE_INFORMATION SystemHandleInfo; PSYSTEM_PROCESSOR_PERFORMANCE_INFORMATION SystemProcessorTimeInfo = NULL; PSID SystemUserSid = NULL; @@ -95,7 +95,7 @@ void PerfDataRefresh(void) HANDLE hProcessToken; SYSTEM_PERFORMANCE_INFORMATION SysPerfInfo; SYSTEM_TIMEOFDAY_INFORMATION SysTimeInfo; - SYSTEM_CACHE_INFORMATION SysCacheInfo; + SYSTEM_FILECACHE_INFORMATION SysCacheInfo; LPBYTE SysHandleInfoData; PSYSTEM_PROCESSOR_PERFORMANCE_INFORMATION SysProcessorTimeInfo; double CurrentKernelTime; @@ -170,7 +170,7 @@ void PerfDataRefresh(void) /* * Save system cache info */ - memcpy(&SystemCacheInfo, &SysCacheInfo, sizeof(SYSTEM_CACHE_INFORMATION)); + memcpy(&SystemCacheInfo, &SysCacheInfo, sizeof(SYSTEM_FILECACHE_INFORMATION)); /* * Save system processor time info diff --git a/reactos/base/services/umpnpmgr/umpnpmgr.c b/reactos/base/services/umpnpmgr/umpnpmgr.c index df68197e022..4cd0cb4b7bf 100644 --- a/reactos/base/services/umpnpmgr/umpnpmgr.c +++ b/reactos/base/services/umpnpmgr/umpnpmgr.c @@ -298,9 +298,8 @@ PNP_GetRelatedDeviceInstance(handle_t BindingHandle, PlugPlayData.Relation = Relationship; - PlugPlayData.RelatedDeviceInstance.Length = 0; - PlugPlayData.RelatedDeviceInstance.MaximumLength = Length; - PlugPlayData.RelatedDeviceInstance.Buffer = RelatedDeviceId; + PlugPlayData.RelatedDeviceInstanceLength = Length; + PlugPlayData.RelatedDeviceInstance = RelatedDeviceId; Status = NtPlugPlayControl(PlugPlayControlGetRelatedDevice, (PVOID)&PlugPlayData, diff --git a/reactos/boot/bootdata/txtsetup.sif b/reactos/boot/bootdata/txtsetup.sif index 1144f6bcb38..86f2ef975d8 100644 --- a/reactos/boot/bootdata/txtsetup.sif +++ b/reactos/boot/bootdata/txtsetup.sif @@ -37,8 +37,8 @@ Cabinet=reactos.cab [SetupData] DefaultPath = \ReactOS -OsLoadOptions = "/NOGUIBOOT /NODEBUG" -;OsLoadOptions = "/NOGUIBOOT /DEBUGPORT=COM1 /BAUDRATE=19200 /IRQ=4" +;OsLoadOptions = "/NOGUIBOOT /NODEBUG" +OsLoadOptions = "/NOGUIBOOT /DEBUGPORT=COM1 /BREAK" ;OsLoadOptions = "/NOGUIBOOT /DEBUGPORT=SCREEN" ;OsLoadOptions = "/NOGUIBOOT /DEBUGPORT=BOCHS" diff --git a/reactos/boot/freeldr/freeldr/arch/i386/loader.c b/reactos/boot/freeldr/freeldr/arch/i386/loader.c index cfefcf6e9e5..832407469bc 100644 --- a/reactos/boot/freeldr/freeldr/arch/i386/loader.c +++ b/reactos/boot/freeldr/freeldr/arch/i386/loader.c @@ -101,7 +101,7 @@ typedef struct _HARDWARE_PTE_X64 { } HARDWARE_PTE_X64, *PHARDWARE_PTE_X64; typedef struct _PAGE_DIRECTORY_X86 { - HARDWARE_PTE_X86 Pde[1024]; + HARDWARE_PTE Pde[1024]; } PAGE_DIRECTORY_X86, *PPAGE_DIRECTORY_X86; typedef struct _PAGE_DIRECTORY_X64 { diff --git a/reactos/boot/freeldr/freeldr/include/freeldr.h b/reactos/boot/freeldr/freeldr/include/freeldr.h index d91b5ec8bc2..d27d4ff5c7c 100644 --- a/reactos/boot/freeldr/freeldr/include/freeldr.h +++ b/reactos/boot/freeldr/freeldr/include/freeldr.h @@ -26,7 +26,10 @@ #include #include #include -#include +#include +#include +#include +#include #include #include #include diff --git a/reactos/boot/freeldr/freeldr/include/reactos.h b/reactos/boot/freeldr/freeldr/include/reactos.h index 80de92bcbf8..ea3ad009850 100644 --- a/reactos/boot/freeldr/freeldr/include/reactos.h +++ b/reactos/boot/freeldr/freeldr/include/reactos.h @@ -49,8 +49,7 @@ ULONG ConvertArcNameToBiosDriveNumber(PCHAR ArcPath); // Loader Functions And Definitions // /////////////////////////////////////////////////////////////////////////////////////// - -extern LOADER_PARAMETER_BLOCK LoaderBlock; /* Multiboot info structure passed to kernel */ +extern ROS_LOADER_PARAMETER_BLOCK LoaderBlock; /* Multiboot info structure passed to kernel */ extern char reactos_kernel_cmdline[255]; // Command line passed to kernel extern LOADER_MODULE reactos_modules[64]; // Array to hold boot module info loaded for the kernel extern char reactos_module_strings[64][256]; // Array to hold module names @@ -65,6 +64,6 @@ ULONG_PTR STDCALL FrLdrCreateModule(LPCSTR ModuleName); ULONG_PTR STDCALL FrLdrLoadModule(FILE *ModuleImage, LPCSTR ModuleName, PULONG ModuleSize); BOOL STDCALL FrLdrCloseModule(ULONG_PTR ModuleBase, ULONG dwModuleSize); VOID STDCALL FrLdrStartup(ULONG Magic); -typedef VOID (FASTCALL *ASMCODE)(ULONG Magic, PLOADER_PARAMETER_BLOCK LoaderBlock); +typedef VOID (FASTCALL *ASMCODE)(ULONG Magic, PROS_LOADER_PARAMETER_BLOCK LoaderBlock); #endif // defined __REACTOS_H diff --git a/reactos/boot/freeldr/freeldr/reactos/reactos.c b/reactos/boot/freeldr/freeldr/reactos/reactos.c index e9d29edd4b1..932c62643e7 100644 --- a/reactos/boot/freeldr/freeldr/reactos/reactos.c +++ b/reactos/boot/freeldr/freeldr/reactos/reactos.c @@ -24,7 +24,7 @@ #define NDEBUG #include -LOADER_PARAMETER_BLOCK LoaderBlock; +ROS_LOADER_PARAMETER_BLOCK LoaderBlock; char reactos_kernel_cmdline[255]; // Command line passed to kernel LOADER_MODULE reactos_modules[64]; // Array to hold boot module info loaded for the kernel char reactos_module_strings[64][256]; // Array to hold module names diff --git a/reactos/boot/freeldr/freeldr/reactos/setupldr.c b/reactos/boot/freeldr/freeldr/reactos/setupldr.c index 0da4ef1800b..105fa8bdc6a 100644 --- a/reactos/boot/freeldr/freeldr/reactos/setupldr.c +++ b/reactos/boot/freeldr/freeldr/reactos/setupldr.c @@ -20,7 +20,7 @@ #include -LOADER_PARAMETER_BLOCK LoaderBlock; +ROS_LOADER_PARAMETER_BLOCK LoaderBlock; char reactos_kernel_cmdline[255]; // Command line passed to kernel LOADER_MODULE reactos_modules[64]; // Array to hold boot module info loaded for the kernel char reactos_module_strings[64][256]; // Array to hold module names diff --git a/reactos/dll/ntdll/def/ntdll.def b/reactos/dll/ntdll/def/ntdll.def index feca2d36311..cba1d5d70aa 100644 --- a/reactos/dll/ntdll/def/ntdll.def +++ b/reactos/dll/ntdll/def/ntdll.def @@ -525,8 +525,8 @@ RtlIpv4StringToAddressExA@16 RtlIpv4StringToAddressExW@16 RtlIpv4StringToAddressW@16 RtlIpv6AddressToStringA@8 -RtlIpv6AddressToStringExA@16 -RtlIpv6AddressToStringExW@16 +RtlIpv6AddressToStringExA@20 +RtlIpv6AddressToStringExW@20 RtlIpv6AddressToStringW@8 RtlIpv6StringToAddressA@12 RtlIpv6StringToAddressExA@16 diff --git a/reactos/dll/ntdll/ldr/startup.c b/reactos/dll/ntdll/ldr/startup.c index 2030dbaaf62..599ac44d42b 100644 --- a/reactos/dll/ntdll/ldr/startup.c +++ b/reactos/dll/ntdll/ldr/startup.c @@ -415,7 +415,7 @@ LdrpInit(PCONTEXT Context, NtModule->TimeDateStamp = NTHeaders->FileHeader.TimeDateStamp; InsertTailList(&Peb->Ldr->InLoadOrderModuleList, - &NtModule->InLoadOrderModuleList); + &NtModule->InLoadOrderLinks); InsertTailList(&Peb->Ldr->InInitializationOrderModuleList, &NtModule->InInitializationOrderModuleList); @@ -463,7 +463,7 @@ LdrpInit(PCONTEXT Context, ExeModule->TimeDateStamp = NTHeaders->FileHeader.TimeDateStamp; InsertHeadList(&Peb->Ldr->InLoadOrderModuleList, - &ExeModule->InLoadOrderModuleList); + &ExeModule->InLoadOrderLinks); LdrpInitLoader(); diff --git a/reactos/dll/ntdll/ldr/utils.c b/reactos/dll/ntdll/ldr/utils.c index 77969689624..44f62fe5d17 100644 --- a/reactos/dll/ntdll/ldr/utils.c +++ b/reactos/dll/ntdll/ldr/utils.c @@ -73,7 +73,7 @@ VOID LdrpLoadUserModuleSymbols(PLDR_DATA_TABLE_ENTRY LdrModule) { NtSystemDebugControl( - DebugDbgLoadSymbols, + SysDbgQueryVersion, (PVOID)LdrModule, 0, NULL, @@ -255,7 +255,7 @@ LdrpInitializeTlsForProccess(VOID) Entry = ModuleListHead->Flink; while (Entry != ModuleListHead) { - Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); if (Module->LoadCount == 0xFFFF && Module->TlsIndex != 0xFFFF) { @@ -498,7 +498,7 @@ LdrAddModuleEntry(PVOID ImageBase, RtlEnterCriticalSection (NtCurrentPeb()->LoaderLock); InsertTailList(&NtCurrentPeb()->Ldr->InLoadOrderModuleList, - &Module->InLoadOrderModuleList); + &Module->InLoadOrderLinks); RtlLeaveCriticalSection(NtCurrentPeb()->LoaderLock); return(Module); @@ -727,7 +727,7 @@ LdrpMapDllImageFile(IN PWSTR SearchPath OPTIONAL, */ NTSTATUS NTAPI LdrLoadDll (IN PWSTR SearchPath OPTIONAL, - IN ULONG LoadFlags, + IN PULONG LoadFlags, IN PUNICODE_STRING Name, OUT PVOID *BaseAddress OPTIONAL) { @@ -747,8 +747,8 @@ LdrLoadDll (IN PWSTR SearchPath OPTIONAL, *BaseAddress = NULL; - Status = LdrpLoadModule(SearchPath, LoadFlags, Name, &Module, BaseAddress); - if (NT_SUCCESS(Status) && 0 == (LoadFlags & LOAD_LIBRARY_AS_DATAFILE)) + Status = LdrpLoadModule(SearchPath, *LoadFlags, Name, &Module, BaseAddress); + if (NT_SUCCESS(Status) && 0 == (*LoadFlags & LOAD_LIBRARY_AS_DATAFILE)) { RtlEnterCriticalSection(NtCurrentPeb()->LoaderLock); Status = LdrpAttachProcess(); @@ -802,7 +802,7 @@ LdrFindEntryForAddress(PVOID Address, while (Entry != ModuleListHead) { - ModulePtr = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + ModulePtr = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); DPRINT("Scanning %wZ at %p\n", &ModulePtr->BaseDllName, ModulePtr->DllBase); @@ -901,7 +901,7 @@ LdrFindEntryForName(PUNICODE_STRING Name, } while (Entry != ModuleListHead) { - ModulePtr = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + ModulePtr = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); DPRINT("Scanning %wZ %wZ\n", &ModulePtr->BaseDllName, &AdjustedName); @@ -970,8 +970,9 @@ LdrFixupForward(PCHAR ForwardName) */ if (!NT_SUCCESS(Status)) { + ULONG Flags = LDRP_PROCESS_CREATION_TIME; Status = LdrLoadDll(NULL, - LDRP_PROCESS_CREATION_TIME, + &Flags, &DllName, &BaseAddress); if (NT_SUCCESS(Status)) @@ -1289,7 +1290,7 @@ LdrPerformRelocations(PIMAGE_NT_HEADERS NTHeaders, ProtectPage2 = NULL; } - RelocationDir = LdrProcessRelocationBlock(Page, + RelocationDir = LdrProcessRelocationBlock((ULONG_PTR)Page, Count, TypeOffset, Delta); @@ -2269,7 +2270,7 @@ LdrDisableThreadCalloutsForDll(IN PVOID BaseAddress) Entry = ModuleListHead->Flink; while (Entry != ModuleListHead) { - Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); DPRINT("BaseDllName %wZ BaseAddress %p\n", &Module->BaseDllName, Module->DllBase); @@ -2346,7 +2347,7 @@ LdrAddRefDll(IN ULONG Flags, Entry = ModuleListHead->Flink; while (Entry != ModuleListHead) { - Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); if (Module->DllBase == BaseAddress) { @@ -2385,7 +2386,7 @@ RtlPcToFileHeader(IN PVOID PcValue, Entry = ModuleListHead->Flink; while (Entry != ModuleListHead) { - Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); if ((ULONG_PTR)PcValue >= (ULONG_PTR)Module->DllBase && (ULONG_PTR)PcValue < (ULONG_PTR)Module->DllBase + Module->SizeOfImage) @@ -2520,7 +2521,7 @@ LdrpDetachProcess(BOOLEAN UnloadAll) ((UnloadAll && Module->LoadCount != 0xFFFF) || Module->LoadCount == 0)) { /* remove the module entry from the list */ - RemoveEntryList (&Module->InLoadOrderModuleList); + RemoveEntryList (&Module->InLoadOrderLinks); RemoveEntryList (&Module->InInitializationOrderModuleList); NtUnmapViewOfSection (NtCurrentProcess (), Module->DllBase); @@ -2653,7 +2654,7 @@ LdrpAttachThread (VOID) } Entry = NtCurrentPeb()->Ldr->InLoadOrderModuleList.Flink; - Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); LdrpTlsCallback(Module, DLL_THREAD_ATTACH); } @@ -2741,7 +2742,7 @@ LdrQueryProcessModuleInformation(IN PRTL_PROCESS_MODULES ModuleInformation OPTIO PCHAR p; DPRINT("LdrQueryProcessModuleInformation() called\n"); - + // FIXME: This code is ultra-duplicated. see lib\rtl\dbgbuffer.c RtlEnterCriticalSection (NtCurrentPeb()->LoaderLock); if (ModuleInformation == NULL || Size == 0) @@ -2750,8 +2751,8 @@ LdrQueryProcessModuleInformation(IN PRTL_PROCESS_MODULES ModuleInformation OPTIO } else { - ModuleInformation->ModuleCount = 0; - ModulePtr = &ModuleInformation->ModuleEntry[0]; + ModuleInformation->NumberOfModules = 0; + ModulePtr = &ModuleInformation->Modules[0]; Status = STATUS_SUCCESS; } @@ -2760,7 +2761,7 @@ LdrQueryProcessModuleInformation(IN PRTL_PROCESS_MODULES ModuleInformation OPTIO while (Entry != ModuleListHead) { - Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); DPRINT(" Module %wZ\n", &Module->FullDllName); @@ -2771,28 +2772,30 @@ LdrQueryProcessModuleInformation(IN PRTL_PROCESS_MODULES ModuleInformation OPTIO } else if (ModuleInformation != NULL) { - ModulePtr->Reserved[0] = ModulePtr->Reserved[1] = 0; // FIXME: ?? - ModulePtr->Base = Module->DllBase; - ModulePtr->Size = Module->SizeOfImage; - ModulePtr->Flags = Module->Flags; - ModulePtr->Index = 0; // FIXME: index ?? - ModulePtr->Unknown = 0; // FIXME: ?? - ModulePtr->LoadCount = Module->LoadCount; - - AnsiString.Length = 0; + ModulePtr->Section = 0; + ModulePtr->MappedBase = NULL; // FIXME: ?? + ModulePtr->ImageBase = Module->DllBase; + ModulePtr->ImageSize = Module->SizeOfImage; + ModulePtr->Flags = Module->Flags; + ModulePtr->LoadOrderIndex = 0; // FIXME: ?? + ModulePtr->InitOrderIndex = 0; // FIXME: ?? + ModulePtr->LoadCount = Module->LoadCount; + + AnsiString.Length = 0; AnsiString.MaximumLength = 256; - AnsiString.Buffer = ModulePtr->ImageName; + AnsiString.Buffer = ModulePtr->FullPathName; RtlUnicodeStringToAnsiString(&AnsiString, &Module->FullDllName, FALSE); - p = strrchr(ModulePtr->ImageName, '\\'); + + p = strrchr(ModulePtr->FullPathName, '\\'); if (p != NULL) - ModulePtr->ModuleNameOffset = p - ModulePtr->ImageName + 1; + ModulePtr->OffsetToFileName = p - ModulePtr->FullPathName + 1; else - ModulePtr->ModuleNameOffset = 0; + ModulePtr->OffsetToFileName = 0; ModulePtr++; - ModuleInformation->ModuleCount++; + ModuleInformation->NumberOfModules++; } UsedSize += sizeof(RTL_PROCESS_MODULE_INFORMATION); @@ -3154,10 +3157,10 @@ LdrQueryImageFileExecutionOptions (IN PUNICODE_STRING SubKey, PIMAGE_BASE_RELOCATION NTAPI -LdrProcessRelocationBlock(IN PVOID Address, - IN USHORT Count, +LdrProcessRelocationBlock(IN ULONG_PTR Address, + IN ULONG Count, IN PUSHORT TypeOffset, - IN ULONG_PTR Delta) + IN LONG_PTR Delta) { SHORT Offset; USHORT Type; diff --git a/reactos/dll/ntdll/ntdll.rbuild b/reactos/dll/ntdll/ntdll.rbuild index e2b213aafb8..41bd902c1b2 100644 --- a/reactos/dll/ntdll/ntdll.rbuild +++ b/reactos/dll/ntdll/ntdll.rbuild @@ -6,7 +6,7 @@ - 0x0600 + 0x0502 rtl diff --git a/reactos/dll/win32/advapi32/sec/ac.c b/reactos/dll/win32/advapi32/sec/ac.c index 0bee9e52f25..c0a01cf60d9 100644 --- a/reactos/dll/win32/advapi32/sec/ac.c +++ b/reactos/dll/win32/advapi32/sec/ac.c @@ -614,6 +614,8 @@ InternalTrusteeAToW(IN PTRUSTEE_A pTrusteeA, { case TRUSTEE_IS_NAME: { + /* directly copy the array, this works as the size of the EXPLICIT_ACCESS_A + structure matches the size of the EXPLICIT_ACCESS_W version */ lpStr = GetTrusteeName(pTrusteeA); if (lpStr != NULL) BufferSize = strlen(lpStr) + 1; diff --git a/reactos/dll/win32/kernel32/file/create.c b/reactos/dll/win32/kernel32/file/create.c index dbf1c4fd4ce..ee3d8bbf8b8 100644 --- a/reactos/dll/win32/kernel32/file/create.c +++ b/reactos/dll/win32/kernel32/file/create.c @@ -14,6 +14,10 @@ /* INCLUDES *****************************************************************/ +/* File contains Vista Semantics */ +#undef _WIN32_WINNT +#define _WIN32_WINNT 0x0600 + #include #define NDEBUG @@ -399,14 +403,14 @@ CreateSymbolicLinkW(IN LPCWSTR lpSymlinkFileName, switch(RtlDetermineDosPathNameType_U(lpTargetFileName)) { - case INVALID_PATH: - case ABSOLUTE_PATH: - case RELATIVE_PATH: + case RtlPathTypeUnknown: + case RtlPathTypeRooted: + case RtlPathTypeRelative: bRelativePath = TRUE; RtlInitUnicodeString(&TargetFileName, lpTargetFileName); break; - case RELATIVE_DRIVE_PATH: + case RtlPathTypeDriveRelative: { LPWSTR FilePart; SIZE_T cchTargetFullFileName; @@ -438,10 +442,10 @@ CreateSymbolicLinkW(IN LPCWSTR lpSymlinkFileName, // fallthrough - case UNC_PATH: - case ABSOLUTE_DRIVE_PATH: - case DEVICE_PATH: - case UNC_DOT_PATH: + case RtlPathTypeUncAbsolute: + case RtlPathTypeDriveAbsolute: + case RtlPathTypeLocalDevice: + case RtlPathTypeRootLocalDevice: default: if(!RtlDosPathNameToNtPathName_U(lpTargetFileName, &TargetFileName, NULL, NULL)) { diff --git a/reactos/dll/win32/kernel32/file/file.c b/reactos/dll/win32/kernel32/file/file.c index 4292973a777..a5db894aaeb 100644 --- a/reactos/dll/win32/kernel32/file/file.c +++ b/reactos/dll/win32/kernel32/file/file.c @@ -12,6 +12,10 @@ /* INCLUDES *****************************************************************/ +/* File contains Vista Semantics */ +#undef _WIN32_WINNT +#define _WIN32_WINNT 0x0600 + #include #define NDEBUG diff --git a/reactos/dll/win32/kernel32/kernel32.rbuild b/reactos/dll/win32/kernel32/kernel32.rbuild index eac725bf9b0..f1d419577f8 100644 --- a/reactos/dll/win32/kernel32/kernel32.rbuild +++ b/reactos/dll/win32/kernel32/kernel32.rbuild @@ -5,11 +5,10 @@ - 0x0600 + 0x0502 - 0x0600 + 0x502 k32.h - break.c debugger.c @@ -104,7 +103,6 @@ thread.c tls.c - lcformat.c profile.c diff --git a/reactos/dll/win32/kernel32/misc/console.c b/reactos/dll/win32/kernel32/misc/console.c index 941716eb9c9..ed52f71e3e9 100644 --- a/reactos/dll/win32/kernel32/misc/console.c +++ b/reactos/dll/win32/kernel32/misc/console.c @@ -14,6 +14,10 @@ /* INCLUDES ******************************************************************/ +/* File contains Vista Semantics */ +#undef _WIN32_WINNT +#define _WIN32_WINNT 0x0600 + #include #define NDEBUG diff --git a/reactos/dll/win32/kernel32/misc/ldr.c b/reactos/dll/win32/kernel32/misc/ldr.c index c8dcf3ee847..21ed4debd55 100644 --- a/reactos/dll/win32/kernel32/misc/ldr.c +++ b/reactos/dll/win32/kernel32/misc/ldr.c @@ -196,14 +196,14 @@ LoadLibraryExW ( { /* Call the API Properly */ Status = LdrLoadDll(SearchPath, - (ULONG)&DllCharacteristics, // Silence compiler + &DllCharacteristics, &DllName, (PVOID*)&hInst); } else { /* Call the ROS API. NOTE: Don't fix this, I have a patch to merge later. */ - Status = LdrLoadDll(SearchPath, dwFlags, &DllName, (PVOID*)&hInst); + Status = LdrLoadDll(SearchPath, &dwFlags, &DllName, (PVOID*)&hInst); } RtlFreeHeap(RtlGetProcessHeap(), 0, SearchPath); if ( !NT_SUCCESS(Status)) @@ -305,7 +305,7 @@ GetModuleFileNameA ( while (Entry != ModuleListHead) { - Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); if (Module->DllBase == (PVOID)hModule) { if (nSize * sizeof(WCHAR) < Module->FullDllName.Length) @@ -372,7 +372,7 @@ GetModuleFileNameW ( Entry = ModuleListHead->Flink; while (Entry != ModuleListHead) { - Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); if (Module->DllBase == (PVOID)hModule) { diff --git a/reactos/dll/win32/kernel32/misc/profile.c b/reactos/dll/win32/kernel32/misc/profile.c index f0d2fef957a..b8a06d2859f 100644 --- a/reactos/dll/win32/kernel32/misc/profile.c +++ b/reactos/dll/win32/kernel32/misc/profile.c @@ -756,7 +756,7 @@ static BOOL PROFILE_Open( LPCWSTR filename ) GetWindowsDirectoryW( windirW, MAX_PATH ); - if ((RtlDetermineDosPathNameType_U(filename) == RELATIVE_PATH) && + if ((RtlDetermineDosPathNameType_U(filename) == RtlPathTypeRelative) && !wcschr(filename, '\\') && !wcschr(filename, '/')) { static const WCHAR wszSeparator[] = {'\\', 0}; diff --git a/reactos/dll/win32/kernel32/misc/recovery.c b/reactos/dll/win32/kernel32/misc/recovery.c index 510397a916f..9a0d818aa83 100644 --- a/reactos/dll/win32/kernel32/misc/recovery.c +++ b/reactos/dll/win32/kernel32/misc/recovery.c @@ -30,6 +30,10 @@ * 10/28/2005 Created stubs (w3) */ +/* File contains Vista Semantics */ +#undef _WIN32_WINNT +#define _WIN32_WINNT 0x0600 + #include #define NDEBUG diff --git a/reactos/dll/win32/kernel32/misc/toolhelp.c b/reactos/dll/win32/kernel32/misc/toolhelp.c index 9a064b260f3..a67e938e85a 100644 --- a/reactos/dll/win32/kernel32/misc/toolhelp.c +++ b/reactos/dll/win32/kernel32/misc/toolhelp.c @@ -92,8 +92,8 @@ typedef struct _TH32SNAPSHOT /* INTERNAL FUNCTIONS *********************************************************/ static VOID -TH32FreeAllocatedResources(PRTL_DEBUG_BUFFER HeapDebug, - PRTL_DEBUG_BUFFER ModuleDebug, +TH32FreeAllocatedResources(PRTL_DEBUG_INFORMATION HeapDebug, + PRTL_DEBUG_INFORMATION ModuleDebug, PVOID ProcThrdInfo, SIZE_T ProcThrdInfoSize) { @@ -118,8 +118,8 @@ TH32FreeAllocatedResources(PRTL_DEBUG_BUFFER HeapDebug, static NTSTATUS TH32CreateSnapshot(DWORD dwFlags, DWORD th32ProcessID, - PRTL_DEBUG_BUFFER *HeapDebug, - PRTL_DEBUG_BUFFER *ModuleDebug, + PRTL_DEBUG_INFORMATION *HeapDebug, + PRTL_DEBUG_INFORMATION *ModuleDebug, PVOID *ProcThrdInfo, SIZE_T *ProcThrdInfoSize) { @@ -221,8 +221,8 @@ TH32CreateSnapshot(DWORD dwFlags, static NTSTATUS TH32CreateSnapshotSectionInitialize(DWORD dwFlags, DWORD th32ProcessID, - PRTL_DEBUG_BUFFER HeapDebug, - PRTL_DEBUG_BUFFER ModuleDebug, + PRTL_DEBUG_INFORMATION HeapDebug, + PRTL_DEBUG_INFORMATION ModuleDebug, PVOID ProcThrdInfo, HANDLE *SectionHandle) { @@ -248,8 +248,8 @@ TH32CreateSnapshotSectionInitialize(DWORD dwFlags, */ if(dwFlags & TH32CS_SNAPHEAPLIST) { - hi = (PRTL_PROCESS_HEAPS)HeapDebug->HeapInformation; - nHeaps = hi->HeapCount; + hi = (PRTL_PROCESS_HEAPS)HeapDebug->Heaps; + nHeaps = hi->NumberOfHeaps; RequiredSnapshotSize += nHeaps * sizeof(HEAPLIST32); } @@ -258,8 +258,8 @@ TH32CreateSnapshotSectionInitialize(DWORD dwFlags, */ if(dwFlags & TH32CS_SNAPMODULE) { - mi = (PRTL_PROCESS_MODULES)ModuleDebug->ModuleInformation; - nModules = mi->ModuleCount; + mi = (PRTL_PROCESS_MODULES)ModuleDebug->Modules; + nModules = mi->NumberOfModules; RequiredSnapshotSize += nModules * sizeof(MODULEENTRY32W); } @@ -350,13 +350,13 @@ TH32CreateSnapshotSectionInitialize(DWORD dwFlags, { HeapListEntry->dwSize = sizeof(HEAPLIST32); HeapListEntry->th32ProcessID = th32ProcessID; - HeapListEntry->th32HeapID = (ULONG_PTR)hi->HeapEntry[i].Base; - HeapListEntry->dwFlags = hi->HeapEntry[i].Flags; + HeapListEntry->th32HeapID = (ULONG_PTR)hi->Heaps[i].BaseAddress; + HeapListEntry->dwFlags = hi->Heaps[i].Flags; HeapListEntry++; } - DataOffset += hi->HeapCount * sizeof(HEAPLIST32); + DataOffset += hi->NumberOfHeaps * sizeof(HEAPLIST32); } /* initialize the module list */ @@ -370,22 +370,22 @@ TH32CreateSnapshotSectionInitialize(DWORD dwFlags, ModuleListEntry->dwSize = sizeof(MODULEENTRY32W); ModuleListEntry->th32ModuleID = 1; /* no longer used, always set to one! */ ModuleListEntry->th32ProcessID = th32ProcessID; - ModuleListEntry->GlblcntUsage = mi->ModuleEntry[i].LoadCount; - ModuleListEntry->ProccntUsage = mi->ModuleEntry[i].LoadCount; - ModuleListEntry->modBaseAddr = (BYTE*)mi->ModuleEntry[i].Base; - ModuleListEntry->modBaseSize = mi->ModuleEntry[i].Size; - ModuleListEntry->hModule = (HMODULE)mi->ModuleEntry[i].Base; + ModuleListEntry->GlblcntUsage = mi->Modules[i].LoadCount; + ModuleListEntry->ProccntUsage = mi->Modules[i].LoadCount; + ModuleListEntry->modBaseAddr = (BYTE*)mi->Modules[i].ImageBase; + ModuleListEntry->modBaseSize = mi->Modules[i].ImageSize; + ModuleListEntry->hModule = (HMODULE)mi->Modules[i].ImageBase; MultiByteToWideChar(CP_ACP, 0, - &mi->ModuleEntry[i].ImageName[mi->ModuleEntry[i].ModuleNameOffset], + &mi->Modules[i].FullPathName[mi->Modules[i].OffsetToFileName], -1, ModuleListEntry->szModule, sizeof(ModuleListEntry->szModule) / sizeof(ModuleListEntry->szModule[0])); MultiByteToWideChar(CP_ACP, 0, - mi->ModuleEntry[i].ImageName, + mi->Modules[i].FullPathName, -1, ModuleListEntry->szExePath, sizeof(ModuleListEntry->szExePath) / sizeof(ModuleListEntry->szExePath[0])); @@ -393,7 +393,7 @@ TH32CreateSnapshotSectionInitialize(DWORD dwFlags, ModuleListEntry++; } - DataOffset += mi->ModuleCount * sizeof(MODULEENTRY32W); + DataOffset += mi->NumberOfModules * sizeof(MODULEENTRY32W); } /* initialize the process list */ @@ -1113,7 +1113,7 @@ HANDLE STDCALL CreateToolhelp32Snapshot(DWORD dwFlags, DWORD th32ProcessID) { - PRTL_DEBUG_BUFFER HeapDebug, ModuleDebug; + PRTL_DEBUG_INFORMATION HeapDebug, ModuleDebug; PVOID ProcThrdInfo; SIZE_T ProcThrdInfoSize; NTSTATUS Status; diff --git a/reactos/dll/win32/kernel32/misc/utils.c b/reactos/dll/win32/kernel32/misc/utils.c index e6410cc6895..119f077910a 100644 --- a/reactos/dll/win32/kernel32/misc/utils.c +++ b/reactos/dll/win32/kernel32/misc/utils.c @@ -9,6 +9,7 @@ /* INCLUDES ****************************************************************/ #include +#include "i386/ketypes.h" #define NDEBUG #include "../include/debug.h" diff --git a/reactos/dll/win32/kernel32/process/create.c b/reactos/dll/win32/kernel32/process/create.c index b7c8e0374c7..fa20595cc41 100644 --- a/reactos/dll/win32/kernel32/process/create.c +++ b/reactos/dll/win32/kernel32/process/create.c @@ -883,7 +883,7 @@ GetAppName: PathType = RtlDetermineDosPathNameType_U(lpApplicationName); /* If it's not relative, try to get the error */ - if (PathType != RELATIVE_PATH) + if (PathType != RtlPathTypeRelative) { /* This should fail, and give us a detailed LastError */ hFile = CreateFileW(lpApplicationName, diff --git a/reactos/dll/win32/kernel32/thread/tls.c b/reactos/dll/win32/kernel32/thread/tls.c index 357cae3b021..404af6046a0 100644 --- a/reactos/dll/win32/kernel32/thread/tls.c +++ b/reactos/dll/win32/kernel32/thread/tls.c @@ -17,8 +17,6 @@ #define NDEBUG #include "../include/debug.h" -#define TLS_EXPANSION_SLOTS (8 * sizeof(((PPEB)NULL)->TlsExpansionBitmapBits)) - /* FUNCTIONS *****************************************************************/ /* diff --git a/reactos/dll/win32/psapi/psapi.c b/reactos/dll/win32/psapi/psapi.c index 5b1f26a5da7..d3fc5971438 100644 --- a/reactos/dll/win32/psapi/psapi.c +++ b/reactos/dll/win32/psapi/psapi.c @@ -42,7 +42,7 @@ typedef struct _ENUM_DEVICE_DRIVERS_CONTEXT } ENUM_DEVICE_DRIVERS_CONTEXT, *PENUM_DEVICE_DRIVERS_CONTEXT; NTSTATUS STDCALL -EnumDeviceDriversCallback(IN PSYSTEM_MODULE_INFORMATION_ENTRY CurrentModule, +EnumDeviceDriversCallback(IN PRTL_PROCESS_MODULE_INFORMATION CurrentModule, IN OUT PVOID CallbackContext) { PENUM_DEVICE_DRIVERS_CONTEXT Context = (PENUM_DEVICE_DRIVERS_CONTEXT)CallbackContext; @@ -54,7 +54,7 @@ EnumDeviceDriversCallback(IN PSYSTEM_MODULE_INFORMATION_ENTRY CurrentModule, } /* return current module */ - *Context->lpImageBase = CurrentModule->Base; + *Context->lpImageBase = CurrentModule->ImageBase; /* go to next array slot */ Context->lpImageBase++; @@ -141,22 +141,22 @@ typedef struct _GET_DEVICE_DRIVER_NAME_CONTEXT } GET_DEVICE_DRIVER_NAME_CONTEXT, *PGET_DEVICE_DRIVER_NAME_CONTEXT; NTSTATUS STDCALL -GetDeviceDriverNameCallback(IN PSYSTEM_MODULE_INFORMATION_ENTRY CurrentModule, +GetDeviceDriverNameCallback(IN PRTL_PROCESS_MODULE_INFORMATION CurrentModule, IN OUT PVOID CallbackContext) { PGET_DEVICE_DRIVER_NAME_CONTEXT Context = (PGET_DEVICE_DRIVER_NAME_CONTEXT)CallbackContext; /* module found */ - if(Context->ImageBase == CurrentModule->Base) + if(Context->ImageBase == CurrentModule->ImageBase) { PCHAR pcModuleName; ULONG l; /* get the full name or just the filename part */ if(Context->bFullName) - pcModuleName = &CurrentModule->ImageName[0]; + pcModuleName = &CurrentModule->FullPathName[0]; else - pcModuleName = &CurrentModule->ImageName[CurrentModule->PathLength]; + pcModuleName = &CurrentModule->FullPathName[CurrentModule->OffsetToFileName]; /* get the length of the name */ l = strlen(pcModuleName); diff --git a/reactos/drivers/base/blue/blue.c b/reactos/drivers/base/blue/blue.c index 6d44f5ff142..5010d8e7e56 100644 --- a/reactos/drivers/base/blue/blue.c +++ b/reactos/drivers/base/blue/blue.c @@ -18,11 +18,18 @@ typedef struct _SECURITY_ATTRIBUTES SECURITY_ATTRIBUTES, *PSECURITY_ATTRIBUTES; #include #include -#include #define NDEBUG #include +// ROS Internal. Please deprecate. +NTHALAPI +BOOLEAN +NTAPI +HalQueryDisplayOwnership( + VOID +); + /* DEFINITIONS ***************************************************************/ #define VIDMEM_BASE 0xb8000 diff --git a/reactos/drivers/filesystems/ms/msfs.h b/reactos/drivers/filesystems/ms/msfs.h index a9776f0677c..ea5c5f1a4dc 100644 --- a/reactos/drivers/filesystems/ms/msfs.h +++ b/reactos/drivers/filesystems/ms/msfs.h @@ -10,7 +10,7 @@ #define __DRIVERS_FS_MS_MSFS_H #include -#include +#include /* * FIXME: GCC doesn't have a working option for defaulting to a calling diff --git a/reactos/drivers/filesystems/vfat/vfat.h b/reactos/drivers/filesystems/vfat/vfat.h index ec7a1dfc0f2..a542ededb9f 100644 --- a/reactos/drivers/filesystems/vfat/vfat.h +++ b/reactos/drivers/filesystems/vfat/vfat.h @@ -4,7 +4,6 @@ #include #ifdef __GNUC__ -#include #include #define USE_ROS_CC_AND_FS diff --git a/reactos/drivers/multimedia/audio/sound/wave.c b/reactos/drivers/multimedia/audio/sound/wave.c index 437752340b8..a2da64d7eff 100644 --- a/reactos/drivers/multimedia/audio/sound/wave.c +++ b/reactos/drivers/multimedia/audio/sound/wave.c @@ -13,7 +13,6 @@ /* FUNCTIONS **************************************************************/ #include -#include #include #include diff --git a/reactos/drivers/network/tcpip/include/precomp.h b/reactos/drivers/network/tcpip/include/precomp.h index 29e4338ef7d..680d9dd01ec 100644 --- a/reactos/drivers/network/tcpip/include/precomp.h +++ b/reactos/drivers/network/tcpip/include/precomp.h @@ -1,6 +1,7 @@ #include #include #include +#include #include #include #include <../recmutex/recmutex.h> @@ -37,5 +38,4 @@ #include #include #include -#include #include diff --git a/reactos/drivers/storage/diskdump/diskdump.c b/reactos/drivers/storage/diskdump/diskdump.c index 732d41c1e65..cc17160d242 100644 --- a/reactos/drivers/storage/diskdump/diskdump.c +++ b/reactos/drivers/storage/diskdump/diskdump.c @@ -33,9 +33,8 @@ #include #include #include - -#include #include + #include "../scsiport/scsiport_int.h" #define NDEBUG diff --git a/reactos/drivers/video/videoprt/int10.c b/reactos/drivers/video/videoprt/int10.c index d3598daef3c..d28e49818cb 100644 --- a/reactos/drivers/video/videoprt/int10.c +++ b/reactos/drivers/video/videoprt/int10.c @@ -22,7 +22,7 @@ */ #include "videoprt.h" -#include "internal/ke.h" +#include "internal/i386/v86m.h" /* PRIVATE FUNCTIONS **********************************************************/ @@ -178,7 +178,7 @@ IntInt10CallBios( Regs.Ds = BiosArguments->SegDs; DPRINT("- Input register SegEs: %x\n", BiosArguments->SegEs); Regs.Es = BiosArguments->SegEs; - Status = Ke386CallBios(0x10, &Regs); + Status = Ke386CallBios(0x10, (PCONTEXT)&Regs); BiosArguments->Eax = Regs.Eax; BiosArguments->Ebx = Regs.Ebx; BiosArguments->Ecx = Regs.Ecx; @@ -234,7 +234,7 @@ VideoPortInt10( Regs.Edi = BiosArguments->Edi; DPRINT("- Input register Ebp: %x\n", BiosArguments->Ebp); Regs.Ebp = BiosArguments->Ebp; - Status = Ke386CallBios(0x10, &Regs); + Status = Ke386CallBios(0x10, (PCONTEXT)&Regs); BiosArguments->Eax = Regs.Eax; BiosArguments->Ebx = Regs.Ebx; BiosArguments->Ecx = Regs.Ecx; diff --git a/reactos/drivers/video/videoprt/videoprt.h b/reactos/drivers/video/videoprt/videoprt.h index e70e073752d..ca99ab1120f 100644 --- a/reactos/drivers/video/videoprt/videoprt.h +++ b/reactos/drivers/video/videoprt/videoprt.h @@ -41,6 +41,14 @@ #define DPFLTR_IHVVIDEO_ID 0 /* FIXME */ +/* ROS Internal. Please deprecate */ +NTHALAPI +VOID +NTAPI +HalReleaseDisplayOwnership( + VOID +); + typedef struct _VIDEO_PORT_ADDRESS_MAPPING { LIST_ENTRY List; diff --git a/reactos/hal/hal/hal.c b/reactos/hal/hal/hal.c index fd97737aafc..8e58f47b3d6 100644 --- a/reactos/hal/hal/hal.c +++ b/reactos/hal/hal/hal.c @@ -14,6 +14,8 @@ #include #include #include +#include +#include #define NDEBUG #include @@ -333,7 +335,7 @@ BOOLEAN NTAPI HalInitSystem( ULONG BootPhase, - PLOADER_PARAMETER_BLOCK LoaderBlock) + PROS_LOADER_PARAMETER_BLOCK LoaderBlock) { UNIMPLEMENTED; @@ -344,7 +346,7 @@ HalInitSystem( VOID NTAPI HalInitializeProcessor(ULONG ProcessorNumber, - PLOADER_PARAMETER_BLOCK LoaderBlock) + PROS_LOADER_PARAMETER_BLOCK LoaderBlock) { UNIMPLEMENTED; } @@ -558,7 +560,7 @@ HalTranslateBusAddress( VOID NTAPI IoAssignDriveLetters( - PLOADER_PARAMETER_BLOCK LoaderBlock, + PROS_LOADER_PARAMETER_BLOCK LoaderBlock, PSTRING NtDeviceName, PUCHAR NtSystemPath, PSTRING NtSystemPathString) diff --git a/reactos/hal/halx86/generic/display.c b/reactos/hal/halx86/generic/display.c index 48e3f44938e..b4ed7c35c29 100644 --- a/reactos/hal/halx86/generic/display.c +++ b/reactos/hal/halx86/generic/display.c @@ -571,7 +571,7 @@ HalRestorePalette(VOID) /* PRIVATE FUNCTIONS ********************************************************/ VOID FASTCALL -HalInitializeDisplay (PLOADER_PARAMETER_BLOCK LoaderBlock) +HalInitializeDisplay (PROS_LOADER_PARAMETER_BLOCK LoaderBlock) /* * FUNCTION: Initalize the display * ARGUMENTS: diff --git a/reactos/hal/halx86/generic/halinit.c b/reactos/hal/halx86/generic/halinit.c index 90c74fe3650..5a99876dc15 100644 --- a/reactos/hal/halx86/generic/halinit.c +++ b/reactos/hal/halx86/generic/halinit.c @@ -33,17 +33,17 @@ DriverEntry( BOOLEAN STDCALL HalInitSystem (ULONG BootPhase, - PLOADER_PARAMETER_BLOCK LoaderBlock) + PROS_LOADER_PARAMETER_BLOCK LoaderBlock) { if (BootPhase == 0) { RtlZeroMemory(&HalpHooks, sizeof(HALP_HOOKS)); - HalpInitPhase0(LoaderBlock); + HalpInitPhase0((PROS_LOADER_PARAMETER_BLOCK)LoaderBlock); } else if (BootPhase == 1) { /* Initialize display and make the screen black */ - HalInitializeDisplay (LoaderBlock); + HalInitializeDisplay ((PROS_LOADER_PARAMETER_BLOCK)LoaderBlock); HalpInitBusHandlers(); HalpInitDma(); diff --git a/reactos/hal/halx86/generic/irql.c b/reactos/hal/halx86/generic/irql.c index dc66dc83116..5ad9d079b3b 100644 --- a/reactos/hal/halx86/generic/irql.c +++ b/reactos/hal/halx86/generic/irql.c @@ -67,7 +67,7 @@ KIRQL STDCALL KeGetCurrentIrql (VOID) * RETURNS: The current irq level */ { - return(KeGetCurrentKPCR()->Irql); + return(KeGetPcr()->Irql); } VOID HalpInitPICs(VOID) @@ -136,7 +136,7 @@ HalpExecuteIrqs(KIRQL NewIrql) { if (HalpPendingInterruptCount[i] > 0) { - KeGetCurrentKPCR()->Irql = (KIRQL)IRQ_TO_DIRQL(i); + KeGetPcr()->Irql = (KIRQL)IRQ_TO_DIRQL(i); while (HalpPendingInterruptCount[i] > 0) { @@ -146,8 +146,8 @@ HalpExecuteIrqs(KIRQL NewIrql) HalpPendingInterruptCount[i]--; KiInterruptDispatch2(i + IRQ_BASE, NewIrql); } - KeGetCurrentKPCR()->Irql--; - HalpEndSystemInterrupt(KeGetCurrentKPCR()->Irql); + KeGetPcr()->Irql--; + HalpEndSystemInterrupt(KeGetPcr()->Irql); } } @@ -158,22 +158,22 @@ HalpLowerIrql(KIRQL NewIrql) { if (NewIrql >= PROFILE_LEVEL) { - KeGetCurrentKPCR()->Irql = NewIrql; + KeGetPcr()->Irql = NewIrql; return; } HalpExecuteIrqs(NewIrql); if (NewIrql >= DISPATCH_LEVEL) { - KeGetCurrentKPCR()->Irql = NewIrql; + KeGetPcr()->Irql = NewIrql; return; } - KeGetCurrentKPCR()->Irql = DISPATCH_LEVEL; - if (((PKIPCR)KeGetCurrentKPCR())->HalReserved[HAL_DPC_REQUEST]) + KeGetPcr()->Irql = DISPATCH_LEVEL; + if (((PKIPCR)KeGetPcr())->HalReserved[HAL_DPC_REQUEST]) { - ((PKIPCR)KeGetCurrentKPCR())->HalReserved[HAL_DPC_REQUEST] = FALSE; + ((PKIPCR)KeGetPcr())->HalReserved[HAL_DPC_REQUEST] = FALSE; KiDispatchInterrupt(); } - KeGetCurrentKPCR()->Irql = APC_LEVEL; + KeGetPcr()->Irql = APC_LEVEL; if (NewIrql == APC_LEVEL) { return; @@ -183,7 +183,7 @@ HalpLowerIrql(KIRQL NewIrql) { KiDeliverApc(KernelMode, NULL, NULL); } - KeGetCurrentKPCR()->Irql = PASSIVE_LEVEL; + KeGetPcr()->Irql = PASSIVE_LEVEL; } /********************************************************************** @@ -207,10 +207,10 @@ KfLowerIrql (KIRQL NewIrql) { DPRINT("KfLowerIrql(NewIrql %d)\n", NewIrql); - if (NewIrql > KeGetCurrentKPCR()->Irql) + if (NewIrql > KeGetPcr()->Irql) { DbgPrint ("(%s:%d) NewIrql %x CurrentIrql %x\n", - __FILE__, __LINE__, NewIrql, KeGetCurrentKPCR()->Irql); + __FILE__, __LINE__, NewIrql, KeGetPcr()->Irql); KEBUGCHECK(0); for(;;); } @@ -266,16 +266,16 @@ KfRaiseIrql (KIRQL NewIrql) DPRINT("KfRaiseIrql(NewIrql %d)\n", NewIrql); - if (NewIrql < KeGetCurrentKPCR()->Irql) + if (NewIrql < KeGetPcr()->Irql) { DbgPrint ("%s:%d CurrentIrql %x NewIrql %x\n", - __FILE__,__LINE__,KeGetCurrentKPCR()->Irql,NewIrql); + __FILE__,__LINE__,KeGetPcr()->Irql,NewIrql); KEBUGCHECK (0); for(;;); } - OldIrql = KeGetCurrentKPCR()->Irql; - KeGetCurrentKPCR()->Irql = NewIrql; + OldIrql = KeGetPcr()->Irql; + KeGetPcr()->Irql = NewIrql; return OldIrql; } @@ -380,13 +380,13 @@ HalBeginSystemInterrupt (ULONG Vector, WRITE_PORT_UCHAR((PUCHAR)0xa0,0x20); } - if (KeGetCurrentKPCR()->Irql >= Irql) + if (KeGetPcr()->Irql >= Irql) { HalpPendingInterruptCount[irq]++; return(FALSE); } - *OldIrql = KeGetCurrentKPCR()->Irql; - KeGetCurrentKPCR()->Irql = Irql; + *OldIrql = KeGetPcr()->Irql; + KeGetPcr()->Irql = Irql; return(TRUE); } @@ -461,11 +461,11 @@ HalRequestSoftwareInterrupt( switch (Request) { case APC_LEVEL: - ((PKIPCR)KeGetCurrentKPCR())->HalReserved[HAL_APC_REQUEST] = TRUE; + ((PKIPCR)KeGetPcr())->HalReserved[HAL_APC_REQUEST] = TRUE; break; case DISPATCH_LEVEL: - ((PKIPCR)KeGetCurrentKPCR())->HalReserved[HAL_DPC_REQUEST] = TRUE; + ((PKIPCR)KeGetPcr())->HalReserved[HAL_DPC_REQUEST] = TRUE; break; default: diff --git a/reactos/hal/halx86/generic/spinlock.c b/reactos/hal/halx86/generic/spinlock.c index 4ff00d3303a..432ca1fb9b1 100644 --- a/reactos/hal/halx86/generic/spinlock.c +++ b/reactos/hal/halx86/generic/spinlock.c @@ -91,7 +91,7 @@ KeAcquireQueuedSpinLock(IN PKLOCK_QUEUE_HANDLE LockHandle) */ KIRQL FASTCALL -KeAcquireQueuedSpinLockRaiseToSynch(IN PKLOCK_QUEUE_HANDLE LockHandle) +KeAcquireQueuedSpinLockRaiseToSynch(IN KSPIN_LOCK_QUEUE_NUMBER LockNumber) { /* Simply raise to dispatch */ return KfRaiseIrql(DISPATCH_LEVEL); diff --git a/reactos/hal/halx86/generic/timer.c b/reactos/hal/halx86/generic/timer.c index 2ec0310c344..3d299686c02 100644 --- a/reactos/hal/halx86/generic/timer.c +++ b/reactos/hal/halx86/generic/timer.c @@ -125,9 +125,9 @@ VOID STDCALL KeStallExecutionProcessor(ULONG Microseconds) { - PKIPCR Pcr = (PKIPCR)KeGetCurrentKPCR(); + PKIPCR Pcr = (PKIPCR)KeGetPcr(); - if (Pcr->PrcbData.FeatureBits & X86_FEATURE_TSC) + if (Pcr->PrcbData.FeatureBits & KF_RDTSC) { LARGE_INTEGER EndCount, CurrentCount; Ki386RdTSC(EndCount); @@ -201,14 +201,14 @@ VOID HalpCalibrateStallExecution(VOID) } UdelayCalibrated = TRUE; - Pcr = (PKIPCR)KeGetCurrentKPCR(); + Pcr = (PKIPCR)KeGetPcr(); /* Initialise timer interrupt with MILLISEC ms interval */ WRITE_PORT_UCHAR((PUCHAR) TMR_CTRL, TMR_SC0 | TMR_BOTH | TMR_MD2); /* binary, mode 2, LSB/MSB, ch 0 */ WRITE_PORT_UCHAR((PUCHAR) TMR_CNT0, LATCH & 0xff); /* LSB */ WRITE_PORT_UCHAR((PUCHAR) TMR_CNT0, LATCH >> 8); /* MSB */ - if (Pcr->PrcbData.FeatureBits & X86_FEATURE_TSC) + if (Pcr->PrcbData.FeatureBits & KF_RDTSC) { WaitFor8254Wraparound(); @@ -325,9 +325,9 @@ KeQueryPerformanceCounter(PLARGE_INTEGER PerformanceFreq) Ki386SaveFlags(Flags); Ki386DisableInterrupts(); - Pcr = (PKIPCR)KeGetCurrentKPCR(); + Pcr = (PKIPCR)KeGetPcr(); - if (Pcr->PrcbData.FeatureBits & X86_FEATURE_TSC) + if (Pcr->PrcbData.FeatureBits & KF_RDTSC) { Ki386RestoreFlags(Flags); if (NULL != PerformanceFreq) diff --git a/reactos/hal/halx86/include/hal.h b/reactos/hal/halx86/include/hal.h index e08a61b36bf..a71920cd408 100644 --- a/reactos/hal/halx86/include/hal.h +++ b/reactos/hal/halx86/include/hal.h @@ -14,11 +14,10 @@ /* IFS/DDK/NDK Headers */ #include #include -#include - -/* Internal Kernel Headers */ -#include -#include +#include +#include +#include +#include #define KPCR_BASE 0xFF000000 // HACK! diff --git a/reactos/hal/halx86/include/halp.h b/reactos/hal/halx86/include/halp.h index c23f39dce4b..2dded8edbb8 100644 --- a/reactos/hal/halx86/include/halp.h +++ b/reactos/hal/halx86/include/halp.h @@ -8,9 +8,18 @@ #define HAL_APC_REQUEST 0 #define HAL_DPC_REQUEST 1 +// +// Kernel Debugger Port Definition +// +typedef struct _KD_PORT_INFORMATION +{ + ULONG ComPort; + ULONG BaudRate; + ULONG BaseAddress; +} KD_PORT_INFORMATION, *PKD_PORT_INFORMATION; + /* display.c */ -struct _LOADER_PARAMETER_BLOCK; -VOID FASTCALL HalInitializeDisplay (struct _LOADER_PARAMETER_BLOCK *LoaderBlock); +VOID FASTCALL HalInitializeDisplay (struct _ROS_LOADER_PARAMETER_BLOCK *LoaderBlock); VOID FASTCALL HalClearDisplay (UCHAR CharAttribute); /* adapter.c */ @@ -38,7 +47,7 @@ VOID HalpInitDma (VOID); PVOID HalpMapPhysMemory(ULONG PhysAddr, ULONG Size); /* Non-generic initialization */ -VOID HalpInitPhase0 (PLOADER_PARAMETER_BLOCK LoaderBlock); +VOID HalpInitPhase0 (PROS_LOADER_PARAMETER_BLOCK LoaderBlock); /* sysinfo.c */ NTSTATUS STDCALL diff --git a/reactos/hal/halx86/include/mps.h b/reactos/hal/halx86/include/mps.h index c0c150d1f67..83f9cfbe501 100644 --- a/reactos/hal/halx86/include/mps.h +++ b/reactos/hal/halx86/include/mps.h @@ -9,6 +9,25 @@ #define IRQL2TPR(irql) ((irql) >= IPI_LEVEL ? IPI_VECTOR : ((irql) >= PROFILE_LEVEL ? LOCAL_TIMER_VECTOR : ((irql) > DISPATCH_LEVEL ? IRQL2VECTOR(irql) : 0))) +typedef struct _KIRQ_TRAPFRAME +{ + ULONG Magic; + ULONG Gs; + ULONG Fs; + ULONG Es; + ULONG Ds; + ULONG Eax; + ULONG Ecx; + ULONG Edx; + ULONG Ebx; + ULONG Esp; + ULONG Ebp; + ULONG Esi; + ULONG Edi; + ULONG Eip; + ULONG Cs; + ULONG Eflags; +} KIRQ_TRAPFRAME, *PKIRQ_TRAPFRAME; #if 0 /* This values are defined in halirql.h */ diff --git a/reactos/hal/halx86/mp/apic.c b/reactos/hal/halx86/mp/apic.c index f90fc007003..8323cf3af39 100644 --- a/reactos/hal/halx86/mp/apic.c +++ b/reactos/hal/halx86/mp/apic.c @@ -28,9 +28,10 @@ /* INCLUDE ***********************************************************************/ #include +#include /* Not in PCH because only used for MP HAL */ +#include /* Not in PCH because only used for MP HAL */ #define NDEBUG #include -#include /* GLOBALS ***********************************************************************/ @@ -809,7 +810,7 @@ MpsTimerHandler(ULONG Vector, PKIRQ_TRAPFRAME Trapframe) CPU = ThisCPU(); if ((Count[CPU] % 100) == 0) { - DbgPrint("(%s:%d) MpsTimerHandler on CPU%d, irql = %d, epi = %x, KPCR = %x\n", __FILE__, __LINE__, CPU, oldIrql,Trapframe->Eip, KeGetCurrentKPCR()); + DbgPrint("(%s:%d) MpsTimerHandler on CPU%d, irql = %d, epi = %x, KPCR = %x\n", __FILE__, __LINE__, CPU, oldIrql,Trapframe->Eip, KeGetPcr()); } Count[CPU]++; #endif @@ -862,7 +863,7 @@ APICCalibrateTimer(ULONG CPU) APICSetupLVTT(1000000000); - TSCPresent = ((PKIPCR)KeGetCurrentKPCR())->PrcbData.FeatureBits & X86_FEATURE_TSC ? TRUE : FALSE; + TSCPresent = ((PKIPCR)KeGetPcr())->PrcbData.FeatureBits & KF_RDTSC ? TRUE : FALSE; /* * The timer chip counts down to zero. Let's wait @@ -891,7 +892,7 @@ APICCalibrateTimer(ULONG CPU) DPRINT("CPU clock speed is %ld.%04ld MHz.\n", CPUMap[CPU].CoreSpeed/1000000, CPUMap[CPU].CoreSpeed%1000000); - ((PKIPCR)KeGetCurrentKPCR())->PrcbData.MHz = CPUMap[CPU].CoreSpeed/1000000; + ((PKIPCR)KeGetPcr())->PrcbData.MHz = CPUMap[CPU].CoreSpeed/1000000; } CPUMap[CPU].BusSpeed = (HZ * (long)(tt1 - tt2) * APIC_DIVISOR); @@ -919,7 +920,7 @@ SetInterruptGate(ULONG index, ULONG address) Access.SystemSegmentFlag = 0; Access.SegmentType = I386_INTERRUPT_GATE; - idt = (KIDTENTRY*)((ULONG)KeGetCurrentKPCR()->IDT + index * sizeof(KIDTENTRY)); + idt = (KIDTENTRY*)((ULONG)KeGetPcr()->IDT + index * sizeof(KIDTENTRY)); idt->Offset = address & 0xffff; idt->Selector = KGDT_R0_CODE; idt->Access = Access.Value; @@ -1037,11 +1038,11 @@ HaliStartApplicationProcessor(ULONG Cpu, ULONG Stack) /* Write the location of the AP stack */ Common->Stack = (ULONG)Stack; /* Write the page directory page */ - Ke386GetPageTableDirectory(Common->PageDirectory); + Common->PageDirectory = __readcr3(); /* Write the kernel entry point */ Common->NtProcessStartup = (ULONG_PTR)RtlImageNtHeader((PVOID)KernelBase)->OptionalHeader.AddressOfEntryPoint + KernelBase; /* Write the state of the mae mode */ - Common->PaeModeEnabled = Ke386GetCr4() & X86_CR4_PAE ? 1 : 0; + Common->PaeModeEnabled = __readcr4() & CR4_PAE ? 1 : 0; DPRINT1("%x %x %x %x\n", Common->Stack, Common->PageDirectory, Common->NtProcessStartup, Common->PaeModeEnabled); diff --git a/reactos/hal/halx86/mp/halinit_mp.c b/reactos/hal/halx86/mp/halinit_mp.c index a7b6bbda77b..9cd0f65ba41 100644 --- a/reactos/hal/halx86/mp/halinit_mp.c +++ b/reactos/hal/halx86/mp/halinit_mp.c @@ -22,7 +22,7 @@ ULONG_PTR KernelBase; /***************************************************************************/ VOID -HalpInitPhase0(PLOADER_PARAMETER_BLOCK LoaderBlock) +HalpInitPhase0(PROS_LOADER_PARAMETER_BLOCK LoaderBlock) { static BOOLEAN MPSInitialized = FALSE; diff --git a/reactos/hal/halx86/mp/mpsirql.c b/reactos/hal/halx86/mp/mpsirql.c index c22dd3139bd..47475c94c1e 100644 --- a/reactos/hal/halx86/mp/mpsirql.c +++ b/reactos/hal/halx86/mp/mpsirql.c @@ -39,7 +39,7 @@ KIRQL STDCALL KeGetCurrentIrql (VOID) DPRINT1 ("CurrentIrql %x\n", irql); KEBUGCHECK (0); } - if (Flags & X86_EFLAGS_IF) + if (Flags & EFLAGS_INTERRUPT_MASK) { Ki386EnableInterrupts(); } @@ -62,7 +62,7 @@ VOID KeSetCurrentIrql (KIRQL NewIrql) Ki386SaveFlags(Flags); Ki386DisableInterrupts(); Ki386WriteFsByte(FIELD_OFFSET(KPCR, Irql), NewIrql); - if (Flags & X86_EFLAGS_IF) + if (Flags & EFLAGS_INTERRUPT_MASK) { Ki386EnableInterrupts(); } @@ -90,7 +90,7 @@ HalpLowerIrql(KIRQL NewIrql, BOOLEAN FromHalEndSystemInterrupt) Ki386WriteFsByte(FIELD_OFFSET(KIPCR, HalReserved[HAL_DPC_REQUEST]), 0); Ki386EnableInterrupts(); KiDispatchInterrupt(); - if (!(Flags & X86_EFLAGS_IF)) + if (!(Flags & EFLAGS_INTERRUPT_MASK)) { Ki386DisableInterrupts(); } @@ -106,7 +106,7 @@ HalpLowerIrql(KIRQL NewIrql, BOOLEAN FromHalEndSystemInterrupt) { Ki386EnableInterrupts(); KiDeliverApc(KernelMode, NULL, NULL); - if (!(Flags & X86_EFLAGS_IF)) + if (!(Flags & EFLAGS_INTERRUPT_MASK)) { Ki386DisableInterrupts(); } @@ -207,7 +207,7 @@ KfRaiseIrql (KIRQL NewIrql) APICWrite (APIC_TPR, IRQL2TPR(NewIrql) & APIC_TPR_PRI); } KeSetCurrentIrql (NewIrql); - if (Flags & X86_EFLAGS_IF) + if (Flags & EFLAGS_INTERRUPT_MASK) { Ki386EnableInterrupts(); } @@ -305,7 +305,7 @@ HalBeginSystemInterrupt (ULONG Vector, } Ki386SaveFlags(Flags); - if (Flags & X86_EFLAGS_IF) + if (Flags & EFLAGS_INTERRUPT_MASK) { DPRINT1("HalBeginSystemInterrupt was called with interrupt's enabled\n"); KEBUGCHECK(0); @@ -327,7 +327,7 @@ HalEndSystemInterrupt (KIRQL Irql, ULONG Flags; Ki386SaveFlags(Flags); - if (Flags & X86_EFLAGS_IF) + if (Flags & EFLAGS_INTERRUPT_MASK) { DPRINT1("HalEndSystemInterrupt was called with interrupt's enabled\n"); KEBUGCHECK(0); diff --git a/reactos/hal/halx86/up/halinit_up.c b/reactos/hal/halx86/up/halinit_up.c index f5dfc25eaba..8b4824abf32 100644 --- a/reactos/hal/halx86/up/halinit_up.c +++ b/reactos/hal/halx86/up/halinit_up.c @@ -18,7 +18,7 @@ /* FUNCTIONS ***************************************************************/ VOID -HalpInitPhase0(PLOADER_PARAMETER_BLOCK LoaderBlock) +HalpInitPhase0(PROS_LOADER_PARAMETER_BLOCK LoaderBlock) { HalpInitPICs(); diff --git a/reactos/hal/halx86/xbox/display_xbox.c b/reactos/hal/halx86/xbox/display_xbox.c index be52bd2a5fb..3d1a070cc3d 100644 --- a/reactos/hal/halx86/xbox/display_xbox.c +++ b/reactos/hal/halx86/xbox/display_xbox.c @@ -284,7 +284,7 @@ I2CTransmitByteGetReturn(UCHAR bPicAddressI2cFormat, UCHAR bDataToWrite, ULONG * } VOID FASTCALL -HalInitializeDisplay (PLOADER_PARAMETER_BLOCK LoaderBlock) +HalInitializeDisplay (PROS_LOADER_PARAMETER_BLOCK LoaderBlock) /* * FUNCTION: Initalize the display * ARGUMENTS: diff --git a/reactos/hal/halx86/xbox/halinit_xbox.c b/reactos/hal/halx86/xbox/halinit_xbox.c index 863e8c52cdb..9824916a2c3 100644 --- a/reactos/hal/halx86/xbox/halinit_xbox.c +++ b/reactos/hal/halx86/xbox/halinit_xbox.c @@ -19,7 +19,7 @@ /* FUNCTIONS ***************************************************************/ VOID -HalpInitPhase0(PLOADER_PARAMETER_BLOCK LoaderBlock) +HalpInitPhase0(PROS_LOADER_PARAMETER_BLOCK LoaderBlock) { HalpHooks.InitPciBus = HalpXboxInitPciBus; diff --git a/reactos/include/ddk/winddk.h b/reactos/include/ddk/winddk.h index 537343aa5c4..270c0f56a7a 100644 --- a/reactos/include/ddk/winddk.h +++ b/reactos/include/ddk/winddk.h @@ -200,8 +200,12 @@ typedef struct _ADAPTER_OBJECT *PADAPTER_OBJECT; #define NtCurrentProcess() ( (HANDLE)(LONG_PTR) -1 ) #define ZwCurrentProcess() NtCurrentProcess() #define NtCurrentThread() ( (HANDLE)(LONG_PTR) -2 ) -#define ZwCurrentThread() NtCurrentThread() +#define ZwCurrentThread() NtCurrentThread() +#ifdef _REACTOS_ +#define KIP0PCRADDRESS 0xff000000 +#else #define KIP0PCRADDRESS 0xffdff000 +#endif #define KERNEL_STACK_SIZE 12288 #define KERNEL_LARGE_STACK_SIZE 61440 @@ -231,6 +235,8 @@ typedef struct _ADAPTER_OBJECT *PADAPTER_OBJECT; #define HIGH_PRIORITY 31 #define MAXIMUM_PRIORITY 32 +#define MAXIMUM_SUSPEND_COUNT MAXCHAR + #define FILE_SUPERSEDED 0x00000000 #define FILE_OPENED 0x00000001 #define FILE_CREATED 0x00000002 @@ -407,6 +413,8 @@ typedef struct _KSYSTEM_TIME LONG High2Time; } KSYSTEM_TIME, *PKSYSTEM_TIME; +extern volatile KSYSTEM_TIME KeTickCount; + typedef struct _KUSER_SHARED_DATA { ULONG TickCountLowDeprecated; @@ -1024,6 +1032,8 @@ typedef struct _KDEVICE_QUEUE_ENTRY { #define LOCK_QUEUE_WAIT 1 #define LOCK_QUEUE_OWNER 2 +#define LOCK_QUEUE_TIMER_LOCK_SHIFT 4 +#define LOCK_QUEUE_TIMER_TABLE_LOCKS (1 << (8 - LOCK_QUEUE_TIMER_LOCK_SHIFT)) typedef enum _KSPIN_LOCK_QUEUE_NUMBER { LockQueueDispatcherLock, @@ -1041,7 +1051,10 @@ typedef enum _KSPIN_LOCK_QUEUE_NUMBER { LockQueueNtfsStructLock, LockQueueAfdWorkQueueLock, LockQueueBcbLock, - LockQueueMaximumLock + LockQueueMmNonPagedPoolLock, + LockQueueUnusedSpare16, + LockQueueTimerTableLock, + LockQueueMaximumLock = LockQueueTimerTableLock + LOCK_QUEUE_TIMER_TABLE_LOCKS } KSPIN_LOCK_QUEUE_NUMBER, *PKSPIN_LOCK_QUEUE_NUMBER; typedef struct _KSPIN_LOCK_QUEUE { diff --git a/reactos/include/ndk/asm.h b/reactos/include/ndk/asm.h index cdd2c68b300..e870d5f6c86 100644 --- a/reactos/include/ndk/asm.h +++ b/reactos/include/ndk/asm.h @@ -26,9 +26,16 @@ Author: #define KernelMode 0x0 #define UserMode 0x1 +// +// CPU Types +// +#define CPU_INTEL 0x1 +#define CPU_AMD 0x2 + // // Selector Names // +#ifdef __ASM__ #define RPL_MASK 0x0003 #define MODE_MASK 0x0001 #define KGDT_R0_CODE (0x8) @@ -41,6 +48,7 @@ Author: #define KGDT_LDT (0x48) #define KGDT_DF_TSS (0x50) #define KGDT_NMI_TSS (0x58) +#endif // // KV86M_REGISTERS Offsets @@ -126,7 +134,7 @@ Author: #define KPCR_CURRENT_THREAD 0x124 #define KPCR_PROCESSOR_NUMBER 0x130 #define KPCR_PRCB_SET_MEMBER 0x134 -#define KPCR_NPX_THREAD 0x2F4 +#define KPCR_NPX_THREAD 0x640 #define KPCR_DR6 0x428 #define KPCR_DR7 0x42C #define KPCR_SYSTEM_CALLS 0x6B8 @@ -302,6 +310,7 @@ Author: // // EFLAGS // +#ifdef __ASM__ #define EFLAGS_TF 0x100 #define EFLAGS_INTERRUPT_MASK 0x200 #define EFLAGS_NESTED_TASK 0x4000 @@ -311,7 +320,6 @@ Author: #define EFLAGS_VIP 0x100000 #define EFLAG_SIGN 0x8000 #define EFLAG_ZERO 0x4000 -#ifndef EFLAG_SELECT #define EFLAG_SELECT (EFLAG_SIGN + EFLAG_ZERO) #endif @@ -333,6 +341,7 @@ Author: // // CR4 // +#ifdef __ASM__ #define CR4_VME 0x1 #define CR4_PVI 0x2 #define CR4_TSD 0x4 @@ -343,6 +352,7 @@ Author: #define CR4_PGE 0x80 #define CR4_FXSR 0x200 #define CR4_XMMEXCPT 0x400 +#endif // // Usermode callout frame definitions @@ -379,6 +389,19 @@ Author: #define SERVICE_DESCRIPTOR_NUMBER 0x000C #define SERVICE_DESCRIPTOR_LENGTH 0x0010 +// +// Machine types +// +#ifdef __ASM__ +#define MACHINE_TYPE_ISA 0x0000 +#define MACHINE_TYPE_EISA 0x0001 +#define MACHINE_TYPE_MCA 0x0002 + +// +// Kernel Feature Bits +// +#define KF_RDTSC 0x00000002 +#endif // // Generic Definitions // diff --git a/reactos/include/ndk/cctypes.h b/reactos/include/ndk/cctypes.h index d2d75c2b0d4..2e04cdb9d6e 100644 --- a/reactos/include/ndk/cctypes.h +++ b/reactos/include/ndk/cctypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ diff --git a/reactos/include/ndk/cmfuncs.h b/reactos/include/ndk/cmfuncs.h index 4e5c8d69403..9d5aec223e6 100644 --- a/reactos/include/ndk/cmfuncs.h +++ b/reactos/include/ndk/cmfuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ diff --git a/reactos/include/ndk/cmtypes.h b/reactos/include/ndk/cmtypes.h index b83d4f57e2b..2faef370eea 100644 --- a/reactos/include/ndk/cmtypes.h +++ b/reactos/include/ndk/cmtypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -42,6 +42,8 @@ Author: #define PNP_SET_DEVICE_STATUS 1 #define PNP_CLEAR_DEVICE_STATUS 2 +#ifdef NTOS_MODE_USER + // // Resource Type // @@ -59,7 +61,6 @@ Author: #define CmResourceTypePcCardConfig 130 #define CmResourceTypeMfCardConfig 131 -#ifdef NTOS_MODE_USER // // Resource Descriptor Share Dispositions @@ -342,7 +343,8 @@ typedef struct _PLUGPLAY_CONTROL_RELATED_DEVICE_DATA { UNICODE_STRING TargetDeviceInstance; ULONG Relation; - UNICODE_STRING RelatedDeviceInstance; + PWCHAR RelatedDeviceInstance; + ULONG RelatedDeviceInstanceLength; } PLUGPLAY_CONTROL_RELATED_DEVICE_DATA, *PPLUGPLAY_CONTROL_RELATED_DEVICE_DATA; // Class 0x0E @@ -473,6 +475,15 @@ typedef struct _CM_RESOURCE_LIST CM_FULL_RESOURCE_DESCRIPTOR List[1]; } CM_RESOURCE_LIST, *PCM_RESOURCE_LIST; +// +// ROM Block Structure +// +typedef struct _CM_ROM_BLOCK +{ + ULONG Address; + ULONG Size; +} CM_ROM_BLOCK, *PCM_ROM_BLOCK; + // // Disk/INT13 Structures // diff --git a/reactos/include/ndk/dbgkfuncs.h b/reactos/include/ndk/dbgkfuncs.h index 06008537793..b53cdf7f5d4 100644 --- a/reactos/include/ndk/dbgkfuncs.h +++ b/reactos/include/ndk/dbgkfuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -56,7 +56,7 @@ NtWaitForDebugEvent( OUT PDBGUI_WAIT_STATE_CHANGE StateChange ); -NTSYSCALLAPI +NTSYSAPI NTSTATUS NTAPI ZwCreateDebugObject( @@ -66,7 +66,7 @@ ZwCreateDebugObject( IN BOOLEAN KillProcessOnExit ); -NTSYSCALLAPI +NTSYSAPI NTSTATUS NTAPI ZwDebugContinue( @@ -75,7 +75,7 @@ ZwDebugContinue( IN NTSTATUS ContinueStatus ); -NTSYSCALLAPI +NTSYSAPI NTSTATUS NTAPI ZwWaitForDebugEvent( diff --git a/reactos/include/ndk/dbgktypes.h b/reactos/include/ndk/dbgktypes.h index e4c2f3bc91e..9c4a4fd7d30 100644 --- a/reactos/include/ndk/dbgktypes.h +++ b/reactos/include/ndk/dbgktypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ diff --git a/reactos/include/ndk/exfuncs.h b/reactos/include/ndk/exfuncs.h index f4c52a481ea..630aa5e6476 100644 --- a/reactos/include/ndk/exfuncs.h +++ b/reactos/include/ndk/exfuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -205,6 +205,15 @@ NtOpenEvent( IN POBJECT_ATTRIBUTES ObjectAttributes ); +NTSYSCALLAPI +NTSTATUS +NTAPI +NtOpenKeyedEvent( + OUT PHANDLE EventHandle, + IN ACCESS_MASK DesiredAccess, + IN POBJECT_ATTRIBUTES ObjectAttributes +); + NTSYSCALLAPI NTSTATUS NTAPI @@ -366,6 +375,16 @@ NtReleaseMutant( IN PLONG ReleaseCount OPTIONAL ); +NTSYSCALLAPI +NTSTATUS +NTAPI +NtReleaseKeyedEvent( + IN HANDLE EventHandle, + IN PVOID Key, + IN BOOLEAN Alertable, + IN PLARGE_INTEGER Timeout OPTIONAL +); + NTSYSCALLAPI NTSTATUS NTAPI @@ -413,6 +432,13 @@ NtSetEvent( OUT PLONG PreviousState OPTIONAL ); +NTSYSCALLAPI +NTSTATUS +NTAPI +NtSetEventBoostPriority( + IN HANDLE EventHandle +); + NTSYSCALLAPI NTSTATUS NTAPI @@ -485,6 +511,16 @@ NtShutdownSystem( IN SHUTDOWN_ACTION Action ); +NTSYSCALLAPI +NTSTATUS +NTAPI +NtWaitForKeyedEvent( + IN HANDLE EventHandle, + IN PVOID Key, + IN BOOLEAN Alertable, + IN PLARGE_INTEGER Timeout OPTIONAL +); + NTSYSCALLAPI NTSTATUS NTAPI @@ -535,7 +571,6 @@ ZwClearEvent( IN HANDLE EventHandle ); -NTSYSAPI NTSYSAPI NTSTATUS NTAPI @@ -823,6 +858,7 @@ ZwSetDefaultHardErrorPort( IN HANDLE PortHandle ); +NTSYSAPI NTSYSAPI NTSTATUS NTAPI diff --git a/reactos/include/ndk/extypes.h b/reactos/include/ndk/extypes.h index 6e1c7d121d1..47ddf860230 100644 --- a/reactos/include/ndk/extypes.h +++ b/reactos/include/ndk/extypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -196,9 +196,9 @@ typedef enum _SYSTEM_INFORMATION_CLASS SystemUnloadGdiDriverInformation, SystemTimeAdjustmentInformation, SystemSummaryMemoryInformation, - SystemNextEventIdInformation, - SystemEventIdsInformation, - SystemCrashDumpInformation, + SystemMirrorMemoryInformation, + SystemPerformanceTraceInformation, + SystemObsolete0, SystemExceptionInformation, SystemCrashDumpStateInformation, SystemKernelDebuggerInformation, @@ -220,7 +220,51 @@ typedef enum _SYSTEM_INFORMATION_CLASS SystemVerifierInformation, SystemAddVerifier, SystemSessionProcessesInformation, - SystemInformationClassMax + SystemLoadGdiDriverInSystemSpaceInformation, + SystemNumaProcessorMap, + SystemPrefetcherInformation, + SystemExtendedProcessInformation, + SystemRecommendedSharedDataAlignment, + SystemComPlusPackage, + SystemNumaAvailableMemory, + SystemProcessorPowerInformation, + SystemEmulationBasicInformation, + SystemEmulationProcessorInformation, + SystemExtendedHanfleInformation, + SystemLostDelayedWriteInformation, + SystemBigPoolInformation, + SystemSessionPoolTagInformation, + SystemSessionMappedViewInformation, + SystemHotpatchInformation, + SystemObjectSecurityMode, + SystemWatchDogTimerHandler, + SystemWatchDogTimerInformation, + SystemLogicalProcessorInformation, + SystemWo64SharedInformationObosolete, + SystemRegisterFirmwareTableInformationHandler, + SystemFirmwareTableInformation, + SystemModuleInformationEx, + SystemVerifierTriageInformation, + SystemSuperfetchInformation, + SystemMemoryListInformation, + SystemFileCacheInformationEx, + SystemThreadPriorityClientIdInformation, + SystemProcessorIdleCycleTimeInformation, + SystemVerifierCancellationInformation, + SystemProcessorPowerInformationEx, + SystemRefTraceInformation, + SystemSpecialPoolInformation, + SystemProcessIdInformation, + SystemErrorPortInformation, + SystemBootEnvironmentInformation, + SystemHypervisorInformation, + SystemVerifierInformationEx, + SystemTimeZoneInformation, + SystemImageFileExecutionOptionsInformation, + SystemCoverageInformation, + SystemPrefetchPathInformation, + SystemVerifierFaultsInformation, + MaxSystemInfoClass, } SYSTEM_INFORMATION_CLASS; // @@ -228,7 +272,8 @@ typedef enum _SYSTEM_INFORMATION_CLASS // typedef enum _MUTANT_INFORMATION_CLASS { - MutantBasicInformation + MutantBasicInformation, + MutantOwnerInformation } MUTANT_INFORMATION_CLASS; // @@ -264,7 +309,28 @@ typedef enum _EVENT_INFORMATION_CLASS EventBasicInformation } EVENT_INFORMATION_CLASS; -#ifndef NTOS_MODE_USER +#ifdef NTOS_MODE_USER + +// +// Firmware Table Actions for SystemFirmwareTableInformation +// +typedef enum _SYSTEM_FIRMWARE_TABLE_ACTION +{ + SystemFirmwareTable_Enumerate = 0, + SystemFirmwareTable_Get = 1, +} SYSTEM_FIRMWARE_TABLE_ACTION, *PSYSTEM_FIRMWARE_TABLE_ACTION; + +// +// Firmware Handler Callback +// +struct _SYSTEM_FIRMWARE_TABLE_INFORMATION; +typedef +NTSTATUS +(__cdecl *PFNFTH)( + IN struct _SYSTEM_FIRMWARE_TABLE_INFORMATION *FirmwareTableInformation +); + +#else // // Executive Work Queue Structures @@ -305,12 +371,10 @@ typedef struct _EX_FAST_REF // typedef struct _EX_RUNDOWN_REF_CACHE_AWARE { - union - { - ULONG_PTR Count; - PVOID Ptr; - }; + PEX_RUNDOWN_REF RunRefs; PVOID PoolToFree; + ULONG RunRefSize; + ULONG Number; } EX_RUNDOWN_REF_CACHE_AWARE, *PEX_RUNDOWN_REF_CACHE_AWARE; // @@ -319,7 +383,7 @@ typedef struct _EX_RUNDOWN_REF_CACHE_AWARE typedef struct _EX_RUNDOWN_WAIT_BLOCK { ULONG_PTR Count; - KEVENT RundownEvent; + KEVENT WakeEvent; } EX_RUNDOWN_WAIT_BLOCK, *PEX_RUNDOWN_WAIT_BLOCK; // @@ -382,18 +446,18 @@ typedef struct _CALLBACK_OBJECT } CALLBACK_OBJECT , *PCALLBACK_OBJECT; // -// Profile OBject +// Profile Object // typedef struct _EPROFILE { PEPROCESS Process; - PVOID ImageBase; - SIZE_T ImageSize; + PVOID RangeBase; + SIZE_T RangeSize; PVOID Buffer; ULONG BufferSize; ULONG BucketSize; - PKPROFILE KeProfile; - PVOID LockedBuffer; + PKPROFILE ProfileObject; + PVOID LockedBufferAddress; PMDL Mdl; ULONG Segment; KPROFILE_SOURCE ProfileSource; @@ -466,6 +530,11 @@ typedef struct _MUTANT_BASIC_INFORMATION BOOLEAN AbandonedState; } MUTANT_BASIC_INFORMATION, *PMUTANT_BASIC_INFORMATION; +typedef struct _MUTANT_OWNER_INFORMATION +{ + CLIENT_ID ClientId; +} MUTANT_OWNER_INFORMATION, *PMUTANT_OWNER_INFORMATION; + // // Information Structures for NtQueryAtom // @@ -662,7 +731,7 @@ typedef struct _SYSTEM_PROCESS_INFORMATION HANDLE InheritedFromUniqueProcessId; ULONG HandleCount; ULONG SessionId; - ULONG PageDirectoryFrame; + ULONG UniqueProcessKey; // // This part corresponds to VM_COUNTERS_EX. @@ -679,7 +748,7 @@ typedef struct _SYSTEM_PROCESS_INFORMATION ULONG QuotaNonPagedPoolUsage; ULONG PagefileUsage; ULONG PeakPagefileUsage; - ULONG PrivateUsage; + ULONG PrivatePageCount; // // This part corresponds to IO_COUNTERS @@ -691,7 +760,7 @@ typedef struct _SYSTEM_PROCESS_INFORMATION LARGE_INTEGER WriteTransferCount; LARGE_INTEGER OtherTransferCount; - SYSTEM_THREAD_INFORMATION TH[1]; + //SYSTEM_THREAD_INFORMATION TH[1]; } SYSTEM_PROCESS_INFORMATION, *PSYSTEM_PROCESS_INFORMATION; // Class 6 @@ -737,57 +806,11 @@ typedef struct _SYSTEM_CALL_TIME_INFORMATION LARGE_INTEGER TimeOfCalls[1]; } SYSTEM_CALL_TIME_INFORMATION, *PSYSTEM_CALL_TIME_INFORMATION; -// Class 11 -typedef struct _SYSTEM_MODULE_INFORMATION_ENTRY -{ - ULONG Unknown1; - ULONG Unknown2; - PVOID Base; - ULONG Size; - ULONG Flags; - USHORT Index; - USHORT NameLength; - USHORT LoadCount; - USHORT PathLength; - CHAR ImageName[256]; -} SYSTEM_MODULE_INFORMATION_ENTRY, *PSYSTEM_MODULE_INFORMATION_ENTRY; -typedef struct _SYSTEM_MODULE_INFORMATION -{ - ULONG Count; - SYSTEM_MODULE_INFORMATION_ENTRY Module[1]; -} SYSTEM_MODULE_INFORMATION, *PSYSTEM_MODULE_INFORMATION; - -// Class 12 -typedef struct _SYSTEM_RESOURCE_LOCK_ENTRY -{ - ULONG ResourceAddress; - ULONG Always1; - ULONG Unknown; - ULONG ActiveCount; - ULONG ContentionCount; - ULONG Unused[2]; - ULONG NumberOfSharedWaiters; - ULONG NumberOfExclusiveWaiters; -} SYSTEM_RESOURCE_LOCK_ENTRY, *PSYSTEM_RESOURCE_LOCK_ENTRY; +// Class 11 - See RTL_PROCESS_MODULES -typedef struct _SYSTEM_RESOURCE_LOCK_INFO -{ - ULONG Count; - SYSTEM_RESOURCE_LOCK_ENTRY Lock[1]; -} SYSTEM_RESOURCE_LOCK_INFO, *PSYSTEM_RESOURCE_LOCK_INFO; - -// FIXME: Class 13 -typedef struct _SYSTEM_BACKTRACE_INFORMATION_ENTRY -{ - ULONG Dummy; -} SYSTEM_BACKTRACE_INFORMATION_ENTRY, *PSYSTEM_BACKTRACE_INFORMATION_ENTRY; +// Class 12 - See RTL_PROCESS_LOCKS -typedef struct _SYSTEM_BACKTRACE_INFORMATION -{ - ULONG Unknown[4]; - ULONG Count; - SYSTEM_BACKTRACE_INFORMATION_ENTRY Trace[1]; -} SYSTEM_BACKTRACE_INFORMATION, *PSYSTEM_BACKTRACE_INFORMATION; +// Class 13 - See RTL_PROCESS_BACKTRACES // Class 14 - 15 typedef struct _SYSTEM_POOL_ENTRY @@ -914,14 +937,10 @@ typedef struct _SYSTEM_VDM_INSTEMUL_INFO ULONG BopCount; } SYSTEM_VDM_INSTEMUL_INFO, *PSYSTEM_VDM_INSTEMUL_INFO; -// FIXME: Class 20 -typedef struct _SYSTEM_VDM_BOP_INFO -{ - PVOID Dummy; -} SYSTEM_VDM_BOP_INFO, *PSYSTEM_VDM_BOP_INFO; +// Class 20 - ULONG VDMBOPINFO // Class 21 -typedef struct _SYSTEM_CACHE_INFORMATION +typedef struct _SYSTEM_FILECACHE_INFORMATION { ULONG CurrentSize; ULONG PeakSize; @@ -930,8 +949,9 @@ typedef struct _SYSTEM_CACHE_INFORMATION ULONG MaximumWorkingSet; ULONG CurrentSizeIncludingTransitionInPages; ULONG PeakSizeIncludingTransitionInPages; - ULONG Unused[2]; -} SYSTEM_CACHE_INFORMATION, *PSYSTEM_CACHE_INFORMATION; + ULONG TransitionRePurposeCount; + ULONG Flags; +} SYSTEM_FILECACHE_INFORMATION, *PSYSTEM_FILECACHE_INFORMATION; // Class 22 typedef struct _SYSTEM_POOLTAG @@ -984,6 +1004,7 @@ typedef struct _SYSTEM_MEMORY_INFO USHORT ModifiedCount; USHORT PageTableCount; } SYSTEM_MEMORY_INFO, *PSYSTEM_MEMORY_INFO; + typedef struct _SYSTEM_MEMORY_INFORMATION { ULONG InfoSize; @@ -999,6 +1020,7 @@ typedef struct _SYSTEM_GDI_DRIVER_INFORMATION PVOID SectionPointer; PVOID EntryPoint; PIMAGE_EXPORT_DIRECTORY ExportSectionPointer; + ULONG ImageLength; } SYSTEM_GDI_DRIVER_INFORMATION, *PSYSTEM_GDI_DRIVER_INFORMATION; // Class 27 @@ -1020,13 +1042,18 @@ typedef struct _SYSTEM_SET_TIME_ADJUST_INFORMATION // Class 29 - Same as 25 -// FIXME: Class 30 - 31 +// FIXME: Class 30 -// Class 32 -typedef struct _SYSTEM_CRASH_DUMP_INFORMATION +// Class 31 +typedef struct _SYSTEM_REF_TRACE_INFORMATION { - HANDLE CrashDumpSection; -} SYSTEM_CRASH_DUMP_INFORMATION, *PSYSTEM_CRASH_DUMP_INFORMATION; + UCHAR TraceEnable; + UCHAR TracePermanent; + UNICODE_STRING TraceProcessName; + UNICODE_STRING TracePoolTags; +} SYSTEM_REF_TRACE_INFORMATION, *PSYSTEM_REF_TRACE_INFORMATION; + +// Class 32 - OBSOLETE // Class 33 typedef struct _SYSTEM_EXCEPTION_INFORMATION @@ -1151,16 +1178,135 @@ typedef struct _SYSTEM_LOOKASIDE_INFORMATION // Class 50 // Not a structure. Only a ULONG_PTR for the SystemRangeStart -// FIXME: Class 51 (Based on MM_DRIVER_VERIFIER_DATA) +// Class 51 +typedef struct _SYSTEM_VERIFIER_INFORMATION +{ + ULONG NextEntryOffset; + ULONG Level; + UNICODE_STRING DriverName; + ULONG RaiseIrqls; + ULONG AcquireSpinLocks; + ULONG SynchronizeExecutions; + ULONG AllocationsAttempted; + ULONG AllocationsSucceeded; + ULONG AllocationsSucceededSpecialPool; + ULONG AllocationsWithNoTag; + ULONG TrimRequests; + ULONG Trims; + ULONG AllocationsFailed; + ULONG AllocationsFailedDeliberately; + ULONG Loads; + ULONG Unloads; + ULONG UnTrackedPool; + ULONG CurrentPagedPoolAllocations; + ULONG CurrentNonPagedPoolAllocations; + ULONG PeakPagedPoolAllocations; + ULONG PeakNonPagedPoolAllocations; + ULONG PagedPoolUsageInBytes; + ULONG NonPagedPoolUsageInBytes; + ULONG PeakPagedPoolUsageInBytes; + ULONG PeakNonPagedPoolUsageInBytes; +} SYSTEM_VERIFIER_INFORMATION, *PSYSTEM_VERIFIER_INFORMATION; // FIXME: Class 52 // Class 53 -typedef struct _SYSTEM_SESSION_PROCESSES_INFORMATION +typedef struct _SYSTEM_SESSION_PROCESS_INFORMATION { ULONG SessionId; - ULONG BufferSize; + ULONG SizeOfBuf; PVOID Buffer; // Same format as in SystemProcessInformation -} SYSTEM_SESSION_PROCESSES_INFORMATION, *PSYSTEM_SESSION_PROCESSES_INFORMATION; +} SYSTEM_SESSION_PROCESS_INFORMATION, *PSYSTEM_SESSION_PROCESS_INFORMATION; + +// FIXME: Class 54-97 +// +// Hotpatch flags +// +#define RTL_HOTPATCH_SUPPORTED_FLAG 0x01 +#define RTL_HOTPATCH_SWAP_OBJECT_NAMES 0x08 << 24 +#define RTL_HOTPATCH_SYNC_RENAME_FILES 0x10 << 24 +#define RTL_HOTPATCH_PATCH_USER_MODE 0x20 << 24 +#define RTL_HOTPATCH_REMAP_SYSTEM_DLL 0x40 << 24 +#define RTL_HOTPATCH_PATCH_KERNEL_MODE 0x80 << 24 + + +// Class 69 +typedef struct _SYSTEM_HOTPATCH_CODE_INFORMATION +{ + ULONG Flags; + ULONG InfoSize; + union + { + struct + { + ULONG Foo; + } CodeInfo; + struct + { + USHORT NameOffset; + USHORT NameLength; + } KernelInfo; + struct + { + USHORT NameOffset; + USHORT NameLength; + USHORT TargetNameOffset; + USHORT TargetNameLength; + UCHAR PatchingFinished; + } UserModeInfo; + struct + { + USHORT NameOffset; + USHORT NameLength; + USHORT TargetNameOffset; + USHORT TargetNameLength; + UCHAR PatchingFinished; + NTSTATUS ReturnCode; + HANDLE TargetProcess; + } InjectionInfo; + struct + { + HANDLE FileHandle1; + PIO_STATUS_BLOCK IoStatusBlock1; + PVOID RenameInformation1; + PVOID RenameInformationLength1; + HANDLE FileHandle2; + PIO_STATUS_BLOCK IoStatusBlock2; + PVOID RenameInformation2; + PVOID RenameInformationLength2; + } RenameInfo; + struct + { + HANDLE ParentDirectory; + HANDLE ObjectHandle1; + HANDLE ObjectHandle2; + } AtomicSwap; + }; +} SYSTEM_HOTPATCH_CODE_INFORMATION, *PSYSTEM_HOTPATCH_CODE_INFORMATION; + +// +// Class 75 +// +#ifdef NTOS_MODE_USER +typedef struct _SYSTEM_FIRMWARE_TABLE_HANDLER +{ + ULONG ProviderSignature; + BOOLEAN Register; + PFNFTH FirmwareTableHandler; + PVOID DriverObject; +} SYSTEM_FIRMWARE_TABLE_HANDLER, *PSYSTEM_FIRMWARE_TABLE_HANDLER; + +// +// Class 76 +// +typedef struct _SYSTEM_FIRMWARE_TABLE_INFORMATION +{ + ULONG ProviderSignature; + SYSTEM_FIRMWARE_TABLE_ACTION Action; + ULONG TableID; + ULONG TableBufferLength; + UCHAR TableBuffer[1]; +} SYSTEM_FIRMWARE_TABLE_INFORMATION, *PSYSTEM_FIRMWARE_TABLE_INFORMATION; +#endif #endif diff --git a/reactos/include/ndk/fixmes.txt b/reactos/include/ndk/fixmes.txt index 3f5c0b87467..e69de29bb2d 100644 --- a/reactos/include/ndk/fixmes.txt +++ b/reactos/include/ndk/fixmes.txt @@ -1,88 +0,0 @@ -List of ReactOS Applications compiling with the NDK -(verify, fix, and optimize their usage) --------------------------------------------------------------- - -apps\utils\ps\ps.c: #include -drivers\dd\blue\blue.c: #include -drivers\dd\bootvid\bootvid.c: #include -drivers\storage\diskdump\diskdump.c: #include -drivers\storage\diskdump\diskdump.c: #include -hal\hal\hal.c: #include -hal\hal\hal.c: #include -lib\crt\except\unwind.c: #include -lib\crt\except\unwind.c: #include -lib\crt\except\unwind.c: #include -lib\dnsapi\dnsapi\stubs.c: #include -lib\epsapi\enum\drivers.c: #include -lib\epsapi\enum\modules.c: #include -lib\epsapi\enum\processes.c: #include -lib\lsasrv\lsaport.c: #include -lib\lsasrv\lsasrv.c: #include -lib\nt\entry_point.c: #include -lib\samlib\samlib.c: #include -lib\samsrv\samsrv.c: #include -lib\smdll\query.c: #include -lib\string\mbstowcs.c: #include -lib\string\mbstowcs.c: #include -lib\string\sscanf.c: #include -lib\string\sscanf.c: #include -lib\string\wcstombs.c: #include -lib\string\wcstombs.c: #include -lib\syssetup\install.c: #include -lib\syssetup\logfile.c: #include -lib\wdmguid\wdmguid.c: #include -regtests\shared\regtests.c: #include -services\umpnpmgr\umpnpmgr.c: #include -subsys\ntvdm\ntvdm.c: #include -subsys\system\autochk\autochk.c: #include -subsys\system\lsass\lsass.c: #include -subsys\system\setup\setup.c: #include -subsys\system\sm\sm.c: #include -boot\freeldr\freeldr\include\freeldr.h: #include -drivers\fs\ms\msfs.h: #include -drivers\fs\np\npfs.h: #include -drivers\fs\vfat\vfat.h: #include -drivers\net\ndis\include\ndissys.h: #include -drivers\net\tcpip\include\precomp.h: #include -drivers\video\miniport\xboxvmp\xboxvmp.h: #include -drivers\video\videoprt\videoprt.h: #include -hal\halx86\include\hal.h: #include -include\drivers\diskdump\diskdump.h: #include -lib\advapi32\advapi32.h: #include -lib\crt\precomp.h: #include -lib\dbghelp\stackframe.h: #include -lib\dbghelp\stackframe.h: #include -lib\dbghelp\stackframe.h: #include -lib\dnsapi\dnsapi\precomp.h: #include -lib\fmifs\precomp.h: #include -lib\fslib\vfatlib\vfatlib.h: #include -lib\fslib\vfatxlib\vfatxlib.h: #include -lib\gdi32\include\precomp.h: #include -lib\imagehlp\precomp.h: #include -lib\imagehlp\precomp.h: #include -lib\iphlpapi\iphlpapi_private.h: #include -lib\kernel32\k32.h: #include -lib\msafd\msafd.h: #include -lib\ntdll\inc\ntdll.h: #include -lib\opengl32\teb.h: #include -lib\psapi\precomp.h: #include -lib\rtl\rtl.h: #include -lib\secur32\precomp.h: #include -lib\setupapi\setupapi_private.h: #include -lib\smlib\precomp.h: #include -lib\user32\include\user32.h: #include -lib\userenv\precomp.h: #include -lib\wshirda\wshirda.h: #include -ntoskrnl\include\ntoskrnl.h: #include -ntoskrnl\include\internal\napi.h: #include -services\dhcp\include\rosdhcp.h: #include -services\eventlog\eventlog.h: #include -services\rpcss\rpcss.h: #include -subsys\csrss\csrss.h: #include -subsys\csrss\include\api.h: #include -subsys\csrss\win32csr\w32csr.h: #include -subsys\smss\smss.h: #include -subsys\system\cmd\precomp.h: #include -subsys\system\services\services.h: #include -subsys\system\taskmgr\precomp.h: #include -subsys\system\usetup\usetup.h: #include diff --git a/reactos/include/ndk/halfuncs.h b/reactos/include/ndk/halfuncs.h index 8c7bb505498..c8e29b93375 100644 --- a/reactos/include/ndk/halfuncs.h +++ b/reactos/include/ndk/halfuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -30,14 +30,6 @@ Author: // // The DDK steals these away from you. // -VOID -_enable( - VOID -); -VOID -_disable( - VOID -); #ifdef _MSC_VER #pragma intrinsic(_enable) #pragma intrinsic(_disable) @@ -46,13 +38,6 @@ _disable( // // Display Functions // -NTHALAPI -BOOLEAN -NTAPI -HalQueryDisplayOwnership( - VOID -); - NTHALAPI VOID NTAPI @@ -60,20 +45,6 @@ HalDisplayString( IN PCHAR String ); -NTHALAPI -BOOLEAN -NTAPI -HalQueryDisplayOwnership( - VOID -); - -NTHALAPI -VOID -NTAPI -HalReleaseDisplayOwnership( - VOID -); - // // Initialization Functions // @@ -84,12 +55,13 @@ HalAllProcessorsStarted( VOID ); +#ifdef _ARC_ NTHALAPI VOID NTAPI HalInitializeProcessor( ULONG ProcessorNumber, - PLOADER_PARAMETER_BLOCK LoaderBlock + struct _LOADER_PARAMETER_BLOCK *LoaderBlock ); NTHALAPI @@ -97,8 +69,9 @@ BOOLEAN NTAPI HalInitSystem( ULONG BootPhase, - PLOADER_PARAMETER_BLOCK LoaderBlock + struct _LOADER_PARAMETER_BLOCK *LoaderBlock ); +#endif NTHALAPI VOID @@ -179,7 +152,7 @@ NTHALAPI VOID NTAPI HalRequestIpi( - ULONG Unknown + KAFFINITY TargetSet ); NTHALAPI @@ -192,6 +165,7 @@ HalHandleNMI( // // I/O Functions // +#ifdef _ARC_ NTHALAPI VOID NTAPI @@ -201,6 +175,7 @@ IoAssignDriveLetters( PUCHAR NtSystemPath, PSTRING NtSystemPathString ); +#endif // // Environment Functions @@ -213,5 +188,15 @@ HalSetEnvironmentVariable( IN PCH Value ); +// +// Time Functions +// +NTHALAPI +VOID +NTAPI +HalQueryRealTimeClock( + IN PTIME_FIELDS RtcTime +); + #endif #endif diff --git a/reactos/include/ndk/haltypes.h b/reactos/include/ndk/haltypes.h index 177dfa239a7..9da8109662f 100644 --- a/reactos/include/ndk/haltypes.h +++ b/reactos/include/ndk/haltypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -26,29 +26,10 @@ Author: #ifndef NTOS_MODE_USER -// -// Multi-Boot Flags (REMOVE ME) -// -#ifdef _REACTOS_ -#define MB_FLAGS_MEM_INFO (0x1) -#define MB_FLAGS_BOOT_DEVICE (0x2) -#define MB_FLAGS_COMMAND_LINE (0x4) -#define MB_FLAGS_MODULE_INFO (0x8) -#define MB_FLAGS_AOUT_SYMS (0x10) -#define MB_FLAGS_ELF_SYMS (0x20) -#define MB_FLAGS_MMAP_INFO (0x40) -#define MB_FLAGS_DRIVES_INFO (0x80) -#define MB_FLAGS_CONFIG_TABLE (0x100) -#define MB_FLAGS_BOOT_LOADER_NAME (0x200) -#define MB_FLAGS_APM_TABLE (0x400) -#define MB_FLAGS_GRAPHICS_TABLE (0x800) -#define MB_FLAGS_ACPI_TABLE (0x1000) -#endif - // // HalShutdownSystem Types // -typedef enum _FIRMWARE_ENTRY +typedef enum _FIRMWARE_REENTRY { HalHaltRoutine, HalPowerDownRoutine, @@ -58,6 +39,64 @@ typedef enum _FIRMWARE_ENTRY HalMaximumRoutine } FIRMWARE_REENTRY, *PFIRMWARE_REENTRY; +// +// HAL Private function Types +// +typedef +PBUS_HANDLER +(*pHalHandlerForConfigSpace)( + IN BUS_DATA_TYPE ConfigSpace, + IN ULONG BusNumber +); + +typedef +NTSTATUS +(*PINSTALL_BUS_HANDLER)( + IN PBUS_HANDLER Bus +); + +typedef +NTSTATUS +(*pHalRegisterBusHandler)( + IN INTERFACE_TYPE InterfaceType, + IN BUS_DATA_TYPE ConfigSpace, + IN ULONG BusNumber, + IN INTERFACE_TYPE ParentInterfaceType, + IN ULONG ParentBusNumber, + IN ULONG ContextSize, + IN PINSTALL_BUS_HANDLER InstallCallback, + OUT PBUS_HANDLER *BusHandler +); + +typedef +VOID +(*pHalSetWakeEnable)( + IN BOOLEAN Enable +); + + +typedef +VOID +(*pHalSetWakeAlarm)( + IN ULONGLONG AlartTime, + IN PTIME_FIELDS TimeFields +); + +typedef +VOID +(*pHalLocateHiberRanges)( + IN PVOID MemoryMap +); + +typedef +BOOLEAN +(*pHalAllocateMapRegisters)( + IN PADAPTER_OBJECT AdapterObject, + IN ULONG Unknown, + IN ULONG Unknown2, + PMAP_REGISTER_ENTRY Registers +); + // // Hal Private dispatch Table // @@ -65,184 +104,48 @@ typedef enum _FIRMWARE_ENTRY typedef struct _HAL_PRIVATE_DISPATCH { ULONG Version; - PVOID HalHandlerForBus; - PVOID HalHandlerForBus2; - PVOID HalLocateHiberRanges; - PVOID HalRegisterBusHandler; - PVOID HalSetWakeEnable; - PVOID HalSetWakeAlarm; - PVOID HalTranslateBusAddress; - PVOID HalTranslateBusAddress2; - PVOID HalHaltSystem; - PVOID Null; - PVOID Null2; - PVOID HalAllocateMapRegisters; - PVOID KdSetupPciDeviceForDebugging; - PVOID KdReleasePciDeviceforDebugging; - PVOID KdGetAcpiTablePhase0; - PVOID HalReferenceHandler; - PVOID HalVectorToIDTEntry; - PVOID MatchAll; - PVOID KdUnmapVirtualAddress; + pHalHandlerForBus HalHandlerForBus; + pHalHandlerForConfigSpace HalHandlerForConfigSpace; + pHalLocateHiberRanges HalLocateHiberRanges; + pHalRegisterBusHandler HalRegisterBusHandler; + pHalSetWakeEnable HalSetWakeEnable; + pHalSetWakeAlarm HalSetWakeAlarm; + pHalTranslateBusAddress HalPciTranslateBusAddress; + pHalAssignSlotResources HalPciAssignSlotResources; + pHalHaltSystem HalHaltSystem; + pHalFindBusAddressTranslation HalFindBusAddressTranslation; + pHalResetDisplay HalResetDisplay; + pHalAllocateMapRegisters HalAllocateMapRegisters; + pKdSetupPciDeviceForDebugging KdSetupPciDeviceForDebugging; + pKdReleasePciDeviceForDebugging KdReleasePciDeviceforDebugging; + pKdGetAcpiTablePhase0 KdGetAcpiTablePhase0; + pKdCheckPowerButton KdCheckPowerButton; + pHalVectorToIDTEntry HalVectorToIDTEntry; + pKdMapPhysicalMemory64 KdMapPhysicalMemory64; + pKdUnmapVirtualAddress KdUnmapVirtualAddress; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + pKdGetPciDataByOffset KdGetPciDataByOffset; + pKdSetPciDataByOffset KdSetPciDataByOffset; + PVOID HalGetInterruptVectorOverride; + PVOID HalGetVectorInputOverride; +#endif } HAL_PRIVATE_DISPATCH, *PHAL_PRIVATE_DISPATCH; -#ifndef _REACTOS_ -// -// NLS Data Block -// -typedef struct _NLS_TABLE_DATA -{ - PVOID AnsiCodePageData; - PVOID OemCodePageData; - PVOID UnicodeCodePageData; -} NLS_TABLE_DATA, *PNLS_TABLE_DATA; - -// -// Subsystem Specific Loader Blocks -// -typedef struct _PROFILE_PARAMETER_BLOCK -{ - USHORT DockData0; - USHORT DockData1; - USHORT DockData2; - USHORT DockData3; - ULONG DockData4; - ULONG DockData5; -} PROFILE_PARAMETER_BLOCK, *PPROFILE_PARAMETER_BLOCK; - -typedef struct _HEADLESS_LOADER_BLOCK -{ - UCHAR Unknown[0xC]; -} HEADLESS_LOADER_BLOCK, *PHEADLESS_LOADER_BLOCK; - -typedef struct _NETWORK_LOADER_BLOCK -{ - UCHAR Unknown[0xC]; -} NETWORK_LOADER_BLOCK, *PNETWORK_LOADER_BLOCK; - -// -// Extended Loader Parameter Block -// -typedef struct _LOADER_PARAMETER_EXTENSION -{ - ULONG Size; - PROFILE_PARAMETER_BLOCK ProfileParameterBlock; - ULONG MajorVersion; - ULONG MinorVersion; - PVOID SpecialConfigInfFile; - ULONG SpecialConfigInfSize; - PVOID TriageDumpData; - // - // NT 5.1 - // - ULONG NumberOfPages; - PHEADLESS_LOADER_BLOCK HeadlessLoaderBlock; - PVOID Unknown1; - PVOID PrefetchDatabaseBase; - ULONG PrefetchDatabaseSize; - PNETWORK_LOADER_BLOCK NetworkLoaderBlock; - // - // NT 5.2+ - // - PVOID Reserved[2]; - LIST_ENTRY FirmwareListEntry; - PVOID AcpiTableBase; - ULONG AcpiTableSize; -} LOADER_PARAMETER_EXTENSION, *PLOADER_PARAMETER_EXTENSION; - // -// Architecture specific Loader Parameter Blocks -// -typedef struct _I386_LOADER_BLOCK -{ - PVOID CommonDataArea; - ULONG MachineType; - ULONG Reserved; -} I386_LOADER_BLOCK, *PI386_LOADER_BLOCK; - -// -// Setup Loader Parameter Block -// -typedef struct _SETUP_LOADER_BLOCK -{ - ULONG Unknown[139]; - ULONG Flags; -} SETUP_LOADER_BLOCK, *PSETUP_LOADER_BLOCK; - -// -// Loader Parameter Block +// Kernel Exports // -typedef struct _LOADER_PARAMETER_BLOCK -{ - LIST_ENTRY LoadOrderListHead; - LIST_ENTRY MemoryDescriptorListHead; - LIST_ENTRY DriverList; - PVOID KernelStack; - PVOID Prcb; - PVOID Process; - PVOID Thread; - ULONG RegistryLength; - PVOID RegistryBase; - PCONFIGURATION_COMPONENT_DATA ConfigurationRoot; - LPSTR ArcBootDeviceName; - LPSTR ArcHalDeviceName; - LPSTR SystemRoot; - LPSTR BootRoot; - LPSTR CommandLine; - PNLS_TABLE_DATA NlsTables; - PARC_DISK_INFORMATION ArcDevices; - PVOID OEMFont; - PSETUP_LOADER_BLOCK SetupLdrBlock; - PLOADER_PARAMETER_EXTENSION LpbExtension; - union - { - I386_LOADER_BLOCK I386; - } u; -} LOADER_PARAMETER_BLOCK, *PLOADER_PARAMETER_BLOCK; - +#ifndef _NTOSKRNL_ +extern PHAL_PRIVATE_DISPATCH HalPrivateDispatchTable; #else - -// -// FIXME: ReactOS ONLY -// -typedef struct _LOADER_MODULE -{ - ULONG ModStart; - ULONG ModEnd; - ULONG String; - ULONG Reserved; -} LOADER_MODULE, *PLOADER_MODULE; -typedef struct _LOADER_PARAMETER_BLOCK -{ - ULONG Flags; - ULONG MemLower; - ULONG MemHigher; - ULONG BootDevice; - ULONG CommandLine; - ULONG ModsCount; - ULONG ModsAddr; - UCHAR Syms[12]; - ULONG MmapLength; - ULONG MmapAddr; - ULONG DrivesCount; - ULONG DrivesAddr; - ULONG ConfigTable; - ULONG BootLoaderName; - ULONG PageDirectoryStart; - ULONG PageDirectoryEnd; - ULONG KernelBase; -} LOADER_PARAMETER_BLOCK, *PLOADER_PARAMETER_BLOCK; +extern HAL_PRIVATE_DISPATCH HalPrivateDispatchTable; #endif // -// Kernel Exports +// HAL Exports // -#ifdef __NTOSKRNL__ -extern HAL_PRIVATE_DISPATCH HalPrivateDispatchTable; -#else -extern PHAL_PRIVATE_DISPATCH HalPrivateDispatchTable; +#ifndef _NTHAL_ +extern PUCHAR *KdComPortInUse; #endif -extern ULONG KdComPortInUse; #endif #endif diff --git a/reactos/include/ndk/i386/ketypes.h b/reactos/include/ndk/i386/ketypes.h index 8cbdde72532..30e7146d5fa 100644 --- a/reactos/include/ndk/i386/ketypes.h +++ b/reactos/include/ndk/i386/ketypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -33,14 +33,58 @@ Author: #define I386_INTERRUPT_GATE 0xE #define I386_TRAP_GATE 0xF +// +// Selector Names +// +#define RPL_MASK 0x0003 +#define MODE_MASK 0x0001 +#define KGDT_R0_CODE (0x8) +#define KGDT_R0_DATA (0x10) +#define KGDT_R3_CODE (0x18) +#define KGDT_R3_DATA (0x20) +#define KGDT_TSS (0x28) +#define KGDT_R0_PCR (0x30) +#define KGDT_R3_TEB (0x38) +#define KGDT_LDT (0x48) +#define KGDT_DF_TSS (0x50) +#define KGDT_NMI_TSS (0x58) + +// +// CR4 +// +#define CR4_VME 0x1 +#define CR4_PVI 0x2 +#define CR4_TSD 0x4 +#define CR4_DE 0x8 +#define CR4_PSE 0x10 +#define CR4_PAE 0x20 +#define CR4_MCE 0x40 +#define CR4_PGE 0x80 +#define CR4_FXSR 0x200 +#define CR4_XMMEXCPT 0x400 + +// +// EFlags +// +#define EFLAGS_TF 0x100 +#define EFLAGS_INTERRUPT_MASK 0x200 +#define EFLAGS_NESTED_TASK 0x4000 +#define EFLAGS_V86_MASK 0x20000 +#define EFLAGS_ALIGN_CHECK 0x40000 +#define EFLAGS_VIF 0x80000 +#define EFLAGS_VIP 0x100000 +#define EFLAG_SIGN 0x8000 +#define EFLAG_ZERO 0x4000 + +#ifndef NTOS_MODE_USER // // IPI Types // #define IPI_APC 1 #define IPI_DPC 2 -#define IPI_FREEZE 3 -#define IPI_PACKET_READY 4 -#define IPI_SYNCH_REQUEST 10 +#define IPI_FREEZE 4 +#define IPI_PACKET_READY 8 +#define IPI_SYNCH_REQUEST 16 // // FN/FX (FPU) Save Area Structures @@ -146,16 +190,16 @@ typedef struct _LDT_ENTRY } Bytes; struct { - ULONG BaseMid : 8; - ULONG Type : 5; - ULONG Dpl : 2; - ULONG Pres : 1; - ULONG LimitHi : 4; - ULONG Sys : 1; - ULONG Reserved_0 : 1; - ULONG Default_Big : 1; - ULONG Granularity : 1; - ULONG BaseHi : 8; + ULONG BaseMid:8; + ULONG Type:5; + ULONG Dpl:2; + ULONG Pres:1; + ULONG LimitHi:4; + ULONG Sys:1; + ULONG Reserved_0:1; + ULONG Default_Big:1; + ULONG Granularity:1; + ULONG BaseHi:8; } Bits; } HighWord; } LDT_ENTRY, *PLDT_ENTRY, *LPLDT_ENTRY; @@ -178,16 +222,16 @@ typedef struct _KGDTENTRY } Bytes; struct { - ULONG BaseMid : 8; - ULONG Type : 5; - ULONG Dpl : 2; - ULONG Pres : 1; - ULONG LimitHi : 4; - ULONG Sys : 1; - ULONG Reserved_0 : 1; - ULONG Default_Big : 1; - ULONG Granularity : 1; - ULONG BaseHi : 8; + ULONG BaseMid:8; + ULONG Type:5; + ULONG Dpl:2; + ULONG Pres:1; + ULONG LimitHi:4; + ULONG Sys:1; + ULONG Reserved_0:1; + ULONG Default_Big:1; + ULONG Granularity:1; + ULONG BaseHi:8; } Bits; } HighWord; } KGDTENTRY, *PKGDTENTRY; @@ -222,26 +266,6 @@ typedef struct _KIDTENTRY USHORT ExtendedOffset; } KIDTENTRY, *PKIDTENTRY; -// -// Page Table Entry Definition -// -typedef struct _HARDWARE_PTE_X86 -{ - ULONG Valid : 1; - ULONG Write : 1; - ULONG Owner : 1; - ULONG WriteThrough : 1; - ULONG CacheDisable : 1; - ULONG Accessed : 1; - ULONG Dirty : 1; - ULONG LargePage : 1; - ULONG Global : 1; - ULONG CopyOnWrite : 1; - ULONG Prototype : 1; - ULONG reserved : 1; - ULONG PageFrameNumber : 20; -} HARDWARE_PTE_X86, *PHARDWARE_PTE_X86; - typedef struct _DESCRIPTOR { USHORT Pad; @@ -277,9 +301,9 @@ typedef struct _KSPECIAL_REGISTERS #pragma pack(push,4) typedef struct _KPROCESSOR_STATE { - PCONTEXT ContextFrame; + CONTEXT ContextFrame; KSPECIAL_REGISTERS SpecialRegisters; -} KPROCESSOR_STATE; +} KPROCESSOR_STATE, *PKPROCESSOR_STATE; // // Processor Region Control Block @@ -301,8 +325,13 @@ typedef struct _KPRCB KPROCESSOR_STATE ProcessorState; ULONG KernelReserved[16]; ULONG HalReserved[16]; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG CFlushSize; + UCHAR PrcbPad0[88]; +#else UCHAR PrcbPad0[92]; - PVOID LockQueue[33]; // Used for Queued Spinlocks +#endif + KSPIN_LOCK_QUEUE LockQueue[LockQueueMaximumLock]; struct _KTHREAD *NpxThread; ULONG InterruptCount; ULONG KernelTime; @@ -314,18 +343,41 @@ typedef struct _KPRCB ULONG PageColor; UCHAR SkipTick; UCHAR DebuggerSavedIRQL; +#if (NTDDI_VERSION >= NTDDI_WS03) + UCHAR NodeColor; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + UCHAR PollSlot; +#else + UCHAR Spare1; +#endif + ULONG NodeShiftedColor; +#else UCHAR Spare1[6]; +#endif struct _KNODE *ParentNode; ULONG MultiThreadProcessorSet; struct _KPRCB *MultiThreadSetMaster; +#if (NTDDI_VERSION >= NTDDI_WS03) + ULONG SecondaryColorMask; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG DpcTimeLimit; +#else + LONG Sleeping; +#endif +#else ULONG ThreadStartCount[2]; +#endif ULONG CcFastReadNoWait; ULONG CcFastReadWait; ULONG CcFastReadNotPossible; ULONG CcCopyReadNoWait; ULONG CcCopyReadWait; ULONG CcCopyReadNoWaitMiss; +#if (NTDDI_VERSION < NTDDI_LONGHORN) ULONG KeAlignmentFixupCount; +#endif + ULONG SpareCounter0; +#if (NTDDI_VERSION < NTDDI_LONGHORN) ULONG KeContextSwitches; ULONG KeDcacheFlushCount; ULONG KeExceptionDispatchCount; @@ -334,13 +386,47 @@ typedef struct _KPRCB ULONG KeIcacheFlushCount; ULONG KeSecondLevelTbFills; ULONG KeSystemCalls; +#endif ULONG IoReadOperationCount; ULONG IoWriteOperationCount; ULONG IoOtherOperationCount; LARGE_INTEGER IoReadTransferCount; LARGE_INTEGER IoWriteTransferCount; LARGE_INTEGER IoOtherTransferCount; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG CcFastMdlReadNoWait; + ULONG CcFastMdlReadWait; + ULONG CcFastMdlReadNotPossible; + ULONG CcMapDataNoWait; + ULONG CcMapDataWait; + ULONG CcPinMappedDataCount; + ULONG CcPinReadNoWait; + ULONG CcPinReadWait; + ULONG CcMdlReadNoWait; + ULONG CcMdlReadWait; + ULONG CcLazyWriteHotSpots; + ULONG CcLazyWriteIos; + ULONG CcLazyWritePages; + ULONG CcDataFlushes; + ULONG CcDataPages; + ULONG CcLostDelayedWrites; + ULONG CcFastReadResourceMiss; + ULONG CcCopyReadWaitMiss; + ULONG CcFastMdlReadResourceMiss; + ULONG CcMapDataNoWaitMiss; + ULONG CcMapDataWaitMiss; + ULONG CcPinReadNoWaitMiss; + ULONG CcPinReadWaitMiss; + ULONG CcMdlReadNoWaitMiss; + ULONG CcMdlReadWaitMiss; + ULONG CcReadAheadIos; + ULONG KeAlignmentFixupCount; + ULONG KeExceptionDispatchCount; + ULONG KeSystemCalls; + ULONG PrcbPad1[3]; +#else ULONG SpareCounter1[8]; +#endif PP_LOOKASIDE_LIST PPLookasideList[16]; PP_LOOKASIDE_LIST PPNPagedLookasideList[32]; PP_LOOKASIDE_LIST PPPagedLookasideList[32]; @@ -350,7 +436,7 @@ typedef struct _KPRCB UCHAR PrcbPad2[52]; PVOID CurrentPacket[3]; ULONG TargetSet; - ULONG_PTR WorkerRoutine; + PKIPI_WORKER WorkerRoutine; ULONG IpiFrozen; UCHAR PrcbPad3[40]; ULONG RequestSummary; @@ -370,22 +456,49 @@ typedef struct _KPRCB ULONG TimerHand; ULONG TimerRequest; PVOID DpcThread; - struct _KEVENT *DpcEvent; + KEVENT DpcEvent; UCHAR ThreadDpcEnable; BOOLEAN QuantumEnd; UCHAR PrcbPad50; UCHAR IdleSchedule; - ULONG DpcSetEventRequest; + LONG DpcSetEventRequest; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + LONG Sleeping; + ULONG PeriodicCount; + ULONG PeriodicBias; + UCHAR PrcbPad5[6]; +#else UCHAR PrcbPad5[18]; +#endif LONG TickOffset; - struct _KDPC* CallDpc; + KDPC CallDpc; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + LONG ClockKeepAlive; + UCHAR ClockCheckSlot; + UCHAR ClockPollCycle; + UCHAR PrcbPad6[2]; + LONG DpcWatchdogPeriod; + LONG DpcWatchDogCount; + LONG ThreadWatchdogPeriod; + LONG ThreadWatchDogCount; + ULONG PrcbPad70[2]; +#else ULONG PrcbPad7[8]; +#endif LIST_ENTRY WaitListHead; ULONG ReadySummary; - ULONG SelectNextLast; + ULONG QueueIndex; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + SINGLE_LIST_ENTRY DeferredReadyListHead; + ULONGLONG StartCycles; + ULONGLONG CycleTime; + ULONGLONG PrcbPad71[3]; + LIST_ENTRY DispatcherReadyListHead[32]; +#else LIST_ENTRY DispatcherReadyListHead[32]; SINGLE_LIST_ENTRY DeferredReadyListHead; ULONG PrcbPad72[11]; +#endif PVOID ChainedInterruptList; LONG LookasideIrpFloat; LONG MmPageFaultCount; @@ -401,7 +514,15 @@ typedef struct _KPRCB LONG MmDirtyWriteIoCount; LONG MmMappedPagesWriteCount; LONG MmMappedWriteIoCount; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG CachedCommit; + ULONG CachedResidentAvailable; + PVOID HyperPte; + UCHAR CpuVendor; + UCHAR PrcbPad9[3]; +#else ULONG SpareFields0[1]; +#endif CHAR VendorString[13]; UCHAR InitialApicId; UCHAR LogicalProcessorsPerPhysicalProcessor; @@ -412,6 +533,23 @@ typedef struct _KPRCB LARGE_INTEGER SpareField1; FX_SAVE_AREA NpxSaveArea; PROCESSOR_POWER_STATE PowerState; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + KDPC DpcWatchdogDoc; + KTIMER DpcWatchdogTimer; + PVOID WheaInfo; + PVOID EtwSupport; + SLIST_HEADER InterruptObjectPool; + LARGE_INTEGER HyperCallPagePhysical; + LARGE_INTEGER HyperCallPageVirtual; + PVOID RateControl; + CACHE_DESCRIPTOR Cache[5]; + ULONG CacheCount; + ULONG CacheProcessorMask[5]; + UCHAR LogicalProcessorsPerCore; + UCHAR PrcbPad8[3]; + ULONG PackageProcessorSet; + ULONG CoreProcessorSet; +#endif } KPRCB, *PKPRCB; // @@ -433,35 +571,36 @@ typedef struct _KIPCR PVOID Used_Self; }; }; - struct _KPCR *Self; /* 1C */ - struct _KPRCB *Prcb; /* 20 */ - KIRQL Irql; /* 24 */ - ULONG IRR; /* 28 */ - ULONG IrrActive; /* 2C */ - ULONG IDR; /* 30 */ - PVOID KdVersionBlock; /* 34 */ - PKIDTENTRY IDT; /* 38 */ + struct _KPCR *Self; + struct _KPRCB *Prcb; + KIRQL Irql; + ULONG IRR; + ULONG IrrActive; + ULONG IDR; + PVOID KdVersionBlock; + PKIDTENTRY IDT; #ifdef _REACTOS_ - PUSHORT GDT; /* 3C */ + PUSHORT GDT; #else - PKGDTENTRY GDT; /* 3C */ + PKGDTENTRY GDT; #endif - struct _KTSS *TSS; /* 40 */ - USHORT MajorVersion; /* 44 */ - USHORT MinorVersion; /* 46 */ - KAFFINITY SetMember; /* 48 */ - ULONG StallScaleFactor; /* 4C */ - UCHAR SparedUnused; /* 50 */ - UCHAR Number; /* 51 */ - UCHAR Reserved; /* 52 */ - UCHAR L2CacheAssociativity; /* 53 */ - ULONG VdmAlert; /* 54 */ - ULONG KernelReserved[14]; /* 58 */ - ULONG L2CacheSize; /* 90 */ - ULONG HalReserved[16]; /* 94 */ - ULONG InterruptMode; /* D4 */ - UCHAR KernelReserved2[0x48]; /* D8 */ - KPRCB PrcbData; /* 120 */ + struct _KTSS *TSS; + USHORT MajorVersion; + USHORT MinorVersion; + KAFFINITY SetMember; + ULONG StallScaleFactor; + UCHAR SparedUnused; + UCHAR Number; + UCHAR Reserved; + UCHAR L2CacheAssociativity; + ULONG VdmAlert; + ULONG KernelReserved[14]; + ULONG SecondLevelCacheSize; + ULONG HalReserved[16]; + ULONG InterruptMode; + UCHAR Spare1; + ULONG KernelReserved2[17]; + KPRCB PrcbData; } KIPCR, *PKIPCR; #pragma pack(pop) @@ -511,5 +650,5 @@ typedef struct _KTSS // i386 CPUs don't have exception frames // typedef struct _KEXCEPTION_FRAME KEXCEPTION_FRAME, *PKEXCEPTION_FRAME; - +#endif #endif diff --git a/reactos/include/ndk/i386/mmtypes.h b/reactos/include/ndk/i386/mmtypes.h index 14194f7082e..549634f5672 100644 --- a/reactos/include/ndk/i386/mmtypes.h +++ b/reactos/include/ndk/i386/mmtypes.h @@ -29,4 +29,121 @@ Author: #define PAGE_SIZE 0x1000 #define PAGE_SHIFT 12L +// +// Page Table Entry Definitions +// +typedef struct _HARDWARE_PTE_X86 +{ + ULONG Valid:1; + ULONG Write:1; + ULONG Owner:1; + ULONG WriteThrough:1; + ULONG CacheDisable:1; + ULONG Accessed:1; + ULONG Dirty:1; + ULONG LargePage:1; + ULONG Global:1; + ULONG CopyOnWrite:1; + ULONG Prototype: 1; + ULONG reserved: 1; + ULONG PageFrameNumber:20; +} HARDWARE_PTE_X86, *PHARDWARE_PTE_X86; + +typedef struct _MMPTE_SOFTWARE +{ + ULONG Valid:1; + ULONG PageFileLow:4; + ULONG Protection:5; + ULONG Prototype:1; + ULONG Transition:1; + ULONG PageFileHigh:20; +} MMPTE_SOFTWARE; + +typedef struct _MMPTE_TRANSITION +{ + ULONG Valid:1; + ULONG Write:1; + ULONG Owner:1; + ULONG WriteThrough:1; + ULONG CacheDisable:1; + ULONG Protection:5; + ULONG Prototype:1; + ULONG Transition:1; + ULONG PageFrameNumber:20; +} MMPTE_TRANSITION; + +typedef struct _MMPTE_PROTOTYPE +{ + ULONG Valid:1; + ULONG ProtoAddressLow:7; + ULONG ReadOnly:1; + ULONG WhichPool:1; + ULONG Prototype:1; + ULONG ProtoAddressHigh:21; +} MMPTE_PROTOTYPE; + +typedef struct _MMPTE_SUBSECTION +{ + ULONG Valid:1; + ULONG SubsectionAddressLow:4; + ULONG Protection:5; + ULONG Prototype:1; + ULONG SubsectionAddressHigh:20; + ULONG WhichPool:1; +} MMPTE_SUBSECTION; + +typedef struct _MMPTE_LIST +{ + ULONG Valid:1; + ULONG OneEntry:1; + ULONG filler10:10; + ULONG NextEntry:20; +} MMPTE_LIST; + +#ifndef CONFIG_SMP + +typedef struct _MMPTE_HARDWARE +{ + ULONG Valid:1; + ULONG Write:1; + ULONG Owner:1; + ULONG WriteThrough:1; + ULONG CacheDisable:1; + ULONG Accessed:1; + ULONG Dirty:1; + ULONG LargePage:1; + ULONG Global:1; + ULONG CopyOnWrite:1; + ULONG Prototype:1; + ULONG reserved:1; + ULONG PageFrameNumber:20; +} MMPTE_HARDWARE, *PMMPTE_HARDWARE; + +#else + +typedef struct _MMPTE_HARDWARE +{ + ULONG Valid:1; + ULONG Writable:1; + ULONG Owner:1; + ULONG WriteThrough:1; + ULONG CacheDisable:1; + ULONG Accessed:1; + ULONG Dirty:1; + ULONG LargePage:1; + ULONG Global:1; + ULONG CopyOnWrite:1; + ULONG Prototype:1; + ULONG Write:1; + ULONG PageFrameNumber:20; +} MMPTE_HARDWARE, *PMMPTE_HARDWARE; + +#endif + +// +// Use the right PTE structure +// +#define HARDWARE_PTE HARDWARE_PTE_X86 +#define PHARDWARE_PTE PHARDWARE_PTE_X86 + #endif diff --git a/reactos/include/ndk/ifssupp.h b/reactos/include/ndk/ifssupp.h index 3b4f9100a9f..c3feeac2243 100644 --- a/reactos/include/ndk/ifssupp.h +++ b/reactos/include/ndk/ifssupp.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ #ifndef _NTIFS_ diff --git a/reactos/include/ndk/inbvfuncs.h b/reactos/include/ndk/inbvfuncs.h index 699cecc8185..142abef54d9 100644 --- a/reactos/include/ndk/inbvfuncs.h +++ b/reactos/include/ndk/inbvfuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -54,7 +54,7 @@ InbvEnableBootDriver( VOID NTAPI InbvInstallDisplayStringFilter( - IN PVOID Unknown + IN PVOID DisplayFilter ); BOOLEAN diff --git a/reactos/include/ndk/iofuncs.h b/reactos/include/ndk/iofuncs.h index ce022dccf51..ab8035e070a 100644 --- a/reactos/include/ndk/iofuncs.h +++ b/reactos/include/ndk/iofuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -140,8 +140,8 @@ NTSYSCALLAPI NTSTATUS NTAPI NtEnumerateBootEntries( - IN ULONG Unknown1, - IN ULONG Unknown2 + IN PVOID Buffer, + IN PULONG BufferLength ); NTSYSCALLAPI @@ -244,16 +244,16 @@ NTSYSCALLAPI NTSTATUS NTAPI NtQueryBootEntryOrder( - IN ULONG Unknown1, - IN ULONG Unknown2 + IN PULONG Ids, + IN PULONG Count ); NTSYSCALLAPI NTSTATUS NTAPI NtQueryBootOptions( - IN ULONG Unknown1, - IN ULONG Unknown2 + IN PBOOT_OPTIONS BootOptions, + IN PULONG BootOptionsLength ); NTSYSCALLAPI @@ -389,16 +389,16 @@ NTSYSCALLAPI NTSTATUS NTAPI NtSetBootEntryOrder( - IN ULONG Unknown1, - IN ULONG Unknown2 + IN PULONG Ids, + IN PULONG Count ); NTSYSCALLAPI NTSTATUS NTAPI NtSetBootOptions( - ULONG Unknown1, - ULONG Unknown2 + IN PBOOT_OPTIONS BootOptions, + IN ULONG FieldsToChange ); NTSYSCALLAPI @@ -458,9 +458,10 @@ NTSYSCALLAPI NTSTATUS NTAPI NtTranslateFilePath( - ULONG Unknown1, - ULONG Unknown2, - ULONG Unknown3 + PFILE_PATH InputFilePath, + ULONG OutputType, + PFILE_PATH OutputFilePath, + ULONG OutputFilePathLength ); NTSYSCALLAPI @@ -619,14 +620,6 @@ ZwDeviceIoControlFile( IN ULONG OutputBufferSize ); -NTSYSAPI -NTSTATUS -NTAPI -ZwEnumerateBootEntries( - IN ULONG Unknown1, - IN ULONG Unknown2 -); - #ifdef NTOS_MODE_USER NTSYSAPI NTSTATUS @@ -727,22 +720,6 @@ ZwQueryAttributesFile( OUT PFILE_BASIC_INFORMATION FileInformation ); -NTSYSAPI -NTSTATUS -NTAPI -ZwQueryBootEntryOrder( - IN ULONG Unknown1, - IN ULONG Unknown2 -); - -NTSYSAPI -NTSTATUS -NTAPI -ZwQueryBootOptions( - IN ULONG Unknown1, - IN ULONG Unknown2 -); - NTSYSAPI NTSTATUS NTAPI @@ -874,22 +851,6 @@ ZwRemoveIoCompletion( IN PLARGE_INTEGER Timeout OPTIONAL ); -NTSYSAPI -NTSTATUS -NTAPI -ZwSetBootEntryOrder( - IN ULONG Unknown1, - IN ULONG Unknown2 -); - -NTSYSAPI -NTSTATUS -NTAPI -ZwSetBootOptions( - ULONG Unknown1, - ULONG Unknown2 -); - #ifdef NTOS_MODE_USER NTSYSAPI NTSTATUS @@ -945,15 +906,6 @@ ZwSetVolumeInformationFile( IN FS_INFORMATION_CLASS FsInformationClass ); -NTSYSAPI -NTSTATUS -NTAPI -ZwTranslateFilePath( - ULONG Unknown1, - ULONG Unknown2, - ULONG Unknown3 -); - NTSYSAPI NTSTATUS NTAPI diff --git a/reactos/include/ndk/iotypes.h b/reactos/include/ndk/iotypes.h index faf2fa6f8c4..4cbb19ca33c 100644 --- a/reactos/include/ndk/iotypes.h +++ b/reactos/include/ndk/iotypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -166,6 +166,14 @@ extern POBJECT_TYPE NTSYSAPI IoDriverObjectType; #define DNUF_DONT_SHOW_IN_UI 0x0002 #define DNUF_NOT_DISABLEABLE 0x0008 +// +// Undocumented WMI Registration Flags +// +#define WMIREG_FLAG_TRACE_PROVIDER 0x00010000 +#define WMIREG_FLAG_TRACE_NOTIFY_MASK 0x00F00000 +#define WMIREG_NOTIFY_DISK_IO 0x00100000 +#define WMIREG_NOTIFY_TDI_IO 0x00200000 + // // I/O Completion Information Class for NtQueryIoCompletionInformation // @@ -201,6 +209,24 @@ typedef enum _INTERFACE_TYPE MaximumInterfaceType }INTERFACE_TYPE, *PINTERFACE_TYPE; +typedef enum _BUS_DATA_TYPE +{ + ConfigurationSpaceUndefined = -1, + Cmos, + EisaConfiguration, + Pos, + CbusConfiguration, + PCIConfiguration, + VMEConfiguration, + NuBusConfiguration, + PCMCIAConfiguration, + MPIConfiguration, + MPSAConfiguration, + PNPISAConfiguration, + SgiInternalConfiguration, + MaximumBusDataType +} BUS_DATA_TYPE, *PBUS_DATA_TYPE; + // // File Information Classes for NtQueryInformationFile // @@ -491,6 +517,21 @@ typedef struct _FILE_VALID_DATA_LENGTH_INFORMATION LARGE_INTEGER ValidDataLength; } FILE_VALID_DATA_LENGTH_INFORMATION, *PFILE_VALID_DATA_LENGTH_INFORMATION; +typedef struct _FILE_DIRECTORY_INFORMATION +{ + ULONG NextEntryOffset; + ULONG FileIndex; + LARGE_INTEGER CreationTime; + LARGE_INTEGER LastAccessTime; + LARGE_INTEGER LastWriteTime; + LARGE_INTEGER ChangeTime; + LARGE_INTEGER EndOfFile; + LARGE_INTEGER AllocationSize; + ULONG FileAttributes; + ULONG FileNameLength; + WCHAR FileName[1]; +} FILE_DIRECTORY_INFORMATION, *PFILE_DIRECTORY_INFORMATION; + // // File System Information structures for NtQueryInformationFile // @@ -996,6 +1037,30 @@ typedef struct _EXTENDED_IO_STACK_LOCATION #endif #endif +// +// Firmware Boot File Path +// +typedef struct _FILE_PATH +{ + ULONG Version; + ULONG Length; + ULONG Type; + CHAR FilePath[1]; +} FILE_PATH, *PFILE_PATH; + +// +// Firmware Boot Options +// +typedef struct _BOOT_OPTIONS +{ + ULONG Version; + ULONG Length; + ULONG Timeout; + ULONG CurrentBootEntryId; + ULONG NextBootEntryId; + WCHAR HeadlessRedirection[1]; +} BOOT_OPTIONS, *PBOOT_OPTIONS; + // // APC Callback for NtCreateFile // diff --git a/reactos/include/ndk/kdfuncs.h b/reactos/include/ndk/kdfuncs.h index 646739dcf19..7e7e458a19c 100644 --- a/reactos/include/ndk/kdfuncs.h +++ b/reactos/include/ndk/kdfuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -34,89 +34,35 @@ UCHAR NTAPI KdPollBreakIn(VOID); -BOOLEAN -NTAPI -KdPortInitialize( - PKD_PORT_INFORMATION PortInformation, - ULONG Unknown1, - ULONG Unknown2 -); - -BOOLEAN -NTAPI -KdPortInitializeEx( - PKD_PORT_INFORMATION PortInformation, - ULONG Unknown1, - ULONG Unknown2 -); - -BOOLEAN -NTAPI -KdPortGetByte( - PUCHAR ByteRecieved -); - -BOOLEAN -NTAPI -KdPortGetByteEx( - PKD_PORT_INFORMATION PortInformation, - PUCHAR ByteRecieved -); - -BOOLEAN -NTAPI -KdPortPollByte( - PUCHAR ByteRecieved -); - -BOOLEAN +NTSTATUS NTAPI -KdPortPollByteEx( - PKD_PORT_INFORMATION PortInformation, - PUCHAR ByteRecieved -); +KdRestore(IN BOOLEAN DisableDbgPorts); -VOID +NTSTATUS NTAPI -KdPortPutByte( - UCHAR ByteToSend -); +KdSave(IN ULONG Unknown); -VOID +#ifdef _ARC_ +NTSTATUS NTAPI -KdPortPutByteEx( - PKD_PORT_INFORMATION PortInformation, - UCHAR ByteToSend +KdDebuggerInitialize0( + IN struct _LOADER_PARAMETER_BLOCK *LoaderBlock ); +#endif -VOID -NTAPI -KdPortRestore(VOID); - -VOID -NTAPI -KdPortSave (VOID); - -VOID -NTAPI -KdRestore(VOID); - -VOID -NTAPI -KdSave (VOID); - -BOOLEAN -NTAPI -KdPortDisableInterrupts(VOID); - -BOOLEAN -NTAPI -KdPortEnableInterrupts(VOID); - -BOOLEAN +// +// Debugger API +// +NTSTATUS NTAPI -KdDebuggerInitialize0( - IN PLOADER_PARAMETER_BLOCK LoaderBlock +KdSystemDebugControl( + SYSDBG_COMMAND Command, + PVOID InputBuffer, + ULONG InputBufferLength, + PVOID OutputBuffer, + ULONG OutputBufferLength, + PULONG ReturnLength, + KPROCESSOR_MODE PreviousMode ); #endif @@ -145,7 +91,7 @@ NTSYSCALLAPI NTSTATUS NTAPI NtSystemDebugControl( - DEBUG_CONTROL_CODE ControlCode, + SYSDBG_COMMAND ControlCode, PVOID InputBuffer, ULONG InputBufferLength, PVOID OutputBuffer, @@ -174,7 +120,7 @@ NTSYSAPI NTSTATUS NTAPI ZwSystemDebugControl( - DEBUG_CONTROL_CODE ControlCode, + SYSDBG_COMMAND ControlCode, PVOID InputBuffer, ULONG InputBufferLength, PVOID OutputBuffer, diff --git a/reactos/include/ndk/kdtypes.h b/reactos/include/ndk/kdtypes.h index 5b8285f7b89..3045cf947c2 100644 --- a/reactos/include/ndk/kdtypes.h +++ b/reactos/include/ndk/kdtypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -47,6 +47,7 @@ Author: // // DebugService Control Types // +#define BREAKPOINT_BREAK 0 #define BREAKPOINT_PRINT 1 #define BREAKPOINT_PROMPT 2 #define BREAKPOINT_LOAD_SYMBOLS 3 @@ -55,25 +56,109 @@ Author: // // Debug Control Codes for NtSystemDebugcontrol // -typedef enum _DEBUG_CONTROL_CODE +typedef enum _SYSDBG_COMMAND { - DebugGetTraceInformation = 1, - DebugSetInternalBreakpoint, - DebugSetSpecialCall, - DebugClearSpecialCalls, - DebugQuerySpecialCalls, - DebugDbgBreakPoint, - DebugDbgLoadSymbols -} DEBUG_CONTROL_CODE; + SysDbgQueryModuleInformation = 0, + SysDbgQueryTraceInformation = 1, + SysDbgSetTracepoint = 2, + SysDbgSetSpecialCall = 3, + SysDbgClearSpecialCalls = 4, + SysDbgQuerySpecialCalls = 5, + SysDbgBreakPoint = 6, + SysDbgQueryVersion = 7, + SysDbgReadVirtual = 8, + SysDbgWriteVirtual = 9, + SysDbgReadPhysical = 10, + SysDbgWritePhysical = 11, + SysDbgReadControlSpace = 12, + SysDbgWriteControlSpace = 13, + SysDbgReadIoSpace = 14, + SysDbgWriteIoSpace = 15, + SysDbgReadMsr = 16, + SysDbgWriteMsr = 17, + SysDbgReadBusData = 18, + SysDbgWriteBusData = 19, + SysDbgCheckLowMemory = 20, + SysDbgEnableKernelDebugger = 21, + SysDbgDisableKernelDebugger = 22, + SysDbgGetAutoKdEnable = 23, + SysDbgSetAutoKdEnable = 24, + SysDbgGetPrintBufferSize = 25, + SysDbgSetPrintBufferSize = 26, + SysDbgGetKdUmExceptionEnable = 27, + SysDbgSetKdUmExceptionEnable = 28, + SysDbgGetTriageDump = 29, + SysDbgGetKdBlockEnable = 30, + SysDbgSetKdBlockEnable = 31, + SysDbgRegisterForUmBreakInfo = 32, + SysDbgGetUmBreakPid = 33, + SysDbgClearUmBreakPid = 34, + SysDbgGetUmAttachPid = 35, + SysDbgClearUmAttachPid = 36, +} SYSDBG_COMMAND; // -// Kernel Debugger Port Definition +// System Debugger Types // -typedef struct _KD_PORT_INFORMATION +typedef struct _SYSDBG_PHYSICAL { - ULONG ComPort; - ULONG BaudRate; - ULONG BaseAddress; -} KD_PORT_INFORMATION, *PKD_PORT_INFORMATION; + PHYSICAL_ADDRESS Address; + PVOID Buffer; + ULONG Request; +} SYSDBG_PHYSICAL, *PSYSDBG_PHYSICAL; + +typedef struct _SYSDBG_VIRTUAL +{ + PVOID Address; + PVOID Buffer; + ULONG Request; +} SYSDBG_VIRTUAL, *PSYSDBG_VIRTUAL; + +typedef struct _SYSDBG_CONTROL_SPACE +{ + ULONGLONG Address; + PVOID Buffer; + ULONG Request; + ULONG Processor; +} SYSDBG_CONTROL_SPACE, *PSYSDBG_CONTROL_SPACE; + +typedef struct _SYSDBG_IO_SPACE +{ + ULONGLONG Address; + PVOID Buffer; + ULONG Request; + INTERFACE_TYPE InterfaceType; + ULONG BusNumber; + ULONG AddressSpace; +} SYSDBG_IO_SPACE, *PSYSDBG_IO_SPACE; + +typedef struct _SYSDBG_BUS_DATA +{ + ULONG Address; + PVOID Buffer; + ULONG Request; + BUS_DATA_TYPE BusDataType; + ULONG BusNumber; + ULONG SlotNumber; +} SYSDBG_BUS_DATA, *PSYSDBG_BUS_DATA; + +typedef struct _SYSDBG_MSR +{ + ULONG Address; + ULONGLONG Data; +} SYSDBG_MSR, *PSYSDBG_MSR; + +typedef struct _SYSDBG_TRIAGE_DUMP +{ + ULONG Flags; + ULONG BugCheckCode; + ULONG_PTR BugCheckParam1; + ULONG_PTR BugCheckParam2; + ULONG_PTR BugCheckParam3; + ULONG_PTR BugCheckParam4; + ULONG ProcessHandles; + ULONG ThreadHandles; + PHANDLE Handles; +} SYSDBG_TRIAGE_DUMP, *PSYSDBG_TRIAGE_DUMP; #endif // _KDTYPES_H diff --git a/reactos/include/ndk/kefuncs.h b/reactos/include/ndk/kefuncs.h index e17a09089fe..4becfadd76a 100644 --- a/reactos/include/ndk/kefuncs.h +++ b/reactos/include/ndk/kefuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -111,6 +111,20 @@ KiReleaseSpinLock( PKSPIN_LOCK SpinLock ); +KIRQL +FASTCALL +KeAcquireQueuedSpinLockRaiseToSynch( + IN KSPIN_LOCK_QUEUE_NUMBER LockNumber +); + +KIRQL +FASTCALL +KeAcquireInStackQueuedSpinLockRaiseToSynch( + IN PKSPIN_LOCK SpinLock, + IN PKLOCK_QUEUE_HANDLE LockHandle +); + + // // Interrupt Functions // @@ -172,9 +186,17 @@ KeIsExecutingDpc( VOID ); +BOOLEAN +NTAPI +KiIpiServiceRoutine( + IN PKTRAP_FRAME TrapFrame, + IN PVOID ExceptionFrame +); + // -// ARC Configuration Functions +// ARC Configuration Functions. Only enabled if you have ARC Support // +#ifdef _ARC_ PCONFIGURATION_COMPONENT_DATA NTAPI KeFindConfigurationNextEntry( @@ -193,6 +215,7 @@ KeFindConfigurationEntry( IN CONFIGURATION_TYPE Type, IN PULONG ComponentKey OPTIONAL ); +#endif // // Low-level Hardware/CPU Control Functions @@ -200,8 +223,22 @@ KeFindConfigurationEntry( VOID NTAPI KeFlushEntireTb( - IN BOOLEAN Unknown, - IN BOOLEAN CurrentCpuOnly + IN BOOLEAN Invalid, + IN BOOLEAN AllProcessors +); + +VOID +NTAPI +KeUpdateSystemTime( + PKTRAP_FRAME TrapFrame, + KIRQL Irql +); + +VOID +NTAPI +KeUpdateRunTime( + PKTRAP_FRAME TrapFrame, + KIRQL Irql ); VOID @@ -230,6 +267,13 @@ KeSetTimeIncrement( IN ULONG MinIncrement ); +NTSTATUS +NTAPI +Ke386CallBios( + IN ULONG BiosCommand, + IN OUT PCONTEXT BiosArguments +); + // // Misc. Functions // @@ -449,8 +493,8 @@ NtW32Call( IN ULONG RoutineIndex, IN PVOID Argument, IN ULONG ArgumentLength, - OUT PVOID* Result, - OUT PULONG ResultLength + OUT PVOID* Result OPTIONAL, + OUT PULONG ResultLength OPTIONAL ); NTSYSCALLAPI diff --git a/reactos/include/ndk/ketypes.h b/reactos/include/ndk/ketypes.h index 3d1760bf668..ece810bb900 100644 --- a/reactos/include/ndk/ketypes.h +++ b/reactos/include/ndk/ketypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -24,7 +24,6 @@ Author: // #include #ifndef NTOS_MODE_USER -#include #include #include #include @@ -38,17 +37,43 @@ Author: // // Maximum System Descriptor Table Entries // -#define SSDT_MAX_ENTRIES 4 +#define SSDT_MAX_ENTRIES 2 // -// Maximum number of times a thread can be suspended +// Dispatcher Priority increments // -#define MAXIMUM_SUSPEND_COUNT 0x7F +#define THREAD_ALERT_INCREMENT 2 // -// Dispatcher Priority increments +// User Shared Data in Kernel-Mode // -#define THREAD_ALERT_INCREMENT 2 +#define KI_USER_SHARED_DATA 0xffdf0000 + +// +// Physical memory offset of KUSER_SHARED_DATA +// +#define KI_USER_SHARED_DATA_PHYSICAL 0x41000 + +// +// Kernel Feature Bits +// +#define KF_RDTSC 0x00000002 + +// +// KPCR Access for non-IA64 builds +// +#define K0IPCR ((ULONG_PTR)(KIP0PCRADDRESS)) +#define PCR ((volatile KPCR * const)K0IPCR) +#define KeGetPcr() PCR + +// +// Number of dispatch codes supported by KINTERRUPT +// +#if (NTDDI_VERSION >= NTDDI_LONGHORN) +#define KINTERRUPT_DISPATCH_CODES 135 +#else +#define KINTERRUPT_DISPATCH_CODES 106 +#endif #ifdef NTOS_MODE_USER @@ -215,6 +240,9 @@ typedef enum _KTHREAD_STATE Waiting, Transition, DeferredReady, +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + GateWait, +#endif } KTHREAD_STATE, *PKTHREAD_STATE; // @@ -225,8 +253,32 @@ typedef enum _KPROCESS_STATE ProcessInMemory, ProcessOutOfMemory, ProcessInTransition, + ProcessInSwap, + ProcessOutSwap, } KPROCESS_STATE, *PKPROCESS_STATE; +// +// NtVdmControl Classes +// +typedef enum _VDMSERVICECLASS +{ + VdmStartExecution = 0, + VdmQueueInterrupt = 1, + VdmDelayInterrupt = 2, + VdmInitialize = 3, + VdmFeatures = 4, + VdmSetInt21Handler = 5, + VdmQueryDir = 6, + VdmPrinterDirectIoOpen = 7, + VdmPrinterDirectIoClose = 8, + VdmPrinterInitialize = 9, + VdmSetLdtEntries = 10, + VdmSetProcessLdtInfo = 11, + VdmAdlibEmulation = 12, + VdmPMCliControl = 13, + VdmQueryVdmProcess = 14, +} VDMSERVICECLASS; + #ifdef NTOS_MODE_USER // @@ -289,6 +341,9 @@ typedef struct _KUSER_SHARED_DATA LARGE_INTEGER SystemExpirationDate; ULONG SuiteMask; BOOLEAN KdDebuggerEnabled; +#if (NTDDI_VERSION >= NTDDI_WINXPSP2) + UCHAR NXSupportPolicy; +#endif volatile ULONG ActiveConsoleId; volatile ULONG DismountCount; ULONG ComPlusPackage; @@ -306,13 +361,84 @@ typedef struct _KUSER_SHARED_DATA volatile ULONG64 TickCountQuad; }; ULONG Cookie; +#if (NTDDI_VERSION >= NTDDI_WS03) LONGLONG ConsoleSessionForegroundProcessId; ULONG Wow64SharedInformation[MAX_WOW64_SHARED_ENTRIES]; - ULONG UserModeGlobalLogging; +#endif +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + USHORT UserModeGlobalLogger[8]; + ULONG HeapTracingPid[2]; + ULONG CritSecTracingPid[2]; + union + { + ULONG SharedDataFlags; + struct + { + ULONG DbgErrorPortPresent:1; + ULONG DbgElevationEnabled:1; + ULONG DbgVirtEnabled:1; + ULONG DbgInstallerDetectEnabled:1; + ULONG SpareBits:28; + }; + }; + ULONG ImageFileExecutionOptions; + KAFFINITY ActiveProcessorAffinity; +#endif } KUSER_SHARED_DATA, *PKUSER_SHARED_DATA; +// +// VDM Structures +// +#include "pshpack1.h" +typedef struct _VdmVirtualIca +{ + LONG ica_count[8]; + LONG ica_int_line; + LONG ica_cpu_int; + USHORT ica_base; + USHORT ica_hipiri; + USHORT ica_mode; + UCHAR ica_master; + UCHAR ica_irr; + UCHAR ica_isr; + UCHAR ica_imr; + UCHAR ica_ssr; +} VDMVIRTUALICA, *PVDMVIRTUALICA; +#include "poppack.h" + +typedef struct _VdmIcaUserData +{ + PVOID pIcaLock; + PVDMVIRTUALICA pIcaMaster; + PVDMVIRTUALICA pIcaSlave; + PULONG pDelayIrq; + PULONG pUndelayIrq; + PULONG pDelayIret; + PULONG pIretHooked; + PULONG pAddrIretBopTable; + PHANDLE phWowIdleEvent; + PLARGE_INTEGER pIcaTimeout; + PHANDLE phMainThreadSuspended; +} VDMICAUSERDATA, *PVDMICAUSERDATA; + +typedef struct _VDM_INITIALIZE_DATA +{ + PVOID TrapcHandler; + PVDMICAUSERDATA IcaUserData; +} VDM_INITIALIZE_DATA, *PVDM_INITIALIZE_DATA; + #else +// +// System Thread Start Routine +// +typedef +VOID +(NTAPI *PKSYSTEM_ROUTINE)( + PKSTART_ROUTINE StartRoutine, + PVOID StartContext +); + // // APC Environment Types // @@ -323,6 +449,17 @@ typedef enum _KAPC_ENVIRONMENT CurrentApcEnvironment } KAPC_ENVIRONMENT; +// +// CPU Cache Types +// +typedef enum _PROCESSOR_CACHE_TYPE +{ + CacheUnified, + CacheInstruction, + CacheData, + CacheTrace, +} PROCESSOR_CACHE_TYPE; + // // PRCB DPC Data // @@ -343,6 +480,18 @@ typedef struct _PP_LOOKASIDE_LIST struct _GENERAL_LOOKASIDE *L; } PP_LOOKASIDE_LIST, *PPP_LOOKASIDE_LIST; +// +// CPU Cache Descriptor +// +typedef struct _CACHE_DESCRIPTOR +{ + UCHAR Level; + UCHAR Associativity; + USHORT LineSize; + ULONG Size; + PROCESSOR_CACHE_TYPE Type; +} CACHE_DESCRIPTOR, *PCACHE_DESCRIPTOR; + // // Architectural Types // @@ -351,11 +500,12 @@ typedef struct _PP_LOOKASIDE_LIST // // Kernel Memory Node // +#include typedef struct _KNODE { SLIST_HEADER DeadStackList; SLIST_HEADER PfnDereferenceSListHead; - ULONG ProcessorMask; + KAFFINITY ProcessorMask; ULONG Color; UCHAR Seed; UCHAR NodeNumber; @@ -364,6 +514,7 @@ typedef struct _KNODE ULONG FreeCount[2]; struct _SINGLE_LIST_ENTRY *PfnDeferredList; } KNODE, *PKNODE; +#include // // Kernel Profile Object @@ -393,6 +544,10 @@ typedef struct _KINTERRUPT CSHORT Size; LIST_ENTRY InterruptListEntry; PKSERVICE_ROUTINE ServiceRoutine; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + PKSERVICE_ROUTINE MessageServiceRoutine; + ULONG MessageIndex; +#endif PVOID ServiceContext; KSPIN_LOCK SpinLock; ULONG TickCount; @@ -406,9 +561,15 @@ typedef struct _KINTERRUPT CHAR Number; UCHAR ShareVector; KINTERRUPT_MODE Mode; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + KINTERRUPT_POLARITY Polarity; +#endif ULONG ServiceCount; ULONG DispatchCount; - ULONG DispatchCode[106]; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONGLONG Rsvd1; +#endif + ULONG DispatchCode[KINTERRUPT_DISPATCH_CODES]; } KINTERRUPT, *PKINTERRUPT; // @@ -475,179 +636,236 @@ typedef enum _KOBJECTS #include typedef struct _KTHREAD { - DISPATCHER_HEADER DispatcherHeader; /* 00 */ - LIST_ENTRY MutantListHead; /* 10 */ - PVOID InitialStack; /* 18 */ - ULONG_PTR StackLimit; /* 1C */ - PVOID KernelStack; /* 20 */ - KSPIN_LOCK ThreadLock; /* 24 */ - union /* 28 */ - { /* 28 */ - KAPC_STATE ApcState; /* 34 */ - struct /* 28 */ - { /* 28 */ - UCHAR ApcStateFill[23]; /* 34 */ - UCHAR ApcQueueable; /* 3F */ - }; /* 3F */ - }; /* 3F */ - UCHAR NextProcessor; /* 40 */ - UCHAR DeferredProcessor; /* 41 */ - UCHAR AdjustReason; /* 42 */ - UCHAR AdjustIncrement; /* 43 */ - KSPIN_LOCK ApcQueueLock; /* 44 */ - ULONG ContextSwitches; /* 48 */ - UCHAR State; /* 4C */ - UCHAR NpxState; /* 4D */ - UCHAR WaitIrql; /* 4E */ - UCHAR WaitMode; /* 4F */ - LONG WaitStatus; /* 50 */ - union /* 54 */ - { /* 54 */ - PKWAIT_BLOCK WaitBlockList; /* 54 */ - PKGATE GateObject; /* 54 */ - }; /* 54 */ - UCHAR Alertable; /* 58 */ - UCHAR WaitNext; /* 59 */ - UCHAR WaitReason; /* 5A */ - UCHAR Priority; /* 5B */ - UCHAR EnableStackSwap; /* 5C */ - UCHAR SwapBusy; /* 5D */ - UCHAR Alerted[2]; /* 5E */ - union /* 60 */ - { /* 60 */ - LIST_ENTRY WaitListEntry; /* 60 */ - SINGLE_LIST_ENTRY SwapListEntry; /* 60 */ - }; /* 68 */ - PKQUEUE Queue; /* 68 */ - ULONG WaitTime; /* 6C */ - union /* 70 */ - { /* 70 */ - struct /* 70 */ - { /* 70 */ - USHORT KernelApcDisable; /* 70 */ - USHORT SpecialApcDisable; /* 72 */ - }; /* 70 */ - ULONG CombinedApcDisable; /* 70 */ - }; /* 74 */ - struct _TEB *Teb; /* 74 */ - union /* 78 */ - { /* 78 */ - KTIMER Timer; /* 78 */ - UCHAR TimerFill[40]; /* 78 */ - }; /* 78 */ - union /* A0 */ - { /* A0 */ - struct /* A0 */ - { /* A0 */ - LONG AutoAlignment:1; /* A0 */ - LONG DisableBoost:1; /* A0 */ - LONG ReservedFlags:30; /* A0 */ - }; /* A0 */ - LONG ThreadFlags; /* A0 */ - }; /* A0 */ - PVOID Padding; /* A4 */ - union /* A8 */ - { /* A8 */ - KWAIT_BLOCK WaitBlock[4]; /* A8 */ - union /* A8 */ - { /* A8 */ - struct /* A8 */ - { /* A8 */ - UCHAR WaitBlockFill0[23]; /* A8 */ - UCHAR SystemAffinityActive; /* BF */ - }; /* A8 */ - struct /* A8 */ - { /* A8 */ - UCHAR WaitBlockFill1[47]; /* A8 */ - UCHAR PreviousMode; /* D7 */ - }; /* A8 */ - struct /* A8 */ - { /* A8 */ - UCHAR WaitBlockFill2[71]; /* A8 */ - UCHAR ResourceIndex; /* EF */ - }; /* A8 */ - struct /* A8 */ - { /* A8 */ - UCHAR WaitBlockFill3[95]; /* A8 */ - UCHAR LargeStack; /* 107 */ - }; /* A8 */ - }; /* A8 */ - }; /* A8 */ - LIST_ENTRY QueueListEntry; /* 108 */ - PKTRAP_FRAME TrapFrame; /* 110 */ - PVOID CallbackStack; /* 114 */ - PVOID ServiceTable; /* 118 */ - UCHAR ApcStateIndex; /* 11C */ - UCHAR IdealProcessor; /* 11D */ - UCHAR Preempted; /* 11E */ - UCHAR ProcessReadyQueue; /* 11F */ - UCHAR KernelStackResident; /* 120 */ - CHAR BasePriority; /* 121 */ - CHAR PriorityDecrement; /* 122 */ - CHAR Saturation; /* 123 */ - KAFFINITY UserAffinity; /* 124 */ - struct _KPROCESS *Process; /* 128 */ - KAFFINITY Affinity; /* 12C */ - PKAPC_STATE ApcStatePointer[2]; /* 130 */ - union /* 138 */ - { /* 138 */ - KAPC_STATE SavedApcState; /* 138 */ - union /* 138 */ - { /* 138 */ - UCHAR SavedApcStateFill[23]; /* 138 */ - CHAR FreezeCount; /* 14F */ - }; /* 138 */ - }; /* 138 */ - CHAR SuspendCount; /* 150 */ - UCHAR UserIdealProcessor; /* 151 */ - UCHAR CalloutActive; /* 152 */ - UCHAR Iopl; /* 153 */ - PVOID Win32Thread; /* 154 */ - PVOID StackBase; /* 158 */ - union /* 15C */ - { /* 15C */ - KAPC SuspendApc; /* 15C */ - union /* 15C */ - { /* 15C */ - UCHAR SuspendApcFill0[1]; /* 15C */ - CHAR Quantum; /* 15D */ - }; /* 15C */ - union /* 15C */ - { /* 15C */ - UCHAR SuspendApcFill1[3]; /* 15C */ - UCHAR QuantumReset; /* 15F */ - }; /* 15C */ - union /* 15C */ - { /* 15C */ - UCHAR SuspendApcFill2[4]; /* 15C */ - ULONG KernelTime; /* 160 */ - }; /* 15C */ - union /* 15C */ - { /* 15C */ - UCHAR SuspendApcFill3[36]; /* 15C */ - PVOID TlsArray; /* 180 */ - }; /* 15C */ - union /* 15C */ - { /* 15C */ - UCHAR SuspendApcFill4[40]; /* 15C */ - PVOID LegoData; /* 184 */ - }; /* 15C */ - union /* 15C */ - { /* 15C */ - UCHAR SuspendApcFill5[47]; /* 15C */ - UCHAR PowerState; /* 18B */ - }; /* 15C */ - }; /* 15C */ - ULONG UserTime; /* 18C */ - union /* 190 */ - { /* 190 */ - KSEMAPHORE SuspendSemaphore; /* 190 */ - UCHAR SuspendSemaphorefill[20]; /* 190 */ - }; /* 190 */ - ULONG SListFaultCount; /* 1A4 */ - LIST_ENTRY ThreadListEntry; /* 1A8 */ - PVOID SListFaultAddress; /* 1B0 */ -} KTHREAD; /* sizeof: 1B4 */ + DISPATCHER_HEADER DispatcherHeader; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONGLONG CycleTime; + ULONG HighCycleTime; +#else + LIST_ENTRY MutantListHead; +#endif + PVOID InitialStack; + ULONG_PTR StackLimit; + PVOID KernelStack; + KSPIN_LOCK ThreadLock; + union + { + KAPC_STATE ApcState; + struct + { + UCHAR ApcStateFill[23]; + UCHAR ApcQueueable; + }; + }; + UCHAR NextProcessor; + UCHAR DeferredProcessor; + UCHAR AdjustReason; + UCHAR AdjustIncrement; + KSPIN_LOCK ApcQueueLock; + ULONG ContextSwitches; + UCHAR State; + UCHAR NpxState; + UCHAR WaitIrql; + UCHAR WaitMode; + LONG WaitStatus; + union + { + PKWAIT_BLOCK WaitBlockList; + PKGATE GateObject; + }; + UCHAR Alertable; + UCHAR WaitNext; + UCHAR WaitReason; + UCHAR Priority; + UCHAR EnableStackSwap; + UCHAR SwapBusy; + UCHAR Alerted[2]; + union + { + LIST_ENTRY WaitListEntry; + SINGLE_LIST_ENTRY SwapListEntry; + }; + PKQUEUE Queue; + ULONG WaitTime; + union + { + struct + { + USHORT KernelApcDisable; + USHORT SpecialApcDisable; + }; + ULONG CombinedApcDisable; + }; + struct _TEB *Teb; + union + { + KTIMER Timer; + UCHAR TimerFill[40]; + }; + union + { + struct + { + LONG AutoAlignment:1; + LONG DisableBoost:1; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + LONG EtwStackTrace1ApcInserted:1; + LONG EtwStackTrace2ApcInserted:1; + LONG CycleChargePending:1; + LONG ReservedFlags:27; +#else + LONG ReservedFlags:30; +#endif + }; + LONG ThreadFlags; + }; + PVOID Padding; + union + { + KWAIT_BLOCK WaitBlock[4]; + union + { + struct + { + UCHAR WaitBlockFill0[23]; + UCHAR SystemAffinityActive; + }; + struct + { + UCHAR WaitBlockFill1[47]; + UCHAR PreviousMode; + }; + struct + { + UCHAR WaitBlockFill2[71]; + UCHAR ResourceIndex; + }; + struct + { + UCHAR WaitBlockFill3[95]; + UCHAR LargeStack; + }; + }; + }; + LIST_ENTRY QueueListEntry; + PKTRAP_FRAME TrapFrame; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + PVOID FirstArgument; +#endif + PVOID CallbackStack; + PVOID ServiceTable; + UCHAR ApcStateIndex; + UCHAR IdealProcessor; + UCHAR Preempted; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + UCHAR CalloutActive; +#else + UCHAR ProcessReadyQueue; +#endif + UCHAR KernelStackResident; + CHAR BasePriority; + CHAR PriorityDecrement; + CHAR Saturation; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG SystemCallNumber; + union + { + struct + { + ULONG Reserved0:1; + ULONG ReadyTransition:1; + ULONG ProcessReadyQueue:1; + ULONG Reserved2:1; + ULONG Reserved3:28; + }; + LONG MiscFlags; + }; +#endif + KAFFINITY UserAffinity; + struct _KPROCESS *Process; + KAFFINITY Affinity; + PKAPC_STATE ApcStatePointer[2]; + union + { + KAPC_STATE SavedApcState; + union + { + UCHAR SavedApcStateFill[23]; + CHAR FreezeCount; + }; + }; + CHAR SuspendCount; + UCHAR UserIdealProcessor; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + union + { + struct + { + UCHAR ReservedBits0:1; + UCHAR SegmentsPresent:1; + UCHAR Reservedbits1:1; + }; + UCHAR NestedStateFlags; + }; +#else + UCHAR CalloutActive; +#endif + UCHAR Iopl; + PVOID Win32Thread; + PVOID StackBase; + union + { + KAPC SuspendApc; + struct + { + UCHAR SuspendApcFill0[1]; + CHAR Quantum; + }; + struct + { + UCHAR SuspendApcFill1[3]; + UCHAR QuantumReset; + }; + struct + { + UCHAR SuspendApcFill2[4]; + ULONG KernelTime; + }; + struct + { + UCHAR SuspendApcFill3[36]; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + PKPRCB WaitPrcb; +#else + PVOID TlsArray; +#endif + }; + struct + { + UCHAR SuspendApcFill4[40]; + PVOID LegoData; + }; + struct + { + UCHAR SuspendApcFill5[47]; + UCHAR PowerState; + }; + }; + ULONG UserTime; + union + { + KSEMAPHORE SuspendSemaphore; + UCHAR SuspendSemaphorefill[20]; + }; + ULONG SListFaultCount; + LIST_ENTRY ThreadListEntry; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + LIST_ENTRY MutantListHead; +#endif + PVOID SListFaultAddress; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + PVOID MdlForLockedteb; +#endif +} KTHREAD; #include // @@ -655,46 +873,55 @@ typedef struct _KTHREAD // typedef struct _KPROCESS { - DISPATCHER_HEADER Header; /* 000 */ - LIST_ENTRY ProfileListHead; /* 010 */ - PHYSICAL_ADDRESS DirectoryTableBase; /* 018 */ + DISPATCHER_HEADER Header; + LIST_ENTRY ProfileListHead; + PHYSICAL_ADDRESS DirectoryTableBase; #if defined(_M_IX86) - KGDTENTRY LdtDescriptor; /* 020 */ - KIDTENTRY Int21Descriptor; /* 028 */ - USHORT IopmOffset; /* 030 */ - UCHAR Iopl; /* 032 */ - UCHAR Unused; /* 033 */ + KGDTENTRY LdtDescriptor; + KIDTENTRY Int21Descriptor; + USHORT IopmOffset; + UCHAR Iopl; + UCHAR Unused; #endif - ULONG ActiveProcessors; /* 034 */ - ULONG KernelTime; /* 038 */ - ULONG UserTime; /* 03C */ - LIST_ENTRY ReadyListHead; /* 040 */ - LIST_ENTRY SwapListEntry; /* 048 */ - PVOID VdmTrapcHandler; /* 04C */ - LIST_ENTRY ThreadListHead; /* 050 */ - KSPIN_LOCK ProcessLock; /* 058 */ - KAFFINITY Affinity; /* 05C */ + ULONG ActiveProcessors; + ULONG KernelTime; + ULONG UserTime; + LIST_ENTRY ReadyListHead; + SINGLE_LIST_ENTRY SwapListEntry; + PVOID VdmTrapcHandler; + LIST_ENTRY ThreadListHead; + KSPIN_LOCK ProcessLock; + KAFFINITY Affinity; union { struct { - ULONG AutoAlignment:1; /* 060.0 */ - ULONG DisableBoost:1; /* 060.1 */ - ULONG DisableQuantum:1; /* 060.2 */ - ULONG ReservedFlags:29; /* 060.3 */ + ULONG AutoAlignment:1; + ULONG DisableBoost:1; + ULONG DisableQuantum:1; + ULONG ReservedFlags:29; }; - ULONG ProcessFlags; /* 060 */ + ULONG ProcessFlags; }; - CHAR BasePriority; /* 064 */ - CHAR QuantumReset; /* 065 */ - UCHAR State; /* 066 */ - UCHAR ThreadSeed; /* 067 */ - UCHAR PowerState; /* 068 */ - UCHAR IdealNode; /* 069 */ - UCHAR Visited; /* 06A */ - KEXECUTE_OPTIONS Flags; /* 06B */ - ULONG StackCount; /* 06C */ - LIST_ENTRY ProcessListEntry; /* 070 */ + CHAR BasePriority; + CHAR QuantumReset; + UCHAR State; + UCHAR ThreadSeed; + UCHAR PowerState; + UCHAR IdealNode; + UCHAR Visited; + union + { + KEXECUTE_OPTIONS Flags; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + UCHAR ExecuteOptions; +#endif + }; + ULONG StackCount; + LIST_ENTRY ProcessListEntry; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONGLONG CycleTime; +#endif } KPROCESS, *PKPROCESS; // @@ -714,10 +941,10 @@ typedef struct _KSERVICE_TABLE_DESCRIPTOR // // Exported Loader Parameter Block // -#ifdef _REACTOS_ -extern LOADER_PARAMETER_BLOCK NTSYSAPI KeLoaderBlock; +#ifndef _REACTOS_ +extern struct _LOADER_PARAMETER_BLOCK NTSYSAPI *KeLoaderBlock; #else -extern PLOADER_PARAMETER_BLOCK NTSYSAPI KeLoaderBlock; +extern struct _ROS_LOADER_PARAMETER_BLOCK NTSYSAPI KeLoaderBlock; #endif // diff --git a/reactos/include/ndk/ldrfuncs.h b/reactos/include/ndk/ldrfuncs.h index a43ff6b3d13..179bbfe00e8 100644 --- a/reactos/include/ndk/ldrfuncs.h +++ b/reactos/include/ndk/ldrfuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -58,6 +58,11 @@ LdrFindResourceDirectory_U( OUT PIMAGE_RESOURCE_DIRECTORY *ResourceDirectory ); +BOOLEAN +LdrUnloadAlternateResourceModule( + IN PVOID BaseAddress +); + // // Misc. Functions // @@ -70,4 +75,28 @@ LdrGetProcedureAddress( OUT PVOID *ProcedureAddress ); +ULONG +NTAPI +LdrRelocateImage( + IN PVOID NewBase, + IN PUCHAR LoaderName, + IN ULONG Success, + IN ULONG Conflict, + IN ULONG Invalid +); + +NTSTATUS +LdrLockLoaderLock( + IN ULONG Flags, + OUT PULONG Disposition OPTIONAL, + OUT PULONG Cookie OPTIONAL +); + +NTSTATUS +NTAPI +LdrUnlockLoaderLock( + IN ULONG Flags, + IN ULONG Cookie OPTIONAL +); + #endif diff --git a/reactos/include/ndk/ldrtypes.h b/reactos/include/ndk/ldrtypes.h index 9d60d20cc6e..9a751ab00b3 100644 --- a/reactos/include/ndk/ldrtypes.h +++ b/reactos/include/ndk/ldrtypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -27,29 +27,45 @@ Author: // // Resource Type Levels // -#define RESOURCE_TYPE_LEVEL 0 -#define RESOURCE_NAME_LEVEL 1 -#define RESOURCE_LANGUAGE_LEVEL 2 -#define RESOURCE_DATA_LEVEL 3 +#define RESOURCE_TYPE_LEVEL 0 +#define RESOURCE_NAME_LEVEL 1 +#define RESOURCE_LANGUAGE_LEVEL 2 +#define RESOURCE_DATA_LEVEL 3 // // Loader Data Table Entry Flags // -#define LDRP_STATIC_LINK 0x00000002 -#define LDRP_IMAGE_DLL 0x00000004 -#define LDRP_LOAD_IN_PROGRESS 0x00001000 -#define LDRP_UNLOAD_IN_PROGRESS 0x00002000 -#define LDRP_ENTRY_PROCESSED 0x00004000 -#define LDRP_ENTRY_INSERTED 0x00008000 -#define LDRP_CURRENT_LOAD 0x00010000 -#define LDRP_FAILED_BUILTIN_LOAD 0x00020000 -#define LDRP_DONT_CALL_FOR_THREADS 0x00040000 -#define LDRP_PROCESS_ATTACH_CALLED 0x00080000 -#define LDRP_DEBUG_SYMBOLS_LOADED 0x00100000 -#define LDRP_IMAGE_NOT_AT_BASE 0x00200000 -#define LDRP_COR_IMAGE 0x00400000 -#define LDR_COR_OWNS_UNMAP 0x00800000 -#define LDRP_REDIRECTED 0x10000000 +#define LDRP_STATIC_LINK 0x00000002 +#define LDRP_IMAGE_DLL 0x00000004 +#define LDRP_LOAD_IN_PROGRESS 0x00001000 +#define LDRP_UNLOAD_IN_PROGRESS 0x00002000 +#define LDRP_ENTRY_PROCESSED 0x00004000 +#define LDRP_ENTRY_INSERTED 0x00008000 +#define LDRP_CURRENT_LOAD 0x00010000 +#define LDRP_FAILED_BUILTIN_LOAD 0x00020000 +#define LDRP_DONT_CALL_FOR_THREADS 0x00040000 +#define LDRP_PROCESS_ATTACH_CALLED 0x00080000 +#define LDRP_DEBUG_SYMBOLS_LOADED 0x00100000 +#define LDRP_IMAGE_NOT_AT_BASE 0x00200000 +#define LDRP_COR_IMAGE 0x00400000 +#define LDR_COR_OWNS_UNMAP 0x00800000 +#define LDRP_REDIRECTED 0x10000000 + +// +// Dll Characteristics for LdrLoadDll +// +#define LDR_IGNORE_CODE_AUTHZ_LEVEL 0x00001000 + +// +// LdrAddRef Flags +// +#define LDR_PIN_MODULE 0x00000001 + +// +// LdrLockLoaderLock Flags +// +#define LDR_LOCK_LOADER_LOCK_FLAG_RAISE_STATUS 0x00000001 +#define LDR_LOCK_LOADER_LOCK_FLAG_TRY_ONLY 0x00000002 // // Loader Data stored in the PEB @@ -70,7 +86,7 @@ typedef struct _PEB_LDR_DATA // typedef struct _LDR_DATA_TABLE_ENTRY { - LIST_ENTRY InLoadOrderModuleList; + LIST_ENTRY InLoadOrderLinks; LIST_ENTRY InMemoryOrderModuleList; LIST_ENTRY InInitializationOrderModuleList; PVOID DllBase; @@ -107,8 +123,45 @@ typedef struct _LDR_RESOURCE_INFO } LDR_RESOURCE_INFO, *PLDR_RESOURCE_INFO; // -// LdrAddRef Flags +// DLL Notifications // -#define LDR_PIN_MODULE 0x00000001 +typedef struct _LDR_DLL_LOADED_NOTIFICATION_DATA +{ + ULONG Flags; + PUNICODE_STRING FullDllName; + PUNICODE_STRING BaseDllName; + PVOID DllBase; + ULONG SizeOfImage; +} LDR_DLL_LOADED_NOTIFICATION_DATA, *PLDR_DLL_LOADED_NOTIFICATION_DATA; + +typedef VOID +(*PLDR_DLL_LOADED_NOTIFICATION_CALLBACK)( + IN BOOLEAN Type, + IN struct _LDR_DLL_LOADED_NOTIFICATION_DATA *Data +); + +typedef struct _LDR_DLL_LOADED_NOTIFICATION_ENTRY +{ + LIST_ENTRY NotificationListEntry; + PLDR_DLL_LOADED_NOTIFICATION_CALLBACK Callback; +} LDR_DLL_LOADED_NOTIFICATION_ENTRY, *PLDR_DLL_LOADED_NOTIFICATION_ENTRY; + +// +// Alternate Resources Support +// +typedef struct _ALT_RESOURCE_MODULE +{ + LANGID LangId; + PVOID ModuleBase; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + PVOID ModuleManifest; +#endif + PVOID AlternateModule; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + HANDLE AlternateFileHandle; + ULONG ModuleCheckSum; + ULONG ErrorCode; +#endif +} ALT_RESOURCE_MODULE, *PALT_RESOURCE_MODULE; #endif diff --git a/reactos/include/ndk/lpcfuncs.h b/reactos/include/ndk/lpcfuncs.h index d1a6373e330..055f8ba4c1e 100644 --- a/reactos/include/ndk/lpcfuncs.h +++ b/reactos/include/ndk/lpcfuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -27,6 +27,7 @@ Author: // // Native calls // +NTSYSCALLAPI NTSTATUS NTAPI NtAcceptConnectPort( @@ -38,6 +39,7 @@ NtAcceptConnectPort( PREMOTE_PORT_VIEW ClientView OPTIONAL ); +NTSYSCALLAPI NTSTATUS NTAPI NtCompleteConnectPort( @@ -58,6 +60,7 @@ NtConnectPort( PULONG ConnectionInformationLength OPTIONAL ); +NTSYSCALLAPI NTSTATUS NTAPI NtCreatePort( @@ -68,6 +71,7 @@ NtCreatePort( ULONG MaxPoolUsage ); +NTSYSCALLAPI NTSTATUS NTAPI NtCreateWaitablePort( @@ -78,6 +82,7 @@ NtCreateWaitablePort( ULONG NPMessageQueueSize OPTIONAL ); +NTSYSCALLAPI NTSTATUS NTAPI NtImpersonateClientOfPort( @@ -85,6 +90,7 @@ NtImpersonateClientOfPort( PPORT_MESSAGE ClientMessage ); +NTSYSCALLAPI NTSTATUS NTAPI NtListenPort( @@ -92,6 +98,7 @@ NtListenPort( PPORT_MESSAGE ConnectionRequest ); +NTSYSCALLAPI NTSTATUS NTAPI NtQueryInformationPort( @@ -102,6 +109,7 @@ NtQueryInformationPort( PULONG ReturnLength ); +NTSYSCALLAPI NTSTATUS NTAPI NtReadRequestData( @@ -113,6 +121,7 @@ NtReadRequestData( PULONG ReturnLength ); +NTSYSCALLAPI NTSTATUS NTAPI NtReplyPort( @@ -120,6 +129,7 @@ NtReplyPort( IN PPORT_MESSAGE LpcReply ); +NTSYSCALLAPI NTSTATUS NTAPI NtReplyWaitReceivePort( @@ -129,6 +139,7 @@ NtReplyWaitReceivePort( OUT PPORT_MESSAGE ReceiveMessage ); +NTSYSCALLAPI NTSTATUS NTAPI NtReplyWaitReceivePortEx( @@ -139,6 +150,7 @@ NtReplyWaitReceivePortEx( IN PLARGE_INTEGER Timeout OPTIONAL ); +NTSYSCALLAPI NTSTATUS NTAPI NtReplyWaitReplyPort( @@ -146,6 +158,7 @@ NtReplyWaitReplyPort( OUT PPORT_MESSAGE ReplyMessage ); +NTSYSCALLAPI NTSTATUS NTAPI NtRequestPort( @@ -177,6 +190,7 @@ NtSecureConnectPort( PULONG ConnectionInformationLength OPTIONAL ); +NTSYSCALLAPI NTSTATUS NTAPI NtWriteRequestData( @@ -188,6 +202,7 @@ NtWriteRequestData( PULONG ReturnLength ); +NTSYSAPI NTSTATUS NTAPI ZwAcceptConnectPort( @@ -199,13 +214,14 @@ ZwAcceptConnectPort( PREMOTE_PORT_VIEW ClientView OPTIONAL ); +NTSYSAPI NTSTATUS NTAPI ZwCompleteConnectPort( HANDLE PortHandle ); -NTSYSCALLAPI +NTSYSAPI NTSTATUS NTAPI ZwConnectPort( @@ -219,6 +235,7 @@ ZwConnectPort( PULONG ConnectionInformationLength OPTIONAL ); +NTSYSAPI NTSTATUS NTAPI ZwCreatePort( @@ -229,6 +246,7 @@ ZwCreatePort( ULONG MaxPoolUsage ); +NTSYSAPI NTSTATUS NTAPI ZwCreateWaitablePort( @@ -239,6 +257,7 @@ ZwCreateWaitablePort( ULONG NPMessageQueueSize OPTIONAL ); +NTSYSAPI NTSTATUS NTAPI ZwImpersonateClientOfPort( @@ -246,6 +265,7 @@ ZwImpersonateClientOfPort( PPORT_MESSAGE ClientMessage ); +NTSYSAPI NTSTATUS NTAPI ZwListenPort( @@ -253,6 +273,7 @@ ZwListenPort( PPORT_MESSAGE ConnectionRequest ); +NTSYSAPI NTSTATUS NTAPI ZwQueryInformationPort( @@ -263,6 +284,7 @@ ZwQueryInformationPort( PULONG ReturnLength ); +NTSYSAPI NTSTATUS NTAPI ZwReadRequestData( @@ -274,6 +296,7 @@ ZwReadRequestData( PULONG ReturnLength ); +NTSYSAPI NTSTATUS NTAPI ZwReplyPort( @@ -281,6 +304,7 @@ ZwReplyPort( IN PPORT_MESSAGE LpcReply ); +NTSYSAPI NTSTATUS NTAPI ZwReplyWaitReceivePort( @@ -290,6 +314,7 @@ ZwReplyWaitReceivePort( OUT PPORT_MESSAGE ReceiveMessage ); +NTSYSAPI NTSTATUS NTAPI ZwReplyWaitReceivePortEx( @@ -300,6 +325,7 @@ ZwReplyWaitReceivePortEx( IN PLARGE_INTEGER Timeout OPTIONAL ); +NTSYSAPI NTSTATUS NTAPI ZwReplyWaitReplyPort( @@ -307,6 +333,7 @@ ZwReplyWaitReplyPort( OUT PPORT_MESSAGE ReplyMessage ); +NTSYSAPI NTSTATUS NTAPI ZwRequestPort( @@ -314,7 +341,7 @@ ZwRequestPort( IN PPORT_MESSAGE LpcMessage ); -NTSYSCALLAPI +NTSYSAPI NTSTATUS NTAPI ZwRequestWaitReplyPort( @@ -323,7 +350,7 @@ ZwRequestWaitReplyPort( IN PPORT_MESSAGE LpcRequest ); -NTSYSCALLAPI +NTSYSAPI NTSTATUS NTAPI ZwSecureConnectPort( @@ -338,6 +365,7 @@ ZwSecureConnectPort( PULONG ConnectionInformationLength OPTIONAL ); +NTSYSAPI NTSTATUS NTAPI ZwWriteRequestData( diff --git a/reactos/include/ndk/lpctypes.h b/reactos/include/ndk/lpctypes.h index c1fa1bb122e..63f50686eb0 100644 --- a/reactos/include/ndk/lpctypes.h +++ b/reactos/include/ndk/lpctypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -228,7 +228,7 @@ typedef struct _LPCP_CONNECTION_MESSAGE #endif // -// Client Died LPC Message (FIXME: should go in pstypes.h?) +// Client Died LPC Message // typedef struct _CLIENT_DIED_MSG { diff --git a/reactos/include/ndk/mmfuncs.h b/reactos/include/ndk/mmfuncs.h index 4b05911a5c6..75fa3c82a39 100644 --- a/reactos/include/ndk/mmfuncs.h +++ b/reactos/include/ndk/mmfuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -29,6 +29,21 @@ Author: // // Section Functions // +NTSTATUS +NTAPI +MmMapViewOfSection( + IN PVOID SectionObject, + IN PEPROCESS Process, + IN OUT PVOID *BaseAddress, + IN ULONG ZeroBits, + IN ULONG CommitSize, + IN OUT PLARGE_INTEGER SectionOffset OPTIONAL, + IN OUT PULONG ViewSize, + IN SECTION_INHERIT InheritDisposition, + IN ULONG AllocationType, + IN ULONG Protect +); + NTSTATUS NTAPI MmUnmapViewOfSection( @@ -41,6 +56,14 @@ MmUnmapViewOfSection( // // Native calls // +NTSYSCALLAPI +NTSTATUS +NTAPI +NtAreMappedFilesTheSame( + IN PVOID File1MappedAsAnImage, + IN PVOID File2MappedAsFile +); + NTSYSCALLAPI NTSTATUS NTAPI @@ -213,6 +236,14 @@ NtWriteVirtualMemory( OUT PULONG NumberOfBytesWritten ); +NTSYSAPI +NTSTATUS +NTAPI +ZwAreMappedFilesTheSame( + IN PVOID File1MappedAsAnImage, + IN PVOID File2MappedAsFile +); + NTSYSAPI NTSTATUS NTAPI diff --git a/reactos/include/ndk/mmtypes.h b/reactos/include/ndk/mmtypes.h index 19bc39b8c15..b4a23414b1f 100644 --- a/reactos/include/ndk/mmtypes.h +++ b/reactos/include/ndk/mmtypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -200,19 +200,240 @@ typedef struct _SECTION_IMAGE_INFORMATION #ifndef NTOS_MODE_USER // -// FIXME: REACTOS SPECIFIC HACK IN EPROCESS +// PTE Structures // -#ifdef _REACTOS_ -typedef struct _MADDRESS_SPACE +typedef struct _MMPTE { - struct _MEMORY_AREA *MemoryAreaRoot; - FAST_MUTEX Lock; - PVOID LowestAddress; - struct _EPROCESS* Process; - PUSHORT PageTableRefCountTable; - ULONG PageTableRefCountTableSize; -} MADDRESS_SPACE, *PMADDRESS_SPACE; -#endif + union + { + ULONG Long; + HARDWARE_PTE Flush; + MMPTE_HARDWARE Hard; + MMPTE_PROTOTYPE Proto; + MMPTE_SOFTWARE Soft; + MMPTE_TRANSITION Trans; + MMPTE_SUBSECTION Subsect; + MMPTE_LIST List; + }; +} MMPTE, *PMMPTE; + +// +// Section Information structure +// +typedef struct _MI_EXTRA_IMAGE_INFORMATION +{ + ULONG SizeOfHeaders; +} MI_EXTRA_IMAGE_INFORMATION, *PMI_EXTRA_IMAGE_INFORMATION; + +typedef struct _MI_SECTION_IMAGE_INFORMATION +{ + SECTION_IMAGE_INFORMATION ExportedImageInformation; + MI_EXTRA_IMAGE_INFORMATION InternalImageInformation; +} MI_SECTION_IMAGE_INFORMATION, *PMI_SECTION_IMAGE_INFORMATION; + +// +// Section Extension Information +// +typedef struct _MMEXTEND_INFO +{ + ULONGLONG CommittedSize; + ULONG ReferenceCount; +} MMEXTEND_INFO, *PMMEXTEND_INFO; + +// +// Segment and Segment Flags +// +typedef struct _SEGMENT_FLAGS +{ + ULONG TotalNumberOfPtes4132:10; + ULONG ExtraSharedWowSubsections:1; + ULONG LargePages:1; + ULONG Spare:20; +} SEGMENT_FLAGS, *PSEGMENT_FLAGS; + +typedef struct _SEGMENT +{ + struct _CONTROL_AREA *ControlArea; + ULONG TotalNumberOfPtes; + ULONG NonExtendedPtes; + ULONG Spare0; + ULONGLONG SizeOfSegment; + MMPTE SegmentPteTemplate; + ULONG NumberOfCommittedPages; + PMMEXTEND_INFO ExtendInfo; + SEGMENT_FLAGS SegmentFlags; + PVOID BaseAddress; + union + { + ULONG ImageCommitment; + PEPROCESS CreatingProcess; + } u1; + union + { + PMI_SECTION_IMAGE_INFORMATION ImageInformation; + PVOID FirstMappedVa; + } u2; + PMMPTE PrototypePte; + MMPTE ThePtes[1]; +} SEGMENT, *PSEGMENT; + +// +// Event Counter Structure +// +typedef struct _EVENT_COUNTER +{ + ULONG RefCount; + KEVENT Event; + LIST_ENTRY ListEntry; +} EVENT_COUNTER, *PEVENT_COUNTER; + +// +// Flags +// +typedef struct _MMSECTION_FLAGS +{ + ULONG BeingDeleted:1; + ULONG BeingCreated:1; + ULONG BeingPurged:1; + ULONG NoModifiedWriting:1; + ULONG FailAllIo:1; + ULONG Image:1; + ULONG Based:1; + ULONG File:1; + ULONG Networked:1; + ULONG NoCache:1; + ULONG PhysicalMemory:1; + ULONG CopyOnWrite:1; + ULONG Reserve:1; + ULONG Commit:1; + ULONG FloppyMedia:1; + ULONG WasPurged:1; + ULONG UserReference:1; + ULONG GlobalMemory:1; + ULONG DeleteOnClose:1; + ULONG FilePointerNull:1; + ULONG DebugSymbolsLoaded:1; + ULONG SetMappedFileIoComplete:1; + ULONG CollidedFlush:1; + ULONG NoChange:1; + ULONG filler0:1; + ULONG ImageMappedInSystemSpace:1; + ULONG UserWritable:1; + ULONG Accessed:1; + ULONG GlobalOnlyPerSession:1; + ULONG Rom:1; + ULONG WriteCombined:1; + ULONG filler:1; +} MMSECTION_FLAGS, *PMMSECTION_FLAGS; + +typedef struct _MMSUBSECTION_FLAGS +{ + ULONG ReadOnly:1; + ULONG ReadWrite:1; + ULONG SubsectionStatic:1; + ULONG GlobalMemory:1; + ULONG Protection:5; + ULONG Spare:1; + ULONG StartingSector4132:10; + ULONG SectorEndOffset:12; +} MMSUBSECTION_FLAGS, *PMMSUBSECTION_FLAGS; + +// +// Control Area Structures +// +typedef struct _CONTROL_AREA +{ + PSEGMENT Segment; + LIST_ENTRY DereferenceList; + ULONG NumberOfSectionReferences; + ULONG NumberOfPfnReferences; + ULONG NumberOfMappedViews; + ULONG NumberOfSystemCacheViews; + ULONG NumberOfUserReferences; + union + { + ULONG LongFlags; + MMSECTION_FLAGS Flags; + } u; + PFILE_OBJECT FilePointer; + PEVENT_COUNTER WaitingForDeletion; + USHORT ModifiedWriteCount; + USHORT FlushInProgressCount; + ULONG WritableUserReferences; + ULONG QuadwordPad; +} CONTROL_AREA, *PCONTROL_AREA; + +typedef struct _LARGE_CONTROL_AREA +{ + PSEGMENT Segment; + LIST_ENTRY DereferenceList; + ULONG NumberOfSectionReferences; + ULONG NumberOfPfnReferences; + ULONG NumberOfMappedViews; + ULONG NumberOfSystemCacheViews; + ULONG NumberOfUserReferences; + union + { + ULONG LongFlags; + MMSECTION_FLAGS Flags; + } u; + PFILE_OBJECT FilePointer; + PEVENT_COUNTER WaitingForDeletion; + USHORT ModifiedWriteCount; + USHORT FlushInProgressCount; + ULONG WritableUserReferences; + ULONG QuadwordPad; + ULONG StartingFrame; + LIST_ENTRY UserGlobalList; + ULONG SessionId; +} LARGE_CONTROL_AREA, *PLARGE_CONTROL_AREA; + +// +// Subsection +// +typedef struct _SUBSECTION +{ + PCONTROL_AREA ControlArea; + union + { + ULONG LongFlags; + MMSUBSECTION_FLAGS SubsectionFlags; + } u; + ULONG StartingSector; + PMMPTE SubsectionBase; + ULONG UnusedPtes; + ULONG PtesInSubsection; + struct _SUBSECTION *NextSubSection; +} SUBSECTION, *PSUBSECTION; + +// +// Segment Object +// +typedef struct _SEGMENT_OBJECT +{ + PVOID BaseAddress; + ULONG TotalNumberOfPtes; + LARGE_INTEGER SizeOfSegment; + ULONG NonExtendedPtes; + ULONG ImageCommitment; + PCONTROL_AREA ControlArea; + PSUBSECTION Subsection; + PLARGE_CONTROL_AREA LargeControlArea; + PMMSECTION_FLAGS MmSectionFlags; + PMMSUBSECTION_FLAGS MmSubSectionFlags; +} SEGMENT_OBJECT, *PSEGMENT_OBJECT; + +// +// Section Object +// +typedef struct _SECTION_OBJECT +{ + PVOID StartingVa; + PVOID EndingVa; + PVOID LeftChild; + PVOID RightChild; + PSEGMENT_OBJECT Segment; +} SECTION_OBJECT, *PSECTION_OBJECT; // // Generic Address Range Structure diff --git a/reactos/include/ndk/ntndk.h b/reactos/include/ndk/ntndk.h index 27e3c805546..35f3d119b51 100644 --- a/reactos/include/ndk/ntndk.h +++ b/reactos/include/ndk/ntndk.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,16 +12,34 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ #ifndef _NTNDK_ #define _NTNDK_ +// +// Disable some warnings that we'd get on /W4. +// Only active for compilers which support this feature. +// +#ifdef _MSC_VER +#pragma warning(push) +#pragma warning(disable:4001) +#pragma warning(disable:4201) +#pragma warning(disable:4115) +#pragma warning(disable:4214) +#endif + +// +// Headers needed for NDK +// #include // C Standard Header #include // General Definitions +// +// Type Headers +// #include // Cache Manager Types #include // Configuration Manager Types #include // User-Mode Kernel Debugging Types @@ -40,6 +58,9 @@ Author: #include // Runtime Library Types #include // Security Subsystem Types +// +// Function Headers +// #include // Configuration Manager Functions #include // User-Mode Kernel Debugging Functions #include // Kernel Debugger Functions @@ -60,4 +81,7 @@ Author: #include // Assembly Offsets +#ifdef _MSC_VER +#pragma warning(pop) +#endif #endif // _NTNDK_ diff --git a/reactos/include/ndk/obfuncs.h b/reactos/include/ndk/obfuncs.h index 362fed90fc6..17ef7ae3531 100644 --- a/reactos/include/ndk/obfuncs.h +++ b/reactos/include/ndk/obfuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ diff --git a/reactos/include/ndk/obtypes.h b/reactos/include/ndk/obtypes.h index e7f1c6e5797..c420fabba33 100644 --- a/reactos/include/ndk/obtypes.h +++ b/reactos/include/ndk/obtypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -48,6 +48,11 @@ Author: (p)->SecurityQualityOfService = NULL; \ } +// +// Number of custom-defined bits that can be attached to a handle +// +#define OBJ_HANDLE_TAGBITS 0x3 + // // Directory Object Access Rights // @@ -132,7 +137,6 @@ typedef struct _OB_DUMP_CONTROL } OB_DUMP_CONTROL, *POB_DUMP_CONTROL; #ifndef NTOS_MODE_USER -#ifndef _REACTOS_ // // Object Type Callbacks @@ -208,87 +212,6 @@ typedef NTSTATUS #else -// -// FIXME: ReactOS ONLY Object Callbacks -// -typedef NTSTATUS -(NTAPI *OB_OPEN_METHOD)( - OB_OPEN_REASON Reason, - PVOID ObjectBody, - PEPROCESS Process, - ULONG HandleCount, - ACCESS_MASK GrantedAccess -); - -typedef NTSTATUS -(NTAPI *OB_PARSE_METHOD)( - PVOID Object, - PVOID *NextObject, - PUNICODE_STRING FullPath, - PWSTR *Path, - ULONG Attributes -); - -typedef VOID -(NTAPI *OB_DELETE_METHOD)( - PVOID DeletedObject -); - -typedef VOID -(NTAPI *OB_CLOSE_METHOD)( - PVOID ClosedObject, - ULONG HandleCount -); - -typedef VOID -(NTAPI *OB_DUMP_METHOD)( - VOID -); - -typedef NTSTATUS -(NTAPI *OB_OKAYTOCLOSE_METHOD)( - VOID -); - -typedef NTSTATUS -(NTAPI *OB_QUERYNAME_METHOD)( - PVOID ObjectBody, - POBJECT_NAME_INFORMATION ObjectNameInfo, - ULONG Length, - PULONG ReturnLength -); - -typedef PVOID -(NTAPI *OB_FIND_METHOD)( - PVOID WinStaObject, - PWSTR Name, - ULONG Attributes -); - -typedef NTSTATUS -(NTAPI *OB_SECURITY_METHOD)( - PVOID Object, - SECURITY_OPERATION_CODE OperationType, - SECURITY_INFORMATION SecurityInformation, - PSECURITY_DESCRIPTOR NewSecurityDescriptor, - PULONG ReturnLength, - PSECURITY_DESCRIPTOR *OldSecurityDescriptor, - POOL_TYPE PoolType, - PGENERIC_MAPPING GenericMapping -); - -typedef NTSTATUS -(NTAPI *OB_CREATE_METHOD)( - PVOID ObjectBody, - PVOID Parent, - PWSTR RemainingPath, - struct _OBJECT_ATTRIBUTES* ObjectAttributes -); - -#endif - -#else - // // Object Information Types for NtQueryInformationObject // @@ -434,9 +357,6 @@ typedef struct _OBJECT_HEADER_CREATOR_INFO // typedef struct _OBJECT_HEADER { -#ifdef _REACTOS_ - LIST_ENTRY Entry; // FIXME: REACTOS ONLY -#endif LONG PointerCount; union { diff --git a/reactos/include/ndk/pofuncs.h b/reactos/include/ndk/pofuncs.h index 33ae0d21089..44bf815896f 100644 --- a/reactos/include/ndk/pofuncs.h +++ b/reactos/include/ndk/pofuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ diff --git a/reactos/include/ndk/potypes.h b/reactos/include/ndk/potypes.h index 6b87610b42b..6627aabe037 100644 --- a/reactos/include/ndk/potypes.h +++ b/reactos/include/ndk/potypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ diff --git a/reactos/include/ndk/psfuncs.h b/reactos/include/ndk/psfuncs.h index fdd0e400f22..a5fe0844275 100644 --- a/reactos/include/ndk/psfuncs.h +++ b/reactos/include/ndk/psfuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -71,7 +71,7 @@ PsGetThreadWin32Thread( VOID NTAPI PsEstablishWin32Callouts( - PW32_CALLOUT_DATA CalloutData + PWIN32_CALLOUTS_FPNS CalloutData ); VOID @@ -297,6 +297,7 @@ NtSetInformationProcess( IN ULONG ProcessInformationLength ); +NTSYSCALLAPI NTSYSCALLAPI NTSTATUS NTAPI @@ -314,6 +315,7 @@ NtSuspendProcess( IN HANDLE ProcessHandle ); +NTSYSCALLAPI NTSTATUS NTAPI NtSuspendThread( diff --git a/reactos/include/ndk/pstypes.h b/reactos/include/ndk/pstypes.h index c886c68d016..0d8d6d9b6a5 100644 --- a/reactos/include/ndk/pstypes.h +++ b/reactos/include/ndk/pstypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -76,6 +76,7 @@ extern NTSYSAPI POBJECT_TYPE PsProcessType; #define FLG_ENABLE_HANDLE_TYPE_TAGGING 0x01000000 #define FLG_HEAP_PAGE_ALLOCS 0x02000000 #define FLG_DEBUG_INITIAL_COMMAND_EX 0x04000000 +#define FLG_VALID_BITS 0x07FFFFFF // // Process priority classes @@ -107,6 +108,11 @@ extern NTSYSAPI POBJECT_TYPE PsProcessType; #define PROCESS_PRIORITY_NORMAL 8 #define PROCESS_PRIORITY_NORMAL_FOREGROUND 9 +// +// Number of TLS expansion slots +// +#define TLS_EXPANSION_SLOTS 64 + // // Process Access Types // @@ -123,7 +129,15 @@ extern NTSYSAPI POBJECT_TYPE PsProcessType; #define PROCESS_QUERY_INFORMATION 0x0400 #define PROCESS_SUSPEND_RESUME 0x0800 #define PROCESS_QUERY_LIMITED_INFORMATION 0x1000 -#define PROCESS_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | SYNCHRONIZE | 0xFFFF) +#if (NTDDI_VERSION >= NTDDI_LONGHORN) +#define PROCESS_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | \ + SYNCHRONIZE | \ + 0xFFFF) +#else +#define PROCESS_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | \ + SYNCHRONIZE | \ + 0xFFF) +#endif // @@ -134,7 +148,9 @@ extern NTSYSAPI POBJECT_TYPE PsProcessType; #define JOB_OBJECT_QUERY 0x4 #define JOB_OBJECT_TERMINATE 0x8 #define JOB_OBJECT_SET_SECURITY_ATTRIBUTES 0x10 -#define JOB_OBJECT_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | SYNCHRONIZE | 31) +#define JOB_OBJECT_ALL_ACCESS (STANDARD_RIGHTS_REQUIRED | \ + SYNCHRONIZE | \ + 31) #endif #ifdef NTOS_MODE_USER @@ -223,6 +239,8 @@ typedef enum _THREADINFOCLASS ThreadCycleTime, ThreadPagePriority, ThreadActualBasePriority, + ThreadTebInformation, + ThreadCSwitchMon, MaxThreadInfoClass } THREADINFOCLASS; @@ -243,6 +261,68 @@ typedef enum _JOBOBJECTINFOCLASS MaxJobObjectInfoClass } JOBOBJECTINFOCLASS; +// +// Power Event Events for Win32K Power Event Callback +// +typedef enum _PSPOWEREVENTTYPE +{ + PsW32FullWake = 0, + PsW32EventCode = 1, + PsW32PowerPolicyChanged = 2, + PsW32SystemPowerState = 3, + PsW32SystemTime = 4, + PsW32DisplayState = 5, + PsW32CapabilitiesChanged = 6, + PsW32SetStateFailed = 7, + PsW32GdiOff = 8, + PsW32GdiOn = 9, + PsW32GdiPrepareResumeUI = 10, + PsW32GdiOffRequest = 11, + PsW32MonitorOff = 12, +} PSPOWEREVENTTYPE; + +// +// Power State Tasks for Win32K Power State Callback +// +typedef enum _POWERSTATETASK +{ + PowerState_BlockSessionSwitch = 0, + PowerState_Init = 1, + PowerState_QueryApps = 2, + PowerState_QueryServices = 3, + PowerState_QueryAppsFailed = 4, + PowerState_QueryServicesFailed = 5, + PowerState_SuspendApps = 6, + PowerState_SuspendServices = 7, + PowerState_ShowUI = 8, + PowerState_NotifyWL = 9, + PowerState_ResumeApps = 10, + PowerState_ResumeServices = 11, + PowerState_UnBlockSessionSwitch = 12, + PowerState_End = 13, + PowerState_BlockInput = 14, + PowerState_UnblockInput = 15, +} POWERSTATETASK; + +// +// Win32K Job Callback Types +// +typedef enum _PSW32JOBCALLOUTTYPE +{ + PsW32JobCalloutSetInformation = 0, + PsW32JobCalloutAddProcess = 1, + PsW32JobCalloutTerminate = 2, +} PSW32JOBCALLOUTTYPE; + +// +// Win32K Thread Callback Types +// +typedef enum _PSW32THREADCALLOUTTYPE +{ + PsW32ThreadCalloutInitialize, + PsW32ThreadCalloutExit, +} PSW32THREADCALLOUTTYPE; + // // Declare empty structure definitions so that they may be referenced by // routines before they are defined @@ -250,24 +330,94 @@ typedef enum _JOBOBJECTINFOCLASS struct _W32THREAD; struct _W32PROCESS; struct _ETHREAD; +struct _WIN32_POWEREVENT_PARAMETERS; +struct _WIN32_POWERSTATE_PARAMETERS; +struct _WIN32_JOBCALLOUT_PARAMETERS; +struct _WIN32_OPENMETHOD_PARAMETERS; +struct _WIN32_OKTOCLOSEMETHOD_PARAMETERS; +struct _WIN32_CLOSEMETHOD_PARAMETERS; +struct _WIN32_DELETEMETHOD_PARAMETERS; +struct _WIN32_PARSEMETHOD_PARAMETERS; // // Win32K Process and Thread Callbacks // typedef NTSTATUS -(NTAPI *PW32_PROCESS_CALLBACK)( +(NTAPI *PKWIN32_PROCESS_CALLOUT)( struct _EPROCESS *Process, BOOLEAN Create ); typedef NTSTATUS -(NTAPI *PW32_THREAD_CALLBACK)( +(NTAPI *PKWIN32_THREAD_CALLOUT)( struct _ETHREAD *Thread, - BOOLEAN Create + PSW32THREADCALLOUTTYPE Type +); + +typedef NTSTATUS +(NTAPI *PKWIN32_GLOBALATOMTABLE_CALLOUT)( + VOID +); + +typedef NTSTATUS +(NTAPI *PKWIN32_POWEREVENT_CALLOUT)( + struct _WIN32_POWEREVENT_PARAMETERS *Parameters +); + +typedef NTSTATUS +(NTAPI *PKWIN32_POWERSTATE_CALLOUT)( + struct _WIN32_POWERSTATE_PARAMETERS *Parameters +); + +typedef NTSTATUS +(NTAPI *PKWIN32_JOB_CALLOUT)( + struct _WIN32_JOBCALLOUT_PARAMETERS *Parameters +); + +typedef NTSTATUS +(NTAPI *PGDI_BATCHFLUSH_ROUTINE)( + VOID +); + +typedef NTSTATUS +(NTAPI *PKWIN32_OPENMETHOD_CALLOUT)( + struct _WIN32_OPENMETHOD_PARAMETERS *Parameters +); + +typedef NTSTATUS +(NTAPI *PKWIN32_OKTOCLOSEMETHOD_CALLOUT)( + struct _WIN32_OKTOCLOSEMETHOD_PARAMETERS *Parameters +); + +typedef NTSTATUS +(NTAPI *PKWIN32_CLOSEMETHOD_CALLOUT)( + struct _WIN32_CLOSEMETHOD_PARAMETERS *Parameters +); + +typedef NTSTATUS +(NTAPI *PKWIN32_DELETEMETHOD_CALLOUT)( + struct _WIN32_DELETEMETHOD_PARAMETERS *Parameters +); + +typedef NTSTATUS +(NTAPI *PKWIN32_PARSEMETHOD_CALLOUT)( + struct _WIN32_PARSEMETHOD_PARAMETERS *Parameters +); + +typedef NTSTATUS +(NTAPI *PKWIN32_WIN32DATACOLLECTION_CALLOUT)( + struct _EPROCESS *Process, + PVOID Callback, + PVOID Context ); #endif +typedef NTSTATUS +(NTAPI *PPOST_PROCESS_INIT_ROUTINE)( + VOID +); + #ifdef NTOS_MODE_USER // @@ -313,63 +463,112 @@ typedef struct _PEB_FREE_BLOCK // typedef struct _PEB { - UCHAR InheritedAddressSpace; /* 00h */ - UCHAR ReadImageFileExecOptions; /* 01h */ - UCHAR BeingDebugged; /* 02h */ - BOOLEAN SpareBool; /* 03h */ - HANDLE Mutant; /* 04h */ - PVOID ImageBaseAddress; /* 08h */ - PPEB_LDR_DATA Ldr; /* 0Ch */ - struct _RTL_USER_PROCESS_PARAMETERS *ProcessParameters; /* 10h */ - PVOID SubSystemData; /* 14h */ - PVOID ProcessHeap; /* 18h */ - PVOID FastPebLock; /* 1Ch */ - PPEBLOCKROUTINE FastPebLockRoutine; /* 20h */ - PPEBLOCKROUTINE FastPebUnlockRoutine; /* 24h */ - ULONG EnvironmentUpdateCount; /* 28h */ - PVOID* KernelCallbackTable; /* 2Ch */ - PVOID EventLogSection; /* 30h */ - PVOID EventLog; /* 34h */ - PPEB_FREE_BLOCK FreeList; /* 38h */ - ULONG TlsExpansionCounter; /* 3Ch */ - PVOID TlsBitmap; /* 40h */ - ULONG TlsBitmapBits[0x2]; /* 44h */ - PVOID ReadOnlySharedMemoryBase; /* 4Ch */ - PVOID ReadOnlySharedMemoryHeap; /* 50h */ - PVOID* ReadOnlyStaticServerData; /* 54h */ - PVOID AnsiCodePageData; /* 58h */ - PVOID OemCodePageData; /* 5Ch */ - PVOID UnicodeCaseTableData; /* 60h */ - ULONG NumberOfProcessors; /* 64h */ - ULONG NtGlobalFlag; /* 68h */ - LARGE_INTEGER CriticalSectionTimeout; /* 70h */ - ULONG HeapSegmentReserve; /* 78h */ - ULONG HeapSegmentCommit; /* 7Ch */ - ULONG HeapDeCommitTotalFreeThreshold; /* 80h */ - ULONG HeapDeCommitFreeBlockThreshold; /* 84h */ - ULONG NumberOfHeaps; /* 88h */ - ULONG MaximumNumberOfHeaps; /* 8Ch */ - PVOID* ProcessHeaps; /* 90h */ - PVOID GdiSharedHandleTable; /* 94h */ - PVOID ProcessStarterHelper; /* 98h */ - PVOID GdiDCAttributeList; /* 9Ch */ - PVOID LoaderLock; /* A0h */ - ULONG OSMajorVersion; /* A4h */ - ULONG OSMinorVersion; /* A8h */ - USHORT OSBuildNumber; /* ACh */ - USHORT OSCSDVersion; /* AEh */ - ULONG OSPlatformId; /* B0h */ - ULONG ImageSubSystem; /* B4h */ - ULONG ImageSubSystemMajorVersion; /* B8h */ - ULONG ImageSubSystemMinorVersion; /* BCh */ - ULONG ImageProcessAffinityMask; /* C0h */ - ULONG GdiHandleBuffer[0x22]; /* C4h */ - PVOID PostProcessInitRoutine; /* 14Ch */ - struct _RTL_BITMAP *TlsExpansionBitmap; /* 150h */ - ULONG TlsExpansionBitmapBits[0x20]; /* 154h */ - ULONG SessionId; /* 1D4h */ - PVOID AppCompatInfo; /* 1D8h */ - UNICODE_STRING CSDVersion; /* 1DCh */ + UCHAR InheritedAddressSpace; + UCHAR ReadImageFileExecOptions; + UCHAR BeingDebugged; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + struct + { + UCHAR ImageUsesLargePages:1; + UCHAR IsProtectedProcess:1; + UCHAR IsLegacyProcess:1; + UCHAR SpareBits:5; + }; +#else + BOOLEAN SpareBool; +#endif + HANDLE Mutant; + PVOID ImageBaseAddress; + PPEB_LDR_DATA Ldr; + struct _RTL_USER_PROCESS_PARAMETERS *ProcessParameters; + PVOID SubSystemData; + PVOID ProcessHeap; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + struct _RTL_CRITICAL_SECTION *FastPebLock; + PVOID AltThunkSListPtr; + PVOID IFEOKey; + ULONG Spare; + union + { + PVOID* KernelCallbackTable; + PVOID UserSharedInfoPtr; + }; + ULONG SystemReserved[1]; + ULONG SpareUlong; +#else + PVOID FastPebLock; + PPEBLOCKROUTINE FastPebLockRoutine; + PPEBLOCKROUTINE FastPebUnlockRoutine; + ULONG EnvironmentUpdateCount; + PVOID* KernelCallbackTable; + PVOID EventLogSection; + PVOID EventLog; +#endif + PPEB_FREE_BLOCK FreeList; + ULONG TlsExpansionCounter; + PVOID TlsBitmap; + ULONG TlsBitmapBits[0x2]; + PVOID ReadOnlySharedMemoryBase; + PVOID ReadOnlySharedMemoryHeap; + PVOID* ReadOnlyStaticServerData; + PVOID AnsiCodePageData; + PVOID OemCodePageData; + PVOID UnicodeCaseTableData; + ULONG NumberOfProcessors; + ULONG NtGlobalFlag; + LARGE_INTEGER CriticalSectionTimeout; + ULONG HeapSegmentReserve; + ULONG HeapSegmentCommit; + ULONG HeapDeCommitTotalFreeThreshold; + ULONG HeapDeCommitFreeBlockThreshold; + ULONG NumberOfHeaps; + ULONG MaximumNumberOfHeaps; + PVOID* ProcessHeaps; + PVOID GdiSharedHandleTable; + PVOID ProcessStarterHelper; + PVOID GdiDCAttributeList; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + struct _RTL_CRITICAL_SECTION *LoaderLock; +#else + PVOID LoaderLock; +#endif + ULONG OSMajorVersion; + ULONG OSMinorVersion; + USHORT OSBuildNumber; + USHORT OSCSDVersion; + ULONG OSPlatformId; + ULONG ImageSubSystem; + ULONG ImageSubSystemMajorVersion; + ULONG ImageSubSystemMinorVersion; + ULONG ImageProcessAffinityMask; + ULONG GdiHandleBuffer[0x22]; + PPOST_PROCESS_INIT_ROUTINE PostProcessInitRoutine; + struct _RTL_BITMAP *TlsExpansionBitmap; + ULONG TlsExpansionBitmapBits[0x20]; + ULONG SessionId; +#if (NTDDI_VERSION >= NTDDI_WINXP) + ULARGE_INTEGER AppCompatFlags; + ULARGE_INTEGER AppCompatFlagsUser; + PVOID pShimData; + PVOID AppCompatInfo; + UNICODE_STRING CSDVersion; + struct _ACTIVATION_CONTEXT_DATA *ActivationContextData; + struct _ASSEMBLY_STORAGE_MAP *ProcessAssemblyStorageMap; + struct _ACTIVATION_CONTEXT_DATA *SystemDefaultActivationContextData; + struct _ASSEMBLY_STORAGE_MAP *SystemAssemblyStorageMap; + ULONG MinimumStackCommit; +#endif +#if (NTDDI_VERSION >= NTDDI_WS03) + PVOID *FlsCallback; + LIST_ENTRY FlsListHead; + struct _RTL_BITMAP *FlsBitmap; + ULONG FlsBitmapBits[4]; + ULONG FlsHighIndex; +#endif +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + PVOID WerRegistrationData; + PVOID WerShipAssertPtr; +#endif } PEB, *PPEB; // @@ -415,77 +614,129 @@ typedef struct _TEB_ACTIVE_FRAME // typedef struct _TEB { - NT_TIB Tib; /* 00h */ - PVOID EnvironmentPointer; /* 1Ch */ - CLIENT_ID Cid; /* 20h */ - PVOID ActiveRpcHandle; /* 28h */ - PVOID ThreadLocalStoragePointer; /* 2Ch */ - struct _PEB *ProcessEnvironmentBlock; /* 30h */ - ULONG LastErrorValue; /* 34h */ - ULONG CountOfOwnedCriticalSections; /* 38h */ - PVOID CsrClientThread; /* 3Ch */ - PVOID Win32ThreadInfo; /* 40h */ - ULONG User32Reserved[0x1A]; /* 44h */ - ULONG UserReserved[5]; /* ACh */ - PVOID WOW32Reserved; /* C0h */ - LCID CurrentLocale; /* C4h */ - ULONG FpSoftwareStatusRegister; /* C8h */ - PVOID SystemReserved1[0x36]; /* CCh */ - LONG ExceptionCode; /* 1A4h */ - struct _ACTIVATION_CONTEXT_STACK *ActivationContextStackPointer; /* 1A8h */ - UCHAR SpareBytes1[0x28]; /* 1ACh */ - GDI_TEB_BATCH GdiTebBatch; /* 1D4h */ - CLIENT_ID RealClientId; /* 6B4h */ - PVOID GdiCachedProcessHandle; /* 6BCh */ - ULONG GdiClientPID; /* 6C0h */ - ULONG GdiClientTID; /* 6C4h */ - PVOID GdiThreadLocalInfo; /* 6C8h */ - ULONG Win32ClientInfo[62]; /* 6CCh */ - PVOID glDispatchTable[0xE9]; /* 7C4h */ - ULONG glReserved1[0x1D]; /* B68h */ - PVOID glReserved2; /* BDCh */ - PVOID glSectionInfo; /* BE0h */ - PVOID glSection; /* BE4h */ - PVOID glTable; /* BE8h */ - PVOID glCurrentRC; /* BECh */ - PVOID glContext; /* BF0h */ - NTSTATUS LastStatusValue; /* BF4h */ - UNICODE_STRING StaticUnicodeString; /* BF8h */ - WCHAR StaticUnicodeBuffer[0x105]; /* C00h */ - PVOID DeallocationStack; /* E0Ch */ - PVOID TlsSlots[0x40]; /* E10h */ - LIST_ENTRY TlsLinks; /* F10h */ - PVOID Vdm; /* F18h */ - PVOID ReservedForNtRpc; /* F1Ch */ - PVOID DbgSsReserved[0x2]; /* F20h */ - ULONG HardErrorDisabled; /* F28h */ - PVOID Instrumentation[14]; /* F2Ch */ - PVOID SubProcessTag; /* F64h */ - PVOID EtwTraceData; /* F68h */ - PVOID WinSockData; /* F6Ch */ - ULONG GdiBatchCount; /* F70h */ - BOOLEAN InDbgPrint; /* F74h */ - BOOLEAN FreeStackOnTermination; /* F75h */ - BOOLEAN HasFiberData; /* F76h */ - UCHAR IdealProcessor; /* F77h */ - ULONG GuaranteedStackBytes; /* F78h */ - PVOID ReservedForPerf; /* F7Ch */ - PVOID ReservedForOle; /* F80h */ - ULONG WaitingOnLoaderLock; /* F84h */ - ULONG SparePointer1; /* F88h */ - ULONG SoftPatchPtr1; /* F8Ch */ - ULONG SoftPatchPtr2; /* F90h */ - PVOID *TlsExpansionSlots; /* F94h */ - ULONG ImpersionationLocale; /* F98h */ - ULONG IsImpersonating; /* F9Ch */ - PVOID NlsCache; /* FA0h */ - PVOID pShimData; /* FA4h */ - ULONG HeapVirualAffinity; /* FA8h */ - PVOID CurrentTransactionHandle; /* FACh */ - PTEB_ACTIVE_FRAME ActiveFrame; /* FB0h */ - PVOID FlsData; /* FB4h */ - UCHAR SafeThunkCall; /* FB8h */ - UCHAR BooleanSpare[3]; /* FB9h */ + NT_TIB Tib; + PVOID EnvironmentPointer; + CLIENT_ID Cid; + PVOID ActiveRpcHandle; + PVOID ThreadLocalStoragePointer; + struct _PEB *ProcessEnvironmentBlock; + ULONG LastErrorValue; + ULONG CountOfOwnedCriticalSections; + PVOID CsrClientThread; + struct _W32THREAD* Win32ThreadInfo; + ULONG User32Reserved[0x1A]; + ULONG UserReserved[5]; + PVOID WOW32Reserved; + LCID CurrentLocale; + ULONG FpSoftwareStatusRegister; + PVOID SystemReserved1[0x36]; + LONG ExceptionCode; + struct _ACTIVATION_CONTEXT_STACK *ActivationContextStackPointer; + UCHAR SpareBytes1[0x24]; + ULONG TxFsContext; + GDI_TEB_BATCH GdiTebBatch; + CLIENT_ID RealClientId; + PVOID GdiCachedProcessHandle; + ULONG GdiClientPID; + ULONG GdiClientTID; + PVOID GdiThreadLocalInfo; + ULONG Win32ClientInfo[62]; + PVOID glDispatchTable[0xE9]; + ULONG glReserved1[0x1D]; + PVOID glReserved2; + PVOID glSectionInfo; + PVOID glSection; + PVOID glTable; + PVOID glCurrentRC; + PVOID glContext; + NTSTATUS LastStatusValue; + UNICODE_STRING StaticUnicodeString; + WCHAR StaticUnicodeBuffer[0x105]; + PVOID DeallocationStack; + PVOID TlsSlots[0x40]; + LIST_ENTRY TlsLinks; + PVOID Vdm; + PVOID ReservedForNtRpc; + PVOID DbgSsReserved[0x2]; + ULONG HardErrorDisabled; + PVOID Instrumentation[9]; + GUID ActivityId; + PVOID SubProcessTag; + PVOID EtwTraceData; + PVOID WinSockData; + ULONG GdiBatchCount; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + BOOLEAN SpareBool0; + BOOLEAN SpareBool1; + BOOLEAN SpareBool2; +#else + BOOLEAN InDbgPrint; + BOOLEAN FreeStackOnTermination; + BOOLEAN HasFiberData; +#endif + UCHAR IdealProcessor; + ULONG GuaranteedStackBytes; + PVOID ReservedForPerf; + PVOID ReservedForOle; + ULONG WaitingOnLoaderLock; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + PVOID SavedPriorityState; +#else + ULONG SparePointer1; +#endif + ULONG SoftPatchPtr1; + ULONG SoftPatchPtr2; + PVOID *TlsExpansionSlots; + ULONG ImpersionationLocale; + ULONG IsImpersonating; + PVOID NlsCache; + PVOID pShimData; + ULONG HeapVirualAffinity; + PVOID CurrentTransactionHandle; + PTEB_ACTIVE_FRAME ActiveFrame; +#if (NTDDI_VERSION >= NTDDI_WS03) + PVOID FlsData; +#endif +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + PVOID PreferredLangauges; + PVOID UserPrefLanguages; + PVOID MergedPrefLanguages; + ULONG MuiImpersonation; + union + { + struct + { + USHORT SpareCrossTebFlags:16; + }; + USHORT CrossTebFlags; + }; + union + { + struct + { + USHORT DbgSafeThunkCall:1; + USHORT DbgInDebugPrint:1; + USHORT DbgHasFiberData:1; + USHORT DbgSkipThreadAttach:1; + USHORT DbgWerInShipAssertCode:1; + USHORT DbgIssuedInitialBp:1; + USHORT DbgClonedThread:1; + USHORT SpareSameTebBits:9; + }; + USHORT SameTebFlags; + }; + PVOID TxnScopeEntercallback; + PVOID TxnScopeExitCAllback; + PVOID TxnScopeContext; + ULONG LockCount; + ULONG ProcessRundown; + ULONGLONG LastSwitchTime; + ULONGLONG TotalSwitchOutTime; + LARGE_INTEGER WaitReasonBitMap; +#else + UCHAR SafeThunkCall; + UCHAR BooleanSpare[3]; +#endif } TEB, *PTEB; #ifdef NTOS_MODE_USER @@ -543,7 +794,7 @@ typedef struct _PROCESS_SESSION_INFORMATION typedef struct _PROCESS_PRIORITY_CLASS { BOOLEAN Foreground; - UCHAR PriorityClass; + UCHAR PriorityClass; } PROCESS_PRIORITY_CLASS, *PPROCESS_PRIORITY_CLASS; // @@ -581,7 +832,7 @@ typedef struct _EPROCESS_QUOTA_BLOCK } EPROCESS_QUOTA_BLOCK, *PEPROCESS_QUOTA_BLOCK; // -// FIXME: This really belongs in mmtypes.h +// Process Pagefault History // typedef struct _PAGEFAULT_HISTORY { @@ -612,253 +863,372 @@ typedef struct _TERMINATION_PORT PVOID Port; } TERMINATION_PORT, *PTERMINATION_PORT; +// +// Per-Process APC Rate Limiting +// +typedef struct _PSP_RATE_APC +{ + union + { + SINGLE_LIST_ENTRY NextApc; + ULONGLONG ExcessCycles; + }; + ULONGLONG TargetGEneration; + KAPC RateApc; +} PSP_RATE_APC, *PPSP_RATE_APC; + // // Executive Thread (ETHREAD) // #include typedef struct _ETHREAD { - KTHREAD Tcb; /* 000 */ - PVOID Padding; /* 1B4 */ - LARGE_INTEGER CreateTime; /* 1B8 */ + KTHREAD Tcb; + PVOID Padding; + LARGE_INTEGER CreateTime; union { - LARGE_INTEGER ExitTime; /* 1C0 */ - LIST_ENTRY LpcReplyChain; /* 1C0 */ - LIST_ENTRY KeyedWaitChain; /* 1C0 */ + LARGE_INTEGER ExitTime; + LIST_ENTRY LpcReplyChain; + LIST_ENTRY KeyedWaitChain; }; union { - NTSTATUS ExitStatus; /* 1C8 */ - PVOID OfsChain; /* 1C8 */ + NTSTATUS ExitStatus; + PVOID OfsChain; }; - LIST_ENTRY PostBlockList; /* 1CC */ + LIST_ENTRY PostBlockList; union { - struct _TERMINATION_PORT *TerminationPort; /* 1D4 */ - struct _ETHREAD *ReaperLink; /* 1D4 */ - PVOID KeyedWaitValue; /* 1D4 */ + struct _TERMINATION_PORT *TerminationPort; + struct _ETHREAD *ReaperLink; + PVOID KeyedWaitValue; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + PVOID Win32StartParameter; +#endif }; - KSPIN_LOCK ActiveTimerListLock; /* 1D8 */ - LIST_ENTRY ActiveTimerListHead; /* 1DC */ - CLIENT_ID Cid; /* 1E4 */ + KSPIN_LOCK ActiveTimerListLock; + LIST_ENTRY ActiveTimerListHead; + CLIENT_ID Cid; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + KSEMAPHORE KeyedWaitSemaphore; +#else union { - KSEMAPHORE LpcReplySemaphore; /* 1EC */ - KSEMAPHORE KeyedReplySemaphore; /* 1EC */ + KSEMAPHORE LpcReplySemaphore; + KSEMAPHORE KeyedReplySemaphore; }; union { - PVOID LpcReplyMessage; /* 200 */ - PVOID LpcWaitingOnPort; /* 200 */ + PVOID LpcReplyMessage; + PVOID LpcWaitingOnPort; }; - PPS_IMPERSONATION_INFORMATION ImpersonationInfo; /* 204 */ - LIST_ENTRY IrpList; /* 208 */ - ULONG TopLevelIrp; /* 210 */ - PDEVICE_OBJECT DeviceToVerify; /* 214 */ - struct _EPROCESS *ThreadsProcess; /* 218 */ - PKSTART_ROUTINE StartAddress; /* 21C */ +#endif + PPS_IMPERSONATION_INFORMATION ImpersonationInfo; + LIST_ENTRY IrpList; + ULONG TopLevelIrp; + PDEVICE_OBJECT DeviceToVerify; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + PPSP_RATE_APC RateControlApc; +#else + struct _EPROCESS *ThreadsProcess; +#endif + PVOID Win32StartAddress; union { - PVOID Win32StartAddress; /* 220 */ - ULONG LpcReceivedMessageId; /* 220 */ + PKSTART_ROUTINE StartAddress; + ULONG LpcReceivedMessageId; }; - LIST_ENTRY ThreadListEntry; /* 224 */ - EX_RUNDOWN_REF RundownProtect; /* 22C */ - EX_PUSH_LOCK ThreadLock; /* 230 */ - ULONG LpcReplyMessageId; /* 234 */ - ULONG ReadClusterSize; /* 238 */ - ACCESS_MASK GrantedAccess; /* 23C */ + LIST_ENTRY ThreadListEntry; + EX_RUNDOWN_REF RundownProtect; + EX_PUSH_LOCK ThreadLock; +#if (NTDDI_VERSION < NTDDI_LONGHORN) + ULONG LpcReplyMessageId; +#endif + ULONG ReadClusterSize; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG SpareUlong0; +#else + ACCESS_MASK GrantedAccess; +#endif union { struct { - ULONG Terminated:1; - ULONG DeadThread:1; - ULONG HideFromDebugger:1; - ULONG ActiveImpersonationInfo:1; - ULONG SystemThread:1; - ULONG HardErrorsAreDisabled:1; - ULONG BreakOnTermination:1; - ULONG SkipCreationMsg:1; - ULONG SkipTerminationMsg:1; + ULONG Terminated:1; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG ThreadInserted:1; +#else + ULONG DeadThread:1; +#endif + ULONG HideFromDebugger:1; + ULONG ActiveImpersonationInfo:1; + ULONG SystemThread:1; + ULONG HardErrorsAreDisabled:1; + ULONG BreakOnTermination:1; + ULONG SkipCreationMsg:1; + ULONG SkipTerminationMsg:1; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG CreateMsgSent:1; + ULONG ThreadIoPriority:3; + ULONG ThreadPagePriority:3; + ULONG PendingRatecontrol:1; +#endif }; - ULONG CrossThreadFlags; /* 240 */ + ULONG CrossThreadFlags; }; union { struct { - ULONG ActiveExWorker:1; - ULONG ExWorkerCanWaitUser:1; - ULONG MemoryMaker:1; - ULONG KeyedEventInUse:1; + ULONG ActiveExWorker:1; + ULONG ExWorkerCanWaitUser:1; + ULONG MemoryMaker:1; + ULONG KeyedEventInUse:1; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG RateApcState:2; +#endif }; - ULONG SameThreadPassiveFlags; /* 244 */ + ULONG SameThreadPassiveFlags; }; union { struct { - ULONG LpcReceivedMsgIdValid:1; - ULONG LpcExitThreadCalled:1; - ULONG AddressSpaceOwner:1; - ULONG OwnsProcessWorkingSetExclusive:1; - ULONG OwnsProcessWorkingSetShared:1; - ULONG OwnsSystemWorkingSetExclusive:1; - ULONG OwnsSystemWorkingSetShared:1; - ULONG OwnsSessionWorkingSetExclusive:1; - ULONG OwnsSessionWorkingSetShared:1; - ULONG ApcNeeded:1; + ULONG LpcReceivedMsgIdValid:1; + ULONG LpcExitThreadCalled:1; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG Spare:1; +#else + ULONG AddressSpaceOwner:1; +#endif + ULONG OwnsProcessWorkingSetExclusive:1; + ULONG OwnsProcessWorkingSetShared:1; + ULONG OwnsSystemWorkingSetExclusive:1; + ULONG OwnsSystemWorkingSetShared:1; + ULONG OwnsSessionWorkingSetExclusive:1; + ULONG OwnsSessionWorkingSetShared:1; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG SupressSymbolLoad:1; + ULONG Spare1:3; + ULONG PriorityRegionActive:4; +#else + ULONG ApcNeeded:1; +#endif }; - ULONG SameThreadApcFlags; /* 248 */ + ULONG SameThreadApcFlags; }; - UCHAR ForwardClusterOnly; /* 24C */ - UCHAR DisablePageFaultClustering; /* 24D */ - UCHAR ActiveFaultCount; /* 24E */ -} ETHREAD; - -#if defined(_NTOSKRNL_) - #include +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + UCHAR CacheManagerActive; +#else + UCHAR ForwardClusterOnly; #endif + UCHAR DisablePageFaultClustering; + UCHAR ActiveFaultCount; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG AlpcMessageId; + union + { + PVOID AlpcMessage; + ULONG AlpcReceiveAttributeSet; + }; + LIST_ENTRY AlpcWaitListEntry; + KSEMAPHORE AlpcWaitSemaphore; + ULONG CacheManagerCount; +#endif +} ETHREAD; // // Executive Process (EPROCESS) // typedef struct _EPROCESS { - KPROCESS Pcb; /* 000 */ - EX_PUSH_LOCK ProcessLock; /* 078 */ - LARGE_INTEGER CreateTime; /* 080 */ - LARGE_INTEGER ExitTime; /* 088 */ - EX_RUNDOWN_REF RundownProtect; /* 090 */ - HANDLE UniqueProcessId; /* 094 */ - LIST_ENTRY ActiveProcessLinks; /* 098 */ - ULONG QuotaUsage[3]; /* 0A0 */ - ULONG QuotaPeak[3]; /* 0AC */ - ULONG CommitCharge; /* 0B8 */ - ULONG PeakVirtualSize; /* 0BC */ - ULONG VirtualSize; /* 0C0 */ - LIST_ENTRY SessionProcessLinks; /* 0C4 */ - PVOID DebugPort; /* 0CC */ - PVOID ExceptionPort; /* 0D0 */ - PHANDLE_TABLE ObjectTable; /* 0D4 */ - EX_FAST_REF Token; /* 0D8 */ - ULONG WorkingSetPage; /* 0DC */ - KGUARDED_MUTEX AddressCreationLock; /* 0E0 */ - KSPIN_LOCK HyperSpaceLock; /* 100 */ - PETHREAD ForkInProgress; /* 104 */ - ULONG HardwareTrigger; /* 108 */ - MM_AVL_TABLE PhysicalVadroot; /* 10C */ - PVOID CloneRoot; /* 110 */ - ULONG NumberOfPrivatePages; /* 114 */ - ULONG NumberOfLockedPages; /* 118 */ - PVOID *Win32Process; /* 11C */ - struct _EJOB *Job; /* 120 */ - PVOID SectionObject; /* 124 */ - PVOID SectionBaseAddress; /* 128 */ - PEPROCESS_QUOTA_BLOCK QuotaBlock; /* 12C */ - PPAGEFAULT_HISTORY WorkingSetWatch; /* 130 */ - PVOID Win32WindowStation; /* 134 */ - HANDLE InheritedFromUniqueProcessId; /* 138 */ - PVOID LdtInformation; /* 13C */ - PVOID VadFreeHint; /* 140 */ - PVOID VdmObjects; /* 144 */ - PVOID DeviceMap; /* 148 */ - PVOID Spare0[3]; /* 14C */ + KPROCESS Pcb; + EX_PUSH_LOCK ProcessLock; + LARGE_INTEGER CreateTime; + LARGE_INTEGER ExitTime; + EX_RUNDOWN_REF RundownProtect; + HANDLE UniqueProcessId; + LIST_ENTRY ActiveProcessLinks; + ULONG QuotaUsage[3]; + ULONG QuotaPeak[3]; + ULONG CommitCharge; + ULONG PeakVirtualSize; + ULONG VirtualSize; + LIST_ENTRY SessionProcessLinks; + PVOID DebugPort; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) union { - HARDWARE_PTE_X86 PagedirectoryPte; /* 158 */ - ULONGLONG Filler; /* 158 */ + PVOID ExceptionPortData; + ULONG ExceptionPortValue; + UCHAR ExceptionPortState:3; }; - ULONG Session; /* 160 */ - CHAR ImageFileName[16]; /* 164 */ - LIST_ENTRY JobLinks; /* 174 */ - PVOID LockedPagesList; /* 17C */ - LIST_ENTRY ThreadListHead; /* 184 */ - PVOID SecurityPort; /* 188 */ - PVOID PaeTop; /* 18C */ - ULONG ActiveThreads; /* 190 */ - ACCESS_MASK GrantedAccess; /* 194 */ - ULONG DefaultHardErrorProcessing; /* 198 */ - NTSTATUS LastThreadExitStatus; /* 19C */ - struct _PEB* Peb; /* 1A0 */ - EX_FAST_REF PrefetchTrace; /* 1A4 */ - LARGE_INTEGER ReadOperationCount; /* 1A8 */ - LARGE_INTEGER WriteOperationCount; /* 1B0 */ - LARGE_INTEGER OtherOperationCount; /* 1B8 */ - LARGE_INTEGER ReadTransferCount; /* 1C0 */ - LARGE_INTEGER WriteTransferCount; /* 1C8 */ - LARGE_INTEGER OtherTransferCount; /* 1D0 */ - ULONG CommitChargeLimit; /* 1D8 */ - ULONG CommitChargePeak; /* 1DC */ - PVOID AweInfo; /* 1E0 */ - SE_AUDIT_PROCESS_CREATION_INFO SeAuditProcessCreationInfo; /* 1E4 */ - MMSUPPORT Vm; /* 1E8 */ - LIST_ENTRY MmProcessLinks; /* 230 */ - ULONG ModifiedPageCount; /* 238 */ - ULONG JobStatus; /* 23C */ +#else + PVOID ExceptionPort; +#endif + PHANDLE_TABLE ObjectTable; + EX_FAST_REF Token; + ULONG WorkingSetPage; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + EX_PUSH_LOCK AddressCreationLock; + PETHREAD RotateInProgress; +#else + KGUARDED_MUTEX AddressCreationLock; + KSPIN_LOCK HyperSpaceLock; +#endif + PETHREAD ForkInProgress; + ULONG HardwareTrigger; + MM_AVL_TABLE PhysicalVadroot; + PVOID CloneRoot; + ULONG NumberOfPrivatePages; + ULONG NumberOfLockedPages; + PVOID *Win32Process; + struct _EJOB *Job; + PVOID SectionObject; + PVOID SectionBaseAddress; + PEPROCESS_QUOTA_BLOCK QuotaBlock; + PPAGEFAULT_HISTORY WorkingSetWatch; + PVOID Win32WindowStation; + HANDLE InheritedFromUniqueProcessId; + PVOID LdtInformation; + PVOID VadFreeHint; + PVOID VdmObjects; + PVOID DeviceMap; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG AlpcPagedPoolQuotaCache; + PVOID EtwDataSource; + PVOID FreeTebHint; +#else + PVOID Spare0[3]; +#endif + union + { + HARDWARE_PTE_X86 PagedirectoryPte; + ULONGLONG Filler; + }; + ULONG Session; + CHAR ImageFileName[16]; + LIST_ENTRY JobLinks; + PVOID LockedPagesList; + LIST_ENTRY ThreadListHead; + PVOID SecurityPort; + PVOID PaeTop; + ULONG ActiveThreads; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG ImagePathHash; +#else + ACCESS_MASK GrantedAccess; +#endif + ULONG DefaultHardErrorProcessing; + NTSTATUS LastThreadExitStatus; + struct _PEB* Peb; + EX_FAST_REF PrefetchTrace; + LARGE_INTEGER ReadOperationCount; + LARGE_INTEGER WriteOperationCount; + LARGE_INTEGER OtherOperationCount; + LARGE_INTEGER ReadTransferCount; + LARGE_INTEGER WriteTransferCount; + LARGE_INTEGER OtherTransferCount; + ULONG CommitChargeLimit; + ULONG CommitChargePeak; + PVOID AweInfo; + SE_AUDIT_PROCESS_CREATION_INFO SeAuditProcessCreationInfo; + MMSUPPORT Vm; + LIST_ENTRY MmProcessLinks; + ULONG ModifiedPageCount; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) union { struct { - ULONG CreateReported:1; - ULONG NoDebugInherit:1; - ULONG ProcessExiting:1; - ULONG ProcessDelete:1; - ULONG Wow64SplitPages:1; - ULONG VmDeleted:1; - ULONG OutswapEnabled:1; - ULONG Outswapped:1; - ULONG ForkFailed:1; - ULONG Wow64VaSpace4Gb:1; - ULONG AddressSpaceInitialized:2; - ULONG SetTimerResolution:1; - ULONG BreakOnTermination:1; - ULONG SessionCreationUnderway:1; - ULONG WriteWatch:1; - ULONG ProcessInSession:1; - ULONG OverrideAddressSpace:1; - ULONG HasAddressSpace:1; - ULONG LaunchPrefetched:1; - ULONG InjectInpageErrors:1; - ULONG VmTopDown:1; - ULONG ImageNotifyDone:1; - ULONG PdeUpdateNeeded:1; - ULONG VdmAllowed:1; - ULONG SmapAllowed:1; - ULONG CreateFailed:1; - ULONG DefaultIoPriority:3; - ULONG Spare1:1; - ULONG Spare2:1; + ULONG JobNotReallyActive:1; + ULONG AccountingFolded:1; + ULONG NewProcessReported:1; + ULONG ExitProcessReported:1; + ULONG ReportCommitChanges:1; + ULONG LastReportMemory:1; + ULONG ReportPhysicalPageChanges:1; + ULONG HandleTableRundown:1; + ULONG NeedsHandleRundown:1; + ULONG RefTraceEnabled:1; + ULONG NumaAware:1; + ULONG ProtectedProcess:1; + ULONG DefaultPagePriority:3; + ULONG ProcessDeleteSelf:1; + ULONG ProcessVerifierTarget:1; }; - ULONG Flags; /* 240 */ + ULONG Flags2; }; - - NTSTATUS ExitStatus; /* 244 */ - USHORT NextPageColor; /* 248 */ +#else + ULONG JobStatus; +#endif union { struct { - UCHAR SubSystemMinorVersion; /* 24A */ - UCHAR SubSystemMajorVersion; /* 24B */ + ULONG CreateReported:1; + ULONG NoDebugInherit:1; + ULONG ProcessExiting:1; + ULONG ProcessDelete:1; + ULONG Wow64SplitPages:1; + ULONG VmDeleted:1; + ULONG OutswapEnabled:1; + ULONG Outswapped:1; + ULONG ForkFailed:1; + ULONG Wow64VaSpace4Gb:1; + ULONG AddressSpaceInitialized:2; + ULONG SetTimerResolution:1; + ULONG BreakOnTermination:1; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG DeprioritizeViews:1; +#else + ULONG SessionCreationUnderway:1; +#endif + ULONG WriteWatch:1; + ULONG ProcessInSession:1; + ULONG OverrideAddressSpace:1; + ULONG HasAddressSpace:1; + ULONG LaunchPrefetched:1; + ULONG InjectInpageErrors:1; + ULONG VmTopDown:1; + ULONG ImageNotifyDone:1; + ULONG PdeUpdateNeeded:1; + ULONG VdmAllowed:1; + ULONG SmapAllowed:1; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG ProcessInserted:1; +#else + ULONG CreateFailed:1; +#endif + ULONG DefaultIoPriority:3; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG SparePsFlags1:2; +#else + ULONG Spare1:1; + ULONG Spare2:1; +#endif }; - USHORT SubSystemVersion; /* 24A */ + ULONG Flags; }; - UCHAR PriorityClass; /* 24C */ - MM_AVL_TABLE VadRoot; /* 250 */ - ULONG Cookie; /* 270 */ - -#ifdef _REACTOS_ - /* FIXME: WILL BE DEPRECATED WITH PUSHLOCK SUPPORT IN 0.3.0*/ - KEVENT LockEvent; /* 274 */ - ULONG LockCount; /* 284 */ - struct _KTHREAD *LockOwner; /* 288 */ - - /* FIXME: MOVE TO AVL TREES */ - MADDRESS_SPACE AddressSpace; /* 28C */ + NTSTATUS ExitStatus; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + USHORT Spare7; +#else + USHORT NextPageColor; #endif + union + { + struct + { + UCHAR SubSystemMinorVersion; + UCHAR SubSystemMajorVersion; + }; + USHORT SubSystemVersion; + }; + UCHAR PriorityClass; + MM_AVL_TABLE VadRoot; + ULONG Cookie; } EPROCESS; #include @@ -925,7 +1295,14 @@ typedef struct _EJOB ULONG PeakProcessMemoryUsed; ULONG PeakJobMemoryUsed; ULONG CurrentJobMemoryUsed; +#if (NTDDI_VERSION == NTDDI_WINXP) + FAST_MUTEX MemoryLimitsLock; +#elif (NTDDI_VERSION == NTDDI_WS03) KGUARDED_MUTEX MemoryLimitsLock; +#elif (NTDDI_VERSION >= NTDDI_LONGHORN) + EX_PUSH_LOCK MemoryLimitsLock; +#endif + LIST_ENTRY JobSetLinks; ULONG MemberLevel; ULONG JobFlags; } EJOB, *PEJOB; @@ -934,29 +1311,93 @@ typedef struct _EJOB // // Win32K Callback Registration Data // -typedef struct _W32_CALLOUT_DATA -{ - PW32_PROCESS_CALLBACK W32ProcessCallout; - PW32_THREAD_CALLBACK W32ThreadCallout; - PVOID UserGlobalAtomTableCallout; - PVOID UserPowerEventCallout; - PVOID UserPowerStateCallout; - PVOID UserJobCallout; - PVOID NtGdiUserFlushUserBatch; - OB_OPEN_METHOD DesktopOpen; - PVOID DesktopUnmap; - OB_DELETE_METHOD DesktopDelete; - OB_OKAYTOCLOSE_METHOD WinstaOkayToClose; - OB_DELETE_METHOD WinStaDelete; - OB_PARSE_METHOD WinStaParse; - OB_OPEN_METHOD WinStaOpen; -#ifdef _REACTOS_ - /* FIXME: REACTOS ONLY */ - OB_FIND_METHOD WinStaFind; - OB_OPEN_METHOD WinStaCreate; - OB_CREATE_METHOD DesktopCreate; -#endif -} W32_CALLOUT_DATA, *PW32_CALLOUT_DATA; +typedef struct _WIN32_POWEREVENT_PARAMETERS +{ + PSPOWEREVENTTYPE EventNumber; + ULONG Code; +} WIN32_POWEREVENT_PARAMETERS, *PWIN32_POWEREVENT_PARAMETERS; + +typedef struct _WIN32_POWERSTATE_PARAMETERS +{ + UCHAR Promotion; + POWER_ACTION SystemAction; + SYSTEM_POWER_STATE MinSystemState; + ULONG Flags; + POWERSTATETASK PowerStateTask; +} WIN32_POWERSTATE_PARAMETERS, *PWIN32_POWERSTATE_PARAMETERS; + +typedef struct _WIN32_JOBCALLOUT_PARAMETERS +{ + PVOID Job; + PSW32JOBCALLOUTTYPE CalloutType; + PVOID Data; +} WIN32_JOBCALLOUT_PARAMETERS, *PWIN32_JOBCALLOUT_PARAMETERS; + +typedef struct _WIN32_OPENMETHOD_PARAMETERS +{ + OB_OPEN_REASON OpenReason; + PEPROCESS Process; + PVOID Object; + ULONG GrantedAccess; + ULONG HandleCount; +} WIN32_OPENMETHOD_PARAMETERS, *PWIN32_OPENMETHOD_PARAMETERS; + +typedef struct _WIN32_OKAYTOCLOSEMETHOD_PARAMETERS +{ + PEPROCESS Process; + PVOID Object; + HANDLE Handle; + KPROCESSOR_MODE PreviousMode; +} WIN32_OKAYTOCLOSEMETHOD_PARAMETERS, *PWIN32_OKAYTOCLOSEMETHOD_PARAMETERS; + +typedef struct _WIN32_CLOSEMETHOD_PARAMETERS +{ + PEPROCESS Process; + PVOID Object; + ACCESS_MASK AccessMask; + ULONG ProcessHandleCount; + ULONG SystemHandleCount; +} WIN32_CLOSEMETHOD_PARAMETERS, *PWIN32_CLOSEMETHOD_PARAMETERS; + +typedef struct _WIN32_DELETEMETHOD_PARAMETERS +{ + PVOID Object; +} WIN32_DELETEMETHOD_PARAMETERS, *PWIN32_DELETEMETHOD_PARAMETERS; + +typedef struct _WIN32_PARSEMETHOD_PARAMETERS +{ + PVOID ParseObject; + PVOID ObjectType; + PACCESS_STATE AccessState; + KPROCESSOR_MODE AccessMode; + ULONG Attributes; + OUT PUNICODE_STRING CompleteName; + PUNICODE_STRING RemainingName; + PVOID Context; + PSECURITY_QUALITY_OF_SERVICE SecurityQos; + PVOID *Object; +} WIN32_PARSEMETHOD_PARAMETERS, *PWIN32_PARSEMETHOD_PARAMETERS; + +typedef struct _WIN32_CALLOUTS_FPNS +{ + PKWIN32_PROCESS_CALLOUT ProcessCallout; + PKWIN32_THREAD_CALLOUT ThreadCallout; + PKWIN32_GLOBALATOMTABLE_CALLOUT GlobalAtomTableCallout; + PKWIN32_POWEREVENT_CALLOUT PowerEventCallout; + PKWIN32_POWERSTATE_CALLOUT PowerStateCallout; + PKWIN32_JOB_CALLOUT JobCallout; + PGDI_BATCHFLUSH_ROUTINE BatchFlushRoutine; + PKWIN32_OPENMETHOD_CALLOUT DesktopOpenProcedure; + PKWIN32_OKTOCLOSEMETHOD_CALLOUT DesktopOkToCloseProcedure; + PKWIN32_CLOSEMETHOD_CALLOUT DesktopCloseProcedure; + PKWIN32_DELETEMETHOD_CALLOUT DesktopDeleteProcedure; + PKWIN32_OKTOCLOSEMETHOD_CALLOUT WindowStationOkToCloseProcedure; + PKWIN32_CLOSEMETHOD_CALLOUT WindowStationCloseProcedure; + PKWIN32_DELETEMETHOD_CALLOUT WindowStationDeleteProcedure; + PKWIN32_PARSEMETHOD_CALLOUT WindowStationParseProcedure; + PKWIN32_OPENMETHOD_CALLOUT WindowStationOpenProcedure; + PKWIN32_WIN32DATACOLLECTION_CALLOUT Win32DataCollectionProcedure; +} WIN32_CALLOUTS_FPNS, *PWIN32_CALLOUTS_FPNS; #endif // !NTOS_MODE_USER diff --git a/reactos/include/ndk/readme.txt b/reactos/include/ndk/readme.txt index 7caf3bbef40..ea9de3ca9e3 100644 --- a/reactos/include/ndk/readme.txt +++ b/reactos/include/ndk/readme.txt @@ -12,7 +12,7 @@ The NDK is Copyright The author, Alex Ionescu, may be reached through the following means: -Email: alex.ionescu@reactos.com +Email: alexi@tinykrnl.org Mail: 2246, Duvernay. H3J 2Y3. Montreal, QC. CANADA. Phone: (514)581-7156 @@ -68,6 +68,7 @@ and sources. The following public sources of information were lawfully used: - GNU NTIFS.H, Revision 43 - W32API, Version 2.5 +- Microsoft Windows Driver Kit - Microsoft Driver Development Kit 2003 SP1 - Microsoft Driver Development Kit 2000 - Microsoft Driver Development Kit NT 4 @@ -140,24 +141,24 @@ you would like to be credited for it. * User Mode Application requiring Native Types: #define WIN32_NO_STATUS /* Tell Windows headers you'll use ntstatus.s from NDK */ - #include /* Declare Windows Headers like you normally would */ - #include /* Declare the NDK Headers */ + #include "windows.h" /* Declare Windows Headers like you normally would */ + #include "ntndk.h" /* Declare the NDK Headers */ * Native Mode Application: - #include /* Declare Windows Headers for basic types. NEEDED UNTIL NDK 1.5 */ - #include /* Declare the NDK Headers */ + #include "windows.h" /* Declare Windows Headers for basic types. NEEDED UNTIL NDK 1.5 */ + #include "ntndk.h" /* Declare the NDK Headers */ * Kernel Mode Driver: - #include /* Declare DDK Headers like you normally would */ - #include /* Declare the NDK Headers */ + #include "ntddk.h" /* Declare DDK Headers like you normally would */ + #include "ntndk.h" /* Declare the NDK Headers */ * You may also include only the files you need (example for User-Mode application): #define WIN32_NO_STATUS /* Tell Windows headers you'll use ntstatus.s from NDK */ - #include /* Declare Windows Headers like you normally would */ - #include /* Declare the Rtl* Functions */ + #include "windows.h" /* Declare Windows Headers like you normally would */ + #include "rtlfuncs.h" /* Declare the Rtl* Functions */ 3.3 CAVEATS @@ -167,5 +168,5 @@ you would like to be credited for it. ones. As such, you 'cannot include winternl.h in any project that uses the NDK. Note however, that the NDK fully replaces it and retains compatibility with any project that used it. * Native programs: Native programs must include "windows.h" until the next release of the NDK (1.5). The upcoming - version will automatically detect the lack of missing types and include them. Note however that you will still need - to have the PSDK installed. + version will automatically detect the lack of missing types and include them. Note however that you will still + need to have the PSDK installed. diff --git a/reactos/include/ndk/rtlfuncs.h b/reactos/include/ndk/rtlfuncs.h index 98cf6ae2f68..cd03f37cbcc 100644 --- a/reactos/include/ndk/rtlfuncs.h +++ b/reactos/include/ndk/rtlfuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -24,8 +24,14 @@ Author: // #include #include -#include #include +#include +#include "in6addr.h" +#include "inaddr.h" + +#ifdef __cplusplus +extern "C" { +#endif #ifdef NTOS_MODE_USER @@ -109,7 +115,7 @@ PushEntryList( FORCEINLINE BOOLEAN RemoveEntryList( - IN PLIST_ENTRY Entry) + IN PLIST_ENTRY Entry) { PLIST_ENTRY OldFlink; PLIST_ENTRY OldBlink; @@ -124,7 +130,7 @@ RemoveEntryList( FORCEINLINE PLIST_ENTRY RemoveHeadList( - IN PLIST_ENTRY ListHead) + IN PLIST_ENTRY ListHead) { PLIST_ENTRY Flink; PLIST_ENTRY Entry; @@ -139,7 +145,7 @@ RemoveHeadList( FORCEINLINE PLIST_ENTRY RemoveTailList( - IN PLIST_ENTRY ListHead) + IN PLIST_ENTRY ListHead) { PLIST_ENTRY Blink; PLIST_ENTRY Entry; @@ -151,11 +157,60 @@ RemoveTailList( return Entry; } +// +// Unicode string macros +// +FORCEINLINE +VOID +RtlInitEmptyUnicodeString(OUT PUNICODE_STRING UnicodeString, + IN PWSTR Buffer, + IN USHORT BufferSize) +{ + UnicodeString->Length = 0; + UnicodeString->MaximumLength = BufferSize; + UnicodeString->Buffer = Buffer; +} + // // LUID Macros // #define RtlEqualLuid(L1, L2) (((L1)->HighPart == (L2)->HighPart) && \ ((L1)->LowPart == (L2)->LowPart)) +FORCEINLINE +LUID +NTAPI_INLINE +RtlConvertUlongToLuid(ULONG Ulong) +{ + LUID TempLuid; + + TempLuid.LowPart = Ulong; + TempLuid.HighPart = 0; + return TempLuid; +} + +// +// ASSERT Macros +// +#ifndef ASSERT +#if DBG + +#define ASSERT( exp ) \ + ((!(exp)) ? \ + (RtlAssert( #exp, __FILE__, __LINE__, NULL ),FALSE) : \ + TRUE) + +#define ASSERTMSG( msg, exp ) \ + ((!(exp)) ? \ + (RtlAssert( #exp, __FILE__, __LINE__, msg ),FALSE) : \ + TRUE) + +#else + +#define ASSERT( exp ) ((void) 0) +#define ASSERTMSG( msg, exp ) ((void) 0) + +#endif +#endif // // RTL Splay Tree Functions @@ -268,17 +323,16 @@ RtlAssert( ); NTSYSAPI -VOID +PVOID NTAPI -RtlCaptureContext(OUT PCONTEXT ContextRecord); +RtlSetUnhandledExceptionFilter( + IN PVOID TopLevelExceptionFilter +); NTSYSAPI -ULONG +VOID NTAPI -RtlComputeCrc32( - IN ULONG Initial, - IN PUCHAR Data, - IN ULONG Length); +RtlCaptureContext(OUT PCONTEXT ContextRecord); NTSYSAPI PVOID @@ -290,6 +344,16 @@ PVOID NTAPI RtlDecodePointer(IN PVOID Pointer); +NTSYSAPI +PVOID +NTAPI +RtlEncodeSystemPointer(IN PVOID Pointer); + +NTSYSAPI +PVOID +NTAPI +RtlDecodeSystemPointer(IN PVOID Pointer); + NTSYSAPI BOOLEAN NTAPI @@ -328,6 +392,14 @@ RtlUnwind( IN PVOID ReturnValue ); +// +// Tracing Functions +// +NTSYSAPI +USHORT +NTAPI +RtlLogStackBackTrace(VOID); + // // Heap Functions // @@ -353,6 +425,15 @@ RtlCreateHeap( ); NTSYSAPI +ULONG +NTAPI +RtlCreateTagHeap( + IN HANDLE HeapHandle, + IN ULONG Flags, + IN PWSTR TagName, + IN PWSTR TagSubName +); + ULONG NTAPI RtlCompactHeap( @@ -525,6 +606,16 @@ RtlAddAuditAccessAce( BOOLEAN Failure ); +NTSYSAPI +NTSTATUS +NTAPI +RtlAcquirePrivilege( + IN PULONG Privilege, + IN ULONG NumPriv, + IN ULONG Flags, + OUT PVOID *ReturnedState +); + NTSYSAPI NTSTATUS NTAPI @@ -827,6 +918,13 @@ RtlQueryInformationAcl( ACL_INFORMATION_CLASS InformationClass ); +NTSYSAPI +VOID +NTAPI +RtlReleasePrivilege( + IN PVOID ReturnedState +); + NTSYSAPI NTSTATUS NTAPI @@ -1091,14 +1189,17 @@ unsigned __int64 __cdecl _byteswap_uint64(unsigned __int64); #else +NTSYSAPI USHORT FASTCALL RtlUshortByteSwap(IN USHORT Source); +NTSYSAPI ULONG FASTCALL RtlUlongByteSwap(IN ULONG Source); +NTSYSAPI ULONGLONG FASTCALL RtlUlonglongByteSwap(IN ULONGLONG Source); @@ -1391,6 +1492,16 @@ RtlEqualUnicodeString( BOOLEAN CaseInsensitive ); +NTSYSAPI +NTSTATUS +NTAPI +RtlFindCharInUnicodeString( + IN ULONG Flags, + IN PUNICODE_STRING SearchString, + IN PCUNICODE_STRING MatchString, + OUT PUSHORT Position +); + NTSYSAPI VOID NTAPI @@ -1410,8 +1521,17 @@ NTSYSAPI VOID NTAPI RtlInitUnicodeString( - IN OUT PUNICODE_STRING DestinationString, - IN PCWSTR SourceString); + IN OUT PUNICODE_STRING DestinationString, + IN PCWSTR SourceString +); + +NTSYSAPI +NTSTATUS +NTAPI +RtlInitUnicodeStringEx( + OUT PUNICODE_STRING DestinationString, + IN PCWSTR SourceString OPTIONAL +); NTSYSAPI ULONG @@ -1458,6 +1578,14 @@ RtlUnicodeStringToInteger( PULONG Value ); +NTSYSAPI +NTSTATUS +NTAPI +RtlValidateUnicodeString( + IN ULONG Flags, + IN PCUNICODE_STRING String +); + // // Ansi String Functions // @@ -1693,31 +1821,61 @@ RtlCreateEnvironment( PWSTR *Environment ); +NTSYSAPI +NTSTATUS +NTAPI +RtlComputePrivatizedDllName_U( + IN PUNICODE_STRING DllName, + OUT PUNICODE_STRING RealName, + OUT PUNICODE_STRING LocalName +); + NTSYSAPI VOID NTAPI -RtlDestroyEnvironment(PWSTR Environment); +RtlDestroyEnvironment( + IN PWSTR Environment +); NTSYSAPI BOOLEAN NTAPI -RtlDoesFileExists_U(PWSTR FileName); +RtlDoesFileExists_U( + IN PCWSTR FileName +); + +NTSYSAPI +BOOLEAN +NTAPI +RtlDoesFileExists_UstrEx( + IN PCUNICODE_STRING FileName, + IN BOOLEAN SucceedIfBusy +); NTSYSAPI ULONG NTAPI -RtlDetermineDosPathNameType_U(PCWSTR Path); +RtlDetermineDosPathNameType_U( + IN PCWSTR Path +); + +NTSYSAPI +ULONG +NTAPI +RtlDetermineDosPathNameType_Ustr( + IN PCUNICODE_STRING Path +); NTSYSAPI ULONG NTAPI RtlDosSearchPath_U( - WCHAR *sp, - WCHAR *name, - WCHAR *ext, - ULONG buf_sz, - WCHAR *buffer, - WCHAR **shortname + IN PCWSTR Path, + IN PCWSTR FileName, + IN PCWSTR Extension, + IN ULONG BufferSize, + OUT PWSTR Buffer, + OUT PWSTR *PartName ); NTSYSAPI @@ -1752,12 +1910,39 @@ NTSYSAPI ULONG NTAPI RtlGetFullPathName_U( - const WCHAR *dosname, - ULONG size, - WCHAR *buf, - WCHAR **shortname + IN PCWSTR FileName, + IN ULONG Size, + IN PWSTR Buffer, + OUT PWSTR *ShortName +); + +NTSYSAPI +ULONG +NTAPI +RtlGetFullPathName_Ustr( + IN PUNICODE_STRING FileName, + IN ULONG Size, + IN PWSTR Buffer, + OUT PWSTR *ShortName, + OUT PBOOLEAN InvalidName, + OUT RTL_PATH_TYPE *PathType +); + +NTSYSAPI +ULONG +NTAPI +RtlIsDosDeviceName_U( + IN PWSTR Name ); +NTSYSAPI +ULONG +NTAPI +RtlIsDosDeviceName_Ustr( + IN PUNICODE_STRING Name +); + + NTSYSAPI BOOLEAN NTAPI @@ -1779,7 +1964,9 @@ RtlQueryEnvironmentVariable_U( NTSYSAPI NTSTATUS NTAPI -RtlSetCurrentDirectory_U(PUNICODE_STRING name); +RtlSetCurrentDirectory_U( + IN PUNICODE_STRING name +); NTSYSAPI NTSTATUS @@ -1829,6 +2016,13 @@ RtlLeaveCriticalSection( IN PRTL_CRITICAL_SECTION CriticalSection ); +NTSYSAPI +BOOLEAN +NTAPI +RtlTryEnterCriticalSection( + IN PRTL_CRITICAL_SECTION CriticalSection +); + NTSYSAPI VOID NTAPI @@ -1943,7 +2137,7 @@ RtlGetCompressionWorkSpaceSize( // Debug Info Functions // NTSYSAPI -PRTL_DEBUG_BUFFER +PRTL_DEBUG_INFORMATION NTAPI RtlCreateQueryDebugBuffer( IN ULONG Size, @@ -1953,7 +2147,7 @@ RtlCreateQueryDebugBuffer( NTSYSAPI NTSTATUS NTAPI -RtlDestroyQueryDebugBuffer(IN PRTL_DEBUG_BUFFER DebugBuffer); +RtlDestroyQueryDebugBuffer(IN PRTL_DEBUG_INFORMATION DebugBuffer); NTSYSAPI NTSTATUS @@ -1961,7 +2155,7 @@ NTAPI RtlQueryProcessDebugInformation( IN ULONG ProcessId, IN ULONG DebugInfoClassMask, - IN OUT PRTL_DEBUG_BUFFER DebugBuffer + IN OUT PRTL_DEBUG_INFORMATION DebugBuffer ); // @@ -2024,7 +2218,15 @@ RtlInitializeBitMap( NTSYSAPI VOID NTAPI -RtlSetBits ( +RtlSetBit( + PRTL_BITMAP BitMapHeader, + ULONG BitNumber +); + +NTSYSAPI +VOID +NTAPI +RtlSetBits( IN PRTL_BITMAP BitMapHeader, IN ULONG StartingIndex, IN ULONG NumberToSet @@ -2083,6 +2285,26 @@ NTSTATUS NTAPI RtlDeleteTimerQueue(HANDLE TimerQueue); +// +// SList functions +// +PSLIST_ENTRY +FASTCALL +InterlockedPushListSList( + IN PSLIST_HEADER ListHead, + IN PSLIST_ENTRY List, + IN PSLIST_ENTRY ListEnd, + IN ULONG Count +); + +// +// Range List functions +// +NTSYSAPI +VOID +NTAPI +RtlFreeRangeList(IN PRTL_RANGE_LIST RangeList); + // // Debug Functions // @@ -2093,6 +2315,24 @@ DbgPrint( IN ... ); +NTSYSAPI +ULONG +__cdecl +DbgPrintEx( + IN ULONG ComponentId, + IN ULONG Level, + IN PCH Format, + IN ... +); + +ULONG +NTAPI +DbgPrompt( + IN PCH PromptString, + OUT PCH OutputString, + IN ULONG OutputSize +); + VOID NTAPI DbgBreakPoint(VOID); @@ -2170,9 +2410,9 @@ NTSYSAPI PVOID NTAPI RtlImageDirectoryEntryToData( - PVOID BaseAddress, - BOOLEAN bFlag, - ULONG Directory, + PVOID BaseAddress, + BOOLEAN MappedAsImage, + USHORT Directory, PULONG Size ); @@ -2191,6 +2431,16 @@ PIMAGE_NT_HEADERS NTAPI RtlImageNtHeader(IN PVOID BaseAddress); +NTSYSAPI +NTSTATUS +NTAPI +RtlImageNtHeaderEx( + IN ULONG Flags, + IN PVOID BaseAddress, + IN ULONGLONG Size, + IN PIMAGE_NT_HEADERS *NtHeader +); + NTSYSAPI PIMAGE_SECTION_HEADER NTAPI @@ -2200,6 +2450,73 @@ RtlImageRvaToSection( ULONG Rva ); +// +// Activation Context Functions +// +#ifdef NTOS_MODE_USER +NTSYSAPI +NTSTATUS +NTAPI +RtlActivateActivationContextUnsafeFast( + IN PRTL_CALLER_ALLOCATED_ACTIVATION_CONTEXT_STACK_FRAME_EXTENDED Frame, + IN PVOID Context +); + +NTSYSAPI +NTSTATUS +NTAPI +RtlAllocateActivationContextStack( + IN PVOID *Context +); + +NTSYSAPI +NTSTATUS +NTAPI +RtlGetActiveActivationContext( + IN PVOID *Context +); + +NTSYSAPI +VOID +NTAPI +RtlReleaseActivationContext( + IN PVOID *Context +); + +NTSYSAPI +NTSTATUS +NTAPI +RtlDeactivateActivationContextUnsafeFast( + IN PRTL_CALLER_ALLOCATED_ACTIVATION_CONTEXT_STACK_FRAME_EXTENDED Frame +); + +NTSYSAPI +NTSTATUS +NTAPI +RtlDosApplyFileIsolationRedirection_Ustr( + IN BOOLEAN Unknown, + IN PUNICODE_STRING OriginalName, + IN PUNICODE_STRING Extension, + IN OUT PUNICODE_STRING RedirectedName, + IN OUT PUNICODE_STRING RedirectedName2, + IN OUT PUNICODE_STRING *OriginalName2, + IN PVOID Unknown1, + IN PVOID Unknown2, + IN PVOID Unknown3 +); + +NTSYSAPI +NTSTATUS +NTAPI +RtlFindActivationContextSectionString( + IN PVOID Unknown0, + IN PVOID Unknown1, + IN ULONG SectionType, + IN PUNICODE_STRING SectionName, + IN PVOID Unknown2 +); +#endif + // // Registry Functions // @@ -2352,7 +2669,18 @@ RtlEnlargedUnsignedMultiply( NTSYSAPI ULONG NTAPI -RtlUniform(PULONG Seed); +RtlUniform( + IN PULONG Seed +); + +NTSYSAPI +ULONG +NTAPI +RtlComputeCrc32( + IN UINT PartialCrc, + IN PUCHAR Buffer, + IN ULONG Length +); // // Network Functions @@ -2361,36 +2689,36 @@ NTSYSAPI NTSTATUS NTAPI RtlIpv4StringToAddressW( - IN LPWSTR IpString, - IN ULONG Base, - OUT PULONG PtrToIpAddr, - OUT PULONG IpAddr + IN PWCHAR String, + IN UCHAR Strict, + OUT PWCHAR Terminator, + OUT struct in_addr *Addr ); NTSYSAPI NTSTATUS NTAPI RtlIpv6StringToAddressA( - IN LPSTR Name, - OUT PULONG Unknown, - OUT PVOID IpAddr + IN PCHAR Name, + OUT PCHAR *Terminator, + OUT struct in6_addr *Addr ); NTSYSAPI NTSTATUS NTAPI RtlIpv6StringToAddressW( - IN LPWSTR Name, - OUT PULONG Unknown, - OUT PVOID IpAddr + IN PWCHAR Name, + OUT PCHAR *Terminator, + OUT struct in6_addr *Addr ); NTSYSAPI NTSTATUS NTAPI RtlIpv6StringToAddressExA( - IN LPSTR AddressName, - IN PVOID Address, + IN PCHAR AddressString, + IN struct in6_addr *Address, IN PULONG ScopeId, IN PUSHORT Port ); @@ -2399,8 +2727,8 @@ NTSYSAPI NTSTATUS NTAPI RtlIpv6StringToAddressExW( - IN LPWSTR AddressName, - IN PVOID Address, + IN PWCHAR AddressName, + IN struct in6_addr *Address, IN PULONG ScopeId, IN PUSHORT Port ); @@ -2409,6 +2737,7 @@ RtlIpv6StringToAddressExW( // // Time Functions // +struct _RTL_TIME_ZONE_INFORMATION; NTSYSAPI NTSTATUS NTAPI @@ -2443,6 +2772,14 @@ RtlTimeToTimeFields( PTIME_FIELDS TimeFields ); +NTSYSAPI +NTSTATUS +NTAPI +RtlSystemTimeToLocalTime( + IN PLARGE_INTEGER SystemTime, + OUT PLARGE_INTEGER LocalTime +); + // // Version Functions // @@ -2465,4 +2802,8 @@ BOOLEAN NTAPI RtlGetNtProductType(OUT PNT_PRODUCT_TYPE ProductType); +#ifdef __cplusplus +} +#endif + #endif diff --git a/reactos/include/ndk/rtltypes.h b/reactos/include/ndk/rtltypes.h index 7b64294bb11..9a1914151aa 100644 --- a/reactos/include/ndk/rtltypes.h +++ b/reactos/include/ndk/rtltypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -42,6 +42,9 @@ Author: #define RTL_USER_PROCESS_PARAMETERS_DISABLE_HEAP_CHECKS 0x100 #define RTL_USER_PROCESS_PARAMETERS_PROCESS_OR_1 0x200 #define RTL_USER_PROCESS_PARAMETERS_PROCESS_OR_2 0x400 +#define RTL_USER_PROCESS_PARAMETERS_PRIVATE_DLL_PATH 0x1000 +#define RTL_USER_PROCESS_PARAMETERS_LOCAL_DLL_PATH 0x2000 +#define RTL_USER_PROCESS_PARAMETERS_NX 0x20000 // // Exception Flags @@ -50,6 +53,7 @@ Author: #define EXCEPTION_UNWINDING 0x02 #define EXCEPTION_EXIT_UNWIND 0x04 #define EXCEPTION_STACK_INVALID 0x08 +#define EXCEPTION_UNWIND (EXCEPTION_UNWINDING + EXCEPTION_EXIT_UNWIND) #define EXCEPTION_NESTED_CALL 0x10 #define EXCEPTION_TARGET_UNWIND 0x20 #define EXCEPTION_COLLIDED_UNWIND 0x20 @@ -63,6 +67,26 @@ Author: #define RTL_RANGE_SHARED 0x01 #define RTL_RANGE_CONFLICT 0x02 +// +// Activation Context Frame Flags +// +#define RTL_CALLER_ALLOCATED_ACTIVATION_CONTEXT_STACK_FRAME_FORMAT_WHISTLER \ + 0x1 + +// +// Heap Flags +// +#define HEAP_CLASS_0 0x00000000 +#define HEAP_CLASS_1 0x00001000 +#define HEAP_CLASS_2 0x00002000 +#define HEAP_CLASS_3 0x00003000 +#define HEAP_CLASS_4 0x00004000 +#define HEAP_CLASS_5 0x00005000 +#define HEAP_CLASS_6 0x00006000 +#define HEAP_CLASS_7 0x00007000 +#define HEAP_CLASS_8 0x00008000 +#define HEAP_CLASS_MASK 0x0000F000 + // // Registry Keys // @@ -120,6 +144,12 @@ Author: #define RTL_CRITSECT_TYPE 0 #define RTL_RESOURCE_TYPE 1 +// +// RtlAcquirePrivileges Flags +// +#define RTL_ACQUIRE_PRIVILEGE_IMPERSONATE 1 +#define RTL_ACQUIRE_PRIVILEGE_PROCESS 2 + #ifdef NTOS_MODE_USER // @@ -141,6 +171,12 @@ Author: #define NLS_MB_CODE_PAGE_TAG NlsMbCodePageTag #define NLS_MB_OEM_CODE_PAGE_TAG NlsMbOemCodePageTag #define NLS_OEM_LEAD_BYTE_INFO NlsOemLeadByteInfo +#else +// +// Message Resource Flag +// +#define MESSAGE_RESOURCE_UNICODE 0x0001 + #endif #define MAXIMUM_LEADBYTES 12 @@ -164,6 +200,14 @@ Author: // #define RTL_ATOM_IS_PINNED 0x1 +// +// Critical section lock bits +// +#define CS_LOCK_BIT 0x1 +#define CS_LOCK_BIT_V 0x0 +#define CS_LOCK_WAITER_WOKEN 0x2 +#define CS_LOCK_WAITER_INC 0x4 + // // Codepage Tags // @@ -221,14 +265,14 @@ typedef enum _ACL_INFORMATION_CLASS // typedef enum _RTL_PATH_TYPE { - INVALID_PATH = 0, - UNC_PATH, // "//foo" - ABSOLUTE_DRIVE_PATH, // "c:/foo" - RELATIVE_DRIVE_PATH, // "c:foo" - ABSOLUTE_PATH, // "/foo" - RELATIVE_PATH, // "foo" - DEVICE_PATH, // "//./foo" - UNC_DOT_PATH // "//." + RtlPathTypeUnknown, + RtlPathTypeUncAbsolute, + RtlPathTypeDriveAbsolute, + RtlPathTypeDriveRelative, + RtlPathTypeRooted, + RtlPathTypeRelative, + RtlPathTypeLocalDevice, + RtlPathTypeRootLocalDevice, } RTL_PATH_TYPE; #ifndef NTOS_MODE_USER @@ -263,6 +307,30 @@ typedef EXCEPTION_DISPOSITION IN OUT PVOID DispatcherContext ); +// +// RTL Library Allocation/Free Routines +// +typedef PVOID +(NTAPI *PRTL_ALLOCATE_STRING_ROUTINE)( + SIZE_T NumberOfBytes +); + +typedef PVOID +(NTAPI *PRTL_REALLOCATE_STRING_ROUTINE)( + SIZE_T NumberOfBytes, + PVOID Buffer +); + +typedef +VOID +(NTAPI *PRTL_FREE_STRING_ROUTINE)( + PVOID Buffer +); + +extern const PRTL_ALLOCATE_STRING_ROUTINE RtlAllocateStringRoutine; +extern const PRTL_FREE_STRING_ROUTINE RtlFreeStringRoutine; +extern const PRTL_REALLOCATE_STRING_ROUTINE RtlReallocateStringRoutine; + #endif // @@ -538,7 +606,39 @@ typedef struct _TIME_FIELDS CSHORT Weekday; } TIME_FIELDS, *PTIME_FIELDS; +// +// Activation Context +// +typedef PVOID PACTIVATION_CONTEXT; + +// +// Activation Context Frame +// +typedef struct _RTL_ACTIVATION_CONTEXT_STACK_FRAME +{ + struct __RTL_ACTIVATION_CONTEXT_STACK_FRAME *Previous; + PACTIVATION_CONTEXT ActivationContext; + ULONG Flags; +} RTL_ACTIVATION_CONTEXT_STACK_FRAME, + *PRTL_ACTIVATION_CONTEXT_STACK_FRAME; + +typedef struct _RTL_CALLER_ALLOCATED_ACTIVATION_CONTEXT_STACK_FRAME_EXTENDED +{ + ULONG Size; + ULONG Format; + RTL_ACTIVATION_CONTEXT_STACK_FRAME Frame; + PVOID Extra1; + PVOID Extra2; + PVOID Extra3; + PVOID Extra4; +} RTL_CALLER_ALLOCATED_ACTIVATION_CONTEXT_STACK_FRAME_EXTENDED, + *PRTL_CALLER_ALLOCATED_ACTIVATION_CONTEXT_STACK_FRAME_EXTENDED; + #endif + +// +// ACE Structure +// typedef struct _ACE { ACE_HEADER Header; @@ -550,42 +650,54 @@ typedef struct _ACE // typedef struct _RTL_PROCESS_MODULE_INFORMATION { - ULONG Reserved[2]; - PVOID Base; - ULONG Size; + ULONG Section; + PVOID MappedBase; + PVOID ImageBase; + ULONG ImageSize; ULONG Flags; - USHORT Index; - USHORT Unknown; + USHORT LoadOrderIndex; + USHORT InitOrderIndex; USHORT LoadCount; - USHORT ModuleNameOffset; - CHAR ImageName[256]; + USHORT OffsetToFileName; + CHAR FullPathName[256]; } RTL_PROCESS_MODULE_INFORMATION, *PRTL_PROCESS_MODULE_INFORMATION; typedef struct _RTL_PROCESS_MODULES { - ULONG ModuleCount; - RTL_PROCESS_MODULE_INFORMATION ModuleEntry[1]; + ULONG NumberOfModules; + RTL_PROCESS_MODULE_INFORMATION Modules[1]; } RTL_PROCESS_MODULES, *PRTL_PROCESS_MODULES; -typedef struct _RTL_PROCESS_HEAP_INFORMATION +typedef struct _RTL_PROCESS_MODULE_INFORMATION_EX +{ + ULONG NextOffset; + RTL_PROCESS_MODULE_INFORMATION BaseInfo; + ULONG ImageCheckSum; + ULONG TimeDateStamp; + PVOID DefaultBase; +} RTL_PROCESS_MODULE_INFORMATION_EX, *PRTL_PROCESS_MODULE_INFORMATION_EX; + +typedef struct _RTL_HEAP_INFORMATION { - PVOID Base; + PVOID BaseAddress; ULONG Flags; - USHORT Granularity; - USHORT Unknown; - ULONG Allocated; - ULONG Committed; - ULONG TagCount; - ULONG BlockCount; - ULONG Reserved[7]; + USHORT EntryOverhead; + USHORT CreatorBackTraceIndex; + ULONG BytesAllocated; + ULONG BytesCommitted; + ULONG NumberOfTags; + ULONG NumberOfEntries; + ULONG NumberOfPseudoTags; + ULONG PseudoTagGranularity; + ULONG Reserved[4]; PVOID Tags; - PVOID Blocks; -} RTL_PROCESS_HEAP_INFORMATION, *PRTL_PROCESS_HEAP_INFORMATION; + PVOID Entries; +} RTL_HEAP_INFORMATION, *PRTL_HEAP_INFORMATION; typedef struct _RTL_PROCESS_HEAPS { - ULONG HeapCount; - RTL_PROCESS_HEAP_INFORMATION HeapEntry[1]; + ULONG NumberOfHeaps; + RTL_HEAP_INFORMATION Heaps[1]; } RTL_PROCESS_HEAPS, *PRTL_PROCESS_HEAPS; typedef struct _RTL_PROCESS_LOCK_INFORMATION @@ -604,8 +716,8 @@ typedef struct _RTL_PROCESS_LOCK_INFORMATION typedef struct _RTL_PROCESS_LOCKS { - ULONG LockCount; - RTL_PROCESS_LOCK_INFORMATION LockEntry[1]; + ULONG NumberOfLocks; + RTL_PROCESS_LOCK_INFORMATION Locks[1]; } RTL_PROCESS_LOCKS, *PRTL_PROCESS_LOCKS; typedef struct _RTL_PROCESS_BACKTRACE_INFORMATION @@ -626,25 +738,59 @@ typedef struct _RTL_PROCESS_BACKTRACES RTL_PROCESS_BACKTRACE_INFORMATION BackTraces[1]; } RTL_PROCESS_BACKTRACES, *PRTL_PROCESS_BACKTRACES; -typedef struct _RTL_DEBUG_BUFFER -{ - HANDLE SectionHandle; - PVOID SectionBase; - PVOID RemoteSectionBase; - ULONG SectionBaseDelta; - HANDLE EventPairHandle; - ULONG Unknown[2]; - HANDLE RemoteThreadHandle; - ULONG InfoClassMask; - ULONG SizeOfInfo; - ULONG AllocatedSize; - ULONG SectionSize; - PRTL_PROCESS_MODULES ModuleInformation; - PRTL_PROCESS_BACKTRACES BackTraceInformation; - PRTL_PROCESS_HEAPS HeapInformation; - PRTL_PROCESS_LOCKS LockInformation; - PVOID Reserved[8]; -} RTL_DEBUG_BUFFER, *PRTL_DEBUG_BUFFER; +typedef struct _RTL_PROCESS_VERIFIER_OPTIONS +{ + ULONG SizeStruct; + ULONG Option; + UCHAR OptionData[1]; + // + // Option array continues below + // +} RTL_PROCESS_VERIFIER_OPTIONS, *PRTL_PROCESS_VERIFIER_OPTIONS; + +typedef struct _RTL_DEBUG_INFORMATION +{ + HANDLE SectionHandleClient; + PVOID ViewBaseClient; + PVOID ViewBaseTarget; + ULONG ViewBaseDelta; + HANDLE EventPairClient; + PVOID EventPairTarget; + HANDLE TargetProcessId; + HANDLE TargetThreadHandle; + ULONG Flags; + ULONG OffsetFree; + ULONG CommitSize; + ULONG ViewSize; + union + { + PRTL_PROCESS_MODULES Modules; + PRTL_PROCESS_MODULE_INFORMATION_EX ModulesEx; + }; + PRTL_PROCESS_BACKTRACES BackTraces; + PRTL_PROCESS_HEAPS Heaps; + PRTL_PROCESS_LOCKS Locks; + HANDLE SpecificHeap; + HANDLE TargetProcessHandle; + RTL_PROCESS_VERIFIER_OPTIONS VerifierOptions; + HANDLE ProcessHeap; + HANDLE CriticalSectionHandle; + HANDLE CriticalSectionOwnerThread; + PVOID Reserved[4]; +} RTL_DEBUG_INFORMATION, *PRTL_DEBUG_INFORMATION; + +// +// Unload Event Trace Structure for RtlGetUnloadEventTrace +// +typedef struct _RTL_UNLOAD_EVENT_TRACE +{ + PVOID BaseAddress; + ULONG SizeOfImage; + ULONG Sequence; + ULONG TimeDateStamp; + ULONG CheckSum; + WCHAR ImageName[32]; +} RTL_UNLOAD_EVENT_TRACE, *PRTL_UNLOAD_EVENT_TRACE; // // RTL Handle Structures @@ -692,6 +838,19 @@ typedef struct RTL_DRIVE_LETTER_CURDIR UNICODE_STRING DosPath; } RTL_DRIVE_LETTER_CURDIR, *PRTL_DRIVE_LETTER_CURDIR; +// +// Private State structure for RtlAcquirePrivilege/RtlReleasePrivilege +// +typedef struct _RTL_ACQUIRE_STATE +{ + HANDLE Token; + HANDLE OldImpersonationToken; + PTOKEN_PRIVILEGES OldPrivileges; + PTOKEN_PRIVILEGES NewPrivileges; + ULONG Flags; + UCHAR OldPrivBuffer[1024]; +} RTL_ACQUIRE_STATE, *PRTL_ACQUIRE_STATE; + #ifndef NTOS_MODE_USER // @@ -718,7 +877,7 @@ typedef struct _RTL_CRITICAL_SECTION ULONG_PTR SpinCount; } RTL_CRITICAL_SECTION, *PRTL_CRITICAL_SECTION; -#else +#endif // // RTL Range List Structures @@ -749,8 +908,6 @@ typedef struct _RANGE_LIST_ITERATOR ULONG Stamp; } RTL_RANGE_LIST_ITERATOR, *PRTL_RANGE_LIST_ITERATOR; -#endif - // // RTL Resource // @@ -901,6 +1058,24 @@ typedef struct _TIME_ZONE_INFORMATION #endif +// +// Hotpatch Header +// +typedef struct _RTL_PATCH_HEADER +{ + LIST_ENTRY PatchList; + PVOID PatchImageBase; + struct _RTL_PATCH_HEADER *NextPath; + ULONG PatchFlags; + LONG PatchRefCount; + struct _HOTPATCH_HEADER *HotpatchHeader; + UNICODE_STRING TargetDllName; + PVOID TargetDllBase; + PLDR_DATA_TABLE_ENTRY TargetLdrDataTableEntry; + PLDR_DATA_TABLE_ENTRY PatchLdrDataTableEntry; + struct _SYSTEM_HOTPATCH_CODE_INFORMATION *CodeInfo; +} RTL_PATCH_HEADER, *PRTL_PATCH_HEADER; + // // Header for NLS Files // @@ -917,4 +1092,47 @@ typedef struct _NLS_FILE_HEADER UCHAR LeadByte[MAXIMUM_LEADBYTES]; } NLS_FILE_HEADER, *PNLS_FILE_HEADER; +// +// Stack Traces +// +typedef struct _RTL_STACK_TRACE_ENTRY +{ + struct _RTL_STACK_TRACE_ENTRY *HashChain; + ULONG TraceCount; + USHORT Index; + USHORT Depth; + PVOID BackTrace[32]; +} RTL_STACK_TRACE_ENTRY, *PRTL_STACK_TRACE_ENTRY; + +typedef struct _STACK_TRACE_DATABASE +{ + RTL_CRITICAL_SECTION CriticalSection; +} STACK_TRACE_DATABASE, *PSTACK_TRACE_DATABASE; + +#ifndef NTOS_MODE_USER + +// +// Message Resource Entry, Block and Data +// +typedef struct _MESSAGE_RESOURCE_ENTRY +{ + USHORT Length; + USHORT Flags; + UCHAR Text[ANYSIZE_ARRAY]; +} MESSAGE_RESOURCE_ENTRY, *PMESSAGE_RESOURCE_ENTRY; + +typedef struct _MESSAGE_RESOURCE_BLOCK +{ + ULONG LowId; + ULONG HighId; + ULONG OffsetToEntries; +} MESSAGE_RESOURCE_BLOCK, *PMESSAGE_RESOURCE_BLOCK; + +typedef struct _MESSAGE_RESOURCE_DATA +{ + ULONG NumberOfBlocks; + MESSAGE_RESOURCE_BLOCK Blocks[ANYSIZE_ARRAY]; +} MESSAGE_RESOURCE_DATA, *PMESSAGE_RESOURCE_DATA; + +#endif #endif diff --git a/reactos/include/ndk/sefuncs.h b/reactos/include/ndk/sefuncs.h index 8152c461e2e..5d52a8eefdf 100644 --- a/reactos/include/ndk/sefuncs.h +++ b/reactos/include/ndk/sefuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -274,7 +274,7 @@ NtQueryInformationToken( OUT PULONG ReturnLength ); -NTSYSAPI +NTSYSCALLAPI NTSTATUS NTAPI NtSetInformationToken( diff --git a/reactos/include/ndk/setypes.h b/reactos/include/ndk/setypes.h index eb1a39813a6..860de4815e3 100644 --- a/reactos/include/ndk/setypes.h +++ b/reactos/include/ndk/setypes.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ diff --git a/reactos/include/ndk/umfuncs.h b/reactos/include/ndk/umfuncs.h index 477c75f6835..3747f391ae3 100644 --- a/reactos/include/ndk/umfuncs.h +++ b/reactos/include/ndk/umfuncs.h @@ -1,4 +1,4 @@ -/*++ NDK Version: 0095 +/*++ NDK Version: 0098 Copyright (c) Alex Ionescu. All rights reserved. @@ -12,7 +12,7 @@ Abstract: Author: - Alex Ionescu (alex.ionescu@reactos.com) 06-Oct-2004 + Alex Ionescu (alexi@tinykrnl.org) - Updated - 27-Feb-2006 --*/ @@ -213,7 +213,7 @@ NTSTATUS NTAPI LdrLoadDll( IN PWSTR SearchPath OPTIONAL, - IN ULONG LoadFlags, + IN PULONG LoadFlags OPTIONAL, IN PUNICODE_STRING Name, OUT PVOID *BaseAddress OPTIONAL ); @@ -228,10 +228,10 @@ RtlPcToFileHeader( PIMAGE_BASE_RELOCATION NTAPI LdrProcessRelocationBlock( - IN PVOID Address, - IN USHORT Count, + IN ULONG_PTR Address, + IN ULONG Count, IN PUSHORT TypeOffset, - IN ULONG_PTR Delta + IN LONG_PTR Delta ); NTSTATUS diff --git a/reactos/include/reactos/arc/arc.h b/reactos/include/reactos/arc/arc.h index 43747c1a15a..f656013585b 100644 --- a/reactos/include/reactos/arc/arc.h +++ b/reactos/include/reactos/arc/arc.h @@ -1,9 +1,5 @@ -/* ARC LOADER TYPES *********************************************************/ - -#ifndef __INCLUDE_ARC_H -#define __INCLUDE_ARC_H - -/* Types */ +#ifndef _ARC_ +#define _ARC_ typedef enum _IDENTIFIER_FLAG { @@ -28,6 +24,20 @@ typedef enum _CONFIGURATION_CLASS MaximumClass } CONFIGURATION_CLASS; +typedef enum +{ + HwFileDriver, + HwFilePort, + HwFileClass, + HwFileInf, + HwFileDll, + HwFileDetect, + HwFileHal, + HwFileCatalog, + HwFileMax, + HwFileDynUpdt = 31, +} HwFileType; + typedef struct _CONFIGURATION_COMPONENT { CONFIGURATION_CLASS Class; @@ -47,7 +57,8 @@ typedef struct _CONFIGURATION_COMPONENT_DATA struct _CONFIGURATION_COMPONENT_DATA *Parent; struct _CONFIGURATION_COMPONENT_DATA *Child; struct _CONFIGURATION_COMPONENT_DATA *Sibling; - CONFIGURATION_COMPONENT Component; + CONFIGURATION_COMPONENT ComponentEntry; + PVOID ConfigurationData; } CONFIGURATION_COMPONENT_DATA, *PCONFIGURATION_COMPONENT_DATA; typedef struct _ARC_DISK_INFORMATION @@ -55,4 +66,202 @@ typedef struct _ARC_DISK_INFORMATION LIST_ENTRY DiskSignatureListHead; } ARC_DISK_INFORMATION, *PARC_DISK_INFORMATION; +typedef struct _MONITOR_CONFIGURATION_DATA +{ + USHORT Version; + USHORT Revision; + USHORT HorizontalResolution; + USHORT HorizontalDisplayTime; + USHORT HorizontalBackPorch; + USHORT HorizontalFrontPorch; + USHORT HorizontalSync; + USHORT VerticalResolution; + USHORT VerticalBackPorch; + USHORT VerticalFrontPorch; + USHORT VerticalSync; + USHORT HorizontalScreenSize; + USHORT VerticalScreenSize; +} MONITOR_CONFIGURATION_DATA, *PMONITOR_CONFIGURATION_DATA; + +typedef struct _FLOPPY_CONFIGURATION_DATA +{ + USHORT Version; + USHORT Revision; + CHAR Size[8]; + ULONG MaxDensity; + ULONG MountDensity; +} FLOPPY_CONFIGURATION_DATA, *PFLOPPY_CONFIGURATION_DATA; + +// +// SMBIOS Table Header (FIXME: maybe move to smbios.h?) +// +typedef struct _SMBIOS_TABLE_HEADER +{ + CHAR Signature[4]; + UCHAR Checksum; + UCHAR Length; + UCHAR MajorVersion; + UCHAR MinorVersion; + USHORT MaximumStructureSize; + UCHAR EntryPointRevision; + UCHAR Reserved[5]; + CHAR Signature2[5]; + UCHAR IntermediateChecksum; + USHORT StructureTableLength; + ULONG StructureTableAddress; + USHORT NumberStructures; + UCHAR Revision; +} SMBIOS_TABLE_HEADER, *PSMBIOS_TABLE_HEADER; + +// +// NLS Data Block +// +typedef struct _NLS_DATA_BLOCK +{ + PVOID AnsiCodePageData; + PVOID OemCodePageData; + PVOID UnicodeCodePageData; +} NLS_DATA_BLOCK, *PNLS_DATA_BLOCK; + +// +// Subsystem Specific Loader Blocks +// +typedef struct _PROFILE_PARAMETER_BLOCK +{ + USHORT Status; + USHORT Reserved; + USHORT DockingState; + USHORT Capabilities; + ULONG DockID; + ULONG SerialNumber; +} PROFILE_PARAMETER_BLOCK, *PPROFILE_PARAMETER_BLOCK; + +typedef struct _HEADLESS_LOADER_BLOCK +{ + UCHAR UsedBiosSettings; + UCHAR DataBits; + UCHAR StopBits; + UCHAR Parity; + ULONG BaudRate; + ULONG PortNumber; + PUCHAR PortAddress; + USHORT PciDeviceId; + USHORT PciVendorId; + UCHAR PciBusNumber; + UCHAR PciSlotNumber; + UCHAR PciFunctionNumber; + ULONG PciFlags; + GUID SystemGUID; + UCHAR IsMMIODevice; + UCHAR TerminalType; +} HEADLESS_LOADER_BLOCK, *PHEADLESS_LOADER_BLOCK; + +typedef struct _NETWORK_LOADER_BLOCK +{ + PCHAR DHCPServerACK; + ULONG DHCPServerACKLength; + PCHAR BootServerReplyPacket; + ULONG BootServerReplyPacketLength; +} NETWORK_LOADER_BLOCK, *PNETWORK_LOADER_BLOCK; + +typedef struct _LOADER_PERFORMANCE_DATA +{ + ULONGLONG StartTime; + ULONGLONG EndTime; +} LOADER_PERFORMANCE_DATA, *PLOADER_PERFORMANCE_DATA; + +// +// Extended Loader Parameter Block +// +typedef struct _LOADER_PARAMETER_EXTENSION +{ + ULONG Size; + PROFILE_PARAMETER_BLOCK Profile; + ULONG MajorVersion; + ULONG MinorVersion; + PVOID EmInfFileImage; + ULONG EmInfFileSize; + PVOID TriageDumpBlock; + // + // NT 5.1 + // + ULONG LoaderPagesSpanned; + PHEADLESS_LOADER_BLOCK HeadlessLoaderBlock; + PSMBIOS_TABLE_HEADER SMBiosEPSHeader; + PVOID DrvDBImage; + ULONG DrvDBSize; + PNETWORK_LOADER_BLOCK NetworkLoaderBlock; + // + // NT 5.2+ + // + PCHAR HalpIRQLToTPR; + PCHAR HalpVectorToIRQL; + LIST_ENTRY FirmwareDescriptorListHead; + PVOID AcpiTable; + ULONG AcpiTableSize; + // + // NT 5.2 SP1+ + // + ULONG BootViaWinload:1; + ULONG BootViaEFI:1; + ULONG Reserved:30; + LOADER_PERFORMANCE_DATA LoaderPerformanceData; + LIST_ENTRY BootApplicationPersistentData; + PVOID WmdTestResult; + GUID BootIdentifier; +} LOADER_PARAMETER_EXTENSION, *PLOADER_PARAMETER_EXTENSION; + +// +// Architecture specific Loader Parameter Blocks +// +typedef struct _IA64_LOADER_BLOCK +{ + ULONG PlaceHolder; +} IA64_LOADER_BLOCK, *PIA64_LOADER_BLOCK; + +typedef struct _ALPHA_LOADER_BLOCK +{ + ULONG PlaceHolder; +} ALPHA_LOADER_BLOCK, *PALPHA_LOADER_BLOCK; + +typedef struct _I386_LOADER_BLOCK +{ + PVOID CommonDataArea; + ULONG MachineType; + ULONG Reserved; +} I386_LOADER_BLOCK, *PI386_LOADER_BLOCK; + +// +// Loader Parameter Block +// +typedef struct _LOADER_PARAMETER_BLOCK +{ + LIST_ENTRY LoadOrderListHead; + LIST_ENTRY MemoryDescriptorListHead; + LIST_ENTRY BootDriverListHead; + ULONG_PTR KernelStack; + ULONG_PTR Prcb; + ULONG_PTR Process; + ULONG_PTR Thread; + ULONG RegistryLength; + PVOID RegistryBase; + PCONFIGURATION_COMPONENT_DATA ConfigurationRoot; + LPSTR ArcBootDeviceName; + LPSTR ArcHalDeviceName; + LPSTR NtBootPathName; + LPSTR NtHalPathName; + LPSTR LoadOptions; + PNLS_DATA_BLOCK NlsData; + PARC_DISK_INFORMATION ArcDiskInformation; + PVOID OemFontFile; + struct _SETUP_LOADER_BLOCK *SetupLdrBlock; + PLOADER_PARAMETER_EXTENSION Extension; + union + { + I386_LOADER_BLOCK I386; + ALPHA_LOADER_BLOCK Alpha; + IA64_LOADER_BLOCK Ia64; + } u; +} LOADER_PARAMETER_BLOCK, *PLOADER_PARAMETER_BLOCK; + #endif diff --git a/reactos/include/reactos/drivers/diskdump/diskdump.h b/reactos/include/reactos/drivers/diskdump/diskdump.h index c9f050db977..59d134cfa4c 100644 --- a/reactos/include/reactos/drivers/diskdump/diskdump.h +++ b/reactos/include/reactos/drivers/diskdump/diskdump.h @@ -2,7 +2,7 @@ #define __DISKDUMP_H #include -#include +#include #define MM_CORE_DUMP_HEADER_MAGIC (0xdeafbead) #define MM_CORE_DUMP_HEADER_VERSION (0x1) diff --git a/reactos/include/reactos/libs/epsapi/epsapi.h b/reactos/include/reactos/libs/epsapi/epsapi.h index e6f5888bbe0..aa81ad9ae0b 100644 --- a/reactos/include/reactos/libs/epsapi/epsapi.h +++ b/reactos/include/reactos/libs/epsapi/epsapi.h @@ -32,7 +32,7 @@ typedef NTSTATUS (NTAPI *PPROC_ENUM_ROUTINE)(IN PSYSTEM_PROCESS_INFORMATION Curr typedef NTSTATUS (NTAPI *PTHREAD_ENUM_ROUTINE)(IN PSYSTEM_THREAD_INFORMATION CurrentThread, IN OUT PVOID CallbackContext); -typedef NTSTATUS (NTAPI *PSYSMOD_ENUM_ROUTINE)(IN PSYSTEM_MODULE_INFORMATION_ENTRY CurrentModule, +typedef NTSTATUS (NTAPI *PSYSMOD_ENUM_ROUTINE)(IN PRTL_PROCESS_MODULE_INFORMATION CurrentModule, IN OUT PVOID CallbackContext); typedef NTSTATUS (NTAPI *PPROCMOD_ENUM_ROUTINE)(IN HANDLE ProcessHandle, @@ -100,18 +100,18 @@ PsaEnumerateSystemModules(IN PSYSMOD_ENUM_ROUTINE Callback, /* capturing & walking */ NTSTATUS NTAPI -PsaCaptureSystemModules(OUT PSYSTEM_MODULE_INFORMATION * SystemModules); +PsaCaptureSystemModules(OUT PRTL_PROCESS_MODULES * SystemModules); NTSTATUS NTAPI -PsaWalkSystemModules(IN PSYSTEM_MODULE_INFORMATION SystemModules, +PsaWalkSystemModules(IN PRTL_PROCESS_MODULES SystemModules, IN PSYSMOD_ENUM_ROUTINE Callback, IN OUT PVOID CallbackContext); -PSYSTEM_MODULE_INFORMATION_ENTRY FASTCALL -PsaWalkFirstSystemModule(IN PSYSTEM_MODULE_INFORMATION SystemModules); +PRTL_PROCESS_MODULE_INFORMATION FASTCALL +PsaWalkFirstSystemModule(IN PRTL_PROCESS_MODULES SystemModules); -PSYSTEM_MODULE_INFORMATION_ENTRY FASTCALL -PsaWalkNextSystemModule(IN PSYSTEM_MODULE_INFORMATION CurrentSystemModule); +PRTL_PROCESS_MODULE_INFORMATION FASTCALL +PsaWalkNextSystemModule(IN PRTL_PROCESS_MODULES CurrentSystemModule); /* Process modules */ NTSTATUS NTAPI diff --git a/reactos/include/reactos/win32k/callout.h b/reactos/include/reactos/win32k/callout.h new file mode 100644 index 00000000000..b7c05bb22a6 --- /dev/null +++ b/reactos/include/reactos/win32k/callout.h @@ -0,0 +1,19 @@ +#ifndef _CALLOUT_ +#define _CALLOUT_ + +#include + +typedef struct _W32_CALLOUT_DATA +{ + PKWIN32_PROCESS_CALLOUT W32ProcessCallout; + PKWIN32_THREAD_CALLOUT W32ThreadCallout; + OB_OPEN_METHOD DesktopOpen; + OB_DELETE_METHOD DesktopDelete; + OB_DELETE_METHOD WinStaDelete; + OB_ROS_PARSE_METHOD WinStaParse; + OB_OPEN_METHOD WinStaOpen; + OB_ROS_FIND_METHOD WinStaFind; + OB_ROS_CREATE_METHOD DesktopCreate; +} W32_CALLOUT_DATA, *PW32_CALLOUT_DATA; + +#endif diff --git a/reactos/include/winnt.h b/reactos/include/winnt.h index cd8f01bd8b1..af4eb24f482 100644 --- a/reactos/include/winnt.h +++ b/reactos/include/winnt.h @@ -968,7 +968,9 @@ typedef enum #define SECTION_QUERY 1 #define SECTION_MAP_EXECUTE 8 #define SECTION_ALL_ACCESS 0xf001f +#ifndef __NTDDK_H #define MESSAGE_RESOURCE_UNICODE 1 +#endif #define RTL_CRITSECT_TYPE 0 #define RTL_RESOURCE_TYPE 1 /* Also in winddk.h */ @@ -2500,7 +2502,6 @@ typedef struct _MEMORY_BASIC_INFORMATION { DWORD Protect; DWORD Type; } MEMORY_BASIC_INFORMATION,*PMEMORY_BASIC_INFORMATION; -#endif typedef struct _MESSAGE_RESOURCE_ENTRY { WORD Length; WORD Flags; @@ -2515,6 +2516,7 @@ typedef struct _MESSAGE_RESOURCE_DATA { DWORD NumberOfBlocks; MESSAGE_RESOURCE_BLOCK Blocks[1]; } MESSAGE_RESOURCE_DATA,*PMESSAGE_RESOURCE_DATA; +#endif typedef struct _LIST_ENTRY { struct _LIST_ENTRY *Flink; struct _LIST_ENTRY *Blink; diff --git a/reactos/include/winsock2.h b/reactos/include/winsock2.h index 8fd425bdc64..49ccad3b0bf 100644 --- a/reactos/include/winsock2.h +++ b/reactos/include/winsock2.h @@ -214,7 +214,8 @@ struct protoent { #define IMPLINK_IP 155 #define IMPLINK_LOWEXPER 156 #define IMPLINK_HIGHEXPER 158 -struct in_addr { +#ifndef s_addr +typedef struct in_addr { union { struct { u_char s_b1,s_b2,s_b3,s_b4; } S_un_b; struct { u_short s_w1,s_w2; } S_un_w; @@ -226,7 +227,8 @@ struct in_addr { #define s_imp S_un.S_un_w.s_w2 #define s_impno S_un.S_un_b.s_b4 #define s_lh S_un.S_un_b.s_b3 -}; +} IN_ADDR, *PIN_ADDR; +#endif #define IN_CLASSA(i) ((long)(i)&0x80000000) #define IN_CLASSA_NET 0xff000000 #define IN_CLASSA_NSHIFT 24 @@ -589,8 +591,6 @@ typedef struct sockaddr_in *LPSOCKADDR_IN; typedef struct linger LINGER; typedef struct linger *PLINGER; typedef struct linger *LPLINGER; -typedef struct in_addr IN_ADDR; -typedef struct in_addr *PIN_ADDR; typedef struct in_addr *LPIN_ADDR; typedef struct fd_set FD_SET; typedef struct fd_set *PFD_SET; diff --git a/reactos/include/ws2tcpip.h b/reactos/include/ws2tcpip.h index 259237f92cd..14ae6260ace 100644 --- a/reactos/include/ws2tcpip.h +++ b/reactos/include/ws2tcpip.h @@ -144,12 +144,6 @@ struct ip_msfilter { (sizeof(struct ip_msfilter) - sizeof(struct in_addr) \ + (numsrc) * sizeof(struct in_addr)) -struct in_pktinfo { - IN_ADDR ipi_addr; - UINT ipi_ifindex; -}; -typedef struct in_pktinfo IN_PKTINFO; - /* ipv6 */ /* These require XP or .NET Server or use of add-on IPv6 stacks on NT 4 diff --git a/reactos/lib/epsapi/enum/drivers.c b/reactos/lib/epsapi/enum/drivers.c index bfed1edc7d4..40aaf685dc3 100644 --- a/reactos/lib/epsapi/enum/drivers.c +++ b/reactos/lib/epsapi/enum/drivers.c @@ -28,7 +28,7 @@ NTSTATUS NTAPI PsaEnumerateSystemModules(IN PSYSMOD_ENUM_ROUTINE Callback, IN OUT PVOID CallbackContext) { - PSYSTEM_MODULE_INFORMATION psmModules; + PRTL_PROCESS_MODULES psmModules; NTSTATUS Status = STATUS_SUCCESS; #if 0 @@ -65,10 +65,10 @@ PsaEnumerateSystemModules(IN PSYSMOD_ENUM_ROUTINE Callback, } NTSTATUS NTAPI -PsaCaptureSystemModules(OUT PSYSTEM_MODULE_INFORMATION *SystemModules) +PsaCaptureSystemModules(OUT PRTL_PROCESS_MODULES *SystemModules) { SIZE_T nSize = 0; - PSYSTEM_MODULE_INFORMATION psmModules = NULL; + PRTL_PROCESS_MODULES psmModules = NULL; NTSTATUS Status; #if 0 @@ -94,8 +94,8 @@ PsaCaptureSystemModules(OUT PSYSTEM_MODULE_INFORMATION *SystemModules) minimize memory operations that could be expensive, or fragment the pool/heap, we try to determine the buffer size in advance, knowing that the number of elements is unlikely to change */ - nSize = sizeof(SYSTEM_MODULE_INFORMATION) + - (nSize * sizeof(SYSTEM_MODULE_INFORMATION)); + nSize = sizeof(RTL_PROCESS_MODULES) + + (nSize * sizeof(RTL_PROCESS_MODULES)); psmModules = NULL; @@ -157,7 +157,7 @@ PsaCaptureSystemModules(OUT PSYSTEM_MODULE_INFORMATION *SystemModules) } NTSTATUS NTAPI -PsaWalkSystemModules(IN PSYSTEM_MODULE_INFORMATION SystemModules, +PsaWalkSystemModules(IN PRTL_PROCESS_MODULES SystemModules, IN PSYSMOD_ENUM_ROUTINE Callback, IN OUT PVOID CallbackContext) { @@ -165,10 +165,10 @@ PsaWalkSystemModules(IN PSYSTEM_MODULE_INFORMATION SystemModules, NTSTATUS Status; /* repeat until all modules have been returned */ - for(i = 0; i < SystemModules->Count; i++) + for(i = 0; i < SystemModules->NumberOfModules; i++) { /* return current module to the callback */ - Status = Callback(&(SystemModules->Module[i]), CallbackContext); + Status = Callback(&(SystemModules->Modules[i]), CallbackContext); if(!NT_SUCCESS(Status)) { @@ -179,18 +179,18 @@ PsaWalkSystemModules(IN PSYSTEM_MODULE_INFORMATION SystemModules, return STATUS_SUCCESS; } -PSYSTEM_MODULE_INFORMATION_ENTRY FASTCALL -PsaWalkFirstSystemModule(IN PSYSTEM_MODULE_INFORMATION SystemModules) +PRTL_PROCESS_MODULE_INFORMATION FASTCALL +PsaWalkFirstSystemModule(IN PRTL_PROCESS_MODULES SystemModules) { - return &(SystemModules->Module[0]); + return &(SystemModules->Modules[0]); } -PSYSTEM_MODULE_INFORMATION_ENTRY FASTCALL -PsaWalkNextSystemModule(IN PSYSTEM_MODULE_INFORMATION CurrentSystemModule) +PRTL_PROCESS_MODULE_INFORMATION FASTCALL +PsaWalkNextSystemModule(IN PRTL_PROCESS_MODULES CurrentSystemModule) { - return (PSYSTEM_MODULE_INFORMATION_ENTRY)((ULONG_PTR)CurrentSystemModule + - (FIELD_OFFSET(SYSTEM_MODULE_INFORMATION, Module[1]) - - FIELD_OFFSET(SYSTEM_MODULE_INFORMATION, Module[0]))); + return (PRTL_PROCESS_MODULE_INFORMATION)((ULONG_PTR)CurrentSystemModule + + (FIELD_OFFSET(RTL_PROCESS_MODULES, Modules[1]) - + FIELD_OFFSET(RTL_PROCESS_MODULES, Modules[0]))); } /* EOF */ diff --git a/reactos/lib/epsapi/enum/modules.c b/reactos/lib/epsapi/enum/modules.c index 4ae83d958e4..55915ee594e 100644 --- a/reactos/lib/epsapi/enum/modules.c +++ b/reactos/lib/epsapi/enum/modules.c @@ -50,7 +50,7 @@ PsaEnumerateProcessModules(IN HANDLE ProcessHandle, while(Current != ListHead) { - PLDR_DATA_TABLE_ENTRY LoaderModule = CONTAINING_RECORD(Current, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + PLDR_DATA_TABLE_ENTRY LoaderModule = CONTAINING_RECORD(Current, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); /* return the current module to the callback */ Status = Callback(ProcessHandle, LoaderModule, CallbackContext); @@ -60,7 +60,7 @@ PsaEnumerateProcessModules(IN HANDLE ProcessHandle, goto Failure; } - Current = LoaderModule->InLoadOrderModuleList.Flink; + Current = LoaderModule->InLoadOrderLinks.Flink; } #if 0 } @@ -117,7 +117,7 @@ PsaEnumerateProcessModules(IN HANDLE ProcessHandle, { /* read the current module */ Status = NtReadVirtualMemory(ProcessHandle, - CONTAINING_RECORD(Current, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList), + CONTAINING_RECORD(Current, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks), &LoaderModule, sizeof(LoaderModule), NULL); @@ -137,7 +137,7 @@ PsaEnumerateProcessModules(IN HANDLE ProcessHandle, } /* address of the next module in the list */ - Current = LoaderModule.InLoadOrderModuleList.Flink; + Current = LoaderModule.InLoadOrderLinks.Flink; } } diff --git a/reactos/lib/epsapi/enum/processes.c b/reactos/lib/epsapi/enum/processes.c index 8d59d9bd046..b624979d38a 100644 --- a/reactos/lib/epsapi/enum/processes.c +++ b/reactos/lib/epsapi/enum/processes.c @@ -265,7 +265,7 @@ PsaWalkFirstThread(IN PSYSTEM_PROCESS_INFORMATION CurrentProcess) static SIZE_T nOffsetOfThreads = 0; /* get the offset of the Threads field */ - nOffsetOfThreads = FIELD_OFFSET(SYSTEM_PROCESS_INFORMATION, TH); + nOffsetOfThreads = sizeof(SYSTEM_PROCESS_INFORMATION); return (PSYSTEM_THREAD_INFORMATION)((ULONG_PTR)CurrentProcess + nOffsetOfThreads); } @@ -274,8 +274,8 @@ PSYSTEM_THREAD_INFORMATION FASTCALL PsaWalkNextThread(IN PSYSTEM_THREAD_INFORMATION CurrentThread) { return (PSYSTEM_THREAD_INFORMATION)((ULONG_PTR)CurrentThread + - (FIELD_OFFSET(SYSTEM_PROCESS_INFORMATION, TH[1]) - - FIELD_OFFSET(SYSTEM_PROCESS_INFORMATION, TH[0]))); + ((sizeof(SYSTEM_PROCESS_INFORMATION) + sizeof(SYSTEM_THREAD_INFORMATION)) - + sizeof(SYSTEM_PROCESS_INFORMATION))); } /* EOF */ diff --git a/reactos/lib/rtl/bootdata.c b/reactos/lib/rtl/bootdata.c index 18c17fc4479..2fb992c1156 100644 --- a/reactos/lib/rtl/bootdata.c +++ b/reactos/lib/rtl/bootdata.c @@ -657,7 +657,7 @@ RtlCreateSystemVolumeInformationFolder( /* free allocated memory */ ASSERT(SecurityDescriptor != NULL); - ASSERT(SecurityDescriptor->Dacl != NULL) + ASSERT(SecurityDescriptor->Dacl != NULL); RtlpFreeMemory(SecurityDescriptor->Dacl, TAG('S', 'e', 'A', 'c')); diff --git a/reactos/lib/rtl/crc32.c b/reactos/lib/rtl/crc32.c index b491b7096ac..d207d002004 100644 --- a/reactos/lib/rtl/crc32.c +++ b/reactos/lib/rtl/crc32.c @@ -85,7 +85,7 @@ static const ULONG CrcTable[256] = * @implemented */ ULONG NTAPI -RtlComputeCrc32 (IN ULONG Initial, +RtlComputeCrc32 (IN UINT Initial, IN PUCHAR Data, IN ULONG Length) { diff --git a/reactos/lib/rtl/dbgbuffer.c b/reactos/lib/rtl/dbgbuffer.c index 5fef2cb63d0..588b39c1e92 100644 --- a/reactos/lib/rtl/dbgbuffer.c +++ b/reactos/lib/rtl/dbgbuffer.c @@ -16,18 +16,18 @@ /* * @unimplemented */ -PRTL_DEBUG_BUFFER NTAPI +PRTL_DEBUG_INFORMATION NTAPI RtlCreateQueryDebugBuffer(IN ULONG Size, IN BOOLEAN EventPair) { NTSTATUS Status; - PRTL_DEBUG_BUFFER Buf = NULL; - SIZE_T SectionSize = 100 * PAGE_SIZE; + PRTL_DEBUG_INFORMATION Buf = NULL; + SIZE_T ViewSize = 100 * PAGE_SIZE; Status = NtAllocateVirtualMemory( NtCurrentProcess(), (PVOID*)&Buf, 0, - &SectionSize, + &ViewSize, MEM_COMMIT, PAGE_READWRITE); if (!NT_SUCCESS(Status)) @@ -35,10 +35,10 @@ RtlCreateQueryDebugBuffer(IN ULONG Size, return NULL; } - Buf->SectionBase = Buf; - Buf->SectionSize = SectionSize; + Buf->ViewBaseClient = Buf; + Buf->ViewSize = ViewSize; - DPRINT("RtlCQDB: BA: %p BS: 0x%lx\n", Buf->SectionBase, Buf->SectionSize); + DPRINT("RtlCQDB: BA: %p BS: 0x%lx\n", Buf->ViewBaseClient, Buf->ViewSize); return Buf; } @@ -47,7 +47,7 @@ RtlCreateQueryDebugBuffer(IN ULONG Size, * @unimplemented */ NTSTATUS NTAPI -RtlDestroyQueryDebugBuffer(IN PRTL_DEBUG_BUFFER Buf) +RtlDestroyQueryDebugBuffer(IN PRTL_DEBUG_INFORMATION Buf) { NTSTATUS Status = STATUS_SUCCESS; @@ -55,7 +55,7 @@ RtlDestroyQueryDebugBuffer(IN PRTL_DEBUG_BUFFER Buf) { Status = NtFreeVirtualMemory( NtCurrentProcess(), (PVOID)&Buf, - &Buf->SectionSize, + &Buf->ViewSize, MEM_RELEASE); } if (!NT_SUCCESS(Status)) @@ -71,7 +71,7 @@ RtlDestroyQueryDebugBuffer(IN PRTL_DEBUG_BUFFER Buf) */ NTSTATUS NTAPI RtlpQueryRemoteProcessModules(HANDLE ProcessHandle, - IN PRTL_PROCESS_MODULES ModuleInformation OPTIONAL, + IN PRTL_PROCESS_MODULES Modules OPTIONAL, IN ULONG Size OPTIONAL, OUT PULONG ReturnedSize) { @@ -103,14 +103,14 @@ RtlpQueryRemoteProcessModules(HANDLE ProcessHandle, return Status; } - if (ModuleInformation == NULL || Size == 0) + if (Modules == NULL || Size == 0) { Status = STATUS_INFO_LENGTH_MISMATCH; } else { - ModuleInformation->ModuleCount = 0; - ModulePtr = &ModuleInformation->ModuleEntry[0]; + Modules->NumberOfModules = 0; + ModulePtr = &Modules->Modules[0]; Status = STATUS_SUCCESS; } @@ -154,7 +154,7 @@ RtlpQueryRemoteProcessModules(HANDLE ProcessHandle, /* read the current module */ Status = NtReadVirtualMemory ( ProcessHandle, - CONTAINING_RECORD(pleCurEntry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList), + CONTAINING_RECORD(pleCurEntry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks), &lmModule, sizeof(LDR_DATA_TABLE_ENTRY), NULL ); @@ -183,36 +183,37 @@ RtlpQueryRemoteProcessModules(HANDLE ProcessHandle, { Status = STATUS_INFO_LENGTH_MISMATCH; } - else if (ModuleInformation != NULL) + else if (Modules != NULL) { - ModulePtr->Reserved[0] = ModulePtr->Reserved[1] = 0; // FIXME: ?? - ModulePtr->Base = lmModule.DllBase; - ModulePtr->Size = lmModule.SizeOfImage; + ModulePtr->Section = 0; + ModulePtr->MappedBase = NULL; // FIXME: ?? + ModulePtr->ImageBase = lmModule.DllBase; + ModulePtr->ImageSize = lmModule.SizeOfImage; ModulePtr->Flags = lmModule.Flags; - ModulePtr->Index = 0; // FIXME: ?? - ModulePtr->Unknown = 0; // FIXME: ?? + ModulePtr->LoadOrderIndex = 0; // FIXME: ?? + ModulePtr->InitOrderIndex = 0; // FIXME: ?? ModulePtr->LoadCount = lmModule.LoadCount; AnsiString.Length = 0; AnsiString.MaximumLength = 256; - AnsiString.Buffer = ModulePtr->ImageName; + AnsiString.Buffer = ModulePtr->FullPathName; RtlUnicodeStringToAnsiString(&AnsiString, &Unicode, FALSE); - p = strrchr(ModulePtr->ImageName, '\\'); + p = strrchr(ModulePtr->FullPathName, '\\'); if (p != NULL) - ModulePtr->ModuleNameOffset = p - ModulePtr->ImageName + 1; + ModulePtr->OffsetToFileName = p - ModulePtr->FullPathName + 1; else - ModulePtr->ModuleNameOffset = 0; + ModulePtr->OffsetToFileName = 0; ModulePtr++; - ModuleInformation->ModuleCount++; + Modules->NumberOfModules++; } UsedSize += sizeof(RTL_PROCESS_MODULE_INFORMATION); /* address of the next module in the list */ - pleCurEntry = lmModule.InLoadOrderModuleList.Flink; + pleCurEntry = lmModule.InLoadOrderLinks.Flink; } if (ReturnedSize != 0) @@ -230,13 +231,13 @@ RtlpQueryRemoteProcessModules(HANDLE ProcessHandle, NTSTATUS NTAPI RtlQueryProcessDebugInformation(IN ULONG ProcessId, IN ULONG DebugInfoMask, - IN OUT PRTL_DEBUG_BUFFER Buf) + IN OUT PRTL_DEBUG_INFORMATION Buf) { NTSTATUS Status = STATUS_SUCCESS; ULONG Pid = (ULONG) NtCurrentTeb()->Cid.UniqueProcess; - Buf->InfoClassMask = DebugInfoMask; - Buf->SizeOfInfo = sizeof(RTL_DEBUG_BUFFER); + Buf->Flags = DebugInfoMask; + Buf->OffsetFree = sizeof(RTL_DEBUG_INFORMATION); DPRINT("QueryProcessDebugInformation Start\n"); @@ -258,7 +259,7 @@ if (Pid == ProcessId) ULONG ReturnSize = 0; ULONG MSize; - Mp = (PRTL_PROCESS_MODULES)(Buf + Buf->SizeOfInfo); + Mp = (PRTL_PROCESS_MODULES)(Buf + Buf->OffsetFree); /* I like this better than the do & while loop. */ Status = LdrQueryProcessModuleInformation( NULL, @@ -272,9 +273,9 @@ if (Pid == ProcessId) return Status; } - MSize = Mp->ModuleCount * (sizeof(RTL_PROCESS_MODULES) + 8); - Buf->ModuleInformation = Mp; - Buf->SizeOfInfo = Buf->SizeOfInfo + MSize; + MSize = Mp->NumberOfModules * (sizeof(RTL_PROCESS_MODULES) + 8); + Buf->Modules = Mp; + Buf->OffsetFree = Buf->OffsetFree + MSize; } if (DebugInfoMask & RTL_DEBUG_QUERY_HEAPS) @@ -282,7 +283,7 @@ if (Pid == ProcessId) PRTL_PROCESS_HEAPS Hp; ULONG HSize; - Hp = (PRTL_PROCESS_HEAPS)(Buf + Buf->SizeOfInfo); + Hp = (PRTL_PROCESS_HEAPS)(Buf + Buf->OffsetFree); HSize = sizeof(RTL_PROCESS_HEAPS); if (DebugInfoMask & RTL_DEBUG_QUERY_HEAP_TAGS) { @@ -290,8 +291,8 @@ if (Pid == ProcessId) if (DebugInfoMask & RTL_DEBUG_QUERY_HEAP_BLOCKS) { } - Buf->HeapInformation = Hp; - Buf->SizeOfInfo = Buf->SizeOfInfo + HSize; + Buf->Heaps = Hp; + Buf->OffsetFree = Buf->OffsetFree + HSize; } @@ -300,14 +301,14 @@ if (Pid == ProcessId) PRTL_PROCESS_LOCKS Lp; ULONG LSize; - Lp = (PRTL_PROCESS_LOCKS)(Buf + Buf->SizeOfInfo); + Lp = (PRTL_PROCESS_LOCKS)(Buf + Buf->OffsetFree); LSize = sizeof(RTL_PROCESS_LOCKS); - Buf->LockInformation = Lp; - Buf->SizeOfInfo = Buf->SizeOfInfo + LSize; + Buf->Locks = Lp; + Buf->OffsetFree = Buf->OffsetFree + LSize; } DPRINT("QueryProcessDebugInformation end \n"); - DPRINT("QueryDebugInfo : 0x%lx\n", Buf->SizeOfInfo); + DPRINT("QueryDebugInfo : 0x%lx\n", Buf->OffsetFree); } else { @@ -315,7 +316,7 @@ else CLIENT_ID ClientId; OBJECT_ATTRIBUTES ObjectAttributes; - Buf->Unknown[0] = (ULONG)NtCurrentProcess(); + Buf->TargetProcessHandle = NtCurrentProcess(); ClientId.UniqueThread = 0; ClientId.UniqueProcess = (HANDLE)ProcessId; @@ -340,7 +341,7 @@ else ULONG ReturnSize = 0; ULONG MSize; - Mp = (PRTL_PROCESS_MODULES)(Buf + Buf->SizeOfInfo); + Mp = (PRTL_PROCESS_MODULES)(Buf + Buf->OffsetFree); Status = RtlpQueryRemoteProcessModules( hProcess, NULL, @@ -356,9 +357,9 @@ else return Status; } - MSize = Mp->ModuleCount * (sizeof(RTL_PROCESS_MODULES) + 8); - Buf->ModuleInformation = Mp; - Buf->SizeOfInfo = Buf->SizeOfInfo + MSize; + MSize = Mp->NumberOfModules * (sizeof(RTL_PROCESS_MODULES) + 8); + Buf->Modules = Mp; + Buf->OffsetFree = Buf->OffsetFree + MSize; } if (DebugInfoMask & RTL_DEBUG_QUERY_HEAPS) @@ -366,7 +367,7 @@ else PRTL_PROCESS_HEAPS Hp; ULONG HSize; - Hp = (PRTL_PROCESS_HEAPS)(Buf + Buf->SizeOfInfo); + Hp = (PRTL_PROCESS_HEAPS)(Buf + Buf->OffsetFree); HSize = sizeof(RTL_PROCESS_HEAPS); if (DebugInfoMask & RTL_DEBUG_QUERY_HEAP_TAGS) { @@ -374,8 +375,8 @@ else if (DebugInfoMask & RTL_DEBUG_QUERY_HEAP_BLOCKS) { } - Buf->HeapInformation = Hp; - Buf->SizeOfInfo = Buf->SizeOfInfo + HSize; + Buf->Heaps = Hp; + Buf->OffsetFree = Buf->OffsetFree + HSize; } @@ -384,14 +385,14 @@ else PRTL_PROCESS_LOCKS Lp; ULONG LSize; - Lp = (PRTL_PROCESS_LOCKS)(Buf + Buf->SizeOfInfo); + Lp = (PRTL_PROCESS_LOCKS)(Buf + Buf->OffsetFree); LSize = sizeof(RTL_PROCESS_LOCKS); - Buf->LockInformation = Lp; - Buf->SizeOfInfo = Buf->SizeOfInfo + LSize; + Buf->Locks = Lp; + Buf->OffsetFree = Buf->OffsetFree + LSize; } DPRINT("QueryProcessDebugInformation end \n"); - DPRINT("QueryDebugInfo : 0x%lx\n", Buf->SizeOfInfo); + DPRINT("QueryDebugInfo : 0x%lx\n", Buf->OffsetFree); } return Status; diff --git a/reactos/lib/rtl/debug.c b/reactos/lib/rtl/debug.c index b799dd06493..035be1362b2 100644 --- a/reactos/lib/rtl/debug.c +++ b/reactos/lib/rtl/debug.c @@ -272,7 +272,7 @@ ULONG NTAPI DbgPrompt(PCH OutputString, PCH InputString, - USHORT InputSize) + ULONG InputSize) { ANSI_STRING Output; ANSI_STRING Input; diff --git a/reactos/lib/rtl/image.c b/reactos/lib/rtl/image.c index fc07d6991a4..09435070b75 100644 --- a/reactos/lib/rtl/image.c +++ b/reactos/lib/rtl/image.c @@ -45,12 +45,10 @@ RtlImageNtHeader (IN PVOID BaseAddress) */ PVOID NTAPI -RtlImageDirectoryEntryToData ( - PVOID BaseAddress, - BOOLEAN bMappedAsImage, - ULONG Directory, - PULONG Size - ) +RtlImageDirectoryEntryToData(PVOID BaseAddress, + BOOLEAN MappedAsImage, + USHORT Directory, + PULONG Size) { PIMAGE_NT_HEADERS NtHeader; ULONG Va; @@ -59,7 +57,7 @@ RtlImageDirectoryEntryToData ( if ((ULONG_PTR)BaseAddress & 1) { BaseAddress = (PVOID)((ULONG_PTR)BaseAddress & ~1); - bMappedAsImage = FALSE; + MappedAsImage = FALSE; } @@ -76,7 +74,7 @@ RtlImageDirectoryEntryToData ( *Size = NtHeader->OptionalHeader.DataDirectory[Directory].Size; - if (bMappedAsImage || Va < NtHeader->OptionalHeader.SizeOfHeaders) + if (MappedAsImage || Va < NtHeader->OptionalHeader.SizeOfHeaders) return (PVOID)((ULONG_PTR)BaseAddress + Va); /* image mapped as ordinary file, we must find raw pointer */ diff --git a/reactos/lib/rtl/network.c b/reactos/lib/rtl/network.c index 948ef110eab..356d3510fc4 100644 --- a/reactos/lib/rtl/network.c +++ b/reactos/lib/rtl/network.c @@ -1,8 +1,8 @@ /* * COPYRIGHT: See COPYING in the top level directory - * PROJECT: ReactOS system libraries + * PROJECT: ReactOS Runtime Library * PURPOSE: Network Address Translation implementation - * PROGRAMMER: + * PROGRAMMER: Alex Ionescu (alexi@tinykrnl.org) */ /* INCLUDES *****************************************************************/ @@ -14,110 +14,74 @@ /* FUNCTIONS ***************************************************************/ -/* Borrow this from some headers... */ -typedef struct -{ - union - { - struct { UCHAR s_b1,s_b2,s_b3,s_b4; } S_un_b; - struct { USHORT s_w1,s_w2; } S_un_w; - ULONG S_addr; - } S_un; -} in_addr; - -typedef struct -{ - union - { - UCHAR _S6_u8[16]; - USHORT _S6_u16[8]; - ULONG _S6_u32[4]; - } S6_un; -} in6_addr; - - /* -* @implemented -*/ + * @implemented + */ LPSTR NTAPI -RtlIpv4AddressToStringA( - PULONG IP, - LPSTR Buffer - ) +RtlIpv4AddressToStringA(IN struct in_addr *Addr, + OUT PCHAR S) { - in_addr addr; - addr.S_un.S_addr = *IP; - return Buffer + sprintf(Buffer, "%u.%u.%u.%u", addr.S_un.S_un_b.s_b1, - addr.S_un.S_un_b.s_b2, - addr.S_un.S_un_b.s_b3, - addr.S_un.S_un_b.s_b4); + return S + sprintf(S, "%u.%u.%u.%u", Addr->S_un.S_un_b.s_b1, + Addr->S_un.S_un_b.s_b2, + Addr->S_un.S_un_b.s_b3, + Addr->S_un.S_un_b.s_b4); } /* -* @unimplemented -*/ + * @unimplemented + */ NTSTATUS NTAPI -RtlIpv4AddressToStringExA( - PULONG IP, - PULONG Port, - LPSTR Buffer, - PULONG MaxSize - ) +RtlIpv4AddressToStringExA(IN struct in_addr *Address, + IN USHORT Port, + OUT PCHAR AddressString, + IN OUT PULONG AddressStringLength) { - UNIMPLEMENTED; - return STATUS_NOT_IMPLEMENTED; + UNIMPLEMENTED; + return STATUS_NOT_IMPLEMENTED; } /* -* @implemented -*/ + * @implemented + */ LPWSTR NTAPI -RtlIpv4AddressToStringW( - PULONG IP, - LPWSTR Buffer - ) +RtlIpv4AddressToStringW(IN struct in_addr *Addr, + OUT PWCHAR S) { - in_addr addr; - addr.S_un.S_addr = *IP; - return Buffer + swprintf(Buffer, L"%u.%u.%u.%u", addr.S_un.S_un_b.s_b1, - addr.S_un.S_un_b.s_b2, - addr.S_un.S_un_b.s_b3, - addr.S_un.S_un_b.s_b4); + return S + swprintf(S, L"%u.%u.%u.%u", Addr->S_un.S_un_b.s_b1, + Addr->S_un.S_un_b.s_b2, + Addr->S_un.S_un_b.s_b3, + Addr->S_un.S_un_b.s_b4); } /* -* @unimplemented -*/ + * @unimplemented + */ NTSTATUS NTAPI -RtlIpv4AddressToStringExW( - PULONG IP, - PULONG Port, - LPWSTR Buffer, - PULONG MaxSize - ) +RtlIpv4AddressToStringExW(IN struct in_addr *Address, + IN USHORT Port, + OUT PWCHAR AddressString, + IN OUT PULONG AddressStringLength) { - UNIMPLEMENTED; - return STATUS_NOT_IMPLEMENTED; + UNIMPLEMENTED; + return STATUS_NOT_IMPLEMENTED; } /* -* @unimplemented -*/ + * @unimplemented + */ NTSTATUS NTAPI -RtlIpv4StringToAddressA( - IN LPSTR IpString, - IN ULONG Base, - OUT PVOID PtrToIpAddr, - OUT ULONG IpAddr - ) +RtlIpv4StringToAddressA(IN PCHAR String, + IN BOOLEAN Strict, + OUT PCHAR *Terminator, + OUT struct in_addr *Addr) { - UNIMPLEMENTED; - return STATUS_NOT_IMPLEMENTED; + UNIMPLEMENTED; + return STATUS_NOT_IMPLEMENTED; } /* @@ -125,15 +89,13 @@ RtlIpv4StringToAddressA( */ NTSTATUS NTAPI -RtlIpv4StringToAddressExA( - IN LPSTR IpString, - IN ULONG Base, - OUT PULONG IpAddr, - OUT PULONG Port - ) +RtlIpv4StringToAddressExA(IN PCHAR AddressString, + IN BOOLEAN Strict, + OUT struct in_addr *Address, + IN PUSHORT Port) { - UNIMPLEMENTED; - return STATUS_NOT_IMPLEMENTED; + UNIMPLEMENTED; + return STATUS_NOT_IMPLEMENTED; } /* @@ -141,15 +103,13 @@ RtlIpv4StringToAddressExA( */ NTSTATUS NTAPI -RtlIpv4StringToAddressW( - IN LPWSTR IpString, - IN ULONG Base, - OUT PULONG PtrToIpAddr, - OUT PULONG IpAddr - ) +RtlIpv4StringToAddressW(IN PWCHAR String, + IN UCHAR Strict, + OUT PWCHAR Terminator, + OUT struct in_addr *Addr) { - UNIMPLEMENTED; - return STATUS_NOT_IMPLEMENTED; + UNIMPLEMENTED; + return STATUS_NOT_IMPLEMENTED; } /* @@ -157,15 +117,13 @@ RtlIpv4StringToAddressW( */ NTSTATUS NTAPI -RtlIpv4StringToAddressExW( - IN LPWSTR IpString, - IN ULONG Base, - OUT PULONG IpAddr, - OUT PULONG Port - ) +RtlIpv4StringToAddressExW(IN PWCHAR AddressString, + IN BOOLEAN Strict, + OUT struct in_addr *Address, + OUT PUSHORT Port) { - UNIMPLEMENTED; - return STATUS_NOT_IMPLEMENTED; + UNIMPLEMENTED; + return STATUS_NOT_IMPLEMENTED; } /* @@ -173,13 +131,11 @@ RtlIpv4StringToAddressExW( */ NTSTATUS NTAPI -RtlIpv6AddressToStringA( - PULONG IP, - LPSTR Buffer - ) +RtlIpv6AddressToStringA(IN struct in6_addr *Addr, + OUT PCHAR S) { - UNIMPLEMENTED; - return STATUS_NOT_IMPLEMENTED; + UNIMPLEMENTED; + return STATUS_NOT_IMPLEMENTED; } /* @@ -187,15 +143,14 @@ RtlIpv6AddressToStringA( */ NTSTATUS NTAPI -RtlIpv6AddressToStringExA( - PULONG IP, - PULONG Port, - LPSTR Buffer, - PULONG MaxSize - ) +RtlIpv6AddressToStringExA(IN struct in6_addr *Address, + IN ULONG ScopeId, + IN ULONG Port, + OUT PCHAR AddressString, + IN OUT PULONG AddressStringLength) { - UNIMPLEMENTED; - return STATUS_NOT_IMPLEMENTED; + UNIMPLEMENTED; + return STATUS_NOT_IMPLEMENTED; } /* @@ -203,13 +158,11 @@ RtlIpv6AddressToStringExA( */ NTSTATUS NTAPI -RtlIpv6AddressToStringW( - PULONG IP, - LPWSTR Buffer - ) +RtlIpv6AddressToStringW(IN struct in6_addr *Addr, + OUT PWCHAR S) { - UNIMPLEMENTED; - return STATUS_NOT_IMPLEMENTED; + UNIMPLEMENTED; + return STATUS_NOT_IMPLEMENTED; } /* @@ -217,15 +170,14 @@ RtlIpv6AddressToStringW( */ NTSTATUS NTAPI -RtlIpv6AddressToStringExW( - PULONG IP, - PULONG Port, - LPWSTR Buffer, - PULONG MaxSize - ) +RtlIpv6AddressToStringExW(IN struct in6_addr *Address, + IN ULONG ScopeId, + IN USHORT Port, + IN OUT PWCHAR AddressString, + IN OUT PULONG AddressStringLength) { - UNIMPLEMENTED; - return STATUS_NOT_IMPLEMENTED; + UNIMPLEMENTED; + return STATUS_NOT_IMPLEMENTED; } /* @@ -233,9 +185,9 @@ RtlIpv6AddressToStringExW( */ NTSTATUS NTAPI -RtlIpv6StringToAddressA(IN LPSTR Name, - OUT PULONG Unknown, - OUT PVOID IpAddr) +RtlIpv6StringToAddressA(IN PCHAR Name, + OUT PCHAR *Terminator, + OUT struct in6_addr *Addr) { UNIMPLEMENTED; return STATUS_NOT_IMPLEMENTED; @@ -246,10 +198,10 @@ RtlIpv6StringToAddressA(IN LPSTR Name, */ NTSTATUS NTAPI -RtlIpv6StringToAddressExA(IN LPSTR AddressName, - IN PVOID Address, - IN PULONG ScopeId, - IN PUSHORT Port) +RtlIpv6StringToAddressExA(IN PCHAR AddressString, + OUT struct in6_addr *Address, + OUT PULONG ScopeId, + OUT PUSHORT Port) { UNIMPLEMENTED; return STATUS_NOT_IMPLEMENTED; @@ -260,9 +212,9 @@ RtlIpv6StringToAddressExA(IN LPSTR AddressName, */ NTSTATUS NTAPI -RtlIpv6StringToAddressW(IN LPWSTR Name, - OUT PULONG Unknown, - OUT PVOID IpAddr) +RtlIpv6StringToAddressW(IN PWCHAR Name, + OUT PCHAR *Terminator, + OUT struct in6_addr *Addr) { UNIMPLEMENTED; return STATUS_NOT_IMPLEMENTED; @@ -273,10 +225,10 @@ RtlIpv6StringToAddressW(IN LPWSTR Name, */ NTSTATUS NTAPI -RtlIpv6StringToAddressExW(IN LPWSTR AddressName, - IN PVOID Address, - IN PULONG ScopeId, - IN PUSHORT Port) +RtlIpv6StringToAddressExW(IN PWCHAR AddressName, + OUT struct in6_addr *Address, + OUT PULONG ScopeId, + OUT PUSHORT Port) { UNIMPLEMENTED; return STATUS_NOT_IMPLEMENTED; diff --git a/reactos/lib/rtl/path.c b/reactos/lib/rtl/path.c index 08045a9d7fb..2b69c371264 100644 --- a/reactos/lib/rtl/path.c +++ b/reactos/lib/rtl/path.c @@ -61,29 +61,29 @@ RtlDetermineDosPathNameType_U(PCWSTR Path) if (Path == NULL) { - return INVALID_PATH; + return RtlPathTypeUnknown; } if (IS_PATH_SEPARATOR(Path[0])) { - if (!IS_PATH_SEPARATOR(Path[1])) return ABSOLUTE_PATH; /* \xxx */ - if (Path[2] != L'.') return UNC_PATH; /* \\xxx */ - if (IS_PATH_SEPARATOR(Path[3])) return DEVICE_PATH; /* \\.\xxx */ - if (Path[3]) return UNC_PATH; /* \\.xxxx */ + if (!IS_PATH_SEPARATOR(Path[1])) return RtlPathTypeRooted; /* \xxx */ + if (Path[2] != L'.') return RtlPathTypeUncAbsolute; /* \\xxx */ + if (IS_PATH_SEPARATOR(Path[3])) return RtlPathTypeLocalDevice; /* \\.\xxx */ + if (Path[3]) return RtlPathTypeUncAbsolute; /* \\.xxxx */ - return UNC_DOT_PATH; /* \\. */ + return RtlPathTypeRootLocalDevice; /* \\. */ } else { /* FIXME: the Wine version of this line reads: - * if (!Path[1] || Path[1] != L':') return RELATIVE_PATH + * if (!Path[1] || Path[1] != L':') return RtlPathTypeRelative * Should we do this too? * -Gunnar */ - if (Path[1] != L':') return RELATIVE_PATH; /* xxx */ - if (IS_PATH_SEPARATOR(Path[2])) return ABSOLUTE_DRIVE_PATH; /* x:\xxx */ + if (Path[1] != L':') return RtlPathTypeRelative; /* xxx */ + if (IS_PATH_SEPARATOR(Path[2])) return RtlPathTypeDriveAbsolute; /* x:\xxx */ - return RELATIVE_DRIVE_PATH; /* x:xxx */ + return RtlPathTypeDriveRelative; /* x:xxx */ } } @@ -448,16 +448,16 @@ static ULONG get_full_path_helper( switch (type = RtlDetermineDosPathNameType_U(name)) { - case UNC_PATH: /* \\foo */ + case RtlPathTypeUncAbsolute: /* \\foo */ ptr = skip_unc_prefix( name ); mark = (ptr - name); break; - case DEVICE_PATH: /* \\.\foo */ + case RtlPathTypeLocalDevice: /* \\.\foo */ mark = 4; break; - case ABSOLUTE_DRIVE_PATH: /* c:\foo */ + case RtlPathTypeDriveAbsolute: /* c:\foo */ reqsize = sizeof(WCHAR); tmp[0] = towupper(name[0]); ins_str = tmp; @@ -465,7 +465,7 @@ static ULONG get_full_path_helper( mark = 3; break; - case RELATIVE_DRIVE_PATH: /* c:foo */ + case RtlPathTypeDriveRelative: /* c:foo */ dep = 2; if (towupper(name[0]) != towupper(cd->Buffer[0]) || cd->Buffer[1] != ':') { @@ -517,7 +517,7 @@ static ULONG get_full_path_helper( } /* fall through */ - case RELATIVE_PATH: /* foo */ + case RtlPathTypeRelative: /* foo */ reqsize = cd->Length; ins_str = cd->Buffer; if (cd->Buffer[1] != ':') @@ -528,7 +528,7 @@ static ULONG get_full_path_helper( else mark = 3; break; - case ABSOLUTE_PATH: /* \xxx */ + case RtlPathTypeRooted: /* \xxx */ #ifdef __WINE__ if (name[0] == '/') /* may be a Unix path */ { @@ -564,7 +564,7 @@ static ULONG get_full_path_helper( } break; - case UNC_DOT_PATH: /* \\. */ + case RtlPathTypeRootLocalDevice: /* \\. */ reqsize = 4 * sizeof(WCHAR); dep = 3; tmp[0] = '\\'; @@ -575,7 +575,7 @@ static ULONG get_full_path_helper( mark = 4; break; - case INVALID_PATH: + case RtlPathTypeUnknown: goto done; } @@ -794,8 +794,8 @@ RtlDosPathNameToNtPathName_U(IN PCWSTR DosPathName, Length = wcslen(fullname + Offset); memcpy (Buffer + tmpLength, fullname + Offset, (Length + 1) * sizeof(WCHAR)); Length += tmpLength; - if (Type == ABSOLUTE_DRIVE_PATH || - Type == RELATIVE_DRIVE_PATH) + if (Type == RtlPathTypeDriveAbsolute || + Type == RtlPathTypeDriveRelative) { /* make the drive letter to uppercase */ Buffer[tmpLength] = towupper(Buffer[tmpLength]); @@ -840,9 +840,9 @@ RtlDosPathNameToNtPathName_U(IN PCWSTR DosPathName, ULONG NTAPI RtlDosSearchPath_U ( - WCHAR *sp, - WCHAR *name, - WCHAR *ext, + PCWSTR sp, + PCWSTR name, + PCWSTR ext, ULONG buf_sz, WCHAR *buffer, PWSTR *FilePart @@ -852,7 +852,7 @@ RtlDosSearchPath_U ( ULONG Length = 0; PWSTR full_name; PWSTR wcs; - PWSTR path; + PCWSTR path; Type = RtlDetermineDosPathNameType_U (name); @@ -915,7 +915,7 @@ RtlDosSearchPath_U ( * @implemented */ BOOLEAN NTAPI -RtlDoesFileExists_U(IN PWSTR FileName) +RtlDoesFileExists_U(IN PCWSTR FileName) { UNICODE_STRING NtFileName; OBJECT_ATTRIBUTES Attr; diff --git a/reactos/lib/rtl/process.c b/reactos/lib/rtl/process.c index 075d616a6de..e75fd9a4fba 100644 --- a/reactos/lib/rtl/process.c +++ b/reactos/lib/rtl/process.c @@ -76,7 +76,7 @@ RtlpInitEnvironment(HANDLE ProcessHandle, ULONG Size; PWCHAR Environment = 0; - DPRINT("RtlpInitEnvironment (hProcess: %p, Peb: %p Params: %p)\n", + DPRINT1("RtlpInitEnvironment (hProcess: %p, Peb: %p Params: %p)\n", ProcessHandle, Peb, ProcessParameters); /* Give the caller 1MB if he requested it */ @@ -106,7 +106,7 @@ RtlpInitEnvironment(HANDLE ProcessHandle, /* Calculate the size of the block */ EnviroSize = (ULONG)((ULONG_PTR)Environment - (ULONG_PTR)ProcessParameters->Environment); - DPRINT("EnvironmentSize %ld\n", EnviroSize); + DPRINT1("EnvironmentSize %ld\n", EnviroSize); /* Allocate and Initialize new Environment Block */ Size = EnviroSize; @@ -133,8 +133,8 @@ RtlpInitEnvironment(HANDLE ProcessHandle, ProcessParameters->Environment = BaseAddress; } - DPRINT("EnvironmentPointer %p\n", BaseAddress); - DPRINT("Ppb->MaximumLength 0x%lx\n", ProcessParameters->MaximumLength); + DPRINT1("EnvironmentPointer %p\n", BaseAddress); + DPRINT1("Ppb->MaximumLength 0x%lx\n", ProcessParameters->MaximumLength); /* Now allocate space for the Parameter Block */ BaseAddress = NULL; diff --git a/reactos/lib/rtl/sd.c b/reactos/lib/rtl/sd.c index c9c72f60c44..f4524e2d7d3 100644 --- a/reactos/lib/rtl/sd.c +++ b/reactos/lib/rtl/sd.c @@ -800,9 +800,6 @@ RtlSelfRelativeToAbsoluteSD2(IN OUT PSECURITY_DESCRIPTOR SelfRelativeSD, return STATUS_BAD_DESCRIPTOR_FORMAT; } - ASSERT(FIELD_OFFSET(SECURITY_DESCRIPTOR, Owner) == - FIELD_OFFSET(SECURITY_DESCRIPTOR_RELATIVE, Owner)); - #ifdef _WIN64 RtlpQuerySecurityDescriptor((PISECURITY_DESCRIPTOR)pRelSD, @@ -915,8 +912,6 @@ RtlSelfRelativeToAbsoluteSD2(IN OUT PSECURITY_DESCRIPTOR SelfRelativeSD, &pSacl, &pDacl); - ASSERT(sizeof(SECURITY_DESCRIPTOR) == sizeof(SECURITY_DESCRIPTOR_RELATIVE)); - /* clear the self-relative flag and simply convert the offsets to pointers */ pAbsSD->Control &= ~SE_SELF_RELATIVE; pAbsSD->Owner = pOwner; diff --git a/reactos/lib/rtl/thread.c b/reactos/lib/rtl/thread.c index 6c699aa53b6..4df102553b2 100644 --- a/reactos/lib/rtl/thread.c +++ b/reactos/lib/rtl/thread.c @@ -12,6 +12,7 @@ /* INCLUDES *****************************************************************/ #include +#include "i386/ketypes.h" #define NDEBUG #include diff --git a/reactos/lib/rtl/unicode.c b/reactos/lib/rtl/unicode.c index d14073cd8f8..14257a00780 100644 --- a/reactos/lib/rtl/unicode.c +++ b/reactos/lib/rtl/unicode.c @@ -2185,7 +2185,7 @@ RtlDuplicateUnicodeString( */ NTSTATUS NTAPI RtlValidateUnicodeString(IN ULONG Flags, - IN PUNICODE_STRING UnicodeString) + IN PCUNICODE_STRING UnicodeString) { /* currently no flags are supported! */ ASSERT(Flags == 0); diff --git a/reactos/ntoskrnl/cm/cm.h b/reactos/ntoskrnl/cm/cm.h index fd340162c68..9d07c6c3bef 100644 --- a/reactos/ntoskrnl/cm/cm.h +++ b/reactos/ntoskrnl/cm/cm.h @@ -459,6 +459,7 @@ CmiObjectSecurity(PVOID ObjectBody, NTSTATUS STDCALL CmiObjectQueryName (PVOID ObjectBody, + IN BOOLEAN HasObjectName, POBJECT_NAME_INFORMATION ObjectNameInfo, ULONG Length, PULONG ReturnLength); diff --git a/reactos/ntoskrnl/cm/registry.c b/reactos/ntoskrnl/cm/registry.c index c2cc4a238b8..b5223944906 100644 --- a/reactos/ntoskrnl/cm/registry.c +++ b/reactos/ntoskrnl/cm/registry.c @@ -369,7 +369,7 @@ CmInitializeRegistry(VOID) ObjectTypeInitializer.ValidAccessMask = KEY_ALL_ACCESS; ObjectTypeInitializer.UseDefaultObject = TRUE; ObjectTypeInitializer.DeleteProcedure = CmiObjectDelete; - ObjectTypeInitializer.ParseProcedure = CmiObjectParse; + ObjectTypeInitializer.ParseProcedure = (PVOID)CmiObjectParse; ObjectTypeInitializer.SecurityProcedure = CmiObjectSecurity; ObjectTypeInitializer.QueryNameProcedure = CmiObjectQueryName; diff --git a/reactos/ntoskrnl/cm/regobj.c b/reactos/ntoskrnl/cm/regobj.c index b824c854714..54192a8d050 100644 --- a/reactos/ntoskrnl/cm/regobj.c +++ b/reactos/ntoskrnl/cm/regobj.c @@ -486,6 +486,7 @@ CmiObjectSecurity(PVOID ObjectBody, NTSTATUS STDCALL CmiObjectQueryName (PVOID ObjectBody, + IN BOOLEAN HasName, POBJECT_NAME_INFORMATION ObjectNameInfo, ULONG Length, PULONG ReturnLength) diff --git a/reactos/ntoskrnl/ex/dbgctrl.c b/reactos/ntoskrnl/ex/dbgctrl.c index fdf6d495d97..c60479e71d2 100644 --- a/reactos/ntoskrnl/ex/dbgctrl.c +++ b/reactos/ntoskrnl/ex/dbgctrl.c @@ -17,7 +17,7 @@ NTSTATUS STDCALL -NtSystemDebugControl(DEBUG_CONTROL_CODE ControlCode, +NtSystemDebugControl(SYSDBG_COMMAND ControlCode, PVOID InputBuffer, ULONG InputBufferLength, PVOID OutputBuffer, @@ -26,15 +26,15 @@ NtSystemDebugControl(DEBUG_CONTROL_CODE ControlCode, { switch (ControlCode) { - case DebugGetTraceInformation: - case DebugSetInternalBreakpoint: - case DebugSetSpecialCall: - case DebugClearSpecialCalls: - case DebugQuerySpecialCalls: - case DebugDbgBreakPoint: + case SysDbgQueryTraceInformation: + case SysDbgSetTracepoint: + case SysDbgSetSpecialCall: + case SysDbgClearSpecialCalls: + case SysDbgQuerySpecialCalls: + case SysDbgBreakPoint: break; - case DebugDbgLoadSymbols: + case SysDbgQueryVersion: KDB_LOADUSERMODULE_HOOK((PLDR_DATA_TABLE_ENTRY) InputBuffer); break; diff --git a/reactos/ntoskrnl/ex/init.c b/reactos/ntoskrnl/ex/init.c index 11e5c5427cd..ae56a7db153 100644 --- a/reactos/ntoskrnl/ex/init.c +++ b/reactos/ntoskrnl/ex/init.c @@ -261,6 +261,7 @@ ExecuteRuntimeAsserts(VOID) ASSERT(FIELD_OFFSET(KPCR, Tib.ExceptionList) == KPCR_EXCEPTION_LIST); ASSERT(FIELD_OFFSET(KPCR, Self) == KPCR_SELF); ASSERT(FIELD_OFFSET(KIPCR, PrcbData) + FIELD_OFFSET(KPRCB, CurrentThread) == KPCR_CURRENT_THREAD); + DPRINT1("NPXThread offset: %lx\n", FIELD_OFFSET(KIPCR, PrcbData) + FIELD_OFFSET(KPRCB, NpxThread)); ASSERT(FIELD_OFFSET(KIPCR, PrcbData) + FIELD_OFFSET(KPRCB, NpxThread) == KPCR_NPX_THREAD); ASSERT(FIELD_OFFSET(KTSS, Esp0) == KTSS_ESP0); ASSERT(FIELD_OFFSET(KTSS, IoMapBase) == KTSS_IOMAPBASE); @@ -610,13 +611,13 @@ ExpInitializeExecutive(VOID) ExpInitializeCallbacks(); /* Call KD Providers at Phase 1 */ - KdInitSystem(1, (PLOADER_PARAMETER_BLOCK)&KeLoaderBlock); + KdInitSystem(1, (PROS_LOADER_PARAMETER_BLOCK)&KeLoaderBlock); /* Initialize I/O Objects, Filesystems, Error Logging and Shutdown */ IoInit(); /* TBD */ - PoInit((PLOADER_PARAMETER_BLOCK)&KeLoaderBlock, ForceAcpiDisable); + PoInit((PROS_LOADER_PARAMETER_BLOCK)&KeLoaderBlock, ForceAcpiDisable); /* Initialize the Registry (Hives are NOT yet loaded!) */ CmInitializeRegistry(); @@ -640,7 +641,7 @@ ExpInitializeExecutive(VOID) if (NoGuiBoot) ExpDisplayNotice(); /* Call KD Providers at Phase 2 */ - KdInitSystem(2, (PLOADER_PARAMETER_BLOCK)&KeLoaderBlock); + KdInitSystem(2, (PROS_LOADER_PARAMETER_BLOCK)&KeLoaderBlock); /* Import and create NLS Data and Sections */ RtlpInitNls(); diff --git a/reactos/ntoskrnl/ex/power.c b/reactos/ntoskrnl/ex/power.c index a43c8f3242f..3dd62dbc351 100644 --- a/reactos/ntoskrnl/ex/power.c +++ b/reactos/ntoskrnl/ex/power.c @@ -15,9 +15,13 @@ /* FUNCTIONS *****************************************************************/ -VOID STDCALL -KeSetTargetProcessorDpc (IN PKDPC Dpc, - IN CCHAR Number); +/* ROS Internal. Please deprecate */ +NTHALAPI +VOID +NTAPI +HalReleaseDisplayOwnership( + VOID +); VOID STDCALL KiHaltProcessorDpcRoutine(IN PKDPC Dpc, diff --git a/reactos/ntoskrnl/ex/profile.c b/reactos/ntoskrnl/ex/profile.c index 142d177a225..8bc069048b9 100644 --- a/reactos/ntoskrnl/ex/profile.c +++ b/reactos/ntoskrnl/ex/profile.c @@ -45,14 +45,14 @@ ExpDeleteProfile(PVOID ObjectBody) Profile = (PEPROFILE)ObjectBody; /* Check if there if the Profile was started */ - if (Profile->LockedBuffer) + if (Profile->LockedBufferAddress) { /* Stop the Profile */ - State = KeStopProfile(Profile->KeProfile); + State = KeStopProfile(Profile->ProfileObject); ASSERT(State != FALSE); /* Unmap the Locked Buffer */ - MmUnmapLockedPages(Profile->LockedBuffer, Profile->Mdl); + MmUnmapLockedPages(Profile->LockedBufferAddress, Profile->Mdl); MmUnlockPages(Profile->Mdl); ExFreePool(Profile->Mdl); } @@ -89,8 +89,8 @@ NTSTATUS NTAPI NtCreateProfile(OUT PHANDLE ProfileHandle, IN HANDLE Process OPTIONAL, - IN PVOID ImageBase, - IN ULONG ImageSize, + IN PVOID RangeBase, + IN ULONG RangeSize, IN ULONG BucketSize, IN PVOID Buffer, IN ULONG BufferSize, @@ -110,17 +110,17 @@ NtCreateProfile(OUT PHANDLE ProfileHandle, if(!BufferSize) return STATUS_INVALID_PARAMETER_7; /* Check if this is a low-memory profile */ - if ((!BucketSize) && (ImageBase < (PVOID)(0x10000))) + if ((!BucketSize) && (RangeBase < (PVOID)(0x10000))) { /* Validate size */ if (BufferSize < sizeof(ULONG)) return STATUS_INVALID_PARAMETER_7; /* This will become a segmented profile object */ - Segment = (ULONG)ImageBase; - ImageBase = 0; + Segment = (ULONG)RangeBase; + RangeBase = 0; /* Recalculate the bucket size */ - BucketSize = ImageSize / (BufferSize / sizeof(ULONG)); + BucketSize = RangeSize / (BufferSize / sizeof(ULONG)); /* Convert it to log2 */ BucketSize--; @@ -136,14 +136,14 @@ NtCreateProfile(OUT PHANDLE ProfileHandle, } /* Make sure that the buckets can map the range */ - if ((ImageSize >> (BucketSize - 2)) > BufferSize) + if ((RangeSize >> (BucketSize - 2)) > BufferSize) { DPRINT1("Bucket size too small\n"); return STATUS_BUFFER_TOO_SMALL; } /* Make sure that the range isn't too gigantic */ - if (((ULONG_PTR)ImageBase + ImageSize) < ImageSize) + if (((ULONG_PTR)RangeBase + RangeSize) < RangeSize) { DPRINT1("Range too big\n"); return STATUS_BUFFER_OVERFLOW; @@ -219,12 +219,12 @@ NtCreateProfile(OUT PHANDLE ProfileHandle, if (!NT_SUCCESS(Status)) return(Status); /* Initialize it */ - Profile->ImageBase = ImageBase; - Profile->ImageSize = ImageSize; + Profile->RangeBase = RangeBase; + Profile->RangeSize = RangeSize; Profile->Buffer = Buffer; Profile->BufferSize = BufferSize; Profile->BucketSize = BucketSize; - Profile->LockedBuffer = NULL; + Profile->LockedBufferAddress = NULL; Profile->Segment = Segment; Profile->ProfileSource = ProfileSource; Profile->Affinity = Affinity; @@ -319,9 +319,9 @@ NTAPI NtStartProfile(IN HANDLE ProfileHandle) { PEPROFILE Profile; - PKPROFILE KeProfile; + PKPROFILE ProfileObject; KPROCESSOR_MODE PreviousMode = ExGetPreviousMode(); - PVOID TempLockedBuffer; + PVOID TempLockedBufferAddress; NTSTATUS Status; PAGED_CODE(); @@ -342,7 +342,7 @@ NtStartProfile(IN HANDLE ProfileHandle) NULL); /* The Profile can still be enabled though, so handle that */ - if (Profile->LockedBuffer) + if (Profile->LockedBufferAddress) { /* Release our lock, dereference and return */ KeReleaseMutex(&ExpProfileMutex, FALSE); @@ -351,7 +351,7 @@ NtStartProfile(IN HANDLE ProfileHandle) } /* Allocate a Kernel Profile Object. */ - KeProfile = ExAllocatePoolWithTag(NonPagedPool, + ProfileObject = ExAllocatePoolWithTag(NonPagedPool, sizeof(EPROFILE), TAG_PROFILE); @@ -362,23 +362,23 @@ NtStartProfile(IN HANDLE ProfileHandle) MmProbeAndLockPages(Profile->Mdl, PreviousMode, IoWriteAccess); /* Map the pages */ - TempLockedBuffer = MmMapLockedPages(Profile->Mdl, KernelMode); + TempLockedBufferAddress = MmMapLockedPages(Profile->Mdl, KernelMode); /* Initialize the Kernel Profile Object */ - Profile->KeProfile = KeProfile; - KeInitializeProfile(KeProfile, + Profile->ProfileObject = ProfileObject; + KeInitializeProfile(ProfileObject, (PKPROCESS)Profile->Process, - Profile->ImageBase, - Profile->ImageSize, + Profile->RangeBase, + Profile->RangeSize, Profile->BucketSize, Profile->ProfileSource, Profile->Affinity); /* Start the Profiling */ - KeStartProfile(KeProfile, TempLockedBuffer); + KeStartProfile(ProfileObject, TempLockedBufferAddress); /* Now it's safe to save this */ - Profile->LockedBuffer = TempLockedBuffer; + Profile->LockedBufferAddress = TempLockedBufferAddress; /* Release mutex, dereference and return */ KeReleaseMutex(&ExpProfileMutex, FALSE); @@ -412,22 +412,22 @@ NtStopProfile(IN HANDLE ProfileHandle) NULL); /* Make sure the Profile Object is really Started */ - if (!Profile->LockedBuffer) + if (!Profile->LockedBufferAddress) { Status = STATUS_PROFILING_NOT_STARTED; goto Exit; } /* Stop the Profile */ - KeStopProfile(Profile->KeProfile); + KeStopProfile(Profile->ProfileObject); /* Unlock the Buffer */ - MmUnmapLockedPages(Profile->LockedBuffer, Profile->Mdl); + MmUnmapLockedPages(Profile->LockedBufferAddress, Profile->Mdl); MmUnlockPages(Profile->Mdl); - ExFreePool(Profile->KeProfile); + ExFreePool(Profile->ProfileObject); /* Clear the Locked Buffer pointer, meaning the Object is Stopped */ - Profile->LockedBuffer = NULL; + Profile->LockedBufferAddress = NULL; Exit: /* Release Mutex, Dereference and Return */ diff --git a/reactos/ntoskrnl/ex/rundown.c b/reactos/ntoskrnl/ex/rundown.c index ca40adcbbfa..f6f98eac0d4 100644 --- a/reactos/ntoskrnl/ex/rundown.c +++ b/reactos/ntoskrnl/ex/rundown.c @@ -230,7 +230,7 @@ ExfReleaseRundownProtection(IN PEX_RUNDOWN_REF RunRef) if (InterlockedExchangeAddSizeT(&WaitBlock->Count, -1)) { /* We're down to 0 now, so signal the event */ - KeSetEvent(&WaitBlock->RundownEvent, IO_NO_INCREMENT, FALSE); + KeSetEvent(&WaitBlock->WakeEvent, IO_NO_INCREMENT, FALSE); } } @@ -290,7 +290,7 @@ ExfReleaseRundownProtectionEx(IN PEX_RUNDOWN_REF RunRef, (LONG)Count) { /* We're down to 0 now, so signal the event */ - KeSetEvent(&WaitBlock->RundownEvent, IO_NO_INCREMENT, FALSE); + KeSetEvent(&WaitBlock->WakeEvent, IO_NO_INCREMENT, FALSE); } } @@ -339,12 +339,12 @@ ExfWaitForRundownProtectionRelease(IN PEX_RUNDOWN_REF RunRef) if (Count || !Event) { /* Initialize the event */ - KeInitializeEvent(&WaitBlock.RundownEvent, + KeInitializeEvent(&WaitBlock.WakeEvent, NotificationEvent, FALSE); /* Set the pointer */ - Event = &WaitBlock.RundownEvent; + Event = &WaitBlock.WakeEvent; } /* Set the count */ diff --git a/reactos/ntoskrnl/ex/sysinfo.c b/reactos/ntoskrnl/ex/sysinfo.c index 73a4b7dc1f5..abaeff7eea4 100644 --- a/reactos/ntoskrnl/ex/sysinfo.c +++ b/reactos/ntoskrnl/ex/sysinfo.c @@ -581,11 +581,12 @@ QSI_DEF(SystemProcessInformation) do { PSYSTEM_PROCESS_INFORMATION SpiCur; - int curSize, i = 0; + int curSize; ANSI_STRING imgName; int inLen=32; // image name len in bytes PLIST_ENTRY current_entry; PETHREAD current; + PSYSTEM_THREAD_INFORMATION ThreadInfo; SpiCur = (PSYSTEM_PROCESS_INFORMATION)pCur; @@ -645,7 +646,8 @@ QSI_DEF(SystemProcessInformation) SpiCur->QuotaNonPagedPoolUsage = pr->QuotaUsage[1]; SpiCur->PagefileUsage = pr->QuotaUsage[3]; SpiCur->PeakPagefileUsage = pr->QuotaPeak[3]; - SpiCur->PrivateUsage = pr->CommitCharge; + SpiCur->PrivatePageCount = pr->CommitCharge; + ThreadInfo = (PSYSTEM_THREAD_INFORMATION)(SpiCur + 1); current_entry = pr->ThreadListHead.Flink; while (current_entry != &pr->ThreadListHead) @@ -653,18 +655,19 @@ QSI_DEF(SystemProcessInformation) current = CONTAINING_RECORD(current_entry, ETHREAD, ThreadListEntry); - SpiCur->TH[i].KernelTime.QuadPart = current->Tcb.KernelTime * 100000LL; - SpiCur->TH[i].UserTime.QuadPart = current->Tcb.UserTime * 100000LL; + + ThreadInfo->KernelTime.QuadPart = current->Tcb.KernelTime * 100000LL; + ThreadInfo->UserTime.QuadPart = current->Tcb.UserTime * 100000LL; // SpiCur->TH[i].CreateTime = current->CreateTime; - SpiCur->TH[i].WaitTime = current->Tcb.WaitTime; - SpiCur->TH[i].StartAddress = (PVOID) current->StartAddress; - SpiCur->TH[i].ClientId = current->Cid; - SpiCur->TH[i].Priority = current->Tcb.Priority; - SpiCur->TH[i].BasePriority = current->Tcb.BasePriority; - SpiCur->TH[i].ContextSwitches = current->Tcb.ContextSwitches; - SpiCur->TH[i].ThreadState = current->Tcb.State; - SpiCur->TH[i].WaitReason = current->Tcb.WaitReason; - i++; + ThreadInfo->WaitTime = current->Tcb.WaitTime; + ThreadInfo->StartAddress = (PVOID) current->StartAddress; + ThreadInfo->ClientId = current->Cid; + ThreadInfo->Priority = current->Tcb.Priority; + ThreadInfo->BasePriority = current->Tcb.BasePriority; + ThreadInfo->ContextSwitches = current->Tcb.ContextSwitches; + ThreadInfo->ThreadState = current->Tcb.State; + ThreadInfo->WaitReason = current->Tcb.WaitReason; + ThreadInfo++; current_entry = current_entry->Flink; } @@ -986,15 +989,15 @@ QSI_DEF(SystemVdmBopInformation) /* Class 21 - File Cache Information */ QSI_DEF(SystemFileCacheInformation) { - SYSTEM_CACHE_INFORMATION *Sci = (SYSTEM_CACHE_INFORMATION *) Buffer; + SYSTEM_FILECACHE_INFORMATION *Sci = (SYSTEM_FILECACHE_INFORMATION *) Buffer; - if (Size < sizeof (SYSTEM_CACHE_INFORMATION)) + if (Size < sizeof (SYSTEM_FILECACHE_INFORMATION)) { - * ReqSize = sizeof (SYSTEM_CACHE_INFORMATION); + * ReqSize = sizeof (SYSTEM_FILECACHE_INFORMATION); return (STATUS_INFO_LENGTH_MISMATCH); } - RtlZeroMemory(Sci, sizeof(SYSTEM_CACHE_INFORMATION)); + RtlZeroMemory(Sci, sizeof(SYSTEM_FILECACHE_INFORMATION)); /* Return the Byte size not the page size. */ Sci->CurrentSize = @@ -1011,7 +1014,7 @@ QSI_DEF(SystemFileCacheInformation) SSI_DEF(SystemFileCacheInformation) { - if (Size < sizeof (SYSTEM_CACHE_INFORMATION)) + if (Size < sizeof (SYSTEM_FILECACHE_INFORMATION)) { return (STATUS_INFO_LENGTH_MISMATCH); } @@ -1545,7 +1548,7 @@ NtQuerySystemInformation (IN SYSTEM_INFORMATION_CLASS SystemInformationClass, /* * Check the request is valid. */ - if (SystemInformationClass >= SystemInformationClassMax) + if (SystemInformationClass >= MaxSystemInfoClass) { return (STATUS_INVALID_INFO_CLASS); } @@ -1621,7 +1624,7 @@ NtSetSystemInformation ( * Check the request is valid. */ if ( (SystemInformationClass >= SystemBasicInformation) - && (SystemInformationClass < SystemInformationClassMax) + && (SystemInformationClass < MaxSystemInfoClass) ) { if (NULL != CallQS [SystemInformationClass].Set) diff --git a/reactos/ntoskrnl/ex/win32k.c b/reactos/ntoskrnl/ex/win32k.c index 0b5bd5df45e..9853d4fa9e6 100644 --- a/reactos/ntoskrnl/ex/win32k.c +++ b/reactos/ntoskrnl/ex/win32k.c @@ -36,10 +36,10 @@ static GENERIC_MAPPING ExpDesktopMapping = }; OB_OPEN_METHOD ExpWindowStationObjectOpen = NULL; -OB_PARSE_METHOD ExpWindowStationObjectParse = NULL; +OB_ROS_PARSE_METHOD ExpWindowStationObjectParse = NULL; OB_DELETE_METHOD ExpWindowStationObjectDelete = NULL; -OB_FIND_METHOD ExpWindowStationObjectFind = NULL; -OB_CREATE_METHOD ExpDesktopObjectCreate = NULL; +OB_ROS_FIND_METHOD ExpWindowStationObjectFind = NULL; +OB_ROS_CREATE_METHOD ExpDesktopObjectCreate = NULL; OB_DELETE_METHOD ExpDesktopObjectDelete = NULL; /* FUNCTIONS ****************************************************************/ @@ -133,9 +133,9 @@ ExpWin32kInit(VOID) ObjectTypeInitializer.Length = sizeof(ObjectTypeInitializer); ObjectTypeInitializer.GenericMapping = ExpWindowStationMapping; ObjectTypeInitializer.PoolType = NonPagedPool; - ObjectTypeInitializer.OpenProcedure = ExpWinStaObjectOpen; + ObjectTypeInitializer.OpenProcedure = (OB_OPEN_METHOD)ExpWinStaObjectOpen; ObjectTypeInitializer.DeleteProcedure = ExpWinStaObjectDelete; - ObjectTypeInitializer.ParseProcedure = ExpWinStaObjectParse; + ObjectTypeInitializer.ParseProcedure = (OB_PARSE_METHOD)ExpWinStaObjectParse; ObpCreateTypeObject(&ObjectTypeInitializer, &Name, &ExWindowStationObjectType); diff --git a/reactos/ntoskrnl/inbv/inbv.c b/reactos/ntoskrnl/inbv/inbv.c index 815b5469a8e..314485892a7 100755 --- a/reactos/ntoskrnl/inbv/inbv.c +++ b/reactos/ntoskrnl/inbv/inbv.c @@ -19,6 +19,13 @@ #pragma alloc_text(INIT, InbvEnableBootDriver) #endif +/* ROS Internal. Please deprecate */ +NTHALAPI +VOID +NTAPI +HalReleaseDisplayOwnership( + VOID +); /* GLOBALS *******************************************************************/ diff --git a/reactos/ntoskrnl/include/internal/ex.h b/reactos/ntoskrnl/include/internal/ex.h index fa28e1ab7e4..b96bda5f4e7 100644 --- a/reactos/ntoskrnl/include/internal/ex.h +++ b/reactos/ntoskrnl/include/internal/ex.h @@ -8,10 +8,10 @@ extern LARGE_INTEGER ExpTimeZoneBias; extern ULONG ExpTimeZoneId; extern POBJECT_TYPE ExEventPairObjectType; -#define EX_OBJ_TO_HDR(eob) ((POBJECT_HEADER)((ULONG_PTR)(eob) & \ +#define EX_OBJ_TO_HDR(eob) ((PROS_OBJECT_HEADER)((ULONG_PTR)(eob) & \ ~(EX_HANDLE_ENTRY_PROTECTFROMCLOSE | EX_HANDLE_ENTRY_INHERITABLE | \ EX_HANDLE_ENTRY_AUDITONCLOSE))) -#define EX_HTE_TO_HDR(hte) ((POBJECT_HEADER)((ULONG_PTR)((hte)->u1.Object) & \ +#define EX_HTE_TO_HDR(hte) ((PROS_OBJECT_HEADER)((ULONG_PTR)((hte)->u1.Object) & \ ~(EX_HANDLE_ENTRY_PROTECTFROMCLOSE | EX_HANDLE_ENTRY_INHERITABLE | \ EX_HANDLE_ENTRY_AUDITONCLOSE))) diff --git a/reactos/ntoskrnl/include/internal/i386/ke.h b/reactos/ntoskrnl/include/internal/i386/ke.h index 585388d0332..ee569240346 100644 --- a/reactos/ntoskrnl/include/internal/i386/ke.h +++ b/reactos/ntoskrnl/include/internal/i386/ke.h @@ -26,7 +26,7 @@ #define X86_CR4_OSFXSR 0x00000200 /* enable FXSAVE/FXRSTOR instructions */ #define X86_CR4_OSXMMEXCPT 0x00000400 /* enable #XF exception */ -#define X86_FEATURE_TSC 0x00000010 /* time stamp counters are present */ +#define KF_RDTSC 0x00000002 /* time stamp counters are present */ #define X86_FEATURE_PAE 0x00000040 /* physical address extension is present */ #define X86_FEATURE_CX8 0x00000100 /* CMPXCHG8B instruction present */ #define X86_FEATURE_SYSCALL 0x00000800 /* SYSCALL/SYSRET support present */ @@ -51,81 +51,6 @@ #ifndef __ASM__ -typedef struct _KIRQ_TRAPFRAME -{ - ULONG Magic; - ULONG Gs; - ULONG Fs; - ULONG Es; - ULONG Ds; - ULONG Eax; - ULONG Ecx; - ULONG Edx; - ULONG Ebx; - ULONG Esp; - ULONG Ebp; - ULONG Esi; - ULONG Edi; - ULONG Eip; - ULONG Cs; - ULONG Eflags; -} KIRQ_TRAPFRAME, *PKIRQ_TRAPFRAME; - -/* Emulate cli/sti instructions */ -#define KV86M_EMULATE_CLI_STI (0x1) -/* Allow the v86 mode code to access i/o ports */ -#define KV86M_ALLOW_IO_PORT_ACCESS (0x2) - -typedef struct _KV86M_REGISTERS -{ - /* - * General purpose registers - */ - ULONG Ebp; - ULONG Edi; - ULONG Esi; - ULONG Edx; - ULONG Ecx; - ULONG Ebx; - ULONG Eax; - ULONG Ds; - ULONG Es; - ULONG Fs; - ULONG Gs; - - /* - * Control registers - */ - ULONG Eip; - ULONG Cs; - ULONG Eflags; - ULONG Esp; - ULONG Ss; - - /* - * Control structures - */ - ULONG RecoveryAddress; - UCHAR RecoveryInstruction[4]; - ULONG Vif; - ULONG Flags; - PNTSTATUS PStatus; -} KV86M_REGISTERS, *PKV86M_REGISTERS; - -typedef struct _KV86M_TRAP_FRAME -{ - KTRAP_FRAME Tf; - - ULONG SavedExceptionStack; - - /* - * These are put on the top of the stack by the routine that entered - * v86 mode so the exception handlers can find the control information - */ - struct _KV86M_REGISTERS* regs; - ULONG orig_ebp; -} KV86M_TRAP_FRAME, *PKV86M_TRAP_FRAME; - extern ULONG Ke386CacheAlignment; struct _KPCR; diff --git a/reactos/ntoskrnl/include/internal/i386/v86m.h b/reactos/ntoskrnl/include/internal/i386/v86m.h new file mode 100644 index 00000000000..20a32f40c6e --- /dev/null +++ b/reactos/ntoskrnl/include/internal/i386/v86m.h @@ -0,0 +1,126 @@ +#ifndef __V86M_ +#define __V86M_ + +#include "ketypes.h" + +/* Emulate cli/sti instructions */ +#define KV86M_EMULATE_CLI_STI (0x1) +/* Allow the v86 mode code to access i/o ports */ +#define KV86M_ALLOW_IO_PORT_ACCESS (0x2) + +typedef struct _KV86M_REGISTERS +{ + /* + * General purpose registers + */ + ULONG Ebp; + ULONG Edi; + ULONG Esi; + ULONG Edx; + ULONG Ecx; + ULONG Ebx; + ULONG Eax; + ULONG Ds; + ULONG Es; + ULONG Fs; + ULONG Gs; + + /* + * Control registers + */ + ULONG Eip; + ULONG Cs; + ULONG Eflags; + ULONG Esp; + ULONG Ss; + + /* + * Control structures + */ + ULONG RecoveryAddress; + UCHAR RecoveryInstruction[4]; + ULONG Vif; + ULONG Flags; + PNTSTATUS PStatus; +} KV86M_REGISTERS, *PKV86M_REGISTERS; + +typedef struct _KV86M_TRAP_FRAME +{ + KTRAP_FRAME Tf; + + ULONG SavedExceptionStack; + + /* + * These are put on the top of the stack by the routine that entered + * v86 mode so the exception handlers can find the control information + */ + struct _KV86M_REGISTERS* regs; + ULONG orig_ebp; +} KV86M_TRAP_FRAME, *PKV86M_TRAP_FRAME; + +#endif + +/* EOF */ +#ifndef __V86M_ +#define __V86M_ + +#include "ketypes.h" + +/* Emulate cli/sti instructions */ +#define KV86M_EMULATE_CLI_STI (0x1) +/* Allow the v86 mode code to access i/o ports */ +#define KV86M_ALLOW_IO_PORT_ACCESS (0x2) + +typedef struct _KV86M_REGISTERS +{ + /* + * General purpose registers + */ + ULONG Ebp; + ULONG Edi; + ULONG Esi; + ULONG Edx; + ULONG Ecx; + ULONG Ebx; + ULONG Eax; + ULONG Ds; + ULONG Es; + ULONG Fs; + ULONG Gs; + + /* + * Control registers + */ + ULONG Eip; + ULONG Cs; + ULONG Eflags; + ULONG Esp; + ULONG Ss; + + /* + * Control structures + */ + ULONG RecoveryAddress; + UCHAR RecoveryInstruction[4]; + ULONG Vif; + ULONG Flags; + PNTSTATUS PStatus; +} KV86M_REGISTERS, *PKV86M_REGISTERS; + +typedef struct _KV86M_TRAP_FRAME +{ + KTRAP_FRAME Tf; + + ULONG SavedExceptionStack; + + /* + * These are put on the top of the stack by the routine that entered + * v86 mode so the exception handlers can find the control information + */ + struct _KV86M_REGISTERS* regs; + ULONG orig_ebp; +} KV86M_TRAP_FRAME, *PKV86M_TRAP_FRAME; + +#endif + +/* EOF */ diff --git a/reactos/ntoskrnl/include/internal/io.h b/reactos/ntoskrnl/include/internal/io.h index fa7ee7ca458..ea158cf90a4 100644 --- a/reactos/ntoskrnl/include/internal/io.h +++ b/reactos/ntoskrnl/include/internal/io.h @@ -477,6 +477,7 @@ NTSTATUS STDCALL IopQueryNameFile( PVOID ObjectBody, + IN BOOLEAN HasName, POBJECT_NAME_INFORMATION ObjectNameInfo, ULONG Length, PULONG ReturnLength @@ -485,8 +486,11 @@ IopQueryNameFile( VOID STDCALL IopCloseFile( - PVOID ObjectBody, - ULONG HandleCount + IN PEPROCESS Process OPTIONAL, + IN PVOID Object, + IN ACCESS_MASK GrantedAccess, + IN ULONG ProcessHandleCount, + IN ULONG SystemHandleCount ); /* plugplay.c */ @@ -557,7 +561,7 @@ HalExamineMBR( VOID FASTCALL xHalIoAssignDriveLetters( - IN PLOADER_PARAMETER_BLOCK LoaderBlock, + IN PROS_LOADER_PARAMETER_BLOCK LoaderBlock, IN PSTRING NtDeviceName, OUT PUCHAR NtSystemPath, OUT PSTRING NtSystemPathString diff --git a/reactos/ntoskrnl/include/internal/kd.h b/reactos/ntoskrnl/include/internal/kd.h index 4bae37a6d67..f42e69ecafd 100644 --- a/reactos/ntoskrnl/include/internal/kd.h +++ b/reactos/ntoskrnl/include/internal/kd.h @@ -1,10 +1,61 @@ #ifndef __INCLUDE_INTERNAL_KERNEL_DEBUGGER_H #define __INCLUDE_INTERNAL_KERNEL_DEBUGGER_H +// +// Kernel Debugger Port Definition +// +typedef struct _KD_PORT_INFORMATION +{ + ULONG ComPort; + ULONG BaudRate; + ULONG BaseAddress; +} KD_PORT_INFORMATION, *PKD_PORT_INFORMATION; + struct _KD_DISPATCH_TABLE; extern KD_PORT_INFORMATION GdbPortInfo; +BOOLEAN +NTAPI +KdPortInitialize( + PKD_PORT_INFORMATION PortInformation, + ULONG Unknown1, + ULONG Unknown2 +); + +BOOLEAN +NTAPI +KdPortInitializeEx( + PKD_PORT_INFORMATION PortInformation, + ULONG Unknown1, + ULONG Unknown2 +); + +BOOLEAN +NTAPI +KdPortGetByte( + PUCHAR ByteRecieved); + +BOOLEAN +NTAPI +KdPortGetByteEx( + PKD_PORT_INFORMATION PortInformation, + PUCHAR ByteRecieved); + +VOID +NTAPI +KdPortPutByte( + UCHAR ByteToSend +); + +VOID +NTAPI +KdPortPutByteEx( + PKD_PORT_INFORMATION PortInformation, + UCHAR ByteToSend +); + /* SYMBOL ROUTINES **********************************************************/ +#ifdef __NTOSKRNL__ #if defined(KDBG) || defined(DBG) @@ -284,4 +335,5 @@ extern LIST_ENTRY KdProviders; /* Whether to enter KDB as early as possible or not */ extern BOOLEAN KdpEarlyBreak; +#endif #endif /* __INCLUDE_INTERNAL_KERNEL_DEBUGGER_H */ diff --git a/reactos/ntoskrnl/include/internal/ke.h b/reactos/ntoskrnl/include/internal/ke.h index 5f4a6b37fb5..65a450c4435 100644 --- a/reactos/ntoskrnl/include/internal/ke.h +++ b/reactos/ntoskrnl/include/internal/ke.h @@ -277,13 +277,6 @@ KeWaitForGate( /* ipi.c ********************************************************************/ -BOOLEAN -STDCALL -KiIpiServiceRoutine( - IN PKTRAP_FRAME TrapFrame, - IN struct _KEXCEPTION_FRAME* ExceptionFrame -); - VOID NTAPI KiIpiSendRequest( @@ -291,13 +284,6 @@ KiIpiSendRequest( ULONG IpiRequest ); -VOID -NTAPI -KeIpiGenericCall( - VOID (STDCALL *WorkerRoutine)(PVOID), - PVOID Argument -); - /* next file ***************************************************************/ VOID @@ -714,13 +700,6 @@ VOID NTAPI KiSetSystemTime(PLARGE_INTEGER NewSystemTime); -NTSTATUS -STDCALL -Ke386CallBios( - UCHAR Int, - PKV86M_REGISTERS Regs -); - ULONG NTAPI KeV86Exception( diff --git a/reactos/ntoskrnl/include/internal/lpc.h b/reactos/ntoskrnl/include/internal/lpc.h index f6c0ad4965d..5755fd27144 100644 --- a/reactos/ntoskrnl/include/internal/lpc.h +++ b/reactos/ntoskrnl/include/internal/lpc.h @@ -93,8 +93,11 @@ LpcSendTerminationPort( VOID STDCALL LpcpClosePort( - PVOID ObjectBody, - ULONG HandleCount + IN PEPROCESS Process OPTIONAL, + IN PVOID Object, + IN ACCESS_MASK GrantedAccess, + IN ULONG ProcessHandleCount, + IN ULONG SystemHandleCount ); VOID diff --git a/reactos/ntoskrnl/include/internal/mm.h b/reactos/ntoskrnl/include/internal/mm.h index 6f5090008b8..2a95790838a 100644 --- a/reactos/ntoskrnl/include/internal/mm.h +++ b/reactos/ntoskrnl/include/internal/mm.h @@ -5,6 +5,8 @@ /* TYPES *********************************************************************/ +struct _ROS_EPROCESS; + extern ULONG MiFreeSwapPages; extern ULONG MiUsedSwapPages; extern ULONG MmPagedPoolSize; @@ -192,7 +194,7 @@ typedef struct _MM_IMAGE_SECTION_OBJECT PMM_SECTION_SEGMENT Segments; } MM_IMAGE_SECTION_OBJECT, *PMM_IMAGE_SECTION_OBJECT; -typedef struct _SECTION_OBJECT +typedef struct _ROS_SECTION_OBJECT { CSHORT Type; CSHORT Size; @@ -205,7 +207,7 @@ typedef struct _SECTION_OBJECT PMM_IMAGE_SECTION_OBJECT ImageSection; PMM_SECTION_SEGMENT Segment; }; -} SECTION_OBJECT, *PSECTION_OBJECT; +} ROS_SECTION_OBJECT, *PROS_SECTION_OBJECT; typedef struct _MEMORY_AREA { @@ -224,7 +226,7 @@ typedef struct _MEMORY_AREA { struct { - SECTION_OBJECT* Section; + ROS_SECTION_OBJECT* Section; ULONG ViewOffset; PMM_SECTION_SEGMENT Segment; BOOLEAN WriteCopyView; @@ -237,17 +239,15 @@ typedef struct _MEMORY_AREA } Data; } MEMORY_AREA, *PMEMORY_AREA; -#ifndef _MMTYPES_H typedef struct _MADDRESS_SPACE { PMEMORY_AREA MemoryAreaRoot; FAST_MUTEX Lock; PVOID LowestAddress; - struct _EPROCESS* Process; + struct _ROS_EPROCESS* Process; PUSHORT PageTableRefCountTable; ULONG PageTableRefCountTableSize; } MADDRESS_SPACE, *PMADDRESS_SPACE; -#endif typedef struct { @@ -362,7 +362,7 @@ MmGetKernelAddressSpace(VOID); NTSTATUS NTAPI MmInitializeAddressSpace( - struct _EPROCESS* Process, + struct _ROS_EPROCESS* Process, PMADDRESS_SPACE AddressSpace); NTSTATUS @@ -445,7 +445,7 @@ MmFindGap( VOID STDCALL MmReleaseMemoryAreaIfDecommitted( - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PMADDRESS_SPACE AddressSpace, PVOID BaseAddress ); @@ -621,18 +621,18 @@ MmShowOutOfSpaceMessagePagingFile(VOID); NTSTATUS STDCALL MmCreateProcessAddressSpace( - IN struct _EPROCESS* Process, - IN PSECTION_OBJECT Section OPTIONAL + IN struct _ROS_EPROCESS* Process, + IN PROS_SECTION_OBJECT Section OPTIONAL ); NTSTATUS STDCALL -MmCreatePeb(PEPROCESS Process); +MmCreatePeb(struct _ROS_EPROCESS *Process); struct _TEB* STDCALL MmCreateTeb( - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PCLIENT_ID ClientId, PINITIAL_TEB InitialTeb ); @@ -640,7 +640,7 @@ MmCreateTeb( VOID STDCALL MmDeleteTeb( - PEPROCESS Process, + struct _ROS_EPROCESS *Process, struct _TEB* Teb ); @@ -706,7 +706,7 @@ MmQueryAnonMem( VOID NTAPI MmFreeVirtualMemory( - struct _EPROCESS* Process, + struct _ROS_EPROCESS* Process, PMEMORY_AREA MemoryArea ); @@ -860,7 +860,7 @@ VOID NTAPI MmInsertRmap( PFN_TYPE Page, - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PVOID Address ); @@ -869,14 +869,14 @@ NTAPI MmDeleteAllRmaps( PFN_TYPE Page, PVOID Context, - VOID (*DeleteMapping)(PVOID Context, PEPROCESS Process, PVOID Address) + VOID (*DeleteMapping)(PVOID Context, struct _ROS_EPROCESS *Process, PVOID Address) ); VOID NTAPI MmDeleteRmap( PFN_TYPE Page, - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PVOID Address ); @@ -994,7 +994,7 @@ MmCommitPagedPoolAddress( NTSTATUS NTAPI MmCreateVirtualMapping( - struct _EPROCESS* Process, + struct _ROS_EPROCESS* Process, PVOID Address, ULONG flProtect, PPFN_TYPE Pages, @@ -1004,7 +1004,7 @@ MmCreateVirtualMapping( NTSTATUS NTAPI MmCreateVirtualMappingUnsafe( - struct _EPROCESS* Process, + struct _ROS_EPROCESS* Process, PVOID Address, ULONG flProtect, PPFN_TYPE Pages, @@ -1014,13 +1014,13 @@ MmCreateVirtualMappingUnsafe( ULONG NTAPI MmGetPageProtect( - struct _EPROCESS* Process, + struct _ROS_EPROCESS* Process, PVOID Address); VOID NTAPI MmSetPageProtect( - struct _EPROCESS* Process, + struct _ROS_EPROCESS* Process, PVOID Address, ULONG flProtect ); @@ -1028,7 +1028,7 @@ MmSetPageProtect( BOOLEAN NTAPI MmIsPagePresent( - struct _EPROCESS* Process, + struct _ROS_EPROCESS* Process, PVOID Address ); @@ -1039,7 +1039,7 @@ MmInitGlobalKernelPageDirectory(VOID); VOID NTAPI MmDisableVirtualMapping( - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PVOID Address, BOOLEAN* WasDirty, PPFN_TYPE Page @@ -1048,7 +1048,7 @@ MmDisableVirtualMapping( VOID NTAPI MmEnableVirtualMapping( - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PVOID Address ); @@ -1059,7 +1059,7 @@ MmRawDeleteVirtualMapping(PVOID Address); VOID NTAPI MmDeletePageFileMapping( - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PVOID Address, SWAPENTRY* SwapEntry ); @@ -1067,7 +1067,7 @@ MmDeletePageFileMapping( NTSTATUS NTAPI MmCreatePageFileMapping( - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PVOID Address, SWAPENTRY SwapEntry ); @@ -1075,7 +1075,7 @@ MmCreatePageFileMapping( BOOLEAN NTAPI MmIsPageSwapEntry( - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PVOID Address ); @@ -1089,7 +1089,7 @@ MmTransferOwnershipPage( VOID NTAPI MmSetDirtyPage( - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PVOID Address ); @@ -1125,7 +1125,7 @@ MmReferencePageUnsafe(PFN_TYPE Page); BOOLEAN NTAPI MmIsAccessedAndResetAccessPage( - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PVOID Address ); @@ -1160,7 +1160,7 @@ MmGetSavedSwapEntryPage(PFN_TYPE Page); VOID NTAPI MmSetCleanPage( - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PVOID Address ); @@ -1171,37 +1171,37 @@ MmCreatePageTable(PVOID PAddress); VOID NTAPI MmDeletePageTable( - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PVOID Address ); PFN_TYPE NTAPI MmGetPfnForProcess( - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PVOID Address ); NTSTATUS STDCALL MmCopyMmInfo( - PEPROCESS Src, - PEPROCESS Dest, + struct _ROS_EPROCESS *Src, + struct _ROS_EPROCESS *Dest, PPHYSICAL_ADDRESS DirectoryTableBase ); NTSTATUS NTAPI -MmReleaseMmInfo(PEPROCESS Process); +MmReleaseMmInfo(struct _ROS_EPROCESS *Process); NTSTATUS NTAPI -Mmi386ReleaseMmInfo(PEPROCESS Process); +Mmi386ReleaseMmInfo(struct _ROS_EPROCESS *Process); VOID NTAPI MmDeleteVirtualMapping( - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PVOID Address, BOOLEAN FreePage, BOOLEAN* WasDirty, @@ -1211,7 +1211,7 @@ MmDeleteVirtualMapping( BOOLEAN NTAPI MmIsDirtyPage( - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PVOID Address ); @@ -1226,7 +1226,7 @@ MmMarkPageUnmapped(PFN_TYPE Page); VOID NTAPI MmUpdatePageDir( - PEPROCESS Process, + struct _ROS_EPROCESS *Process, PVOID Address, ULONG Size ); @@ -1299,21 +1299,6 @@ MmQuerySectionView( PULONG ResultLength ); -NTSTATUS -NTAPI -MmMapViewOfSection( - IN PVOID SectionObject, - IN PEPROCESS Process, - IN OUT PVOID *BaseAddress, - IN ULONG ZeroBits, - IN ULONG CommitSize, - IN OUT PLARGE_INTEGER SectionOffset OPTIONAL, - IN OUT PULONG ViewSize, - IN SECTION_INHERIT InheritDisposition, - IN ULONG AllocationType, - IN ULONG Protect -); - NTSTATUS NTAPI MmProtectSectionView( diff --git a/reactos/ntoskrnl/include/internal/ntoskrnl.h b/reactos/ntoskrnl/include/internal/ntoskrnl.h index 2b28d37e3d0..65b6e2b7c9a 100644 --- a/reactos/ntoskrnl/include/internal/ntoskrnl.h +++ b/reactos/ntoskrnl/include/internal/ntoskrnl.h @@ -14,6 +14,7 @@ #include "ke.h" #include "i386/mm.h" #include "i386/fpu.h" +#include "i386/v86m.h" #include "ob.h" #include "mm.h" #include "ps.h" @@ -51,7 +52,7 @@ typedef struct __DESCRIPTOR /* * Initalization functions (called once by main()) */ -VOID MmInitSystem(ULONG Phase, PLOADER_PARAMETER_BLOCK LoaderBlock, ULONG LastKernelAddress); +VOID MmInitSystem(ULONG Phase, PROS_LOADER_PARAMETER_BLOCK LoaderBlock, ULONG LastKernelAddress); VOID IoInit(VOID); VOID IoInit2(BOOLEAN BootLog); VOID STDCALL IoInit3(VOID); @@ -63,7 +64,7 @@ VOID CmInit2(PCHAR CommandLine); VOID CmShutdownRegistry(VOID); BOOLEAN CmImportSystemHive(PCHAR ChunkBase, ULONG ChunkSize); BOOLEAN CmImportHardwareHive(PCHAR ChunkBase, ULONG ChunkSize); -VOID KdInitSystem(ULONG Reserved, PLOADER_PARAMETER_BLOCK LoaderBlock); +VOID KdInitSystem(ULONG Reserved, PROS_LOADER_PARAMETER_BLOCK LoaderBlock); /* FIXME - RtlpCreateUnicodeString is obsolete and should be removed ASAP! */ BOOLEAN FASTCALL diff --git a/reactos/ntoskrnl/include/internal/ob.h b/reactos/ntoskrnl/include/internal/ob.h index b24bebfea94..0c667cafe1d 100644 --- a/reactos/ntoskrnl/include/internal/ob.h +++ b/reactos/ntoskrnl/include/internal/ob.h @@ -31,8 +31,31 @@ typedef struct _SYMLINK_OBJECT LARGE_INTEGER CreateTime; } SYMLINK_OBJECT, *PSYMLINK_OBJECT; +typedef struct _ROS_OBJECT_HEADER +{ + LIST_ENTRY Entry; + LONG PointerCount; + union + { + LONG HandleCount; + PVOID NextToFree; + }; + POBJECT_TYPE Type; + UCHAR NameInfoOffset; + UCHAR HandleInfoOffset; + UCHAR QuotaInfoOffset; + UCHAR Flags; + union + { + POBJECT_CREATE_INFORMATION ObjectCreateInfo; + PVOID QuotaBlockCharged; + }; + PSECURITY_DESCRIPTOR SecurityDescriptor; + QUAD Body; +} ROS_OBJECT_HEADER, *PROS_OBJECT_HEADER; + #define BODY_TO_HEADER(objbdy) \ - CONTAINING_RECORD((objbdy), OBJECT_HEADER, Body) + CONTAINING_RECORD((objbdy), ROS_OBJECT_HEADER, Body) #define HEADER_TO_OBJECT_NAME(objhdr) ((POBJECT_HEADER_NAME_INFO) \ (!(objhdr)->NameInfoOffset ? NULL: ((PCHAR)(objhdr) - (objhdr)->NameInfoOffset))) @@ -43,7 +66,7 @@ typedef struct _SYMLINK_OBJECT #define HEADER_TO_CREATOR_INFO(objhdr) ((POBJECT_HEADER_CREATOR_INFO) \ (!((objhdr)->Flags & OB_FLAG_CREATOR_INFO) ? NULL: ((PCHAR)(objhdr) - sizeof(OBJECT_HEADER_CREATOR_INFO)))) -#define OBJECT_ALLOC_SIZE(ObjectSize) ((ObjectSize)+sizeof(OBJECT_HEADER)) +#define OBJECT_ALLOC_SIZE(ObjectSize) ((ObjectSize)+sizeof(ROS_OBJECT_HEADER)) #define KERNEL_HANDLE_FLAG (1 << ((sizeof(HANDLE) * 8) - 1)) #define ObIsKernelHandle(Handle, ProcessorMode) \ @@ -58,17 +81,41 @@ extern PDIRECTORY_OBJECT NameSpaceRoot; extern POBJECT_TYPE ObSymbolicLinkType; extern PHANDLE_TABLE ObpKernelHandleTable; +typedef NTSTATUS +(NTAPI *OB_ROS_CREATE_METHOD)( + PVOID ObjectBody, + PVOID Parent, + PWSTR RemainingPath, + struct _OBJECT_ATTRIBUTES* ObjectAttributes +); + +typedef PVOID +(NTAPI *OB_ROS_FIND_METHOD)( + PVOID WinStaObject, + PWSTR Name, + ULONG Attributes +); + +typedef NTSTATUS +(NTAPI *OB_ROS_PARSE_METHOD)( + PVOID Object, + PVOID *NextObject, + PUNICODE_STRING FullPath, + PWSTR *Path, + ULONG Attributes +); + VOID NTAPI ObpAddEntryDirectory( PDIRECTORY_OBJECT Parent, - POBJECT_HEADER Header, + PROS_OBJECT_HEADER Header, PWSTR Name ); VOID NTAPI -ObpRemoveEntryDirectory(POBJECT_HEADER Header); +ObpRemoveEntryDirectory(PROS_OBJECT_HEADER Header); VOID NTAPI diff --git a/reactos/ntoskrnl/include/internal/po.h b/reactos/ntoskrnl/include/internal/po.h index cbd0937d760..dccdf8cc4f9 100644 --- a/reactos/ntoskrnl/include/internal/po.h +++ b/reactos/ntoskrnl/include/internal/po.h @@ -6,7 +6,7 @@ extern PDEVICE_NODE PopSystemPowerDeviceNode; VOID NTAPI PoInit( - PLOADER_PARAMETER_BLOCK LoaderBlock, + PROS_LOADER_PARAMETER_BLOCK LoaderBlock, BOOLEAN ForceAcpiDisable ); diff --git a/reactos/ntoskrnl/include/internal/ps.h b/reactos/ntoskrnl/include/internal/ps.h index e6968884579..ea9d996828c 100644 --- a/reactos/ntoskrnl/include/internal/ps.h +++ b/reactos/ntoskrnl/include/internal/ps.h @@ -8,6 +8,205 @@ struct _EJOB; #include +// +// ROS Process +// +#include +typedef struct _ROS_EPROCESS +{ + KPROCESS Pcb; + EX_PUSH_LOCK ProcessLock; + LARGE_INTEGER CreateTime; + LARGE_INTEGER ExitTime; + EX_RUNDOWN_REF RundownProtect; + HANDLE UniqueProcessId; + LIST_ENTRY ActiveProcessLinks; + ULONG QuotaUsage[3]; + ULONG QuotaPeak[3]; + ULONG CommitCharge; + ULONG PeakVirtualSize; + ULONG VirtualSize; + LIST_ENTRY SessionProcessLinks; + PVOID DebugPort; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + union + { + PVOID ExceptionPortData; + ULONG ExceptionPortValue; + UCHAR ExceptionPortState:3; + }; +#else + PVOID ExceptionPort; +#endif + PHANDLE_TABLE ObjectTable; + EX_FAST_REF Token; + ULONG WorkingSetPage; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + EX_PUSH_LOCK AddressCreationLock; + PETHREAD RotateInProgress; +#else + KGUARDED_MUTEX AddressCreationLock; + KSPIN_LOCK HyperSpaceLock; +#endif + PETHREAD ForkInProgress; + ULONG HardwareTrigger; + MM_AVL_TABLE PhysicalVadroot; + PVOID CloneRoot; + ULONG NumberOfPrivatePages; + ULONG NumberOfLockedPages; + PVOID *Win32Process; + struct _EJOB *Job; + PVOID SectionObject; + PVOID SectionBaseAddress; + PEPROCESS_QUOTA_BLOCK QuotaBlock; + PPAGEFAULT_HISTORY WorkingSetWatch; + PVOID Win32WindowStation; + HANDLE InheritedFromUniqueProcessId; + PVOID LdtInformation; + PVOID VadFreeHint; + PVOID VdmObjects; + PVOID DeviceMap; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG AlpcPagedPoolQuotaCache; + PVOID EtwDataSource; + PVOID FreeTebHint; +#else + PVOID Spare0[3]; +#endif + union + { + HARDWARE_PTE_X86 PagedirectoryPte; + ULONGLONG Filler; + }; + ULONG Session; + CHAR ImageFileName[16]; + LIST_ENTRY JobLinks; + PVOID LockedPagesList; + LIST_ENTRY ThreadListHead; + PVOID SecurityPort; + PVOID PaeTop; + ULONG ActiveThreads; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG ImagePathHash; +#else + ACCESS_MASK GrantedAccess; +#endif + ULONG DefaultHardErrorProcessing; + NTSTATUS LastThreadExitStatus; + struct _PEB* Peb; + EX_FAST_REF PrefetchTrace; + LARGE_INTEGER ReadOperationCount; + LARGE_INTEGER WriteOperationCount; + LARGE_INTEGER OtherOperationCount; + LARGE_INTEGER ReadTransferCount; + LARGE_INTEGER WriteTransferCount; + LARGE_INTEGER OtherTransferCount; + ULONG CommitChargeLimit; + ULONG CommitChargePeak; + PVOID AweInfo; + SE_AUDIT_PROCESS_CREATION_INFO SeAuditProcessCreationInfo; + MMSUPPORT Vm; + LIST_ENTRY MmProcessLinks; + ULONG ModifiedPageCount; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + union + { + struct + { + ULONG JobNotReallyActive:1; + ULONG AccountingFolded:1; + ULONG NewProcessReported:1; + ULONG ExitProcessReported:1; + ULONG ReportCommitChanges:1; + ULONG LastReportMemory:1; + ULONG ReportPhysicalPageChanges:1; + ULONG HandleTableRundown:1; + ULONG NeedsHandleRundown:1; + ULONG RefTraceEnabled:1; + ULONG NumaAware:1; + ULONG ProtectedProcess:1; + ULONG DefaultPagePriority:3; + ULONG ProcessDeleteSelf:1; + ULONG ProcessVerifierTarget:1; + }; + ULONG Flags2; + }; +#else + ULONG JobStatus; +#endif + union + { + struct + { + ULONG CreateReported:1; + ULONG NoDebugInherit:1; + ULONG ProcessExiting:1; + ULONG ProcessDelete:1; + ULONG Wow64SplitPages:1; + ULONG VmDeleted:1; + ULONG OutswapEnabled:1; + ULONG Outswapped:1; + ULONG ForkFailed:1; + ULONG Wow64VaSpace4Gb:1; + ULONG AddressSpaceInitialized:2; + ULONG SetTimerResolution:1; + ULONG BreakOnTermination:1; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG DeprioritizeViews:1; +#else + ULONG SessionCreationUnderway:1; +#endif + ULONG WriteWatch:1; + ULONG ProcessInSession:1; + ULONG OverrideAddressSpace:1; + ULONG HasAddressSpace:1; + ULONG LaunchPrefetched:1; + ULONG InjectInpageErrors:1; + ULONG VmTopDown:1; + ULONG ImageNotifyDone:1; + ULONG PdeUpdateNeeded:1; + ULONG VdmAllowed:1; + ULONG SmapAllowed:1; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG ProcessInserted:1; +#else + ULONG CreateFailed:1; +#endif + ULONG DefaultIoPriority:3; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + ULONG SparePsFlags1:2; +#else + ULONG Spare1:1; + ULONG Spare2:1; +#endif + }; + ULONG Flags; + }; + NTSTATUS ExitStatus; +#if (NTDDI_VERSION >= NTDDI_LONGHORN) + USHORT Spare7; +#else + USHORT NextPageColor; +#endif + union + { + struct + { + UCHAR SubSystemMinorVersion; + UCHAR SubSystemMajorVersion; + }; + USHORT SubSystemVersion; + }; + UCHAR PriorityClass; + MM_AVL_TABLE VadRoot; + ULONG Cookie; + KEVENT LockEvent; + ULONG LockCount; + struct _KTHREAD *LockOwner; + MADDRESS_SPACE AddressSpace; +} ROS_EPROCESS, *PROS_EPROCESS; +#include + extern LCID PsDefaultThreadLocaleId; extern LCID PsDefaultSystemLocaleId; extern LIST_ENTRY PspReaperListHead; @@ -368,12 +567,12 @@ PspGetSystemDllEntryPoints(VOID); NTSTATUS NTAPI PsLockProcess( - PEPROCESS Process, + PROS_EPROCESS Process, BOOLEAN Timeout ); VOID NTAPI -PsUnlockProcess(PEPROCESS Process); +PsUnlockProcess(PROS_EPROCESS Process); #endif /* __INCLUDE_INTERNAL_PS_H */ diff --git a/reactos/ntoskrnl/include/ntoskrnl.h b/reactos/ntoskrnl/include/ntoskrnl.h index 2c095b9fc94..1fdfb208761 100755 --- a/reactos/ntoskrnl/include/ntoskrnl.h +++ b/reactos/ntoskrnl/include/ntoskrnl.h @@ -16,6 +16,7 @@ #include #include #include +#include #include #undef TEXT #define TEXT(s) L##s @@ -23,6 +24,7 @@ /* FIXME: Temporary until CC Ros is gone */ #include +#include /* Disk Dump Driver Header */ #include diff --git a/reactos/ntoskrnl/io/disk.c b/reactos/ntoskrnl/io/disk.c index 92320b0c190..afec63e142b 100644 --- a/reactos/ntoskrnl/io/disk.c +++ b/reactos/ntoskrnl/io/disk.c @@ -65,7 +65,26 @@ HAL_DISPATCH HalDispatchTable = HAL_PRIVATE_DISPATCH HalPrivateDispatchTable = { - HAL_PRIVATE_DISPATCH_VERSION + HAL_PRIVATE_DISPATCH_VERSION, + (pHalHandlerForBus) NULL, + (pHalHandlerForConfigSpace) NULL, + (pHalLocateHiberRanges) NULL, + (pHalRegisterBusHandler) NULL, + (pHalSetWakeEnable) NULL, + (pHalSetWakeAlarm) NULL, + (pHalTranslateBusAddress) NULL, + (pHalAssignSlotResources) NULL, + (pHalHaltSystem) NULL, + (pHalFindBusAddressTranslation) NULL, + (pHalResetDisplay) NULL, + (pHalAllocateMapRegisters) NULL, + (pKdSetupPciDeviceForDebugging) NULL, + (pKdReleasePciDeviceForDebugging) NULL, + (pKdGetAcpiTablePhase0) NULL, + (pKdCheckPowerButton) NULL, + (pHalVectorToIDTEntry) NULL, + (pKdMapPhysicalMemory64) NULL, + (pKdUnmapVirtualAddress) NULL }; const WCHAR DiskMountString[] = L"\\DosDevices\\%C:"; @@ -597,7 +616,7 @@ xHalpGetDiskNumberFromRDisk(ULONG RDisk, PULONG DiskNumber) VOID FASTCALL -xHalIoAssignDriveLetters(IN PLOADER_PARAMETER_BLOCK LoaderBlock, +xHalIoAssignDriveLetters(IN PROS_LOADER_PARAMETER_BLOCK LoaderBlock, IN PSTRING NtDeviceName, OUT PUCHAR NtSystemPath, OUT PSTRING NtSystemPathString) diff --git a/reactos/ntoskrnl/io/driver.c b/reactos/ntoskrnl/io/driver.c index 862d9825647..41311653429 100644 --- a/reactos/ntoskrnl/io/driver.c +++ b/reactos/ntoskrnl/io/driver.c @@ -15,8 +15,6 @@ #include /* ke/main.c */ -extern LOADER_PARAMETER_BLOCK KeLoaderBlock; -extern ULONG KeTickCount; extern BOOLEAN SetupMode; extern BOOLEAN NoGuiBoot; diff --git a/reactos/ntoskrnl/io/efi.c b/reactos/ntoskrnl/io/efi.c index 913791c9a3c..9bf3ab14111 100644 --- a/reactos/ntoskrnl/io/efi.c +++ b/reactos/ntoskrnl/io/efi.c @@ -39,8 +39,8 @@ NtDeleteBootEntry( NTSTATUS STDCALL NtEnumerateBootEntries( - IN ULONG Unknown1, - IN ULONG Unknown2 + IN PVOID Buffer, + IN PULONG BufferLength ) { UNIMPLEMENTED; @@ -50,8 +50,8 @@ NtEnumerateBootEntries( NTSTATUS STDCALL NtQueryBootEntryOrder( - IN ULONG Unknown1, - IN ULONG Unknown2 + IN PULONG Ids, + IN PULONG Count ) { UNIMPLEMENTED; @@ -61,8 +61,8 @@ NtQueryBootEntryOrder( NTSTATUS STDCALL NtQueryBootOptions( - IN ULONG Unknown1, - IN ULONG Unknown2 + IN PBOOT_OPTIONS BootOptions, + IN PULONG BootOptionsLength ) { UNIMPLEMENTED; @@ -72,8 +72,8 @@ NtQueryBootOptions( NTSTATUS STDCALL NtSetBootEntryOrder( - IN ULONG Unknown1, - IN ULONG Unknown2 + IN PULONG Ids, + IN PULONG Count ) { UNIMPLEMENTED; @@ -83,8 +83,8 @@ NtSetBootEntryOrder( NTSTATUS STDCALL NtSetBootOptions( - ULONG Unknown1, - ULONG Unknown2 + IN PBOOT_OPTIONS BootOptions, + IN ULONG FieldsToChange ) { UNIMPLEMENTED; @@ -94,9 +94,10 @@ NtSetBootOptions( NTSTATUS STDCALL NtTranslateFilePath( - ULONG Unknown1, - ULONG Unknown2, - ULONG Unknown3 + PFILE_PATH InputFilePath, + ULONG OutputType, + PFILE_PATH OutputFilePath, + ULONG OutputFilePathLength ) { UNIMPLEMENTED; diff --git a/reactos/ntoskrnl/io/file.c b/reactos/ntoskrnl/io/file.c index a416f147975..faa07555543 100644 --- a/reactos/ntoskrnl/io/file.c +++ b/reactos/ntoskrnl/io/file.c @@ -397,6 +397,7 @@ IopSecurityFile(PVOID ObjectBody, NTSTATUS STDCALL IopQueryNameFile(PVOID ObjectBody, + IN BOOLEAN HasName, POBJECT_NAME_INFORMATION ObjectNameInfo, ULONG Length, PULONG ReturnLength) @@ -456,8 +457,11 @@ IopQueryNameFile(PVOID ObjectBody, VOID STDCALL -IopCloseFile(PVOID ObjectBody, - ULONG HandleCount) +IopCloseFile(IN PEPROCESS Process OPTIONAL, + IN PVOID ObjectBody, + IN ACCESS_MASK GrantedAccess, + IN ULONG HandleCount, + IN ULONG SystemHandleCount) { PFILE_OBJECT FileObject = (PFILE_OBJECT)ObjectBody; KEVENT Event; diff --git a/reactos/ntoskrnl/io/iomgr.c b/reactos/ntoskrnl/io/iomgr.c index 7845d08e19c..5d92c555335 100644 --- a/reactos/ntoskrnl/io/iomgr.c +++ b/reactos/ntoskrnl/io/iomgr.c @@ -424,7 +424,7 @@ IoInit3(VOID) KdbInit(); /* I/O is now setup for disk access, so phase 3 */ - KdInitSystem(3, (PLOADER_PARAMETER_BLOCK)&KeLoaderBlock); + KdInitSystem(3, (PROS_LOADER_PARAMETER_BLOCK)&KeLoaderBlock); /* Load services for devices found by PnP manager */ IopInitializePnpServices(IopRootDeviceNode, FALSE); diff --git a/reactos/ntoskrnl/io/plugplay.c b/reactos/ntoskrnl/io/plugplay.c index 6957bae2157..e44e7e0d0c8 100644 --- a/reactos/ntoskrnl/io/plugplay.c +++ b/reactos/ntoskrnl/io/plugplay.c @@ -539,8 +539,8 @@ IopGetRelatedDevice(PPLUGPLAY_CONTROL_RELATED_DEVICE_DATA RelatedDeviceData) _SEH_TRY { Relation = RelatedDeviceData->Relation; - MaximumLength = RelatedDeviceData->RelatedDeviceInstance.MaximumLength; - ProbeForWrite(RelatedDeviceData->RelatedDeviceInstance.Buffer, + MaximumLength = RelatedDeviceData->RelatedDeviceInstanceLength; + ProbeForWrite(RelatedDeviceData->RelatedDeviceInstance, MaximumLength, sizeof(WCHAR)); } @@ -622,10 +622,10 @@ IopGetRelatedDevice(PPLUGPLAY_CONTROL_RELATED_DEVICE_DATA RelatedDeviceData) /* Copy related device instance name */ _SEH_TRY { - RtlCopyMemory(RelatedDeviceData->RelatedDeviceInstance.Buffer, + RtlCopyMemory(RelatedDeviceData->RelatedDeviceInstance, RelatedDeviceNode->InstancePath.Buffer, RelatedDeviceNode->InstancePath.Length); - RelatedDeviceData->RelatedDeviceInstance.Length = RelatedDeviceNode->InstancePath.Length; + RelatedDeviceData->RelatedDeviceInstanceLength = RelatedDeviceNode->InstancePath.Length; } _SEH_HANDLE { diff --git a/reactos/ntoskrnl/kd/kdinit.c b/reactos/ntoskrnl/kd/kdinit.c index ffb48c5bcc8..cb72a1c9192 100644 --- a/reactos/ntoskrnl/kd/kdinit.c +++ b/reactos/ntoskrnl/kd/kdinit.c @@ -44,7 +44,7 @@ PKDP_INIT_ROUTINE InitRoutines[KdMax] = {KdpScreenInit, PCHAR STDCALL KdpGetWrapperDebugMode(PCHAR Currentp2, - PLOADER_PARAMETER_BLOCK LoaderBlock) + PROS_LOADER_PARAMETER_BLOCK LoaderBlock) { PCHAR p2 = Currentp2; @@ -160,7 +160,7 @@ KdpCallInitRoutine(ULONG BootPhase) VOID INIT_FUNCTION KdInitSystem(ULONG BootPhase, - PLOADER_PARAMETER_BLOCK LoaderBlock) + PROS_LOADER_PARAMETER_BLOCK LoaderBlock) { ULONG Value; ULONG i; diff --git a/reactos/ntoskrnl/kdbg/kdb.c b/reactos/ntoskrnl/kdbg/kdb.c index 49e68ef1012..7cf7823421b 100644 --- a/reactos/ntoskrnl/kdbg/kdb.c +++ b/reactos/ntoskrnl/kdbg/kdb.c @@ -80,7 +80,7 @@ STATIC KDB_ENTER_CONDITION KdbEnterConditions[][2] = }; /* Exception descriptions */ -STATIC CONST PCHAR ExceptionNrToString[] = +STATIC CONST CHAR *ExceptionNrToString[] = { "Divide Error", "Debug Trap", @@ -122,6 +122,14 @@ NTAPI KiEspToTrapFrame(IN PKTRAP_FRAME TrapFrame, IN ULONG Esp); +/* ROS Internal. Please deprecate */ +NTHALAPI +VOID +NTAPI +HalReleaseDisplayOwnership( + VOID +); + /* FUNCTIONS *****************************************************************/ STATIC VOID @@ -183,7 +191,7 @@ KdbpOverwriteInstruction( KAPC_STATE ApcState; /* Get the protection for the address. */ - Protect = MmGetPageProtect(Process, (PVOID)PAGE_ROUND_DOWN(Address)); + Protect = MmGetPageProtect((PROS_EPROCESS)Process, (PVOID)PAGE_ROUND_DOWN(Address)); /* Return if that page isn't present. */ if (Protect & PAGE_NOACCESS) @@ -200,7 +208,7 @@ KdbpOverwriteInstruction( /* Make the page writeable if it is read only. */ if (Protect & (PAGE_READONLY|PAGE_EXECUTE|PAGE_EXECUTE_READ)) { - MmSetPageProtect(Process, (PVOID)PAGE_ROUND_DOWN(Address), + MmSetPageProtect((PROS_EPROCESS)Process, (PVOID)PAGE_ROUND_DOWN(Address), (Protect & ~(PAGE_READONLY|PAGE_EXECUTE|PAGE_EXECUTE_READ)) | PAGE_READWRITE); } @@ -212,7 +220,7 @@ KdbpOverwriteInstruction( { if (Protect & (PAGE_READONLY|PAGE_EXECUTE|PAGE_EXECUTE_READ)) { - MmSetPageProtect(Process, (PVOID)PAGE_ROUND_DOWN(Address), Protect); + MmSetPageProtect((PROS_EPROCESS)Process, (PVOID)PAGE_ROUND_DOWN(Address), Protect); } /* Detach from process */ if (CurrentProcess != Process) @@ -229,7 +237,7 @@ KdbpOverwriteInstruction( /* Restore the page protection. */ if (Protect & (PAGE_READONLY|PAGE_EXECUTE|PAGE_EXECUTE_READ)) { - MmSetPageProtect(Process, (PVOID)PAGE_ROUND_DOWN(Address), Protect); + MmSetPageProtect((PROS_EPROCESS)Process, (PVOID)PAGE_ROUND_DOWN(Address), Protect); } /* Detach from process */ @@ -643,13 +651,13 @@ KdbpDeleteBreakPoint( */ STATIC LONG KdbpIsBreakPointOurs( - IN ULONG ExpNr, + IN NTSTATUS ExceptionCode, IN PKTRAP_FRAME TrapFrame) { UINT i; - ASSERT(ExpNr == 1 || ExpNr == 3); + ASSERT(ExceptionCode == STATUS_SINGLE_STEP || ExceptionCode == STATUS_BREAKPOINT); - if (ExpNr == 3) /* Software interrupt */ + if (ExceptionCode == STATUS_BREAKPOINT) /* Software interrupt */ { ULONG_PTR BpEip = (ULONG_PTR)TrapFrame->Eip - 1; /* Get EIP of INT3 instruction */ for (i = 0; i < KdbSwBreakPointCount; i++) @@ -663,7 +671,7 @@ KdbpIsBreakPointOurs( } } } - else if (ExpNr == 1) /* Hardware interrupt */ + else if (ExceptionCode == STATUS_SINGLE_STEP) /* Hardware interrupt */ { UCHAR DebugReg; for (i = 0; i < KdbHwBreakPointCount; i++) @@ -1156,6 +1164,55 @@ KdbpInternalEnter() KbdEnableMouse(); } +STATIC ULONG +KdbpGetExceptionNumberFromStatus(IN NTSTATUS ExceptionCode) +{ + ULONG Ret; + + switch (ExceptionCode) + { + case STATUS_INTEGER_DIVIDE_BY_ZERO: + Ret = 0; + break; + case STATUS_SINGLE_STEP: + Ret = 1; + break; + case STATUS_BREAKPOINT: + Ret = 3; + break; + case STATUS_INTEGER_OVERFLOW: + Ret = 4; + break; + case STATUS_ARRAY_BOUNDS_EXCEEDED: + Ret = 5; + break; + case STATUS_ILLEGAL_INSTRUCTION: + Ret = 6; + break; + case STATUS_FLOAT_INVALID_OPERATION: + Ret = 7; + break; + case STATUS_STACK_OVERFLOW: + Ret = 12; + break; + case STATUS_ACCESS_VIOLATION: + Ret = 14; + break; + case STATUS_DATATYPE_MISALIGNMENT: + Ret = 17; + break; + case STATUS_FLOAT_MULTIPLE_TRAPS: + Ret = 18; + break; + + default: + Ret = RTL_NUMBER_OF(KdbEnterConditions) - 1; + break; + } + + return Ret; +} + /*!\brief KDB Exception filter * * Called by the exception dispatcher. @@ -1177,25 +1234,28 @@ KdbEnterDebuggerException( IN OUT PKTRAP_FRAME TrapFrame, IN BOOLEAN FirstChance) { - ULONG ExpNr = (ULONG)TrapFrame->DbgArgMark; KDB_ENTER_CONDITION EnterCondition; KD_CONTINUE_TYPE ContinueType = kdHandleException; PKDB_BREAKPOINT BreakPoint; - ULONG ul; + ULONG ExpNr; ULONGLONG ull; BOOLEAN Resume = FALSE; BOOLEAN EnterConditionMet = TRUE; ULONG OldEflags; + NTSTATUS ExceptionCode; + + ExceptionCode = (ExceptionRecord != NULL ? ExceptionRecord->ExceptionCode : STATUS_BREAKPOINT); KdbCurrentProcess = PsGetCurrentProcess(); /* Set continue type to kdContinue for single steps and breakpoints */ - if (ExpNr == 1 || ExpNr == 3) + if (ExceptionCode == STATUS_SINGLE_STEP || ExceptionCode == STATUS_BREAKPOINT) ContinueType = kdContinue; /* Check if we should handle the exception. */ - ul = min(ExpNr, RTL_NUMBER_OF(KdbEnterConditions) - 1); - EnterCondition = KdbEnterConditions[ul][FirstChance ? 0 : 1]; + /* FIXME - won't get all exceptions here :( */ + ExpNr = KdbpGetExceptionNumberFromStatus(ExceptionCode); + EnterCondition = KdbEnterConditions[ExpNr][FirstChance ? 0 : 1]; if (EnterCondition == KdbDoNotEnter || (EnterCondition == KdbEnterFromUmode && PreviousMode == KernelMode) || (EnterCondition == KdbEnterFromKmode && PreviousMode != KernelMode)) @@ -1207,12 +1267,12 @@ KdbEnterDebuggerException( KdbLastBreakPointNr = -1; KdbEnteredOnSingleStep = FALSE; - if (FirstChance && (ExpNr == 1 || ExpNr == 3) && - (KdbLastBreakPointNr = KdbpIsBreakPointOurs(ExpNr, TrapFrame)) >= 0) + if (FirstChance && (ExceptionCode == STATUS_SINGLE_STEP || ExceptionCode == STATUS_BREAKPOINT) && + (KdbLastBreakPointNr = KdbpIsBreakPointOurs(ExceptionCode, TrapFrame)) >= 0) { BreakPoint = KdbBreakPoints + KdbLastBreakPointNr; - if (ExpNr == 3) + if (ExceptionCode == STATUS_BREAKPOINT) { /* * The breakpoint will point to the next instruction by default so @@ -1272,7 +1332,7 @@ KdbEnterDebuggerException( else if (BreakPoint->Type == KdbBreakPointSoftware || BreakPoint->Type == KdbBreakPointTemporary) { - ASSERT(ExpNr == 3); + ASSERT(ExceptionCode == STATUS_BREAKPOINT); TrapFrame->EFlags |= X86_EFLAGS_TF; KdbBreakPointToReenable = BreakPoint; } @@ -1322,7 +1382,7 @@ KdbEnterDebuggerException( } } - else if (ExpNr == 1) + else if (ExceptionCode == STATUS_SINGLE_STEP) { /* Silently ignore a debugger initiated single step. */ if ((TrapFrame->Dr6 & 0xf) == 0 && KdbBreakPointToReenable != NULL) @@ -1380,7 +1440,7 @@ KdbEnterDebuggerException( DbgPrint("Entered debugger on unexpected debug trap!\n"); } } - else if (ExpNr == 3) + else if (ExceptionCode == STATUS_BREAKPOINT) { if (KdbInitFileBuffer != NULL) { @@ -1397,7 +1457,7 @@ KdbEnterDebuggerException( } else { - CONST PCHAR ExceptionString = (ExpNr < RTL_NUMBER_OF(ExceptionNrToString)) ? + CONST CHAR *ExceptionString = (ExpNr < RTL_NUMBER_OF(ExceptionNrToString)) ? (ExceptionNrToString[ExpNr]) : ("Unknown/User defined exception"); @@ -1406,9 +1466,10 @@ KdbEnterDebuggerException( return ContinueType; } - DbgPrint("Entered debugger on %s-chance exception number %d (%s)\n", - FirstChance ? "first" : "last", ExpNr, ExceptionString); - if (ExpNr == 14) + DbgPrint("Entered debugger on %s-chance exception (Exception Code: 0x%x) (%s)\n", + FirstChance ? "first" : "last", ExceptionCode, ExceptionString); + if (ExceptionCode == STATUS_ACCESS_VIOLATION && + ExceptionRecord != NULL && ExceptionRecord->NumberParameters != 0) { /* FIXME: Add noexec memory stuff */ ULONG_PTR Cr2; @@ -1491,7 +1552,7 @@ KdbEnterDebuggerException( continue_execution: /* Clear debug status */ - if (ExpNr == 1 || ExpNr == 3) /* FIXME: Why clear DR6 on INT3? */ + if (ExceptionCode == STATUS_SINGLE_STEP || ExceptionCode == STATUS_BREAKPOINT) /* FIXME: Why clear DR6 on INT3? */ { /* Set the RF flag so we don't trigger the same breakpoint again. */ if (Resume) diff --git a/reactos/ntoskrnl/kdbg/kdb_cli.c b/reactos/ntoskrnl/kdbg/kdb_cli.c index ac4be5b5ecf..fa14881ef0a 100644 --- a/reactos/ntoskrnl/kdbg/kdb_cli.c +++ b/reactos/ntoskrnl/kdbg/kdb_cli.c @@ -1453,7 +1453,7 @@ KdbpCmdPcr(ULONG Argc, PCHAR Argv[]) Pcr->IDR, Pcr->KdVersionBlock, Pcr->IDT, Pcr->GDT, Pcr->TSS, Pcr->MajorVersion, Pcr->MinorVersion, Pcr->SetMember, Pcr->StallScaleFactor, Pcr->Number, Pcr->L2CacheAssociativity, - Pcr->VdmAlert, Pcr->L2CacheSize, Pcr->InterruptMode); + Pcr->VdmAlert, Pcr->SecondLevelCacheSize, Pcr->InterruptMode); return TRUE; } diff --git a/reactos/ntoskrnl/kdbg/kdb_symbols.c b/reactos/ntoskrnl/kdbg/kdb_symbols.c index bc3719171e1..bb8df6d205c 100644 --- a/reactos/ntoskrnl/kdbg/kdb_symbols.c +++ b/reactos/ntoskrnl/kdbg/kdb_symbols.c @@ -73,7 +73,7 @@ KdbpSymFindUserModule(IN PVOID Address OPTIONAL, while (current_entry != &Peb->Ldr->InLoadOrderModuleList && current_entry != NULL) { - current = CONTAINING_RECORD(current_entry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + current = CONTAINING_RECORD(current_entry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); Length = min(current->BaseDllName.Length / sizeof(WCHAR), 255); if ((Address != NULL && (Address >= (PVOID)current->DllBase && Address < (PVOID)((char *)current->DllBase + current->SizeOfImage))) || @@ -115,7 +115,7 @@ KdbpSymFindModule(IN PVOID Address OPTIONAL, while (current_entry != &ModuleListHead) { - current = CONTAINING_RECORD(current_entry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + current = CONTAINING_RECORD(current_entry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); Length = min(current->BaseDllName.Length / sizeof(WCHAR), 255); if ((Address != NULL && (Address >= (PVOID)current->DllBase && @@ -537,7 +537,7 @@ KdbSymFreeProcessSymbols(IN PEPROCESS Process) while (CurrentEntry != &Peb->Ldr->InLoadOrderModuleList && CurrentEntry != NULL) { - Current = CONTAINING_RECORD(CurrentEntry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + Current = CONTAINING_RECORD(CurrentEntry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); KdbpSymUnloadModuleSymbols(Current->PatchInformation); diff --git a/reactos/ntoskrnl/ke/bug.c b/reactos/ntoskrnl/ke/bug.c index ee55dfd1d65..839198598f3 100644 --- a/reactos/ntoskrnl/ke/bug.c +++ b/reactos/ntoskrnl/ke/bug.c @@ -19,6 +19,14 @@ #pragma alloc_text(INIT, KiInitializeBugCheck) #endif +/* ROS Internal. Please deprecate */ +NTHALAPI +VOID +NTAPI +HalReleaseDisplayOwnership( + VOID +); + /* GLOBALS ******************************************************************/ static LIST_ENTRY BugcheckCallbackListHead = {NULL,NULL}; @@ -315,7 +323,7 @@ KeBugCheckWithTf(ULONG BugCheckCode, Address = (PVOID)Tf->Eip; /* Try to get information on the module */ - LIST_FOR_EACH(CurrentModule, &ModuleListHead, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList) + LIST_FOR_EACH(CurrentModule, &ModuleListHead, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks) { /* Check if this is the right one */ if ((Address != NULL && (Address >= (PVOID)CurrentModule->DllBase && diff --git a/reactos/ntoskrnl/ke/clock.c b/reactos/ntoskrnl/ke/clock.c index b0d697a84b0..29a27cd84a7 100644 --- a/reactos/ntoskrnl/ke/clock.c +++ b/reactos/ntoskrnl/ke/clock.c @@ -42,7 +42,7 @@ static BOOLEAN KiClockSetupComplete = FALSE; /* * Number of timer interrupts since initialisation */ -volatile ULONGLONG KeTickCount = 0; +volatile KSYSTEM_TIME KeTickCount = {0}; volatile ULONG KiRawTicks = 0; extern LIST_ENTRY KiTimerListHead; @@ -165,7 +165,7 @@ KeQueryTickCount(PLARGE_INTEGER TickCount) * TickCount (OUT) = Points to storage for the number of ticks */ { - TickCount->QuadPart = KeTickCount; + TickCount->QuadPart = *(PULONGLONG)&KeTickCount; } /* @@ -352,7 +352,7 @@ KeUpdateSystemTime( /* * Increment the number of timers ticks */ - KeTickCount++; + (*(PULONGLONG)&KeTickCount)++; SharedUserData->TickCountLowDeprecated++; Time.u.LowPart = SharedUserData->InterruptTime.LowPart; diff --git a/reactos/ntoskrnl/ke/device.c b/reactos/ntoskrnl/ke/device.c index 98d0cf424bd..b1d5300e0f5 100644 --- a/reactos/ntoskrnl/ke/device.c +++ b/reactos/ntoskrnl/ke/device.c @@ -71,9 +71,9 @@ KeFindConfigurationNextEntry(IN PCONFIGURATION_COMPONENT_DATA Child, else { /* Try to get a match */ - if (Child->Component.Class == Class && - Child->Component.Type == Type && - (Child->Component.Key & Mask) == Key) + if (Child->ComponentEntry.Class == Class && + Child->ComponentEntry.Type == Type && + (Child->ComponentEntry.Key & Mask) == Key) { /* Match found */ return Child; @@ -93,9 +93,9 @@ KeFindConfigurationNextEntry(IN PCONFIGURATION_COMPONENT_DATA Child, else { /* Try to get a match */ - if (Sibling->Component.Class == Class && - Sibling->Component.Type == Type && - (Sibling->Component.Key & Mask) == Key) + if (Sibling->ComponentEntry.Class == Class && + Sibling->ComponentEntry.Type == Type && + (Sibling->ComponentEntry.Key & Mask) == Key) { /* Match found */ return Sibling; diff --git a/reactos/ntoskrnl/ke/dpc.c b/reactos/ntoskrnl/ke/dpc.c index 502b3c6e1c2..5ca1616d96c 100644 --- a/reactos/ntoskrnl/ke/dpc.c +++ b/reactos/ntoskrnl/ke/dpc.c @@ -439,13 +439,9 @@ KiQuantumEnd(VOID) Process = CurrentThread->ApcState.Process; /* Set DPC Event if requested */ - if (Prcb->DpcSetEventRequest) { - /* - * FIXME: - * Prcb->DpcEvent is not initialized. - */ - KEBUGCHECK(0); - KeSetEvent(Prcb->DpcEvent, 0, 0); + if (Prcb->DpcSetEventRequest) + { + KeSetEvent(&Prcb->DpcEvent, 0, 0); } /* Check if Quantum expired */ diff --git a/reactos/ntoskrnl/ke/i386/bios.c b/reactos/ntoskrnl/ke/i386/bios.c index 2e3dea873f8..58cb5bbf4d4 100644 --- a/reactos/ntoskrnl/ke/i386/bios.c +++ b/reactos/ntoskrnl/ke/i386/bios.c @@ -24,11 +24,12 @@ extern VOID Ki386RetToV86Mode(PKV86M_REGISTERS InRegs, /* FUNCTIONS *****************************************************************/ NTSTATUS STDCALL -Ke386CallBios(UCHAR Int, PKV86M_REGISTERS Regs) +Ke386CallBios(ULONG Int, PCONTEXT regs) { PUCHAR Ip; KV86M_REGISTERS ORegs; NTSTATUS Status; + PKV86M_REGISTERS Regs = (PKV86M_REGISTERS)regs; /* * Set up a trampoline for executing the BIOS interrupt diff --git a/reactos/ntoskrnl/ke/i386/exp.c b/reactos/ntoskrnl/ke/i386/exp.c index 316e424c22b..27db6a39d92 100644 --- a/reactos/ntoskrnl/ke/i386/exp.c +++ b/reactos/ntoskrnl/ke/i386/exp.c @@ -118,7 +118,7 @@ KiRosPrintAddress(PVOID address) while (current_entry != &ModuleListHead) { current = - CONTAINING_RECORD(current_entry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + CONTAINING_RECORD(current_entry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); if (address >= (PVOID)current->DllBase && address < (PVOID)((ULONG_PTR)current->DllBase + current->SizeOfImage)) diff --git a/reactos/ntoskrnl/ke/i386/irq.c b/reactos/ntoskrnl/ke/i386/irq.c index ddca05b4a8e..0a567f8a8ff 100644 --- a/reactos/ntoskrnl/ke/i386/irq.c +++ b/reactos/ntoskrnl/ke/i386/irq.c @@ -19,6 +19,7 @@ #include #include <../hal/halx86/include/halirq.h> +#include <../hal/halx86/include/mps.h> #define NDEBUG #include diff --git a/reactos/ntoskrnl/ke/i386/kernel.c b/reactos/ntoskrnl/ke/i386/kernel.c index d1e013e8ba8..aec8b839aa7 100644 --- a/reactos/ntoskrnl/ke/i386/kernel.c +++ b/reactos/ntoskrnl/ke/i386/kernel.c @@ -139,7 +139,7 @@ Ki386GetCpuId(VOID) if (MaxCpuidLevel >= 0x80000006) { Ki386Cpuid(0x80000006, &Dummy, &Dummy, &Ecx, &Dummy); - Pcr->L2CacheSize = Ecx >> 16; + Pcr->SecondLevelCacheSize = Ecx >> 16; } } @@ -494,9 +494,9 @@ KeInit2(VOID) DPRINT("Ke386L1CacheSize: %dkB\n", Ke386L1CacheSize); } - if (Pcr->L2CacheSize) + if (Pcr->SecondLevelCacheSize) { - DPRINT("Ke386L2CacheSize: %dkB\n", Pcr->L2CacheSize); + DPRINT("Ke386L2CacheSize: %dkB\n", Pcr->SecondLevelCacheSize); } } @@ -532,7 +532,7 @@ Ki386SetProcessorFeatures(VOID) SharedUserData->ProcessorFeatures[PF_3DNOW_INSTRUCTIONS_AVAILABLE] = (Ke386CpuidExFlags & X86_EXT_FEATURE_3DNOW) ? TRUE : FALSE; SharedUserData->ProcessorFeatures[PF_RDTSC_INSTRUCTION_AVAILABLE] = - (Pcr->PrcbData.FeatureBits & X86_FEATURE_TSC) ? TRUE : FALSE; + (Pcr->PrcbData.FeatureBits & KF_RDTSC) ? TRUE : FALSE; SharedUserData->ProcessorFeatures[PF_PAE_ENABLED] = Ke386Pae; SharedUserData->ProcessorFeatures[PF_XMMI64_INSTRUCTIONS_AVAILABLE] = (Pcr->PrcbData.FeatureBits & X86_FEATURE_SSE2) ? TRUE : FALSE; diff --git a/reactos/ntoskrnl/ke/i386/usertrap.c b/reactos/ntoskrnl/ke/i386/usertrap.c index cb4c29facbf..61fe7998005 100644 --- a/reactos/ntoskrnl/ke/i386/usertrap.c +++ b/reactos/ntoskrnl/ke/i386/usertrap.c @@ -61,7 +61,7 @@ print_user_address(PVOID address) current_entry != NULL) { current = - CONTAINING_RECORD(current_entry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + CONTAINING_RECORD(current_entry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); if (address >= (PVOID)current->DllBase && address < (PVOID)((char*)current->DllBase + current->SizeOfImage)) diff --git a/reactos/ntoskrnl/ke/ipi.c b/reactos/ntoskrnl/ke/ipi.c index f910cf3590d..a43593a0faf 100644 --- a/reactos/ntoskrnl/ke/ipi.c +++ b/reactos/ntoskrnl/ke/ipi.c @@ -43,9 +43,9 @@ KiIpiSendRequest(KAFFINITY TargetSet, ULONG IpiRequest) * @implemented */ BOOLEAN -STDCALL +NTAPI KiIpiServiceRoutine(IN PKTRAP_FRAME TrapFrame, - IN PKEXCEPTION_FRAME ExceptionFrame) + IN PVOID ExceptionFrame) { #ifdef DBG LARGE_INTEGER StartTime, CurrentTime, Frequency; diff --git a/reactos/ntoskrnl/ke/kthread.c b/reactos/ntoskrnl/ke/kthread.c index 6980816e6b5..8ccda9c6097 100644 --- a/reactos/ntoskrnl/ke/kthread.c +++ b/reactos/ntoskrnl/ke/kthread.c @@ -154,7 +154,7 @@ KiDispatchThreadNoLock(ULONG NewThreadStatus) IdleProcessorMask |= Affinity; } - MmUpdatePageDir(PsGetCurrentProcess(),((PETHREAD)CurrentThread)->ThreadsProcess, sizeof(EPROCESS)); + MmUpdatePageDir((PROS_EPROCESS)PsGetCurrentProcess(),((PETHREAD)CurrentThread)->ThreadsProcess, sizeof(ROS_EPROCESS)); /* Special note for Filip: This will release the Dispatcher DB Lock ;-) -- Alex */ DPRINT("You are : %x, swapping to: %x\n", OldThread, CurrentThread); @@ -864,8 +864,8 @@ KeInitializeThread(PKPROCESS Process, * while handling page faults. At this point it isn't possible to call the * page fault handler for the missing pde's. */ - MmUpdatePageDir((PEPROCESS)Process, (PVOID)Thread->StackLimit, KERNEL_STACK_SIZE); - MmUpdatePageDir((PEPROCESS)Process, (PVOID)Thread, sizeof(ETHREAD)); + MmUpdatePageDir((PROS_EPROCESS)Process, (PVOID)Thread->StackLimit, KERNEL_STACK_SIZE); + MmUpdatePageDir((PROS_EPROCESS)Process, (PVOID)Thread, sizeof(ETHREAD)); /* Initalize the Thread Context */ DPRINT("Initializing the Context for the thread: %x\n", Thread); diff --git a/reactos/ntoskrnl/ke/main.c b/reactos/ntoskrnl/ke/main.c index 2bdeb11b230..048313e138f 100644 --- a/reactos/ntoskrnl/ke/main.c +++ b/reactos/ntoskrnl/ke/main.c @@ -26,7 +26,7 @@ ULONG NtBuildNumber = KERNEL_VERSION_BUILD; ULONG NtGlobalFlag = 0; CHAR KeNumberProcessors; KAFFINITY KeActiveProcessors = 1; -LOADER_PARAMETER_BLOCK KeLoaderBlock; +ROS_LOADER_PARAMETER_BLOCK KeLoaderBlock; ULONG KeDcacheFlushCount = 0; ULONG KeIcacheFlushCount = 0; ULONG KiDmaIoCoherency = 0; /* RISC Architectures only */ @@ -66,7 +66,7 @@ PLOADER_MODULE CachedModules[MaximumCachedModuleType]; extern unsigned int _image_base__; ULONG_PTR KERNEL_BASE = (ULONG_PTR)&_image_base__; -VOID INIT_FUNCTION _main(ULONG MultiBootMagic, PLOADER_PARAMETER_BLOCK _LoaderBlock); +VOID INIT_FUNCTION _main(ULONG MultiBootMagic, PROS_LOADER_PARAMETER_BLOCK _LoaderBlock); #if defined (ALLOC_PRAGMA) #pragma alloc_text(INIT, _main) @@ -146,7 +146,7 @@ KiSystemStartup(BOOLEAN BootProcessor) VOID INIT_FUNCTION _main(ULONG MultiBootMagic, - PLOADER_PARAMETER_BLOCK _LoaderBlock) + PROS_LOADER_PARAMETER_BLOCK _LoaderBlock) { ULONG i; ULONG size; @@ -282,7 +282,7 @@ _main(ULONG MultiBootMagic, } /* Initialize the Debugger */ - KdInitSystem (0, (PLOADER_PARAMETER_BLOCK)&KeLoaderBlock); + KdInitSystem (0, &KeLoaderBlock); /* Initialize HAL */ HalInitSystem (0, (PLOADER_PARAMETER_BLOCK)&KeLoaderBlock); diff --git a/reactos/ntoskrnl/ke/process.c b/reactos/ntoskrnl/ke/process.c index da367933343..db8f06cb2ad 100644 --- a/reactos/ntoskrnl/ke/process.c +++ b/reactos/ntoskrnl/ke/process.c @@ -22,8 +22,6 @@ KeServiceDescriptorTable[SSDT_MAX_ENTRIES] = { { MainSSDT, NULL, NUMBER_OF_SYSCALLS, MainSSPT }, { NULL, NULL, 0, NULL }, - { NULL, NULL, 0, NULL }, - { NULL, NULL, 0, NULL } }; KSERVICE_TABLE_DESCRIPTOR @@ -31,8 +29,6 @@ KeServiceDescriptorTableShadow[SSDT_MAX_ENTRIES] = { { MainSSDT, NULL, NUMBER_OF_SYSCALLS, MainSSPT }, { NULL, NULL, 0, NULL }, - { NULL, NULL, 0, NULL }, - { NULL, NULL, 0, NULL } }; /* FUNCTIONS *****************************************************************/ @@ -60,8 +56,8 @@ UpdatePageDirs(IN PKTHREAD Thread, * To prevent this, make sure the page directory of the process we're * attaching to is up-to-date. */ - MmUpdatePageDir((PEPROCESS)Process, (PVOID)Thread->StackLimit, KERNEL_STACK_SIZE); - MmUpdatePageDir((PEPROCESS)Process, (PVOID)Thread, sizeof(ETHREAD)); + MmUpdatePageDir((PROS_EPROCESS)Process, (PVOID)Thread->StackLimit, KERNEL_STACK_SIZE); + MmUpdatePageDir((PROS_EPROCESS)Process, (PVOID)Thread, sizeof(ETHREAD)); } VOID diff --git a/reactos/ntoskrnl/ldr/loader.c b/reactos/ntoskrnl/ldr/loader.c index 0f47e691a71..ad57df7a875 100644 --- a/reactos/ntoskrnl/ldr/loader.c +++ b/reactos/ntoskrnl/ldr/loader.c @@ -131,7 +131,7 @@ LdrInitModuleManagement ( VOID ) DPRINT("ModuleObject:%08x entrypoint at %x\n", &NtoskrnlModuleObject, NtoskrnlModuleObject.EntryPoint); NtoskrnlModuleObject.SizeOfImage = NtHeader->OptionalHeader.SizeOfImage; - InsertTailList(&ModuleListHead, &NtoskrnlModuleObject.InLoadOrderModuleList); + InsertTailList(&ModuleListHead, &NtoskrnlModuleObject.InLoadOrderLinks); /* Initialize ModuleObject for HAL */ RtlZeroMemory(&HalModuleObject, sizeof(LDR_DATA_TABLE_ENTRY)); @@ -145,7 +145,7 @@ LdrInitModuleManagement ( VOID ) DPRINT("ModuleObject:%08x entrypoint at %x\n", &HalModuleObject, HalModuleObject.EntryPoint); HalModuleObject.SizeOfImage = NtHeader->OptionalHeader.SizeOfImage; - InsertTailList(&ModuleListHead, &HalModuleObject.InLoadOrderModuleList); + InsertTailList(&ModuleListHead, &HalModuleObject.InLoadOrderLinks); } NTSTATUS @@ -343,7 +343,7 @@ LdrUnloadModule ( PLDR_DATA_TABLE_ENTRY ModuleObject ) /* Remove the module from the module list */ KeAcquireSpinLock(&ModuleListLock,&Irql); - RemoveEntryList(&ModuleObject->InLoadOrderModuleList); + RemoveEntryList(&ModuleObject->InLoadOrderLinks); KeReleaseSpinLock(&ModuleListLock, Irql); /* Hook for KDB on unloading a driver. */ @@ -390,7 +390,7 @@ LdrpQueryModuleInformation ( PLIST_ENTRY current_entry; PLDR_DATA_TABLE_ENTRY current; ULONG ModuleCount = 0; - PSYSTEM_MODULE_INFORMATION Smi; + PRTL_PROCESS_MODULES Smi; ANSI_STRING AnsiName; PCHAR p; KIRQL Irql; @@ -405,13 +405,13 @@ LdrpQueryModuleInformation ( while (current_entry != (&ModuleListHead)) { ModuleCount++; - current = CONTAINING_RECORD(current_entry,LDR_DATA_TABLE_ENTRY,InLoadOrderModuleList); + current = CONTAINING_RECORD(current_entry,LDR_DATA_TABLE_ENTRY,InLoadOrderLinks); tmpBufferSize += current->FullDllName.Length + sizeof(WCHAR) + sizeof(UNICODE_STRING); current_entry = current_entry->Flink; } - *ReqSize = sizeof(SYSTEM_MODULE_INFORMATION)+ - (ModuleCount - 1) * sizeof(SYSTEM_MODULE_INFORMATION_ENTRY); + *ReqSize = sizeof(RTL_PROCESS_MODULES)+ + (ModuleCount - 1) * sizeof(RTL_PROCESS_MODULE_INFORMATION); if (Size < *ReqSize) { @@ -431,23 +431,23 @@ LdrpQueryModuleInformation ( /* fill the buffer */ memset(Buffer, '=', Size); - Smi = (PSYSTEM_MODULE_INFORMATION)Buffer; - Smi->Count = ModuleCount; + Smi = (PRTL_PROCESS_MODULES)Buffer; + Smi->NumberOfModules = ModuleCount; ModuleCount = 0; current_entry = ModuleListHead.Flink; while (current_entry != (&ModuleListHead)) { - current = CONTAINING_RECORD(current_entry,LDR_DATA_TABLE_ENTRY,InLoadOrderModuleList); - - Smi->Module[ModuleCount].Unknown1 = 0; /* Always 0 */ - Smi->Module[ModuleCount].Unknown2 = 0; /* Always 0 */ - Smi->Module[ModuleCount].Base = current->DllBase; - Smi->Module[ModuleCount].Size = current->SizeOfImage; - Smi->Module[ModuleCount].Flags = 0; /* Flags ??? (GN) */ - Smi->Module[ModuleCount].Index = (USHORT)ModuleCount; - Smi->Module[ModuleCount].NameLength = 0; - Smi->Module[ModuleCount].LoadCount = 0; /* FIXME */ + current = CONTAINING_RECORD(current_entry,LDR_DATA_TABLE_ENTRY,InLoadOrderLinks); + + Smi->Modules[ModuleCount].Section = 0; /* Always 0 */ + Smi->Modules[ModuleCount].MappedBase = 0; /* Always 0 */ + Smi->Modules[ModuleCount].ImageBase = current->DllBase; + Smi->Modules[ModuleCount].ImageSize = current->SizeOfImage; + Smi->Modules[ModuleCount].Flags = 0; /* Flags ??? (GN) */ + Smi->Modules[ModuleCount].LoadOrderIndex = (USHORT)ModuleCount; + Smi->Modules[ModuleCount].InitOrderIndex = 0; + Smi->Modules[ModuleCount].LoadCount = 0; /* FIXME */ UnicodeName[ModuleCount].Buffer = tmpNameBuffer; UnicodeName[ModuleCount].MaximumLength = current->FullDllName.Length + sizeof(WCHAR); tmpNameBuffer += UnicodeName[ModuleCount].MaximumLength / sizeof(WCHAR); @@ -459,24 +459,24 @@ LdrpQueryModuleInformation ( KeReleaseSpinLock(&ModuleListLock, Irql); - for (ModuleCount = 0; ModuleCount < Smi->Count; ModuleCount++) + for (ModuleCount = 0; ModuleCount < Smi->NumberOfModules; ModuleCount++) { AnsiName.Length = 0; AnsiName.MaximumLength = 255; - AnsiName.Buffer = Smi->Module[ModuleCount].ImageName; + AnsiName.Buffer = Smi->Modules[ModuleCount].FullPathName; RtlUnicodeStringToAnsiString(&AnsiName, &UnicodeName[ModuleCount], FALSE); AnsiName.Buffer[AnsiName.Length] = 0; - Smi->Module[ModuleCount].NameLength = AnsiName.Length; + Smi->Modules[ModuleCount].InitOrderIndex = AnsiName.Length; p = strrchr(AnsiName.Buffer, '\\'); if (p == NULL) { - Smi->Module[ModuleCount].PathLength = 0; + Smi->Modules[ModuleCount].OffsetToFileName = 0; } else { p++; - Smi->Module[ModuleCount].PathLength = p - AnsiName.Buffer; + Smi->Modules[ModuleCount].OffsetToFileName = p - AnsiName.Buffer; } } @@ -596,7 +596,7 @@ LdrGetModuleObject ( PUNICODE_STRING ModuleName ) Entry = ModuleListHead.Flink; while (Entry != &ModuleListHead) { - Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderModuleList); + Module = CONTAINING_RECORD(Entry, LDR_DATA_TABLE_ENTRY, InLoadOrderLinks); DPRINT("Comparing %wZ and %wZ\n", &Module->BaseDllName, @@ -897,7 +897,7 @@ LdrPEProcessModule( /* Insert module */ KeAcquireSpinLock(&ModuleListLock, &Irql); InsertTailList(&ModuleListHead, - &CreatedModuleObject->InLoadOrderModuleList); + &CreatedModuleObject->InLoadOrderLinks); KeReleaseSpinLock(&ModuleListLock, Irql); *ModuleObject = CreatedModuleObject; diff --git a/reactos/ntoskrnl/lpc/close.c b/reactos/ntoskrnl/lpc/close.c index 1091bfcc837..00516454bd3 100644 --- a/reactos/ntoskrnl/lpc/close.c +++ b/reactos/ntoskrnl/lpc/close.c @@ -28,7 +28,11 @@ * REVISIONS */ VOID STDCALL -LpcpClosePort (PVOID ObjectBody, ULONG HandleCount) +LpcpClosePort (IN PEPROCESS Process OPTIONAL, + IN PVOID ObjectBody, + IN ACCESS_MASK GrantedAccess, + IN ULONG HandleCount, + IN ULONG SystemHandleCount) { PEPORT Port = (PEPORT)ObjectBody; PORT_MESSAGE Message; diff --git a/reactos/ntoskrnl/mm/anonmem.c b/reactos/ntoskrnl/mm/anonmem.c index 543d83cb825..548ff4a9bbd 100644 --- a/reactos/ntoskrnl/mm/anonmem.c +++ b/reactos/ntoskrnl/mm/anonmem.c @@ -544,7 +544,7 @@ NtAllocateVirtualMemory(IN HANDLE ProcessHandle, * RETURNS: Status */ { - PEPROCESS Process; + PROS_EPROCESS Process; MEMORY_AREA* MemoryArea; ULONG_PTR MemoryAreaLength; ULONG Type; @@ -784,7 +784,7 @@ MmFreeVirtualMemoryPage(PVOID Context, MmFreeSwapPage(SavedSwapEntry); MmSetSavedSwapEntryPage(Page, 0); } - MmDeleteRmap(Page, Process, Address); + MmDeleteRmap(Page, (PROS_EPROCESS)Process, Address); MmReleasePageMemoryConsumer(MC_USER, Page); } else if (SwapEntry != 0) @@ -795,7 +795,7 @@ MmFreeVirtualMemoryPage(PVOID Context, VOID NTAPI -MmFreeVirtualMemory(PEPROCESS Process, +MmFreeVirtualMemory(PROS_EPROCESS Process, PMEMORY_AREA MemoryArea) { PLIST_ENTRY current_entry; @@ -889,7 +889,7 @@ NtFreeVirtualMemory(IN HANDLE ProcessHandle, { MEMORY_AREA* MemoryArea; NTSTATUS Status; - PEPROCESS Process; + PROS_EPROCESS Process; PMADDRESS_SPACE AddressSpace; PVOID BaseAddress; ULONG RegionSize; diff --git a/reactos/ntoskrnl/mm/aspace.c b/reactos/ntoskrnl/mm/aspace.c index 72186c3ebc1..72d0b040b04 100644 --- a/reactos/ntoskrnl/mm/aspace.c +++ b/reactos/ntoskrnl/mm/aspace.c @@ -64,7 +64,7 @@ PMADDRESS_SPACE NTAPI MmGetCurrentAddressSpace(VOID) { - return(&PsGetCurrentProcess()->AddressSpace); + return(&((PROS_EPROCESS)PsGetCurrentProcess())->AddressSpace); } PMADDRESS_SPACE @@ -76,7 +76,7 @@ MmGetKernelAddressSpace(VOID) NTSTATUS NTAPI -MmInitializeAddressSpace(PEPROCESS Process, +MmInitializeAddressSpace(PROS_EPROCESS Process, PMADDRESS_SPACE AddressSpace) { AddressSpace->MemoryAreaRoot = NULL; diff --git a/reactos/ntoskrnl/mm/i386/page.c b/reactos/ntoskrnl/mm/i386/page.c index b41fe46b0c5..abac0734e37 100644 --- a/reactos/ntoskrnl/mm/i386/page.c +++ b/reactos/ntoskrnl/mm/i386/page.c @@ -203,7 +203,7 @@ ProtectToPTE(ULONG flProtect) NTSTATUS NTAPI -Mmi386ReleaseMmInfo(PEPROCESS Process) +Mmi386ReleaseMmInfo(PROS_EPROCESS Process) { PUSHORT LdtDescriptor; ULONG LdtBase; @@ -329,8 +329,8 @@ Mmi386ReleaseMmInfo(PEPROCESS Process) NTSTATUS STDCALL -MmCopyMmInfo(PEPROCESS Src, - PEPROCESS Dest, +MmCopyMmInfo(PROS_EPROCESS Src, + PROS_EPROCESS Dest, PPHYSICAL_ADDRESS DirectoryTableBase) { NTSTATUS Status; @@ -408,9 +408,9 @@ MmCopyMmInfo(PEPROCESS Src, VOID NTAPI -MmDeletePageTable(PEPROCESS Process, PVOID Address) +MmDeletePageTable(PROS_EPROCESS Process, PVOID Address) { - PEPROCESS CurrentProcess = PsGetCurrentProcess(); + PROS_EPROCESS CurrentProcess = (PROS_EPROCESS)PsGetCurrentProcess(); if (Process != NULL && Process != CurrentProcess) { @@ -441,9 +441,9 @@ MmDeletePageTable(PEPROCESS Process, PVOID Address) VOID NTAPI -MmFreePageTable(PEPROCESS Process, PVOID Address) +MmFreePageTable(PROS_EPROCESS Process, PVOID Address) { - PEPROCESS CurrentProcess = PsGetCurrentProcess(); + PROS_EPROCESS CurrentProcess = (PROS_EPROCESS)PsGetCurrentProcess(); ULONG i; PFN_TYPE Pfn; @@ -504,7 +504,7 @@ MmFreePageTable(PEPROCESS Process, PVOID Address) } static PULONGLONG -MmGetPageTableForProcessForPAE(PEPROCESS Process, PVOID Address, BOOLEAN Create) +MmGetPageTableForProcessForPAE(PROS_EPROCESS Process, PVOID Address, BOOLEAN Create) { NTSTATUS Status; PFN_TYPE Pfn; @@ -520,7 +520,7 @@ MmGetPageTableForProcessForPAE(PEPROCESS Process, PVOID Address, BOOLEAN Create) { KEBUGCHECK(0); } - if (Address < MmSystemRangeStart && Process && Process != PsGetCurrentProcess()) + if (Address < MmSystemRangeStart && Process && Process != (PROS_EPROCESS)PsGetCurrentProcess()) { PageDirTable = MmCreateHyperspaceMapping(PAE_PTE_TO_PFN(Process->Pcb.DirectoryTableBase.QuadPart)); if (PageDirTable == NULL) @@ -618,7 +618,7 @@ MmGetPageTableForProcessForPAE(PEPROCESS Process, PVOID Address, BOOLEAN Create) } static PULONG -MmGetPageTableForProcess(PEPROCESS Process, PVOID Address, BOOLEAN Create) +MmGetPageTableForProcess(PROS_EPROCESS Process, PVOID Address, BOOLEAN Create) { ULONG PdeOffset = ADDR_TO_PDE_OFFSET(Address); NTSTATUS Status; @@ -626,7 +626,7 @@ MmGetPageTableForProcess(PEPROCESS Process, PVOID Address, BOOLEAN Create) ULONG Entry; PULONG Pt, PageDir; - if (Address < MmSystemRangeStart && Process && Process != PsGetCurrentProcess()) + if (Address < MmSystemRangeStart && Process && Process != (PROS_EPROCESS)PsGetCurrentProcess()) { PageDir = MmCreateHyperspaceMapping(PTE_TO_PFN(Process->Pcb.DirectoryTableBase.QuadPart)); if (PageDir == NULL) @@ -736,7 +736,7 @@ BOOLEAN MmUnmapPageTable(PULONG Pt) return FALSE; } -static ULONGLONG MmGetPageEntryForProcessForPAE(PEPROCESS Process, PVOID Address) +static ULONGLONG MmGetPageEntryForProcessForPAE(PROS_EPROCESS Process, PVOID Address) { ULONGLONG Pte; PULONGLONG Pt; @@ -751,7 +751,7 @@ static ULONGLONG MmGetPageEntryForProcessForPAE(PEPROCESS Process, PVOID Address return 0; } -static ULONG MmGetPageEntryForProcess(PEPROCESS Process, PVOID Address) +static ULONG MmGetPageEntryForProcess(PROS_EPROCESS Process, PVOID Address) { ULONG Pte; PULONG Pt; @@ -768,7 +768,7 @@ static ULONG MmGetPageEntryForProcess(PEPROCESS Process, PVOID Address) PFN_TYPE NTAPI -MmGetPfnForProcess(PEPROCESS Process, +MmGetPfnForProcess(PROS_EPROCESS Process, PVOID Address) { @@ -796,7 +796,7 @@ MmGetPfnForProcess(PEPROCESS Process, VOID NTAPI -MmDisableVirtualMapping(PEPROCESS Process, PVOID Address, BOOLEAN* WasDirty, PPFN_TYPE Page) +MmDisableVirtualMapping(PROS_EPROCESS Process, PVOID Address, BOOLEAN* WasDirty, PPFN_TYPE Page) /* * FUNCTION: Delete a virtual mapping */ @@ -916,7 +916,7 @@ MmRawDeleteVirtualMapping(PVOID Address) VOID NTAPI -MmDeleteVirtualMapping(PEPROCESS Process, PVOID Address, BOOLEAN FreePage, +MmDeleteVirtualMapping(PROS_EPROCESS Process, PVOID Address, BOOLEAN FreePage, BOOLEAN* WasDirty, PPFN_TYPE Page) /* * FUNCTION: Delete a virtual mapping @@ -1060,7 +1060,7 @@ MmDeleteVirtualMapping(PEPROCESS Process, PVOID Address, BOOLEAN FreePage, VOID NTAPI -MmDeletePageFileMapping(PEPROCESS Process, PVOID Address, +MmDeletePageFileMapping(PROS_EPROCESS Process, PVOID Address, SWAPENTRY* SwapEntry) /* * FUNCTION: Delete a virtual mapping @@ -1199,7 +1199,7 @@ Mmi386MakeKernelPageTableGlobal(PVOID PAddress) BOOLEAN NTAPI -MmIsDirtyPage(PEPROCESS Process, PVOID Address) +MmIsDirtyPage(PROS_EPROCESS Process, PVOID Address) { if (Ke386Pae) { @@ -1213,7 +1213,7 @@ MmIsDirtyPage(PEPROCESS Process, PVOID Address) BOOLEAN NTAPI -MmIsAccessedAndResetAccessPage(PEPROCESS Process, PVOID Address) +MmIsAccessedAndResetAccessPage(PROS_EPROCESS Process, PVOID Address) { if (Address < MmSystemRangeStart && Process == NULL) { @@ -1280,7 +1280,7 @@ MmIsAccessedAndResetAccessPage(PEPROCESS Process, PVOID Address) VOID NTAPI -MmSetCleanPage(PEPROCESS Process, PVOID Address) +MmSetCleanPage(PROS_EPROCESS Process, PVOID Address) { if (Address < MmSystemRangeStart && Process == NULL) { @@ -1345,7 +1345,7 @@ MmSetCleanPage(PEPROCESS Process, PVOID Address) VOID NTAPI -MmSetDirtyPage(PEPROCESS Process, PVOID Address) +MmSetDirtyPage(PROS_EPROCESS Process, PVOID Address) { if (Address < MmSystemRangeStart && Process == NULL) { @@ -1406,7 +1406,7 @@ MmSetDirtyPage(PEPROCESS Process, PVOID Address) VOID NTAPI -MmEnableVirtualMapping(PEPROCESS Process, PVOID Address) +MmEnableVirtualMapping(PROS_EPROCESS Process, PVOID Address) { if (Ke386Pae) { @@ -1462,7 +1462,7 @@ MmEnableVirtualMapping(PEPROCESS Process, PVOID Address) BOOLEAN NTAPI -MmIsPagePresent(PEPROCESS Process, PVOID Address) +MmIsPagePresent(PROS_EPROCESS Process, PVOID Address) { if (Ke386Pae) { @@ -1476,7 +1476,7 @@ MmIsPagePresent(PEPROCESS Process, PVOID Address) BOOLEAN NTAPI -MmIsPageSwapEntry(PEPROCESS Process, PVOID Address) +MmIsPageSwapEntry(PROS_EPROCESS Process, PVOID Address) { if (Ke386Pae) { @@ -1622,7 +1622,7 @@ MmCreateVirtualMappingForKernel(PVOID Address, NTSTATUS NTAPI -MmCreatePageFileMapping(PEPROCESS Process, +MmCreatePageFileMapping(PROS_EPROCESS Process, PVOID Address, SWAPENTRY SwapEntry) { @@ -1710,7 +1710,7 @@ MmCreatePageFileMapping(PEPROCESS Process, NTSTATUS NTAPI -MmCreateVirtualMappingUnsafe(PEPROCESS Process, +MmCreateVirtualMappingUnsafe(PROS_EPROCESS Process, PVOID Address, ULONG flProtect, PPFN_TYPE Pages, @@ -1916,7 +1916,7 @@ MmCreateVirtualMappingUnsafe(PEPROCESS Process, NTSTATUS NTAPI -MmCreateVirtualMapping(PEPROCESS Process, +MmCreateVirtualMapping(PROS_EPROCESS Process, PVOID Address, ULONG flProtect, PPFN_TYPE Pages, @@ -1942,7 +1942,7 @@ MmCreateVirtualMapping(PEPROCESS Process, ULONG NTAPI -MmGetPageProtect(PEPROCESS Process, PVOID Address) +MmGetPageProtect(PROS_EPROCESS Process, PVOID Address) { ULONG Entry; ULONG Protect; @@ -1988,7 +1988,7 @@ MmGetPageProtect(PEPROCESS Process, PVOID Address) VOID NTAPI -MmSetPageProtect(PEPROCESS Process, PVOID Address, ULONG flProtect) +MmSetPageProtect(PROS_EPROCESS Process, PVOID Address, ULONG flProtect) { ULONG Attributes = 0; BOOLEAN NoExecute = FALSE; @@ -2273,7 +2273,7 @@ MmDeleteHyperspaceMapping(PVOID Address) VOID NTAPI -MmUpdatePageDir(PEPROCESS Process, PVOID Address, ULONG Size) +MmUpdatePageDir(PROS_EPROCESS Process, PVOID Address, ULONG Size) { ULONG StartOffset, EndOffset, Offset; @@ -2307,7 +2307,7 @@ MmUpdatePageDir(PEPROCESS Process, PVOID Address, ULONG Size) EndOffset = 511; } - if (Process != NULL && Process != PsGetCurrentProcess()) + if (Process != NULL && Process != (PROS_EPROCESS)PsGetCurrentProcess()) { PageDirTable = MmCreateHyperspaceMapping(PAE_PTE_TO_PFN(Process->Pcb.DirectoryTableBase.QuadPart)); Pde = (PULONGLONG)MmCreateHyperspaceMapping(PTE_TO_PFN(PageDirTable[i])); @@ -2334,7 +2334,7 @@ MmUpdatePageDir(PEPROCESS Process, PVOID Address, ULONG Size) StartOffset = ADDR_TO_PDE_OFFSET(Address); EndOffset = ADDR_TO_PDE_OFFSET((PVOID)((ULONG_PTR)Address + Size)); - if (Process != NULL && Process != PsGetCurrentProcess()) + if (Process != NULL && Process != (PROS_EPROCESS)PsGetCurrentProcess()) { Pde = MmCreateHyperspaceMapping(PTE_TO_PFN(Process->Pcb.DirectoryTableBase.u.LowPart)); } diff --git a/reactos/ntoskrnl/mm/marea.c b/reactos/ntoskrnl/mm/marea.c index e1880e1fab3..a031f649825 100644 --- a/reactos/ntoskrnl/mm/marea.c +++ b/reactos/ntoskrnl/mm/marea.c @@ -747,7 +747,7 @@ MmFreeMemoryArea( PMEMORY_AREA *ParentReplace; ULONG_PTR Address; PVOID EndAddress; - PEPROCESS CurrentProcess = PsGetCurrentProcess(); + PROS_EPROCESS CurrentProcess = (PROS_EPROCESS)PsGetCurrentProcess(); if (AddressSpace->Process != NULL && AddressSpace->Process != CurrentProcess) @@ -1025,7 +1025,7 @@ MmCreateMemoryArea(PMADDRESS_SPACE AddressSpace, VOID STDCALL -MmReleaseMemoryAreaIfDecommitted(PEPROCESS Process, +MmReleaseMemoryAreaIfDecommitted(PROS_EPROCESS Process, PMADDRESS_SPACE AddressSpace, PVOID BaseAddress) { diff --git a/reactos/ntoskrnl/mm/mdl.c b/reactos/ntoskrnl/mm/mdl.c index 558de995277..8d07720d56e 100644 --- a/reactos/ntoskrnl/mm/mdl.c +++ b/reactos/ntoskrnl/mm/mdl.c @@ -241,7 +241,7 @@ MmUnmapLockedPages(PVOID BaseAddress, PMDL Mdl) /* Unmap all the pages. */ for (i = 0; i < PageCount; i++) { - MmDeleteVirtualMapping(Mdl->Process, + MmDeleteVirtualMapping((PROS_EPROCESS)Mdl->Process, (char*)BaseAddress + (i * PAGE_SIZE), FALSE, NULL, @@ -273,14 +273,14 @@ MmUnmapLockedPages(PVOID BaseAddress, PMDL Mdl) ASSERT(Mdl->Process == PsGetCurrentProcess()); - Marea = MmLocateMemoryAreaByAddress( &Mdl->Process->AddressSpace, BaseAddress ); + Marea = MmLocateMemoryAreaByAddress( &((PROS_EPROCESS)Mdl->Process)->AddressSpace, BaseAddress ); if (Marea == NULL) { DPRINT1( "Couldn't open memory area when unmapping user-space pages!\n" ); KEBUGCHECK(0); } - MmFreeMemoryArea( &Mdl->Process->AddressSpace, Marea, NULL, NULL ); + MmFreeMemoryArea( &((PROS_EPROCESS)Mdl->Process)->AddressSpace, Marea, NULL, NULL ); Mdl->Process = NULL; } @@ -411,7 +411,7 @@ VOID STDCALL MmProbeAndLockPages (PMDL Mdl, /* FIXME: why isn't AccessMode used? */ Mode = UserMode; Mdl->Process = CurrentProcess; - AddressSpace = &CurrentProcess->AddressSpace; + AddressSpace = &((PROS_EPROCESS)CurrentProcess)->AddressSpace; } @@ -771,7 +771,7 @@ MmMapLockedPagesSpecifyCache ( IN PMDL Mdl, KIRQL oldIrql; ULONG PageCount; ULONG StartingOffset; - PEPROCESS CurrentProcess; + PROS_EPROCESS CurrentProcess; NTSTATUS Status; ULONG Protect; @@ -803,7 +803,7 @@ MmMapLockedPagesSpecifyCache ( IN PMDL Mdl, BoundaryAddressMultiple.QuadPart = 0; Base = BaseAddress; - CurrentProcess = PsGetCurrentProcess(); + CurrentProcess = (PROS_EPROCESS)PsGetCurrentProcess(); MmLockAddressSpace(&CurrentProcess->AddressSpace); Status = MmCreateMemoryArea(&CurrentProcess->AddressSpace, @@ -828,7 +828,7 @@ MmMapLockedPagesSpecifyCache ( IN PMDL Mdl, ASSERT(0); } - Mdl->Process = CurrentProcess; + Mdl->Process = (PEPROCESS)CurrentProcess; } else /* if (AccessMode == KernelMode) */ { diff --git a/reactos/ntoskrnl/mm/mm.c b/reactos/ntoskrnl/mm/mm.c index 686cd46b34d..95642b3e873 100644 --- a/reactos/ntoskrnl/mm/mm.c +++ b/reactos/ntoskrnl/mm/mm.c @@ -30,7 +30,7 @@ MM_STATS MmStats; NTSTATUS NTAPI -MmReleaseMmInfo(PEPROCESS Process) +MmReleaseMmInfo(PROS_EPROCESS Process) { PVOID Address; PMEMORY_AREA MemoryArea; @@ -47,7 +47,7 @@ MmReleaseMmInfo(PEPROCESS Process) case MEMORY_AREA_SECTION_VIEW: Address = (PVOID)MemoryArea->StartingAddress; MmUnlockAddressSpace(&Process->AddressSpace); - MmUnmapViewOfSection(Process, Address); + MmUnmapViewOfSection((PEPROCESS)Process, Address); MmLockAddressSpace(&Process->AddressSpace); break; @@ -114,7 +114,7 @@ BOOLEAN STDCALL MmIsAddressValid(PVOID VirtualAddress) } else { - AddressSpace = &PsGetCurrentProcess()->AddressSpace; + AddressSpace = &((PROS_EPROCESS)PsGetCurrentProcess())->AddressSpace; } MmLockAddressSpace(AddressSpace); @@ -171,7 +171,7 @@ MmAccessFault(KPROCESSOR_MODE Mode, } else { - AddressSpace = &PsGetCurrentProcess()->AddressSpace; + AddressSpace = &((PROS_EPROCESS)PsGetCurrentProcess())->AddressSpace; } if (!FromMdl) @@ -304,7 +304,7 @@ MmNotPresentFault(KPROCESSOR_MODE Mode, } else { - AddressSpace = &PsGetCurrentProcess()->AddressSpace; + AddressSpace = &((PROS_EPROCESS)PsGetCurrentProcess())->AddressSpace; } if (!FromMdl) @@ -357,7 +357,7 @@ MmNotPresentFault(KPROCESSOR_MODE Mode, case MEMORY_AREA_SHARED_DATA: Pfn = MmSharedDataPagePhysicalAddress.QuadPart >> PAGE_SHIFT; Status = - MmCreateVirtualMapping(PsGetCurrentProcess(), + MmCreateVirtualMapping((PROS_EPROCESS)PsGetCurrentProcess(), (PVOID)PAGE_ROUND_DOWN(Address), PAGE_READONLY, &Pfn, diff --git a/reactos/ntoskrnl/mm/process.c b/reactos/ntoskrnl/mm/process.c index c44d9a59f3f..e533c66e1b6 100644 --- a/reactos/ntoskrnl/mm/process.c +++ b/reactos/ntoskrnl/mm/process.c @@ -25,7 +25,7 @@ extern ULONG NtGlobalFlag; PVOID STDCALL -MiCreatePebOrTeb(PEPROCESS Process, +MiCreatePebOrTeb(PROS_EPROCESS Process, PVOID BaseAddress) { NTSTATUS Status; @@ -107,7 +107,7 @@ MmDeleteKernelStack(PVOID Stack, VOID STDCALL -MmDeleteTeb(PEPROCESS Process, +MmDeleteTeb(PROS_EPROCESS Process, PTEB Teb) { PMADDRESS_SPACE ProcessAddressSpace = &Process->AddressSpace; @@ -220,7 +220,7 @@ MmGrowKernelStack(PVOID StackPointer) NTSTATUS STDCALL -MmCreatePeb(PEPROCESS Process) +MmCreatePeb(PROS_EPROCESS Process) { PPEB Peb = NULL; LARGE_INTEGER SectionOffset; @@ -241,7 +241,7 @@ MmCreatePeb(PEPROCESS Process) /* Map NLS Tables */ DPRINT("Mapping NLS\n"); Status = MmMapViewOfSection(NlsSectionObject, - Process, + (PEPROCESS)Process, &TableBase, 0, 0, @@ -357,7 +357,7 @@ MmCreatePeb(PEPROCESS Process) PTEB STDCALL -MmCreateTeb(PEPROCESS Process, +MmCreateTeb(PROS_EPROCESS Process, PCLIENT_ID ClientId, PINITIAL_TEB InitialTeb) { @@ -366,7 +366,7 @@ MmCreateTeb(PEPROCESS Process, /* Attach to the process */ DPRINT("MmCreateTeb\n"); - if (Process != PsGetCurrentProcess()) + if (Process != (PROS_EPROCESS)PsGetCurrentProcess()) { /* Attach to Target */ KeAttachProcess(&Process->Pcb); @@ -407,8 +407,8 @@ MmCreateTeb(PEPROCESS Process, NTSTATUS STDCALL -MmCreateProcessAddressSpace(IN PEPROCESS Process, - IN PSECTION_OBJECT Section OPTIONAL) +MmCreateProcessAddressSpace(IN PROS_EPROCESS Process, + IN PROS_SECTION_OBJECT Section OPTIONAL) { NTSTATUS Status; PMADDRESS_SPACE ProcessAddressSpace = &Process->AddressSpace; @@ -491,7 +491,7 @@ MmCreateProcessAddressSpace(IN PEPROCESS Process, DPRINT("Mapping process image. Section: %p, Process: %p, ImageBase: %p\n", Section, Process, &ImageBase); Status = MmMapViewOfSection(Section, - Process, + (PEPROCESS)Process, (PVOID*)&ImageBase, 0, 0, diff --git a/reactos/ntoskrnl/mm/rmap.c b/reactos/ntoskrnl/mm/rmap.c index 8837932e284..6c89ee820c8 100644 --- a/reactos/ntoskrnl/mm/rmap.c +++ b/reactos/ntoskrnl/mm/rmap.c @@ -62,7 +62,7 @@ MmWritePagePhysicalAddress(PFN_TYPE Page) PMADDRESS_SPACE AddressSpace; ULONG Type; PVOID Address; - PEPROCESS Process; + PROS_EPROCESS Process; PMM_PAGEOP PageOp; ULONG Offset; NTSTATUS Status = STATUS_SUCCESS; @@ -78,7 +78,7 @@ MmWritePagePhysicalAddress(PFN_TYPE Page) ExReleaseFastMutex(&RmapListLock); return(STATUS_UNSUCCESSFUL); } - Process = entry->Process; + Process = (PROS_EPROCESS)entry->Process; Address = entry->Address; if ((((ULONG_PTR)Address) & 0xFFF) != 0) { @@ -196,7 +196,7 @@ MmPageOutPhysicalAddress(PFN_TYPE Page) PMADDRESS_SPACE AddressSpace; ULONG Type; PVOID Address; - PEPROCESS Process; + PROS_EPROCESS Process; PMM_PAGEOP PageOp; ULONG Offset; NTSTATUS Status = STATUS_SUCCESS; @@ -208,7 +208,7 @@ MmPageOutPhysicalAddress(PFN_TYPE Page) ExReleaseFastMutex(&RmapListLock); return(STATUS_UNSUCCESSFUL); } - Process = entry->Process; + Process = (PROS_EPROCESS)entry->Process; Address = entry->Address; if ((((ULONG_PTR)Address) & 0xFFF) != 0) { @@ -326,7 +326,7 @@ MmSetCleanAllRmaps(PFN_TYPE Page) } while (current_entry != NULL) { - MmSetCleanPage(current_entry->Process, current_entry->Address); + MmSetCleanPage((PROS_EPROCESS)current_entry->Process, current_entry->Address); current_entry = current_entry->Next; } ExReleaseFastMutex(&RmapListLock); @@ -347,7 +347,7 @@ MmSetDirtyAllRmaps(PFN_TYPE Page) } while (current_entry != NULL) { - MmSetDirtyPage(current_entry->Process, current_entry->Address); + MmSetDirtyPage((PROS_EPROCESS)current_entry->Process, current_entry->Address); current_entry = current_entry->Next; } ExReleaseFastMutex(&RmapListLock); @@ -368,7 +368,7 @@ MmIsDirtyPageRmap(PFN_TYPE Page) } while (current_entry != NULL) { - if (MmIsDirtyPage(current_entry->Process, current_entry->Address)) + if (MmIsDirtyPage((PROS_EPROCESS)current_entry->Process, current_entry->Address)) { ExReleaseFastMutex(&RmapListLock); return(TRUE); @@ -381,7 +381,7 @@ MmIsDirtyPageRmap(PFN_TYPE Page) VOID NTAPI -MmInsertRmap(PFN_TYPE Page, PEPROCESS Process, +MmInsertRmap(PFN_TYPE Page, PROS_EPROCESS Process, PVOID Address) { PMM_RMAP_ENTRY current_entry; @@ -396,7 +396,7 @@ MmInsertRmap(PFN_TYPE Page, PEPROCESS Process, KEBUGCHECK(0); } new_entry->Address = Address; - new_entry->Process = Process; + new_entry->Process = (PEPROCESS)Process; #ifdef DBG new_entry->Caller = __builtin_return_address(0); #endif @@ -433,7 +433,7 @@ MmInsertRmap(PFN_TYPE Page, PEPROCESS Process, ExReleaseFastMutex(&RmapListLock); if (Process == NULL) { - Process = PsInitialSystemProcess; + Process = (PROS_EPROCESS)PsInitialSystemProcess; } if (Process) { @@ -448,7 +448,7 @@ MmInsertRmap(PFN_TYPE Page, PEPROCESS Process, VOID NTAPI MmDeleteAllRmaps(PFN_TYPE Page, PVOID Context, - VOID (*DeleteMapping)(PVOID Context, PEPROCESS Process, + VOID (*DeleteMapping)(PVOID Context, PROS_EPROCESS Process, PVOID Address)) { PMM_RMAP_ENTRY current_entry; @@ -470,7 +470,7 @@ MmDeleteAllRmaps(PFN_TYPE Page, PVOID Context, current_entry = current_entry->Next; if (DeleteMapping) { - DeleteMapping(Context, previous_entry->Process, + DeleteMapping(Context, (PROS_EPROCESS)previous_entry->Process, previous_entry->Address); } Process = previous_entry->Process; @@ -488,7 +488,7 @@ MmDeleteAllRmaps(PFN_TYPE Page, PVOID Context, VOID NTAPI -MmDeleteRmap(PFN_TYPE Page, PEPROCESS Process, +MmDeleteRmap(PFN_TYPE Page, PROS_EPROCESS Process, PVOID Address) { PMM_RMAP_ENTRY current_entry, previous_entry; @@ -498,7 +498,7 @@ MmDeleteRmap(PFN_TYPE Page, PEPROCESS Process, current_entry = MmGetRmapListHeadPage(Page); while (current_entry != NULL) { - if (current_entry->Process == Process && + if (current_entry->Process == (PEPROCESS)Process && current_entry->Address == Address) { if (previous_entry == NULL) @@ -513,7 +513,7 @@ MmDeleteRmap(PFN_TYPE Page, PEPROCESS Process, ExFreeToNPagedLookasideList(&RmapLookasideList, current_entry); if (Process == NULL) { - Process = PsInitialSystemProcess; + Process = (PROS_EPROCESS)PsInitialSystemProcess; } if (Process) { diff --git a/reactos/ntoskrnl/mm/section.c b/reactos/ntoskrnl/mm/section.c index 64994099ffa..6786566a3a0 100644 --- a/reactos/ntoskrnl/mm/section.c +++ b/reactos/ntoskrnl/mm/section.c @@ -60,7 +60,7 @@ typedef struct { - PSECTION_OBJECT Section; + PROS_SECTION_OBJECT Section; PMM_SECTION_SEGMENT Segment; ULONG Offset; BOOLEAN WasDirty; @@ -316,7 +316,7 @@ MmSharePageEntrySectionSegment(PMM_SECTION_SEGMENT Segment, BOOLEAN NTAPI -MmUnsharePageEntrySectionSegment(PSECTION_OBJECT Section, +MmUnsharePageEntrySectionSegment(PROS_SECTION_OBJECT Section, PMM_SECTION_SEGMENT Segment, ULONG Offset, BOOLEAN Dirty, @@ -646,7 +646,7 @@ MmNotPresentFaultSectionView(PMADDRESS_SPACE AddressSpace, PFN_TYPE Page; NTSTATUS Status; PVOID PAddress; - PSECTION_OBJECT Section; + PROS_SECTION_OBJECT Section; PMM_SECTION_SEGMENT Segment; ULONG Entry; ULONG Entry1; @@ -1162,7 +1162,7 @@ MmAccessFaultSectionView(PMADDRESS_SPACE AddressSpace, BOOLEAN Locked) { PMM_SECTION_SEGMENT Segment; - PSECTION_OBJECT Section; + PROS_SECTION_OBJECT Section; PFN_TYPE OldPage; PFN_TYPE NewPage; NTSTATUS Status; @@ -1329,7 +1329,7 @@ MmAccessFaultSectionView(PMADDRESS_SPACE AddressSpace, } VOID -MmPageOutDeleteMapping(PVOID Context, PEPROCESS Process, PVOID Address) +MmPageOutDeleteMapping(PVOID Context, PROS_EPROCESS Process, PVOID Address) { MM_SECTION_PAGEOUT_CONTEXT* PageOutContext; BOOLEAN WasDirty; @@ -1353,7 +1353,7 @@ MmPageOutDeleteMapping(PVOID Context, PEPROCESS Process, PVOID Address) if (!PageOutContext->Private) { MmLockSectionSegment(PageOutContext->Segment); - MmUnsharePageEntrySectionSegment(PageOutContext->Section, + MmUnsharePageEntrySectionSegment((PROS_SECTION_OBJECT)PageOutContext->Section, PageOutContext->Segment, PageOutContext->Offset, PageOutContext->WasDirty, @@ -1734,7 +1734,7 @@ MmWritePageSectionView(PMADDRESS_SPACE AddressSpace, PMM_PAGEOP PageOp) { ULONG Offset; - PSECTION_OBJECT Section; + PROS_SECTION_OBJECT Section; PMM_SECTION_SEGMENT Segment; PFN_TYPE Page; SWAPENTRY SwapEntry; @@ -1980,7 +1980,7 @@ MmQuerySectionView(PMEMORY_AREA MemoryArea, { PMM_REGION Region; PVOID RegionBaseAddress; - PSECTION_OBJECT Section; + PROS_SECTION_OBJECT Section; PMM_SECTION_SEGMENT Segment; Region = MmFindRegion((PVOID)MemoryArea->StartingAddress, @@ -2054,7 +2054,7 @@ MmpFreePageFileSegment(PMM_SECTION_SEGMENT Segment) VOID STDCALL MmpDeleteSection(PVOID ObjectBody) { - PSECTION_OBJECT Section = (PSECTION_OBJECT)ObjectBody; + PROS_SECTION_OBJECT Section = (PROS_SECTION_OBJECT)ObjectBody; DPRINT("MmpDeleteSection(ObjectBody %x)\n", ObjectBody); if (Section->AllocationAttributes & SEC_IMAGE) @@ -2123,11 +2123,14 @@ MmpDeleteSection(PVOID ObjectBody) } VOID STDCALL -MmpCloseSection(PVOID ObjectBody, - ULONG HandleCount) +MmpCloseSection(IN PEPROCESS Process OPTIONAL, + IN PVOID Object, + IN ACCESS_MASK GrantedAccess, + IN ULONG ProcessHandleCount, + IN ULONG SystemHandleCount) { DPRINT("MmpCloseSection(OB %x, HC %d) RC %d\n", - ObjectBody, HandleCount, ObGetObjectPointerCount(ObjectBody)); + Object, ProcessHandleCount, ObGetObjectPointerCount(Object)); } NTSTATUS @@ -2135,7 +2138,7 @@ INIT_FUNCTION NTAPI MmCreatePhysicalMemorySection(VOID) { - PSECTION_OBJECT PhysSection; + PROS_SECTION_OBJECT PhysSection; NTSTATUS Status; OBJECT_ATTRIBUTES Obj; UNICODE_STRING Name = RTL_CONSTANT_STRING(L"\\Device\\PhysicalMemory"); @@ -2193,7 +2196,7 @@ MmInitSectionImplementation(VOID) RtlZeroMemory(&ObjectTypeInitializer, sizeof(ObjectTypeInitializer)); RtlInitUnicodeString(&Name, L"Section"); ObjectTypeInitializer.Length = sizeof(ObjectTypeInitializer); - ObjectTypeInitializer.DefaultPagedPoolCharge = sizeof(SECTION_OBJECT); + ObjectTypeInitializer.DefaultPagedPoolCharge = sizeof(ROS_SECTION_OBJECT); ObjectTypeInitializer.PoolType = PagedPool; ObjectTypeInitializer.UseDefaultObject = TRUE; ObjectTypeInitializer.GenericMapping = MmpSectionMapping; @@ -2206,7 +2209,7 @@ MmInitSectionImplementation(VOID) NTSTATUS NTAPI -MmCreatePageFileSection(PSECTION_OBJECT *SectionObject, +MmCreatePageFileSection(PROS_SECTION_OBJECT *SectionObject, ACCESS_MASK DesiredAccess, POBJECT_ATTRIBUTES ObjectAttributes, PLARGE_INTEGER UMaximumSize, @@ -2217,7 +2220,7 @@ MmCreatePageFileSection(PSECTION_OBJECT *SectionObject, */ { LARGE_INTEGER MaximumSize; - PSECTION_OBJECT Section; + PROS_SECTION_OBJECT Section; PMM_SECTION_SEGMENT Segment; NTSTATUS Status; @@ -2235,7 +2238,7 @@ MmCreatePageFileSection(PSECTION_OBJECT *SectionObject, ObjectAttributes, ExGetPreviousMode(), NULL, - sizeof(SECTION_OBJECT), + sizeof(ROS_SECTION_OBJECT), 0, 0, (PVOID*)(PVOID)&Section); @@ -2278,7 +2281,7 @@ MmCreatePageFileSection(PSECTION_OBJECT *SectionObject, NTSTATUS NTAPI -MmCreateDataFileSection(PSECTION_OBJECT *SectionObject, +MmCreateDataFileSection(PROS_SECTION_OBJECT *SectionObject, ACCESS_MASK DesiredAccess, POBJECT_ATTRIBUTES ObjectAttributes, PLARGE_INTEGER UMaximumSize, @@ -2289,7 +2292,7 @@ MmCreateDataFileSection(PSECTION_OBJECT *SectionObject, * Create a section backed by a data file */ { - PSECTION_OBJECT Section; + PROS_SECTION_OBJECT Section; NTSTATUS Status; LARGE_INTEGER MaximumSize; PFILE_OBJECT FileObject; @@ -2308,7 +2311,7 @@ MmCreateDataFileSection(PSECTION_OBJECT *SectionObject, ObjectAttributes, ExGetPreviousMode(), NULL, - sizeof(SECTION_OBJECT), + sizeof(ROS_SECTION_OBJECT), 0, 0, (PVOID*)(PVOID)&Section); @@ -3170,7 +3173,7 @@ ExeFmtpCreateImageSection(HANDLE FileHandle, } NTSTATUS -MmCreateImageSection(PSECTION_OBJECT *SectionObject, +MmCreateImageSection(PROS_SECTION_OBJECT *SectionObject, ACCESS_MASK DesiredAccess, POBJECT_ATTRIBUTES ObjectAttributes, PLARGE_INTEGER UMaximumSize, @@ -3178,7 +3181,7 @@ MmCreateImageSection(PSECTION_OBJECT *SectionObject, ULONG AllocationAttributes, HANDLE FileHandle) { - PSECTION_OBJECT Section; + PROS_SECTION_OBJECT Section; NTSTATUS Status; PFILE_OBJECT FileObject; PMM_SECTION_SEGMENT SectionSegments; @@ -3230,7 +3233,7 @@ MmCreateImageSection(PSECTION_OBJECT *SectionObject, ObjectAttributes, ExGetPreviousMode(), NULL, - sizeof(SECTION_OBJECT), + sizeof(ROS_SECTION_OBJECT), 0, 0, (PVOID*)(PVOID)&Section); @@ -3484,7 +3487,7 @@ NtOpenSection(PHANDLE SectionHandle, NTSTATUS STATIC MmMapViewOfSegment(PMADDRESS_SPACE AddressSpace, - PSECTION_OBJECT Section, + PROS_SECTION_OBJECT Section, PMM_SECTION_SEGMENT Segment, PVOID* BaseAddress, SIZE_T ViewSize, @@ -3591,8 +3594,8 @@ NtMapViewOfSection(IN HANDLE SectionHandle, PVOID SafeBaseAddress; LARGE_INTEGER SafeSectionOffset; SIZE_T SafeViewSize; - PSECTION_OBJECT Section; - PEPROCESS Process; + PROS_SECTION_OBJECT Section; + PROS_EPROCESS Process; KPROCESSOR_MODE PreviousMode; PMADDRESS_SPACE AddressSpace; NTSTATUS Status = STATUS_SUCCESS; @@ -3689,7 +3692,7 @@ NtMapViewOfSection(IN HANDLE SectionHandle, } Status = MmMapViewOfSection(Section, - Process, + (PEPROCESS)Process, (BaseAddress != NULL ? &SafeBaseAddress : NULL), ZeroBits, CommitSize, @@ -3741,7 +3744,7 @@ MmFreeSectionPage(PVOID Context, MEMORY_AREA* MemoryArea, PVOID Address, SWAPENTRY SavedSwapEntry; PMM_PAGEOP PageOp; NTSTATUS Status; - PSECTION_OBJECT Section; + PROS_SECTION_OBJECT Section; PMM_SECTION_SEGMENT Segment; PMADDRESS_SPACE AddressSpace; @@ -3843,7 +3846,7 @@ MmUnmapViewOfSegment(PMADDRESS_SPACE AddressSpace, { NTSTATUS Status; PMEMORY_AREA MemoryArea; - PSECTION_OBJECT Section; + PROS_SECTION_OBJECT Section; PMM_SECTION_SEGMENT Segment; PLIST_ENTRY CurrentEntry; PMM_REGION CurrentRegion; @@ -3899,7 +3902,7 @@ MmUnmapViewOfSection(PEPROCESS Process, NTSTATUS Status; PMEMORY_AREA MemoryArea; PMADDRESS_SPACE AddressSpace; - PSECTION_OBJECT Section; + PROS_SECTION_OBJECT Section; PMM_PAGEOP PageOp; ULONG_PTR Offset; @@ -3908,7 +3911,7 @@ MmUnmapViewOfSection(PEPROCESS Process, ASSERT(Process); - AddressSpace = &Process->AddressSpace; + AddressSpace = &((PROS_EPROCESS)Process)->AddressSpace; MmLockAddressSpace(AddressSpace); MemoryArea = MmLocateMemoryAreaByAddress(AddressSpace, @@ -4088,7 +4091,7 @@ NtQuerySection(IN HANDLE SectionHandle, IN ULONG SectionInformationLength, OUT PULONG ResultLength OPTIONAL) { - PSECTION_OBJECT Section; + PROS_SECTION_OBJECT Section; KPROCESSOR_MODE PreviousMode; NTSTATUS Status = STATUS_SUCCESS; @@ -4216,7 +4219,7 @@ NtExtendSection(IN HANDLE SectionHandle, IN PLARGE_INTEGER NewMaximumSize) { LARGE_INTEGER SafeNewMaximumSize; - PSECTION_OBJECT Section; + PROS_SECTION_OBJECT Section; KPROCESSOR_MODE PreviousMode; NTSTATUS Status = STATUS_SUCCESS; @@ -4408,7 +4411,7 @@ MmMapViewOfSection(IN PVOID SectionObject, IN ULONG AllocationType, IN ULONG Protect) { - PSECTION_OBJECT Section; + PROS_SECTION_OBJECT Section; PMADDRESS_SPACE AddressSpace; ULONG ViewOffset; NTSTATUS Status = STATUS_SUCCESS; @@ -4428,8 +4431,8 @@ MmMapViewOfSection(IN PVOID SectionObject, } - Section = (PSECTION_OBJECT)SectionObject; - AddressSpace = &Process->AddressSpace; + Section = (PROS_SECTION_OBJECT)SectionObject; + AddressSpace = &((PROS_EPROCESS)Process)->AddressSpace; AllocationType |= (Section->AllocationAttributes & SEC_NO_CHANGE); @@ -4655,13 +4658,13 @@ MmMapViewInSystemSpace (IN PVOID SectionObject, OUT PVOID * MappedBase, IN OUT PULONG ViewSize) { - PSECTION_OBJECT Section; + PROS_SECTION_OBJECT Section; PMADDRESS_SPACE AddressSpace; NTSTATUS Status; DPRINT("MmMapViewInSystemSpace() called\n"); - Section = (PSECTION_OBJECT)SectionObject; + Section = (PROS_SECTION_OBJECT)SectionObject; AddressSpace = MmGetKernelAddressSpace(); MmLockAddressSpace(AddressSpace); @@ -4823,7 +4826,7 @@ MmCreateSection (OUT PVOID * Section, IN PFILE_OBJECT File OPTIONAL) { ULONG Protection; - PSECTION_OBJECT *SectionObject = (PSECTION_OBJECT *)Section; + PROS_SECTION_OBJECT *SectionObject = (PROS_SECTION_OBJECT *)Section; /* * Check the protection diff --git a/reactos/ntoskrnl/mm/virtual.c b/reactos/ntoskrnl/mm/virtual.c index 420c09ce035..ab413ab8202 100644 --- a/reactos/ntoskrnl/mm/virtual.c +++ b/reactos/ntoskrnl/mm/virtual.c @@ -119,7 +119,7 @@ MiQueryVirtualMemory (IN HANDLE ProcessHandle, OUT PULONG ResultLength) { NTSTATUS Status; - PEPROCESS Process; + PROS_EPROCESS Process; MEMORY_AREA* MemoryArea; PMADDRESS_SPACE AddressSpace; @@ -393,7 +393,7 @@ MiProtectVirtualMemory(IN PEPROCESS Process, PAGE_ROUND_DOWN(*BaseAddress); *BaseAddress = (PVOID)PAGE_ROUND_DOWN(*BaseAddress); - AddressSpace = &Process->AddressSpace; + AddressSpace = &((PROS_EPROCESS)Process)->AddressSpace; MmLockAddressSpace(AddressSpace); MemoryArea = MmLocateMemoryAreaByAddress(AddressSpace, *BaseAddress); diff --git a/reactos/ntoskrnl/ntoskrnl.def b/reactos/ntoskrnl/ntoskrnl.def index c8745267cd7..962554c9149 100644 --- a/reactos/ntoskrnl/ntoskrnl.def +++ b/reactos/ntoskrnl/ntoskrnl.def @@ -1116,8 +1116,8 @@ RtlIpv4StringToAddressExA@16 RtlIpv4StringToAddressExW@16 RtlIpv4StringToAddressW@16 RtlIpv6AddressToStringA@8 -RtlIpv6AddressToStringExA@16 -RtlIpv6AddressToStringExW@16 +RtlIpv6AddressToStringExA@20 +RtlIpv6AddressToStringExW@20 RtlIpv6AddressToStringW@8 RtlIpv6StringToAddressA@12 RtlIpv6StringToAddressExA@16 diff --git a/reactos/ntoskrnl/ntoskrnl.rbuild b/reactos/ntoskrnl/ntoskrnl.rbuild index 4646fb2e262..881d76617e3 100644 --- a/reactos/ntoskrnl/ntoskrnl.rbuild +++ b/reactos/ntoskrnl/ntoskrnl.rbuild @@ -45,7 +45,6 @@ vdm.c - apc.c bug.c clock.c @@ -68,26 +67,21 @@ timer.c usercall.c wait.c - - cacheman.c copy.c fs.c mdl.c pin.c view.c - - import.c ntfunc.c regfile.c registry.c regobj.c - @@ -125,7 +119,6 @@ fastinterlck_asm.S - atom.c callback.c dbgctrl.c @@ -150,11 +143,9 @@ win32k.c work.c zone.c - zw.S - context.c fastio.c filelock.c @@ -166,13 +157,11 @@ tunnel.c unc.c util.c - inbv.c - adapter.c arcname.c bootlog.c @@ -205,11 +194,9 @@ timer.c vpb.c wmi.c - file.c - bochs.c gdbstub.c @@ -217,16 +204,12 @@ kdinit.c kdio.c kdmain.c - - loader.c rtl.c - - close.c complete.c connect.c @@ -238,7 +221,6 @@ receive.c reply.c send.c - @@ -248,7 +230,6 @@ pfault.c - anonmem.c aspace.c balance.c @@ -280,12 +261,10 @@ verifier.c virtual.c wset.c - elf32.c elf64.c - dirobj.c handle.c namespc.c @@ -295,13 +274,11 @@ security.c symlink.c wait.c - power.c - debug.c idle.c job.c @@ -316,7 +293,6 @@ suspend.c thread.c win32.c - @@ -325,16 +301,13 @@ seh.s - libsupp.c misc.c nls.c regio.c strtok.c - - access.c acl.c audit.c @@ -345,7 +318,6 @@ semgr.c sid.c token.c - ntoskrnl.rc -nostartfiles diff --git a/reactos/ntoskrnl/ob/dirobj.c b/reactos/ntoskrnl/ob/dirobj.c index e2558f05614..90cef4d9c54 100644 --- a/reactos/ntoskrnl/ob/dirobj.c +++ b/reactos/ntoskrnl/ob/dirobj.c @@ -223,7 +223,7 @@ NtQueryDirectoryObject (IN HANDLE DirectoryHandle, BufferLength); if(TemporaryBuffer != NULL) { - POBJECT_HEADER EntryHeader; + PROS_OBJECT_HEADER EntryHeader; PLIST_ENTRY ListEntry; KIRQL OldLevel; ULONG RequiredSize = sizeof(OBJECT_DIRECTORY_INFORMATION); @@ -244,7 +244,7 @@ NtQueryDirectoryObject (IN HANDLE DirectoryHandle, PUNICODE_STRING Name, Type; ULONG EntrySize; - EntryHeader = CONTAINING_RECORD(ListEntry, OBJECT_HEADER, Entry); + EntryHeader = CONTAINING_RECORD(ListEntry, ROS_OBJECT_HEADER, Entry); /* calculate the size of the required buffer space for this entry */ Name = (HEADER_TO_OBJECT_NAME(EntryHeader)->Name.Length != 0 ? &HEADER_TO_OBJECT_NAME(EntryHeader)->Name : NULL); diff --git a/reactos/ntoskrnl/ob/handle.c b/reactos/ntoskrnl/ob/handle.c index 55146834057..483d6f7ec79 100644 --- a/reactos/ntoskrnl/ob/handle.c +++ b/reactos/ntoskrnl/ob/handle.c @@ -52,7 +52,7 @@ ExpDesktopCreate(PVOID ObjectBody, static VOID ObpDecrementHandleCount(PVOID ObjectBody) { - POBJECT_HEADER ObjectHeader = BODY_TO_HEADER(ObjectBody); + PROS_OBJECT_HEADER ObjectHeader = BODY_TO_HEADER(ObjectBody); LONG NewHandleCount = InterlockedDecrement(&ObjectHeader->HandleCount); DPRINT("Header: %x\n", ObjectHeader); DPRINT("NewHandleCount: %x\n", NewHandleCount); @@ -63,7 +63,7 @@ ObpDecrementHandleCount(PVOID ObjectBody) { /* the handle count should be decremented but we pass the previous value to the callback */ - ObjectHeader->Type->TypeInfo.CloseProcedure(ObjectBody, NewHandleCount + 1); + ObjectHeader->Type->TypeInfo.CloseProcedure(NULL, ObjectBody, 0, NewHandleCount + 1, NewHandleCount + 1); } if(NewHandleCount == 0) @@ -75,7 +75,7 @@ ObpDecrementHandleCount(PVOID ObjectBody) /* delete the object from the namespace when the last handle got closed. Only do this if it's actually been inserted into the namespace and if it's not a permanent object. */ - ObpRemoveEntryDirectory(ObjectHeader); + ObpRemoveEntryDirectory((PROS_OBJECT_HEADER)ObjectHeader); } /* remove the keep-alive reference */ @@ -216,7 +216,7 @@ ObpDeleteHandle(HANDLE Handle) { PHANDLE_TABLE_ENTRY HandleEntry; PVOID Body; - POBJECT_HEADER ObjectHeader; + PROS_OBJECT_HEADER ObjectHeader; PHANDLE_TABLE ObjectTable; PAGED_CODE(); @@ -274,7 +274,7 @@ ObDuplicateObject(PEPROCESS SourceProcess, HANDLE_TABLE_ENTRY NewHandleEntry; BOOLEAN AttachedToProcess = FALSE; PVOID ObjectBody; - POBJECT_HEADER ObjectHeader; + PROS_OBJECT_HEADER ObjectHeader; ULONG NewHandleCount; HANDLE NewTargetHandle; PEPROCESS CurrentProcess; @@ -613,7 +613,7 @@ SweepHandleCallback(PHANDLE_TABLE HandleTable, ULONG GrantedAccess, PVOID Context) { - POBJECT_HEADER ObjectHeader; + PROS_OBJECT_HEADER ObjectHeader; PVOID ObjectBody; PAGED_CODE(); @@ -629,7 +629,7 @@ DuplicateHandleCallback(PHANDLE_TABLE HandleTable, PHANDLE_TABLE_ENTRY HandleTableEntry, PVOID Context) { - POBJECT_HEADER ObjectHeader; + PROS_OBJECT_HEADER ObjectHeader; BOOLEAN Ret = FALSE; PAGED_CODE(); @@ -709,7 +709,7 @@ ObpCreateHandle(PVOID ObjectBody, { HANDLE_TABLE_ENTRY NewEntry; PEPROCESS Process, CurrentProcess; - POBJECT_HEADER ObjectHeader; + PROS_OBJECT_HEADER ObjectHeader; HANDLE Handle; KAPC_STATE ApcState; BOOLEAN AttachedToProcess = FALSE; @@ -877,7 +877,7 @@ ObReferenceObjectByHandle(HANDLE Handle, POBJECT_HANDLE_INFORMATION HandleInformation) { PHANDLE_TABLE_ENTRY HandleEntry; - POBJECT_HEADER ObjectHeader; + PROS_OBJECT_HEADER ObjectHeader; PVOID ObjectBody; ACCESS_MASK GrantedAccess; ULONG Attributes; @@ -1141,10 +1141,10 @@ ObInsertObject(IN PVOID Object, OUT PHANDLE Handle) { POBJECT_CREATE_INFORMATION ObjectCreateInfo; - POBJECT_HEADER Header; + PROS_OBJECT_HEADER Header; POBJECT_HEADER_NAME_INFO ObjectNameInfo; PVOID FoundObject = NULL; - POBJECT_HEADER FoundHeader = NULL; + PROS_OBJECT_HEADER FoundHeader = NULL; NTSTATUS Status = STATUS_SUCCESS; UNICODE_STRING RemainingPath; BOOLEAN ObjectAttached = FALSE; @@ -1203,7 +1203,7 @@ ObInsertObject(IN PVOID Object, PWSTR BufferPos = RemainingPath.Buffer; ULONG Delta = 0; - ObpAddEntryDirectory(FoundObject, Header, NULL); + ObpAddEntryDirectory(FoundObject, (PROS_OBJECT_HEADER)Header, NULL); ObjectAttached = TRUE; ObjectNameInfo = HEADER_TO_OBJECT_NAME(Header); @@ -1251,8 +1251,8 @@ ObInsertObject(IN PVOID Object, { DPRINT("Calling %x\n", Header->Type->TypeInfo.OpenProcedure); Status = Header->Type->TypeInfo.OpenProcedure(ObCreateHandle, - &Header->Body, NULL, + &Header->Body, 0, 0); } @@ -1262,7 +1262,7 @@ ObInsertObject(IN PVOID Object, DPRINT("Create Failed\n"); if (ObjectAttached == TRUE) { - ObpRemoveEntryDirectory(Header); + ObpRemoveEntryDirectory((PROS_OBJECT_HEADER)Header); } if (FoundObject) { diff --git a/reactos/ntoskrnl/ob/namespc.c b/reactos/ntoskrnl/ob/namespc.c index 56f85340262..dd6f62936b6 100644 --- a/reactos/ntoskrnl/ob/namespc.c +++ b/reactos/ntoskrnl/ob/namespc.c @@ -50,7 +50,7 @@ ObpAllocateObject(POBJECT_CREATE_INFORMATION ObjectCreateInfo, PUNICODE_STRING ObjectName, POBJECT_TYPE ObjectType, ULONG ObjectSize, - POBJECT_HEADER *ObjectHeader); + PROS_OBJECT_HEADER *ObjectHeader); /* FUNCTIONS **************************************************************/ @@ -247,7 +247,7 @@ ObQueryDeviceMapInformation(PEPROCESS Process, VOID NTAPI ObpAddEntryDirectory(PDIRECTORY_OBJECT Parent, - POBJECT_HEADER Header, + PROS_OBJECT_HEADER Header, PWSTR Name) /* * FUNCTION: Add an entry to a namespace directory @@ -270,7 +270,7 @@ ObpAddEntryDirectory(PDIRECTORY_OBJECT Parent, VOID NTAPI -ObpRemoveEntryDirectory(POBJECT_HEADER Header) +ObpRemoveEntryDirectory(PROS_OBJECT_HEADER Header) /* * FUNCTION: Remove an entry from a namespace directory * ARGUMENTS: @@ -293,10 +293,10 @@ ObpRemoveEntryDirectory(POBJECT_HEADER Header) NTSTATUS STDCALL ObpCreateDirectory(OB_OPEN_REASON Reason, - PVOID ObjectBody, PEPROCESS Process, - ULONG HandleCount, - ACCESS_MASK GrantedAccess) + PVOID ObjectBody, + ACCESS_MASK GrantedAccess, + ULONG HandleCount) { PDIRECTORY_OBJECT Directory = ObjectBody; @@ -315,7 +315,7 @@ ObpFindEntryDirectory(PDIRECTORY_OBJECT DirectoryObject, ULONG Attributes) { PLIST_ENTRY current = DirectoryObject->head.Flink; - POBJECT_HEADER current_obj; + PROS_OBJECT_HEADER current_obj; DPRINT("ObFindEntryDirectory(dir %x, name %S)\n",DirectoryObject, Name); @@ -333,7 +333,7 @@ ObpFindEntryDirectory(PDIRECTORY_OBJECT DirectoryObject, } while (current!=(&(DirectoryObject->head))) { - current_obj = CONTAINING_RECORD(current,OBJECT_HEADER,Entry); + current_obj = CONTAINING_RECORD(current,ROS_OBJECT_HEADER,Entry); DPRINT(" Scanning: %S for: %S\n",HEADER_TO_OBJECT_NAME(current_obj)->Name.Buffer, Name); if (Attributes & OBJ_CASE_INSENSITIVE) { @@ -458,7 +458,7 @@ ObInit(VOID) ObjectTypeInitializer.ValidAccessMask = DIRECTORY_ALL_ACCESS; ObjectTypeInitializer.UseDefaultObject = FALSE; ObjectTypeInitializer.OpenProcedure = ObpCreateDirectory; - ObjectTypeInitializer.ParseProcedure = ObpParseDirectory; + ObjectTypeInitializer.ParseProcedure = (OB_PARSE_METHOD)ObpParseDirectory; ObjectTypeInitializer.MaintainTypeList = FALSE; ObjectTypeInitializer.GenericMapping = ObpDirectoryMapping; ObjectTypeInitializer.DefaultNonPagedPoolCharge = sizeof(DIRECTORY_OBJECT); @@ -526,8 +526,8 @@ ObInit(VOID) /* Insert the two objects we already created but couldn't add */ /* NOTE: Uses TypeList & Creator Info in OB 2.0 */ - ObpAddEntryDirectory(ObpTypeDirectoryObject, BODY_TO_HEADER(ObTypeObjectType), NULL); - ObpAddEntryDirectory(ObpTypeDirectoryObject, BODY_TO_HEADER(ObDirectoryType), NULL); + ObpAddEntryDirectory(ObpTypeDirectoryObject, (PROS_OBJECT_HEADER)BODY_TO_HEADER(ObTypeObjectType), NULL); + ObpAddEntryDirectory(ObpTypeDirectoryObject, (PROS_OBJECT_HEADER)BODY_TO_HEADER(ObDirectoryType), NULL); /* Create 'symbolic link' object type */ ObInitSymbolicLinkImplementation(); @@ -543,7 +543,7 @@ ObpCreateTypeObject(POBJECT_TYPE_INITIALIZER ObjectTypeInitializer, PUNICODE_STRING TypeName, POBJECT_TYPE *ObjectType) { - POBJECT_HEADER Header; + PROS_OBJECT_HEADER Header; POBJECT_TYPE LocalObjectType; ULONG HeaderSize; NTSTATUS Status; @@ -555,7 +555,7 @@ ObpCreateTypeObject(POBJECT_TYPE_INITIALIZER ObjectTypeInitializer, TypeName, ObTypeObjectType, OBJECT_ALLOC_SIZE(sizeof(OBJECT_TYPE)), - &Header); + (PROS_OBJECT_HEADER*)&Header); if (!NT_SUCCESS(Status)) { DPRINT1("ObpAllocateObject failed!\n"); @@ -601,7 +601,7 @@ ObpCreateTypeObject(POBJECT_TYPE_INITIALIZER ObjectTypeInitializer, } /* Calculate how much space our header'll take up */ - HeaderSize = sizeof(OBJECT_HEADER) + sizeof(OBJECT_HEADER_NAME_INFO) + + HeaderSize = sizeof(ROS_OBJECT_HEADER) + sizeof(OBJECT_HEADER_NAME_INFO) + (ObjectTypeInitializer->MaintainHandleCount ? sizeof(OBJECT_HEADER_HANDLE_INFO) : 0); diff --git a/reactos/ntoskrnl/ob/ntobj.c b/reactos/ntoskrnl/ob/ntobj.c index 527ac5d4d8b..40f4a1bac28 100644 --- a/reactos/ntoskrnl/ob/ntobj.c +++ b/reactos/ntoskrnl/ob/ntobj.c @@ -86,7 +86,7 @@ NtQueryObject (IN HANDLE ObjectHandle, OUT PULONG ResultLength OPTIONAL) { OBJECT_HANDLE_INFORMATION HandleInfo; - POBJECT_HEADER ObjectHeader; + PROS_OBJECT_HEADER ObjectHeader; ULONG InfoLength; PVOID Object; NTSTATUS Status; @@ -220,7 +220,7 @@ NtQueryObject (IN HANDLE ObjectHandle, VOID FASTCALL ObpSetPermanentObject (IN PVOID ObjectBody, IN BOOLEAN Permanent) { - POBJECT_HEADER ObjectHeader; + PROS_OBJECT_HEADER ObjectHeader; ObjectHeader = BODY_TO_HEADER(ObjectBody); ASSERT (ObjectHeader->PointerCount > 0); @@ -234,7 +234,7 @@ ObpSetPermanentObject (IN PVOID ObjectBody, IN BOOLEAN Permanent) if (ObjectHeader->HandleCount == 0 && HEADER_TO_OBJECT_NAME(ObjectHeader)->Directory) { /* Remove the object from the namespace */ - ObpRemoveEntryDirectory(ObjectHeader); + ObpRemoveEntryDirectory((PROS_OBJECT_HEADER)ObjectHeader); } } } diff --git a/reactos/ntoskrnl/ob/object.c b/reactos/ntoskrnl/ob/object.c index a4ade3b97f0..dfe1b772a97 100644 --- a/reactos/ntoskrnl/ob/object.c +++ b/reactos/ntoskrnl/ob/object.c @@ -22,7 +22,7 @@ typedef struct _RETENTION_CHECK_PARAMS { WORK_QUEUE_ITEM WorkItem; - POBJECT_HEADER ObjectHeader; + PROS_OBJECT_HEADER ObjectHeader; } RETENTION_CHECK_PARAMS, *PRETENTION_CHECK_PARAMS; /* FUNCTIONS ************************************************************/ @@ -298,7 +298,7 @@ ObFindObject(POBJECT_CREATE_INFORMATION ObjectCreateInfo, PVOID NextObject; PVOID CurrentObject; PVOID RootObject; - POBJECT_HEADER CurrentHeader; + PROS_OBJECT_HEADER CurrentHeader; NTSTATUS Status; PWSTR current; UNICODE_STRING PathString; @@ -384,7 +384,7 @@ ObFindObject(POBJECT_CREATE_INFORMATION ObjectCreateInfo, DPRINT("Current object can't parse\n"); break; } - Status = CurrentHeader->Type->TypeInfo.ParseProcedure(CurrentObject, + Status = ((OB_ROS_PARSE_METHOD)CurrentHeader->Type->TypeInfo.ParseProcedure)(CurrentObject, &NextObject, &PathString, ¤t, @@ -441,7 +441,7 @@ ObQueryNameString(IN PVOID Object, OUT PULONG ReturnLength) { POBJECT_HEADER_NAME_INFO LocalInfo; - POBJECT_HEADER ObjectHeader; + PROS_OBJECT_HEADER ObjectHeader; PDIRECTORY_OBJECT ParentDirectory; ULONG NameSize; PWCH ObjectName; @@ -459,6 +459,7 @@ ObQueryNameString(IN PVOID Object, /* Call the procedure */ DPRINT("Calling Object's Procedure\n"); Status = ObjectHeader->Type->TypeInfo.QueryNameProcedure(Object, + TRUE, //fixme ObjectNameInfo, Length, ReturnLength); @@ -618,9 +619,9 @@ ObpAllocateObject(POBJECT_CREATE_INFORMATION ObjectCreateInfo, PUNICODE_STRING ObjectName, POBJECT_TYPE ObjectType, ULONG ObjectSize, - POBJECT_HEADER *ObjectHeader) + PROS_OBJECT_HEADER *ObjectHeader) { - POBJECT_HEADER Header; + PROS_OBJECT_HEADER Header; BOOLEAN HasHandleInfo = FALSE; BOOLEAN HasNameInfo = FALSE; BOOLEAN HasCreatorInfo = FALSE; @@ -684,7 +685,7 @@ ObpAllocateObject(POBJECT_CREATE_INFORMATION ObjectCreateInfo, HandleInfo = (POBJECT_HEADER_HANDLE_INFO)Header; DPRINT("Info: %x\n", HandleInfo); HandleInfo->SingleEntry.HandleCount = 0; - Header = (POBJECT_HEADER)(HandleInfo + 1); + Header = (PROS_OBJECT_HEADER)(HandleInfo + 1); } /* Initialize the Object Name Info */ @@ -694,7 +695,7 @@ ObpAllocateObject(POBJECT_CREATE_INFORMATION ObjectCreateInfo, DPRINT("Info: %x %wZ\n", NameInfo, ObjectName); NameInfo->Name = *ObjectName; NameInfo->Directory = NULL; - Header = (POBJECT_HEADER)(NameInfo + 1); + Header = (PROS_OBJECT_HEADER)(NameInfo + 1); } /* Initialize Creator Info */ @@ -706,7 +707,7 @@ ObpAllocateObject(POBJECT_CREATE_INFORMATION ObjectCreateInfo, * CreatorInfo->CreatorUniqueProcess = PsGetCurrentProcessId(); */ InitializeListHead(&CreatorInfo->TypeList); - Header = (POBJECT_HEADER)(CreatorInfo + 1); + Header = (PROS_OBJECT_HEADER)(CreatorInfo + 1); } /* Initialize the object header */ @@ -777,7 +778,7 @@ ObCreateObject(IN KPROCESSOR_MODE ObjectAttributesAccessMode OPTIONAL, NTSTATUS Status; POBJECT_CREATE_INFORMATION ObjectCreateInfo; UNICODE_STRING ObjectName; - POBJECT_HEADER Header; + PROS_OBJECT_HEADER Header; DPRINT("ObCreateObject(Type %p ObjectAttributes %p, Object %p)\n", Type, ObjectAttributes, Object); @@ -845,7 +846,7 @@ ObReferenceObjectByPointer(IN PVOID Object, IN POBJECT_TYPE ObjectType, IN KPROCESSOR_MODE AccessMode) { - POBJECT_HEADER Header; + PROS_OBJECT_HEADER Header; /* NOTE: should be possible to reference an object above APC_LEVEL! */ @@ -938,7 +939,7 @@ ObOpenObjectByPointer(IN PVOID Object, static NTSTATUS -ObpDeleteObject(POBJECT_HEADER Header) +ObpDeleteObject(PROS_OBJECT_HEADER Header) { PVOID HeaderLocation = Header; POBJECT_HEADER_HANDLE_INFO HandleInfo; @@ -1015,7 +1016,7 @@ ObpDeleteObjectWorkRoutine (IN PVOID Parameter) STATIC NTSTATUS -ObpDeleteObjectDpcLevel(IN POBJECT_HEADER ObjectHeader, +ObpDeleteObjectDpcLevel(IN PROS_OBJECT_HEADER ObjectHeader, IN LONG OldPointerCount) { #if 0 @@ -1094,7 +1095,7 @@ ObpDeleteObjectDpcLevel(IN POBJECT_HEADER ObjectHeader, VOID FASTCALL ObfReferenceObject(IN PVOID Object) { - POBJECT_HEADER Header; + PROS_OBJECT_HEADER Header; ASSERT(Object); @@ -1127,7 +1128,7 @@ ObfReferenceObject(IN PVOID Object) VOID FASTCALL ObfDereferenceObject(IN PVOID Object) { - POBJECT_HEADER Header; + PROS_OBJECT_HEADER Header; LONG NewPointerCount; BOOL Permanent; @@ -1222,7 +1223,7 @@ ObFastReplaceObject(IN PEX_FAST_REF FastRef, ULONG STDCALL ObGetObjectPointerCount(PVOID Object) { - POBJECT_HEADER Header; + PROS_OBJECT_HEADER Header; PAGED_CODE(); @@ -1250,7 +1251,7 @@ ULONG NTAPI ObGetObjectHandleCount(PVOID Object) { - POBJECT_HEADER Header; + PROS_OBJECT_HEADER Header; PAGED_CODE(); diff --git a/reactos/ntoskrnl/ob/security.c b/reactos/ntoskrnl/ob/security.c index 110da540e4c..c1d70141c7d 100644 --- a/reactos/ntoskrnl/ob/security.c +++ b/reactos/ntoskrnl/ob/security.c @@ -66,7 +66,7 @@ ObGetObjectSecurity(IN PVOID Object, OUT PSECURITY_DESCRIPTOR *SecurityDescriptor, OUT PBOOLEAN MemoryAllocated) { - POBJECT_HEADER Header; + PROS_OBJECT_HEADER Header; ULONG Length; NTSTATUS Status; @@ -161,7 +161,7 @@ NtQuerySecurityObject(IN HANDLE Handle, { KPROCESSOR_MODE PreviousMode; PVOID Object; - POBJECT_HEADER Header; + PROS_OBJECT_HEADER Header; ACCESS_MASK DesiredAccess = (ACCESS_MASK)0; NTSTATUS Status = STATUS_SUCCESS; @@ -240,7 +240,7 @@ NtSetSecurityObject(IN HANDLE Handle, { KPROCESSOR_MODE PreviousMode; PVOID Object; - POBJECT_HEADER Header; + PROS_OBJECT_HEADER Header; SECURITY_DESCRIPTOR_RELATIVE *CapturedSecurityDescriptor; ACCESS_MASK DesiredAccess = (ACCESS_MASK)0; NTSTATUS Status; diff --git a/reactos/ntoskrnl/ob/symlink.c b/reactos/ntoskrnl/ob/symlink.c index f7682b29efb..acab37f058c 100644 --- a/reactos/ntoskrnl/ob/symlink.c +++ b/reactos/ntoskrnl/ob/symlink.c @@ -152,7 +152,7 @@ ObInitSymbolicLinkImplementation (VOID) ObjectTypeInitializer.PoolType = NonPagedPool; ObjectTypeInitializer.ValidAccessMask = SYMBOLIC_LINK_ALL_ACCESS; ObjectTypeInitializer.UseDefaultObject = TRUE; - ObjectTypeInitializer.ParseProcedure = ObpParseSymbolicLink; + ObjectTypeInitializer.ParseProcedure = (OB_PARSE_METHOD)ObpParseSymbolicLink; ObjectTypeInitializer.DeleteProcedure = ObpDeleteSymbolicLink; ObpCreateTypeObject(&ObjectTypeInitializer, &Name, &ObSymbolicLinkType); } diff --git a/reactos/ntoskrnl/ob/wait.c b/reactos/ntoskrnl/ob/wait.c index 0943abf2f60..490b0e7342a 100644 --- a/reactos/ntoskrnl/ob/wait.c +++ b/reactos/ntoskrnl/ob/wait.c @@ -35,7 +35,7 @@ NtWaitForMultipleObjects(IN ULONG ObjectCount, LARGE_INTEGER SafeTimeOut; BOOLEAN LockInUse; PHANDLE_TABLE_ENTRY HandleEntry; - POBJECT_HEADER ObjectHeader; + PROS_OBJECT_HEADER ObjectHeader; PHANDLE_TABLE HandleTable; ACCESS_MASK GrantedAccess; PVOID DefaultObject; diff --git a/reactos/ntoskrnl/po/power.c b/reactos/ntoskrnl/po/power.c index d3f83223ab9..d14ccc099ff 100644 --- a/reactos/ntoskrnl/po/power.c +++ b/reactos/ntoskrnl/po/power.c @@ -298,7 +298,7 @@ PopSetSystemPowerState( VOID INIT_FUNCTION NTAPI -PoInit(PLOADER_PARAMETER_BLOCK LoaderBlock, +PoInit(PROS_LOADER_PARAMETER_BLOCK LoaderBlock, BOOLEAN ForceAcpiDisable) { if (ForceAcpiDisable) diff --git a/reactos/ntoskrnl/ps/job.c b/reactos/ntoskrnl/ps/job.c index 05686336e9e..edf1b263404 100644 --- a/reactos/ntoskrnl/ps/job.c +++ b/reactos/ntoskrnl/ps/job.c @@ -157,7 +157,7 @@ NtAssignProcessToJobObject ( /* lock the process so we can safely assign the process. Note that in the meanwhile another thread could have assigned this process to a job! */ - Status = PsLockProcess(Process, FALSE); + Status = PsLockProcess((PROS_EPROCESS)Process, FALSE); if(NT_SUCCESS(Status)) { if(Process->Job == NULL && Process->Session == Job->SessionId) @@ -173,7 +173,7 @@ NtAssignProcessToJobObject ( /* process is already assigned to a job or session id differs! */ Status = STATUS_ACCESS_DENIED; } - PsUnlockProcess(Process); + PsUnlockProcess((PROS_EPROCESS)Process); if(NT_SUCCESS(Status)) { diff --git a/reactos/ntoskrnl/ps/kill.c b/reactos/ntoskrnl/ps/kill.c index ab1fb9bbdd7..15796650be2 100644 --- a/reactos/ntoskrnl/ps/kill.c +++ b/reactos/ntoskrnl/ps/kill.c @@ -166,7 +166,7 @@ PspDeleteProcess(PVOID ObjectBody) SeDeassignPrimaryToken(Process); /* Release Memory Information */ - MmReleaseMmInfo(Process); + MmReleaseMmInfo((PROS_EPROCESS)Process); /* Delete the W32PROCESS structure if there's one associated */ if(Process->Win32Process != NULL) ExFreePool(Process->Win32Process); @@ -240,7 +240,7 @@ PspExitThread(NTSTATUS ExitStatus) KeLowerIrql(PASSIVE_LEVEL); /* Lock the Process before we modify its thread entries */ - PsLockProcess(CurrentProcess, FALSE); + PsLockProcess((PROS_EPROCESS)CurrentProcess, FALSE); /* wake up the thread so we don't deadlock on PsLockProcess */ KeForceResumeThread(&CurrentThread->Tcb); @@ -308,7 +308,7 @@ PspExitThread(NTSTATUS ExitStatus) } DPRINT("Decommit teb at %p\n", Teb); - MmDeleteTeb(CurrentProcess, Teb); + MmDeleteTeb((PROS_EPROCESS)CurrentProcess, Teb); CurrentThread->Tcb.Teb = NULL; } @@ -316,7 +316,7 @@ PspExitThread(NTSTATUS ExitStatus) if (Last) PspExitProcess(CurrentProcess); /* Unlock the Process */ - PsUnlockProcess(CurrentProcess); + PsUnlockProcess((PROS_EPROCESS)CurrentProcess); /* Cancel I/O for the thread. */ IoCancelThreadIo(CurrentThread); @@ -563,11 +563,11 @@ NtTerminateProcess(IN HANDLE ProcessHandle OPTIONAL, CurrentThread = PsGetCurrentThread(); - PsLockProcess(Process, FALSE); + PsLockProcess((PROS_EPROCESS)Process, FALSE); if(Process->ExitTime.QuadPart != 0) { - PsUnlockProcess(Process); + PsUnlockProcess((PROS_EPROCESS)Process); ObDereferenceObject(Process); return STATUS_PROCESS_IS_TERMINATING; } @@ -592,7 +592,7 @@ NtTerminateProcess(IN HANDLE ProcessHandle OPTIONAL, unlocking the process, fail */ CurrentThread->Terminated = TRUE; - PsUnlockProcess(Process); + PsUnlockProcess((PROS_EPROCESS)Process); /* we can safely dereference the process because the current thread holds a reference to it until it gets reaped */ @@ -610,7 +610,7 @@ NtTerminateProcess(IN HANDLE ProcessHandle OPTIONAL, } /* unlock and dereference the process so the threads can kill themselves */ - PsUnlockProcess(Process); + PsUnlockProcess((PROS_EPROCESS)Process); ObDereferenceObject(Process); return(STATUS_SUCCESS); @@ -668,7 +668,7 @@ NtTerminateThread(IN HANDLE ThreadHandle, if (Thread != PsGetCurrentThread()) { /* we need to lock the process to make sure it's not already terminating */ - PsLockProcess(Thread->ThreadsProcess, FALSE); + PsLockProcess((PROS_EPROCESS)Thread->ThreadsProcess, FALSE); /* This isn't our thread, terminate it if not already done */ if (!Thread->Terminated) { @@ -679,7 +679,7 @@ NtTerminateThread(IN HANDLE ThreadHandle, PspTerminateThreadByPointer(Thread, ExitStatus); } - PsUnlockProcess(Thread->ThreadsProcess); + PsUnlockProcess((PROS_EPROCESS)Thread->ThreadsProcess); /* Dereference the Thread and return */ ObDereferenceObject(Thread); diff --git a/reactos/ntoskrnl/ps/process.c b/reactos/ntoskrnl/ps/process.c index 4ecc0015812..ef6cda37626 100644 --- a/reactos/ntoskrnl/ps/process.c +++ b/reactos/ntoskrnl/ps/process.c @@ -31,7 +31,7 @@ LARGE_INTEGER ShortPsLockDelay, PsLockTimeout; NTSTATUS NTAPI -PsLockProcess(PEPROCESS Process, BOOLEAN Timeout) +PsLockProcess(PROS_EPROCESS Process, BOOLEAN Timeout) { ULONG Attempts = 0; PKTHREAD PrevLockOwner; @@ -90,7 +90,7 @@ PsLockProcess(PEPROCESS Process, BOOLEAN Timeout) VOID NTAPI -PsUnlockProcess(PEPROCESS Process) +PsUnlockProcess(PROS_EPROCESS Process) { PAGED_CODE(); @@ -288,7 +288,7 @@ PspCreateProcess(OUT PHANDLE ProcessHandle, ObjectAttributes, PreviousMode, NULL, - sizeof(EPROCESS), + sizeof(ROS_EPROCESS), 0, 0, (PVOID*)&Process); @@ -301,7 +301,7 @@ PspCreateProcess(OUT PHANDLE ProcessHandle, /* Clean up the Object */ DPRINT("Cleaning Process Object\n"); - RtlZeroMemory(Process, sizeof(EPROCESS)); + RtlZeroMemory(Process, sizeof(ROS_EPROCESS)); /* Inherit stuff from the Parent since we now have the object created */ if (pParentProcess) @@ -325,7 +325,7 @@ PspCreateProcess(OUT PHANDLE ProcessHandle, /* Setup the Lock Event */ DPRINT("Initialzing Process Lock\n"); - KeInitializeEvent(&Process->LockEvent, SynchronizationEvent, FALSE); + KeInitializeEvent(&((PROS_EPROCESS)Process)->LockEvent, SynchronizationEvent, FALSE); /* Setup the Thread List Head */ DPRINT("Initialzing Process ThreadListHead\n"); @@ -338,8 +338,8 @@ PspCreateProcess(OUT PHANDLE ProcessHandle, /* Set Process's Directory Base */ DPRINT("Initialzing Process Directory Base\n"); - MmCopyMmInfo(pParentProcess ? pParentProcess : PsInitialSystemProcess, - Process, + MmCopyMmInfo((PROS_EPROCESS)(pParentProcess ? pParentProcess : PsInitialSystemProcess), + (PROS_EPROCESS)Process, &DirectoryTableBase); /* Now initialize the Kernel Process */ @@ -360,7 +360,7 @@ PspCreateProcess(OUT PHANDLE ProcessHandle, /* Create the Process' Address Space */ DPRINT("Initialzing Process Address Space\n"); - Status = MmCreateProcessAddressSpace(Process, SectionObject); + Status = MmCreateProcessAddressSpace((PROS_EPROCESS)Process, (PROS_SECTION_OBJECT)SectionObject); if (!NT_SUCCESS(Status)) { DPRINT1("Failed to create Address Space\n"); @@ -393,7 +393,7 @@ PspCreateProcess(OUT PHANDLE ProcessHandle, if (pParentProcess) { DPRINT("Creating PEB\n"); - Status = MmCreatePeb(Process); + Status = MmCreatePeb((PROS_EPROCESS)Process); if (!NT_SUCCESS(Status)) { DbgPrint("NtCreateProcess() Peb creation failed: Status %x\n",Status); diff --git a/reactos/ntoskrnl/ps/psmgr.c b/reactos/ntoskrnl/ps/psmgr.c index ce0d3195a2e..a2824c84282 100644 --- a/reactos/ntoskrnl/ps/psmgr.c +++ b/reactos/ntoskrnl/ps/psmgr.c @@ -154,7 +154,7 @@ PsInitProcessManagment(VOID) RtlZeroMemory(&ObjectTypeInitializer, sizeof(ObjectTypeInitializer)); RtlInitUnicodeString(&Name, L"Process"); ObjectTypeInitializer.Length = sizeof(ObjectTypeInitializer); - ObjectTypeInitializer.DefaultNonPagedPoolCharge = sizeof(EPROCESS); + ObjectTypeInitializer.DefaultNonPagedPoolCharge = sizeof(ROS_EPROCESS); ObjectTypeInitializer.GenericMapping = PiProcessMapping; ObjectTypeInitializer.PoolType = NonPagedPool; ObjectTypeInitializer.ValidAccessMask = PROCESS_ALL_ACCESS; @@ -181,7 +181,7 @@ PsInitProcessManagment(VOID) NULL, KernelMode, NULL, - sizeof(EPROCESS), + sizeof(ROS_EPROCESS), 0, 0, (PVOID*)&PsIdleProcess); @@ -192,7 +192,7 @@ PsInitProcessManagment(VOID) return; } - RtlZeroMemory(PsIdleProcess, sizeof(EPROCESS)); + RtlZeroMemory(PsIdleProcess, sizeof(ROS_EPROCESS)); PsIdleProcess->Pcb.Affinity = 0xFFFFFFFF; PsIdleProcess->Pcb.IopmOffset = 0xffff; @@ -203,7 +203,7 @@ PsInitProcessManagment(VOID) InitializeListHead(&PsIdleProcess->ActiveProcessLinks); KeInitializeDispatcherHeader(&PsIdleProcess->Pcb.Header, ProcessObject, - sizeof(EPROCESS) / sizeof(LONG), + sizeof(ROS_EPROCESS) / sizeof(LONG), FALSE); PsIdleProcess->Pcb.DirectoryTableBase.QuadPart = (ULONG_PTR)MmGetPageDirectory(); strcpy(PsIdleProcess->ImageFileName, "Idle"); @@ -217,7 +217,7 @@ PsInitProcessManagment(VOID) NULL, KernelMode, NULL, - sizeof(EPROCESS), + sizeof(ROS_EPROCESS), 0, 0, (PVOID*)&PsInitialSystemProcess); @@ -229,7 +229,7 @@ PsInitProcessManagment(VOID) } /* System threads may run on any processor. */ - RtlZeroMemory(PsInitialSystemProcess, sizeof(EPROCESS)); + RtlZeroMemory(PsInitialSystemProcess, sizeof(ROS_EPROCESS)); #ifdef CONFIG_SMP /* FIXME: * Only the boot cpu is initialized. Threads of the @@ -245,15 +245,15 @@ PsInitProcessManagment(VOID) InitializeListHead(&PsInitialSystemProcess->Pcb.ThreadListHead); KeInitializeDispatcherHeader(&PsInitialSystemProcess->Pcb.Header, ProcessObject, - sizeof(EPROCESS) / sizeof(LONG), + sizeof(ROS_EPROCESS) / sizeof(LONG), FALSE); KProcess = &PsInitialSystemProcess->Pcb; PspInheritQuota(PsInitialSystemProcess, NULL); - MmInitializeAddressSpace(PsInitialSystemProcess, - &PsInitialSystemProcess->AddressSpace); + MmInitializeAddressSpace((PROS_EPROCESS)PsInitialSystemProcess, + &((PROS_EPROCESS)PsInitialSystemProcess)->AddressSpace); - KeInitializeEvent(&PsInitialSystemProcess->LockEvent, SynchronizationEvent, FALSE); + KeInitializeEvent(&((PROS_EPROCESS)PsInitialSystemProcess)->LockEvent, SynchronizationEvent, FALSE); #if defined(__GNUC__) KProcess->DirectoryTableBase = diff --git a/reactos/ntoskrnl/ps/query.c b/reactos/ntoskrnl/ps/query.c index ae39db081d3..be90e24ba95 100644 --- a/reactos/ntoskrnl/ps/query.c +++ b/reactos/ntoskrnl/ps/query.c @@ -428,11 +428,11 @@ NtQueryInformationProcess(IN HANDLE ProcessHandle, case ProcessImageFileName: { ULONG ImagePathLen = 0; - PSECTION_OBJECT Section; + PROS_SECTION_OBJECT Section; PUNICODE_STRING DstPath = (PUNICODE_STRING)ProcessInformation; PWSTR SrcBuffer = NULL, DstBuffer = (PWSTR)(DstPath + 1); - Section = (PSECTION_OBJECT)Process->SectionObject; + Section = (PROS_SECTION_OBJECT)Process->SectionObject; if (Section != NULL && Section->FileObject != NULL) { @@ -653,7 +653,7 @@ NtSetInformationProcess(IN HANDLE ProcessHandle, { /* lock the process to be thread-safe! */ - Status = PsLockProcess(Process, FALSE); + Status = PsLockProcess((PROS_EPROCESS)Process, FALSE); if(NT_SUCCESS(Status)) { /* @@ -671,7 +671,7 @@ NtSetInformationProcess(IN HANDLE ProcessHandle, ObDereferenceObject(ExceptionPort); Status = STATUS_PORT_ALREADY_SET; } - PsUnlockProcess(Process); + PsUnlockProcess((PROS_EPROCESS)Process); } else { @@ -758,7 +758,7 @@ NtSetInformationProcess(IN HANDLE ProcessHandle, /* FIXME - update the session id for the process token */ - Status = PsLockProcess(Process, FALSE); + Status = PsLockProcess((PROS_EPROCESS)Process, FALSE); if(NT_SUCCESS(Status)) { Process->Session = SessionInfo.SessionId; @@ -785,7 +785,7 @@ NtSetInformationProcess(IN HANDLE ProcessHandle, KeDetachProcess(); } - PsUnlockProcess(Process); + PsUnlockProcess((PROS_EPROCESS)Process); } } break; diff --git a/reactos/ntoskrnl/ps/thread.c b/reactos/ntoskrnl/ps/thread.c index 90c55a5ed21..f7518ecc9b7 100644 --- a/reactos/ntoskrnl/ps/thread.c +++ b/reactos/ntoskrnl/ps/thread.c @@ -220,7 +220,7 @@ PspCreateThread(OUT PHANDLE ThreadHandle, /* Create Teb */ DPRINT("Initialliazing Thread PEB\n"); - TebBase = MmCreateTeb(Process, &Thread->Cid, InitialTeb); + TebBase = MmCreateTeb((PROS_EPROCESS)Process, &Thread->Cid, InitialTeb); /* Set the Start Addresses */ DPRINT("Initialliazing Thread Start Addresses :%x, %x\n", ThreadContext->Eip, ThreadContext->Eax); diff --git a/reactos/ntoskrnl/ps/win32.c b/reactos/ntoskrnl/ps/win32.c index 4f38ded8f14..a80b378d6cc 100644 --- a/reactos/ntoskrnl/ps/win32.c +++ b/reactos/ntoskrnl/ps/win32.c @@ -13,17 +13,18 @@ #include #define NDEBUG #include +#include /* GLOBALS ******************************************************************/ -static PW32_PROCESS_CALLBACK PspWin32ProcessCallback = NULL; -static PW32_THREAD_CALLBACK PspWin32ThreadCallback = NULL; +static PKWIN32_PROCESS_CALLOUT PspWin32ProcessCallback = NULL; +static PKWIN32_THREAD_CALLOUT PspWin32ThreadCallback = NULL; extern OB_OPEN_METHOD ExpWindowStationObjectOpen; -extern OB_PARSE_METHOD ExpWindowStationObjectParse; +extern OB_ROS_PARSE_METHOD ExpWindowStationObjectParse; extern OB_DELETE_METHOD ExpWindowStationObjectDelete; -extern OB_FIND_METHOD ExpWindowStationObjectFind; -extern OB_CREATE_METHOD ExpDesktopObjectCreate; +extern OB_ROS_FIND_METHOD ExpWindowStationObjectFind; +extern OB_ROS_CREATE_METHOD ExpDesktopObjectCreate; extern OB_DELETE_METHOD ExpDesktopObjectDelete; #ifndef ALEX_CB_REWRITE @@ -55,11 +56,12 @@ KeSwitchKernelStack( */ VOID STDCALL -PsEstablishWin32Callouts(PW32_CALLOUT_DATA CalloutData) +PsEstablishWin32Callouts(PWIN32_CALLOUTS_FPNS calloutData) { + PW32_CALLOUT_DATA CalloutData = (PW32_CALLOUT_DATA)calloutData; PspWin32ProcessCallback = CalloutData->W32ProcessCallout; PspWin32ThreadCallback = CalloutData->W32ThreadCallout; - ExpWindowStationObjectOpen = CalloutData->WinStaCreate; + ExpWindowStationObjectOpen = CalloutData->WinStaOpen; ExpWindowStationObjectParse = CalloutData->WinStaParse; ExpWindowStationObjectDelete = CalloutData->WinStaDelete; ExpWindowStationObjectFind = CalloutData->WinStaFind; @@ -142,7 +144,7 @@ PsConvertToGuiThread(VOID) ASSERT(Thread->Tcb.Win32Thread == 0); /* Tell Win32k about our thread */ - Status = PspWin32ThreadCallback(Thread, TRUE); + Status = PspWin32ThreadCallback(Thread, PsW32ThreadCalloutInitialize); if (!NT_SUCCESS(Status)) { /* Revert our table */ @@ -179,7 +181,7 @@ PsTerminateWin32Thread (PETHREAD Thread) { if (PspWin32ThreadCallback != NULL) { - PspWin32ThreadCallback (Thread, FALSE); + PspWin32ThreadCallback (Thread, PsW32ThreadCalloutExit); } /* don't delete the W32THREAD structure at this point, wait until the diff --git a/reactos/ntoskrnl/se/semgr.c b/reactos/ntoskrnl/se/semgr.c index 1f52a26ec2b..5b41c60a7d7 100644 --- a/reactos/ntoskrnl/se/semgr.c +++ b/reactos/ntoskrnl/se/semgr.c @@ -212,7 +212,7 @@ SeDefaultObjectMethod(PVOID Object, PISECURITY_DESCRIPTOR ObjectSd; PISECURITY_DESCRIPTOR NewSd; PISECURITY_DESCRIPTOR SecurityDescriptor = _SecurityDescriptor; - POBJECT_HEADER Header = BODY_TO_HEADER(Object); + PROS_OBJECT_HEADER Header = BODY_TO_HEADER(Object); PSID Owner = 0; PSID Group = 0; PACL Dacl = 0; diff --git a/reactos/subsystems/win32/win32k/include/winsta.h b/reactos/subsystems/win32/win32k/include/winsta.h index 79158f55848..a4fe714fd37 100644 --- a/reactos/subsystems/win32/win32k/include/winsta.h +++ b/reactos/subsystems/win32/win32k/include/winsta.h @@ -54,11 +54,11 @@ CleanupWindowStationImpl(VOID); NTSTATUS STDCALL -IntWinStaObjectOpen(OB_OPEN_REASON Reason, - PVOID ObjectBody, - PEPROCESS Process, - ULONG HandleCount, - ACCESS_MASK GrantedAccess); +IntWinStaObjectOpen(IN OB_OPEN_REASON Reason, + IN PEPROCESS Process OPTIONAL, + IN PVOID ObjectBody, + IN ACCESS_MASK GrantedAccess, + IN ULONG HandleCount); VOID STDCALL IntWinStaObjectDelete(PVOID DeletedObject); diff --git a/reactos/subsystems/win32/win32k/main/dllmain.c b/reactos/subsystems/win32/win32k/main/dllmain.c index 567c2a3ca56..415ddec685e 100644 --- a/reactos/subsystems/win32/win32k/main/dllmain.c +++ b/reactos/subsystems/win32/win32k/main/dllmain.c @@ -23,6 +23,7 @@ #include #include +#include #define NDEBUG #include @@ -164,7 +165,7 @@ CLEANUP: NTSTATUS STDCALL Win32kThreadCallback(struct _ETHREAD *Thread, - BOOLEAN Create) + PSW32THREADCALLOUTTYPE Type) { struct _EPROCESS *Process; PW32THREAD Win32Thread; @@ -193,7 +194,7 @@ Win32kThreadCallback(struct _ETHREAD *Thread, PsSetThreadWin32Thread(Thread, Win32Thread); /* FIXME - unlock the process */ } - if (Create) + if (Type == PsW32ThreadCalloutInitialize) { HWINSTA hWinSta = NULL; HDESK hDesk = NULL; @@ -342,7 +343,7 @@ Win32kInitWin32Thread(PETHREAD Thread) RtlZeroMemory(Thread->Tcb.Win32Thread, sizeof(W32THREAD)); - Win32kThreadCallback(Thread, TRUE); + Win32kThreadCallback(Thread, PsW32ThreadCalloutInitialize); } return(STATUS_SUCCESS); @@ -380,7 +381,7 @@ DriverEntry ( /* * Register Object Manager Callbacks */ - CalloutData.WinStaCreate = IntWinStaObjectOpen; + CalloutData.WinStaOpen = IntWinStaObjectOpen; CalloutData.WinStaParse = IntWinStaObjectParse; CalloutData.WinStaDelete = IntWinStaObjectDelete; CalloutData.WinStaFind = IntWinStaObjectFind; @@ -392,7 +393,7 @@ DriverEntry ( /* * Register our per-process and per-thread structures. */ - PsEstablishWin32Callouts(&CalloutData); + PsEstablishWin32Callouts((PWIN32_CALLOUTS_FPNS)&CalloutData); GlobalUserHeap = UserCreateHeap(&GlobalUserHeapSection, &GlobalUserHeapBase, diff --git a/reactos/subsystems/win32/win32k/ntuser/winsta.c b/reactos/subsystems/win32/win32k/ntuser/winsta.c index f258f0308bc..68530be8095 100644 --- a/reactos/subsystems/win32/win32k/ntuser/winsta.c +++ b/reactos/subsystems/win32/win32k/ntuser/winsta.c @@ -97,10 +97,10 @@ CleanupWindowStationImpl(VOID) NTSTATUS STDCALL IntWinStaObjectOpen(OB_OPEN_REASON Reason, - PVOID ObjectBody, PEPROCESS Process, - ULONG HandleCount, - ACCESS_MASK GrantedAccess) + PVOID ObjectBody, + ACCESS_MASK GrantedAccess, + ULONG HandleCount) { PWINSTATION_OBJECT WinSta = (PWINSTATION_OBJECT)ObjectBody; NTSTATUS Status; diff --git a/reactos/subsystems/win32/win32k/objects/dc.c b/reactos/subsystems/win32/win32k/objects/dc.c index 2442265995f..48933ca093f 100644 --- a/reactos/subsystems/win32/win32k/objects/dc.c +++ b/reactos/subsystems/win32/win32k/objects/dc.c @@ -28,6 +28,14 @@ #define NDEBUG #include +/* ROS Internal. Please deprecate */ +NTHALAPI +BOOLEAN +NTAPI +HalQueryDisplayOwnership( + VOID +); + #ifndef OBJ_COLORSPACE #define OBJ_COLORSPACE (14) #endif diff --git a/reactos/subsystems/win32/win32k/w32k.h b/reactos/subsystems/win32/win32k/w32k.h index 886617134ff..df3f1ac95f5 100644 --- a/reactos/subsystems/win32/win32k/w32k.h +++ b/reactos/subsystems/win32/win32k/w32k.h @@ -17,6 +17,7 @@ #include #include #include +//#include /* Win32 Headers */ /* FIXME: Defines in winbase.h that we need... */ @@ -56,9 +57,6 @@ typedef struct _SECURITY_ATTRIBUTES SECURITY_ATTRIBUTES, *LPSECURITY_ATTRIBUTES; #include #include -/* For access to SECTION_OBJECT. FIXME: Once compatible with NT, use NDK! */ -#include - /* Internal Win32K Header */ #include "include/win32k.h" -- 2.17.1