2007-12-15 18:14:41 +00:00
|
|
|
/*
|
|
|
|
* PROJECT: ReactOS Kernel
|
|
|
|
* LICENSE: GPL - See COPYING in the top level directory
|
|
|
|
* FILE: ntoskrnl/config/cmdata.c
|
|
|
|
* PURPOSE: Configuration Manager - Global Configuration Data
|
|
|
|
* PROGRAMMERS: Alex Ionescu (alex.ionescu@reactos.org)
|
|
|
|
*/
|
|
|
|
|
|
|
|
/* INCLUDES ******************************************************************/
|
|
|
|
|
|
|
|
#include "ntoskrnl.h"
|
|
|
|
#define NDEBUG
|
|
|
|
#include "debug.h"
|
2010-04-20 22:47:51 +00:00
|
|
|
#include "./../mm/ARM3/miarm.h"
|
|
|
|
|
2007-12-15 18:14:41 +00:00
|
|
|
/* GLOBALS *******************************************************************/
|
|
|
|
|
|
|
|
ULONG DummyData;
|
|
|
|
ULONG CmNtGlobalFlag;
|
[NTOS]: Make MM init read MmProductType to determine what SKU of ReactOS this is, instead of assuming Server. If you want to go back to the old behavior, you need to change "WinNT" to "ServerNT" in the hivesys under Product Type.
[NTOS]: Configure the MmSystemSize variable properly based on SKU and RAM. Previously, ReactOS told all drivers and applications you were running on a system with < 13MB RAM.
[NTOS]: Initialize thresholds for low and high memory (in pages), low and high paged pool memory, and low and high nonpaged pool memory. These are described in the source.
[NTOS]: Initialize events for each of those thresholds, and populate the \KernelObject\xxxCondition events that are documented in MSDN for driver and app developers.
[NTOS]: Define some internal thresholds to use later, representing the minimum number of free pages under we go berserk, and the minimum number of free pages that we consider "plenty".
[NTOS]: Rename MiRemoveFromList to MiUnlinkFreeOrZeroedPage (Windows name). Make the function handle MmAvailablePages decrement, instead of having the caller do it.
[NTOS]: Remove run-time initialization of the PFN lists, just initialize them statically (also fixes the fact we forgot to initialize their names).
[NTOS]: Move some more initialization code to ARM3 instead of mm.
[NTOS]: Read ProductType from registry into MmProductType instead of dummy value. Remove duplicate "Mirroring" variable read.
svn path=/trunk/; revision=45638
2010-02-20 21:48:36 +00:00
|
|
|
extern ULONG MmProductType;
|
2007-12-15 18:14:41 +00:00
|
|
|
|
|
|
|
WCHAR CmDefaultLanguageId[12];
|
|
|
|
ULONG CmDefaultLanguageIdLength = sizeof(CmDefaultLanguageId);
|
|
|
|
ULONG CmDefaultLanguageIdType;
|
|
|
|
|
|
|
|
WCHAR CmInstallUILanguageId[12];
|
|
|
|
ULONG CmInstallUILanguageIdLength = sizeof(CmInstallUILanguageId);
|
|
|
|
ULONG CmInstallUILanguageIdType;
|
|
|
|
|
|
|
|
WCHAR CmSuiteBuffer[128];
|
|
|
|
ULONG CmSuiteBufferLength = sizeof(CmSuiteBuffer);
|
|
|
|
ULONG CmSuiteBufferType;
|
|
|
|
|
|
|
|
CMHIVE CmControlHive;
|
|
|
|
|
|
|
|
ULONG CmpConfigurationAreaSize = PAGE_SIZE * 4;
|
|
|
|
PCM_FULL_RESOURCE_DESCRIPTOR CmpConfigurationData;
|
|
|
|
|
|
|
|
EX_PUSH_LOCK CmpHiveListHeadLock, CmpLoadHiveLock;
|
|
|
|
|
|
|
|
HIVE_LIST_ENTRY CmpMachineHiveList[] =
|
|
|
|
{
|
|
|
|
{ L"HARDWARE", L"MACHINE\\", NULL, HIVE_VOLATILE , 0 , NULL, FALSE, FALSE, FALSE},
|
|
|
|
{ L"SECURITY", L"MACHINE\\", NULL, 0 , 0 , NULL, FALSE, FALSE, FALSE},
|
|
|
|
{ L"SOFTWARE", L"MACHINE\\", NULL, 0 , 0 , NULL, FALSE, FALSE, FALSE},
|
|
|
|
{ L"SYSTEM", L"MACHINE\\", NULL, 0 , 0 , NULL, FALSE, FALSE, FALSE},
|
|
|
|
{ L"DEFAULT", L"USER\\.DEFAULT", NULL, 0 , 0 , NULL, FALSE, FALSE, FALSE},
|
|
|
|
{ L"SAM", L"MACHINE\\", NULL, HIVE_NOLAZYFLUSH , 0 , NULL, FALSE, FALSE, FALSE},
|
|
|
|
{ NULL, NULL, 0, 0 , 0 , NULL, FALSE, FALSE, FALSE}
|
|
|
|
};
|
|
|
|
|
|
|
|
UNICODE_STRING CmSymbolicLinkValueName =
|
|
|
|
RTL_CONSTANT_STRING(L"SymbolicLinkValue");
|
|
|
|
|
|
|
|
UNICODE_STRING CmpLoadOptions;
|
|
|
|
|
|
|
|
BOOLEAN CmpShareSystemHives;
|
|
|
|
BOOLEAN CmSelfHeal = TRUE;
|
|
|
|
BOOLEAN CmpSelfHeal = TRUE;
|
|
|
|
BOOLEAN CmpMiniNTBoot;
|
|
|
|
ULONG CmpBootType;
|
|
|
|
|
|
|
|
USHORT CmpUnknownBusCount;
|
|
|
|
ULONG CmpTypeCount[MaximumType + 1];
|
|
|
|
|
|
|
|
HANDLE CmpRegistryRootHandle;
|
|
|
|
|
|
|
|
UNICODE_STRING CmClassName[MaximumClass + 1] =
|
|
|
|
{
|
|
|
|
RTL_CONSTANT_STRING(L"System"),
|
|
|
|
RTL_CONSTANT_STRING(L"Processor"),
|
|
|
|
RTL_CONSTANT_STRING(L"Cache"),
|
|
|
|
RTL_CONSTANT_STRING(L"Adapter"),
|
|
|
|
RTL_CONSTANT_STRING(L"Controller"),
|
|
|
|
RTL_CONSTANT_STRING(L"Peripheral"),
|
|
|
|
RTL_CONSTANT_STRING(L"MemoryClass"),
|
|
|
|
RTL_CONSTANT_STRING(L"Undefined")
|
|
|
|
};
|
|
|
|
|
|
|
|
UNICODE_STRING CmTypeName[MaximumType + 1] =
|
|
|
|
{
|
|
|
|
RTL_CONSTANT_STRING(L"System"),
|
|
|
|
RTL_CONSTANT_STRING(L"CentralProcessor"),
|
|
|
|
RTL_CONSTANT_STRING(L"FloatingPointProcessor"),
|
|
|
|
RTL_CONSTANT_STRING(L"PrimaryICache"),
|
|
|
|
RTL_CONSTANT_STRING(L"PrimaryDCache"),
|
|
|
|
RTL_CONSTANT_STRING(L"SecondaryICache"),
|
|
|
|
RTL_CONSTANT_STRING(L"SecondaryDCache"),
|
|
|
|
RTL_CONSTANT_STRING(L"SecondaryCache"),
|
|
|
|
RTL_CONSTANT_STRING(L"EisaAdapter"),
|
|
|
|
RTL_CONSTANT_STRING(L"TcAdapter"),
|
|
|
|
RTL_CONSTANT_STRING(L"ScsiAdapter"),
|
|
|
|
RTL_CONSTANT_STRING(L"DtiAdapter"),
|
|
|
|
RTL_CONSTANT_STRING(L"MultifunctionAdapter"),
|
|
|
|
RTL_CONSTANT_STRING(L"DiskController"),
|
|
|
|
RTL_CONSTANT_STRING(L"TapeController"),
|
|
|
|
RTL_CONSTANT_STRING(L"CdRomController"),
|
|
|
|
RTL_CONSTANT_STRING(L"WormController"),
|
|
|
|
RTL_CONSTANT_STRING(L"SerialController"),
|
|
|
|
RTL_CONSTANT_STRING(L"NetworkController"),
|
|
|
|
RTL_CONSTANT_STRING(L"DisplayController"),
|
|
|
|
RTL_CONSTANT_STRING(L"ParallelController"),
|
|
|
|
RTL_CONSTANT_STRING(L"PointerController"),
|
|
|
|
RTL_CONSTANT_STRING(L"KeyboardController"),
|
|
|
|
RTL_CONSTANT_STRING(L"AudioController"),
|
|
|
|
RTL_CONSTANT_STRING(L"OtherController"),
|
|
|
|
RTL_CONSTANT_STRING(L"DiskPeripheral"),
|
|
|
|
RTL_CONSTANT_STRING(L"FloppyDiskPeripheral"),
|
|
|
|
RTL_CONSTANT_STRING(L"TapePeripheral"),
|
|
|
|
RTL_CONSTANT_STRING(L"ModemPeripheral"),
|
|
|
|
RTL_CONSTANT_STRING(L"MonitorPeripheral"),
|
|
|
|
RTL_CONSTANT_STRING(L"PrinterPeripheral"),
|
|
|
|
RTL_CONSTANT_STRING(L"PointerPeripheral"),
|
|
|
|
RTL_CONSTANT_STRING(L"KeyboardPeripheral"),
|
|
|
|
RTL_CONSTANT_STRING(L"TerminalPeripheral"),
|
|
|
|
RTL_CONSTANT_STRING(L"OtherPeripheral"),
|
|
|
|
RTL_CONSTANT_STRING(L"LinePeripheral"),
|
|
|
|
RTL_CONSTANT_STRING(L"NetworkPeripheral"),
|
|
|
|
RTL_CONSTANT_STRING(L"SystemMemory"),
|
|
|
|
RTL_CONSTANT_STRING(L"DockingInformation"),
|
|
|
|
RTL_CONSTANT_STRING(L"RealModeIrqRoutingTable"),
|
|
|
|
RTL_CONSTANT_STRING(L"RealModePCIEnumeration"),
|
|
|
|
RTL_CONSTANT_STRING(L"Undefined")
|
|
|
|
};
|
|
|
|
|
|
|
|
CMP_MF_TYPE CmpMultifunctionTypes[] =
|
|
|
|
{
|
2008-01-25 16:35:34 +00:00
|
|
|
{"ISA", Isa, 0},
|
|
|
|
{"MCA", MicroChannel, 0},
|
|
|
|
{"PCI", PCIBus, 0},
|
|
|
|
{"VME", VMEBus, 0},
|
|
|
|
{"PCMCIA", PCMCIABus, 0},
|
|
|
|
{"CBUS", CBus, 0},
|
|
|
|
{"MPIPI", MPIBus, 0},
|
|
|
|
{"MPSA", MPSABus, 0},
|
2007-12-15 18:14:41 +00:00
|
|
|
{NULL, Internal, 0}
|
|
|
|
};
|
|
|
|
|
|
|
|
CM_SYSTEM_CONTROL_VECTOR CmControlVector[] =
|
|
|
|
{
|
|
|
|
{
|
|
|
|
L"Session Manager",
|
|
|
|
L"ProtectionMode",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager",
|
|
|
|
L"ObjectSecurityMode",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager",
|
|
|
|
L"LUIDDeviceMapsDisabled",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"LSA",
|
|
|
|
L"AuditBaseDirectories",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"LSA",
|
|
|
|
L"AuditBaseObjects",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"LSA\\audit",
|
|
|
|
L"ProcessAccessesToAudit",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"TimeZoneInformation",
|
|
|
|
L"ActiveTimeBias",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"TimeZoneInformation",
|
|
|
|
L"Bias",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"TimeZoneInformation",
|
|
|
|
L"RealTimeIsUniversal",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager",
|
|
|
|
L"GlobalFlag",
|
|
|
|
&CmNtGlobalFlag,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"PagedPoolQuota",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"NonPagedPoolQuota",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"PagingFileQuota",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"AllocationPreference",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"DynamicMemory",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmDynamicPfn,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"Mirroring",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmMirroring,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"SystemViewSize",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"SessionImageSize",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"SessionPoolSize",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"PoolUsageMaximum",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmConsumedPoolPercentage,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"MapAllocationFragment",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmAllocationFragment,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"PagedPoolSize",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmSizeOfPagedPoolInBytes,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"NonPagedPoolSize",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmSizeOfNonPagedPoolInBytes,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"NonPagedPoolMaximumPercent",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"LargeSystemCache",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmLargeSystemCache,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"LargeStackSize",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"SystemPages",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmNumberOfSystemPtes,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"LowMemoryThreshold",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmLowMemoryThreshold,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"HighMemoryThreshold",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmHighMemoryThreshold,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"DisablePagingExecutive",
|
2009-10-19 23:04:50 +00:00
|
|
|
&MmDisablePagingExecutive,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"ModifiedPageLife",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"SecondLevelDataCache",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmSecondaryColors,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"ClearPageFileAtShutdown",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmZeroPageFile,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"PoolTagSmallTableSize",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"PoolTagBigTableSize",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"PoolTag",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"PoolTagOverruns",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"SnapUnloads",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"ProtectNonPagedPool",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmProtectFreedNonPagedPool,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"TrackLockedPages",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmTrackLockedPages,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"TrackPtes",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmTrackPtes,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"VerifyDrivers",
|
2010-04-20 22:47:51 +00:00
|
|
|
MmVerifyDriverBuffer,
|
|
|
|
&MmVerifyDriverBufferLength,
|
|
|
|
&MmVerifyDriverBufferType
|
2007-12-15 18:14:41 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"VerifyDriverLevel",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmVerifyDriverLevel,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"VerifyMode",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"LargePageMinimum",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"EnforceWriteProtection",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmEnforceWriteProtection,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"MakeLowMemory",
|
2010-04-20 22:47:51 +00:00
|
|
|
&MmMakeLowMemory,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Memory Management",
|
|
|
|
L"WriteWatch",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Executive",
|
|
|
|
L"AdditionalCriticalWorkerThreads",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Executive",
|
|
|
|
L"AdditionalDelayedWorkerThreads",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Executive",
|
|
|
|
L"PriorityQuantumMatrix",
|
|
|
|
&DummyData,
|
|
|
|
&DummyData,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Kernel",
|
|
|
|
L"DpcQueueDepth",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Kernel",
|
|
|
|
L"MinimumDpcRate",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Kernel",
|
|
|
|
L"AdjustDpcThreshold",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Kernel",
|
|
|
|
L"IdealDpcRate",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\I/O System",
|
|
|
|
L"CountOperations",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\I/O System",
|
|
|
|
L"LargeIrpStackLocations",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\I/O System",
|
|
|
|
L"IoVerifierLevel",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager",
|
|
|
|
L"ResourceTimeoutCount",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager",
|
|
|
|
L"CriticalSectionTimeout",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager",
|
|
|
|
L"HeapSegmentReserve",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager",
|
|
|
|
L"HeapSegmentCommit",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager",
|
|
|
|
L"HeapDeCommitTotalFreeThreshold",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager",
|
|
|
|
L"HeapDeCommitFreeBlockThreshold",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"ProductOptions",
|
|
|
|
L"ProductType",
|
[NTOS]: Make MM init read MmProductType to determine what SKU of ReactOS this is, instead of assuming Server. If you want to go back to the old behavior, you need to change "WinNT" to "ServerNT" in the hivesys under Product Type.
[NTOS]: Configure the MmSystemSize variable properly based on SKU and RAM. Previously, ReactOS told all drivers and applications you were running on a system with < 13MB RAM.
[NTOS]: Initialize thresholds for low and high memory (in pages), low and high paged pool memory, and low and high nonpaged pool memory. These are described in the source.
[NTOS]: Initialize events for each of those thresholds, and populate the \KernelObject\xxxCondition events that are documented in MSDN for driver and app developers.
[NTOS]: Define some internal thresholds to use later, representing the minimum number of free pages under we go berserk, and the minimum number of free pages that we consider "plenty".
[NTOS]: Rename MiRemoveFromList to MiUnlinkFreeOrZeroedPage (Windows name). Make the function handle MmAvailablePages decrement, instead of having the caller do it.
[NTOS]: Remove run-time initialization of the PFN lists, just initialize them statically (also fixes the fact we forgot to initialize their names).
[NTOS]: Move some more initialization code to ARM3 instead of mm.
[NTOS]: Read ProductType from registry into MmProductType instead of dummy value. Remove duplicate "Mirroring" variable read.
svn path=/trunk/; revision=45638
2010-02-20 21:48:36 +00:00
|
|
|
&MmProductType,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Terminal Server",
|
|
|
|
L"TSEnabled",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Terminal Server",
|
|
|
|
L"TSAppCompat",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
{
|
|
|
|
L"ProductOptions",
|
|
|
|
L"ProductSuite",
|
|
|
|
CmSuiteBuffer,
|
|
|
|
&CmSuiteBufferLength,
|
|
|
|
&CmSuiteBufferType
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Windows",
|
|
|
|
L"CSDVersion",
|
|
|
|
&CmNtCSDVersion,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Nls\\Language",
|
|
|
|
L"Default",
|
|
|
|
CmDefaultLanguageId,
|
|
|
|
&CmDefaultLanguageIdLength,
|
|
|
|
&CmDefaultLanguageIdType
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Nls\\Language",
|
|
|
|
L"InstallLanguage",
|
|
|
|
CmInstallUILanguageId,
|
|
|
|
&CmInstallUILanguageIdLength,
|
|
|
|
&CmInstallUILanguageIdType
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"\0\0",
|
|
|
|
L"RegistrySizeLimit",
|
|
|
|
&DummyData,
|
|
|
|
&DummyData,
|
|
|
|
&DummyData
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager",
|
|
|
|
L"ForceNpxEmulation",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager",
|
|
|
|
L"PowerPolicySimulate",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager\\Executive",
|
|
|
|
L"MaxTimeSeparationBeforeCorrect",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Windows",
|
|
|
|
L"ShutdownTime",
|
|
|
|
&DummyData,
|
|
|
|
&DummyData,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"PriorityControl",
|
|
|
|
L"Win32PrioritySeparation",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager",
|
|
|
|
L"EnableTimerWatchdog",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"Session Manager",
|
|
|
|
L"Debugger Retries",
|
2009-11-02 17:45:51 +00:00
|
|
|
&KdpContext.KdpDefaultRetries,
|
2007-12-15 18:14:41 +00:00
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
2009-11-02 17:45:51 +00:00
|
|
|
{
|
|
|
|
L"Session Manager\\Debug Print Filter",
|
|
|
|
L"WIN2000",
|
|
|
|
&Kd_WIN2000_Mask,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
/* TODO: Add the other masks */
|
|
|
|
|
2007-12-15 18:14:41 +00:00
|
|
|
{
|
|
|
|
L"WMI",
|
|
|
|
L"MaxEventSize",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"WMI\\Trace",
|
|
|
|
L"UsePerformanceClock",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
L"WMI\\Trace",
|
|
|
|
L"TraceAlignment",
|
|
|
|
&DummyData,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
},
|
|
|
|
|
|
|
|
{
|
|
|
|
NULL,
|
|
|
|
NULL,
|
|
|
|
NULL,
|
|
|
|
NULL,
|
|
|
|
NULL
|
|
|
|
}
|
|
|
|
};
|