windows-nt/Source/XPSP1/NT/base/ntos/config/cmdat.c
2020-09-26 16:20:57 +08:00

409 lines
14 KiB
C
Raw Blame History

This file contains invisible Unicode characters

This file contains invisible Unicode characters that are indistinguishable to humans but may be processed differently by a computer. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

/*++
Copyright (c) 1990, 1991 Microsoft Corporation
Module Name:
cmdat.c
Abstract:
This module contains registry "static" data, except for data
also used by setup, which is in cmdat2.c.
Author:
Bryan Willman (bryanwi) 19-Oct-93
Environment:
Kernel mode.
Revision History:
--*/
#include "cmp.h"
//
// ***** INIT *****
//
#ifdef ALLOC_DATA_PRAGMA
#pragma data_seg("INIT")
#pragma const_seg("INITCONST")
#endif
//
// ---------------------------
//
UNICODE_STRING CmpLoadOptions = { 0 }; // sys options from FW or boot.ini
//
// CmpClassString - contains strings which are used as the class
// strings in the keynode.
// The associated enumerated type is CONFIGURATION_CLASS in arc.h
//
UNICODE_STRING CmClassName[MaximumClass + 1] = { 0 };
const PWCHAR CmClassString[MaximumClass + 1] = {
L"System",
L"Processor",
L"Cache",
L"Adapter",
L"Controller",
L"Peripheral",
L"MemoryClass",
L"Undefined"
};
struct {
PUCHAR AscString;
USHORT InterfaceType;
USHORT Count;
} CmpMultifunctionTypes[] = {
"ISA", Isa, 0,
"MCA", MicroChannel, 0,
"PCI", PCIBus, 0,
"VME", VMEBus, 0,
"PCMCIA", PCMCIABus, 0,
"CBUS", CBus, 0,
"MPIPI", MPIBus, 0,
"MPSA", MPSABus, 0,
NULL, Internal, 0
};
USHORT CmpUnknownBusCount = 0;
ULONG CmpConfigurationAreaSize = 0x4000; // Initialize size = 16K
PCM_FULL_RESOURCE_DESCRIPTOR CmpConfigurationData = { 0 };
//
// The following strings will be used as the keynames for registry
// nodes.
// The associated enumerated type is CONFIGURATION_TYPE in arc.h
//
UNICODE_STRING CmTypeName[MaximumType + 1] = { 0 };
//
// ***** PAGE *****
//
#ifdef ALLOC_DATA_PRAGMA
#pragma data_seg("PAGEDATA")
#pragma const_seg("PAGECONST")
#endif
const PWCHAR CmTypeString[MaximumType + 1] = {
L"System",
L"CentralProcessor",
L"FloatingPointProcessor",
L"PrimaryICache",
L"PrimaryDCache",
L"SecondaryICache",
L"SecondaryDCache",
L"SecondaryCache",
L"EisaAdapter",
L"TcAdapter",
L"ScsiAdapter",
L"DtiAdapter",
L"MultifunctionAdapter",
L"DiskController",
L"TapeController",
L"CdRomController",
L"WormController",
L"SerialController",
L"NetworkController",
L"DisplayController",
L"ParallelController",
L"PointerController",
L"KeyboardController",
L"AudioController",
L"OtherController",
L"DiskPeripheral",
L"FloppyDiskPeripheral",
L"TapePeripheral",
L"ModemPeripheral",
L"MonitorPeripheral",
L"PrinterPeripheral",
L"PointerPeripheral",
L"KeyboardPeripheral",
L"TerminalPeripheral",
L"OtherPeripheral",
L"LinePeripheral",
L"NetworkPeripheral",
L"SystemMemory",
L"DockingInformation",
L"RealModeIrqRoutingTable",
L"RealModePCIEnumeration",
L"Undefined"
};
//
// CmpTypeCount[] - For each 'type', a count is used to keep track how many
// keys have been created.
//
ULONG CmpTypeCount[NUMBER_TYPES] = {
0, // ArcSystem
0, // CentralProcessor",
0, // FloatingPointProcessor",
0, // PrimaryICache",
0, // PrimaryDCache",
0, // SecondaryICache",
0, // SecondaryDCache",
0, // SecondaryCache",
0, // EisaAdapter", (8)
0, // TcAdapter", (9)
0, // ScsiAdapter",
0, // DtiAdapter",
0, // MultifunctionAdapter", (12)
0, // DiskController", (13)
0, // TapeController",
0, // CdRomController",
0, // WormController",
0, // SerialController",
0, // NetworkController",
0, // DisplayController",
0, // ParallelController",
0, // PointerController",
0, // KeyboardController",
0, // AudioController",
0, // OtherController",
0, // DiskPeripheral",
0, // FloppyDiskPeripheral",
0, // TapePeripheral",
0, // ModemPeripheral",
0, // MonitorPeripheral",
0, // PrinterPeripheral",
0, // PointerPeripheral",
0, // KeyboardPeripheral",
0, // TerminalPeripheral",
0, // OtherPeripheral",
0, // LinePeripheral",
0, // NetworkPeripheral",
0, // SystemMemory",
0, // DockingInformation,
0, // RealModeIrqRoutingTable
0 // Undefined"
};
const UNICODE_STRING nullclass = { 0, 0, NULL };
//
// All names used by the registry
//
UNICODE_STRING CmRegistryRootName = { 0 };
UNICODE_STRING CmRegistryMachineName = { 0 };
UNICODE_STRING CmRegistryMachineHardwareName = { 0 };
UNICODE_STRING CmRegistryMachineHardwareDescriptionName = { 0 };
UNICODE_STRING CmRegistryMachineHardwareDescriptionSystemName = { 0 };
UNICODE_STRING CmRegistryMachineHardwareDeviceMapName = { 0 };
UNICODE_STRING CmRegistryMachineHardwareResourceMapName = { 0 };
UNICODE_STRING CmRegistryMachineHardwareOwnerMapName = { 0 };
UNICODE_STRING CmRegistryMachineSystemName = { 0 };
UNICODE_STRING CmRegistryMachineSystemCurrentControlSet = { 0 };
UNICODE_STRING CmRegistryMachineSystemCurrentControlSetEnumName = { 0 };
UNICODE_STRING CmRegistryMachineSystemCurrentControlSetEnumRootName = { 0 };
UNICODE_STRING CmRegistryMachineSystemCurrentControlSetServices = { 0 };
UNICODE_STRING CmRegistryMachineSystemCurrentControlSetHardwareProfilesCurrent = { 0 };
UNICODE_STRING CmRegistryMachineSystemCurrentControlSetControlClass = { 0 };
UNICODE_STRING CmRegistryMachineSystemCurrentControlSetControlSafeBoot = { 0 };
UNICODE_STRING CmRegistryMachineSystemCurrentControlSetControlSessionManagerMemoryManagement = { 0 };
UNICODE_STRING CmRegistryMachineSystemCurrentControlSetControlBootLog = { 0 };
UNICODE_STRING CmRegistryMachineSystemCurrentControlSetServicesEventLog = { 0 };
UNICODE_STRING CmRegistryUserName = { 0 };
UNICODE_STRING CmRegistrySystemCloneName = { 0 };
UNICODE_STRING CmpSystemFileName = { 0 };
UNICODE_STRING CmSymbolicLinkValueName = { 0 };
#ifdef _WANT_MACHINE_IDENTIFICATION
UNICODE_STRING CmRegistryMachineSystemCurrentControlSetControlBiosInfo = { 0 };
#endif
const PWCHAR CmpRegistryRootString = L"\\REGISTRY";
const PWCHAR CmpRegistryMachineString = L"\\REGISTRY\\MACHINE";
const PWCHAR CmpRegistryMachineHardwareString =
L"\\REGISTRY\\MACHINE\\HARDWARE";
const PWCHAR CmpRegistryMachineHardwareDescriptionString =
L"\\REGISTRY\\MACHINE\\HARDWARE\\DESCRIPTION";
const PWCHAR CmpRegistryMachineHardwareDescriptionSystemString =
L"\\REGISTRY\\MACHINE\\HARDWARE\\DESCRIPTION\\SYSTEM";
const PWCHAR CmpRegistryMachineHardwareDeviceMapString =
L"\\REGISTRY\\MACHINE\\HARDWARE\\DEVICEMAP";
const PWCHAR CmpRegistryMachineHardwareResourceMapString =
L"\\REGISTRY\\MACHINE\\HARDWARE\\RESOURCEMAP";
const PWCHAR CmpRegistryMachineHardwareOwnerMapString =
L"\\REGISTRY\\MACHINE\\HARDWARE\\OWNERMAP";
const PWCHAR CmpRegistryMachineSystemString =
L"\\REGISTRY\\MACHINE\\SYSTEM";
const PWCHAR CmpRegistryMachineSystemCurrentControlSetString =
L"\\REGISTRY\\MACHINE\\SYSTEM\\CURRENTCONTROLSET";
const PWCHAR CmpRegistryMachineSystemCurrentControlSetEnumString =
L"\\REGISTRY\\MACHINE\\SYSTEM\\CURRENTCONTROLSET\\ENUM";
const PWCHAR CmpRegistryMachineSystemCurrentControlSetEnumRootString =
L"\\REGISTRY\\MACHINE\\SYSTEM\\CURRENTCONTROLSET\\ENUM\\ROOT";
const PWCHAR CmpRegistryMachineSystemCurrentControlSetServicesString =
L"\\REGISTRY\\MACHINE\\SYSTEM\\CURRENTCONTROLSET\\SERVICES";
const PWCHAR CmpRegistryMachineSystemCurrentControlSetHardwareProfilesCurrentString =
L"\\REGISTRY\\MACHINE\\SYSTEM\\CURRENTCONTROLSET\\HARDWARE PROFILES\\CURRENT";
const PWCHAR CmpRegistryMachineSystemCurrentControlSetControlClassString =
L"\\REGISTRY\\MACHINE\\SYSTEM\\CURRENTCONTROLSET\\CONTROL\\CLASS";
const PWCHAR CmpRegistryMachineSystemCurrentControlSetControlSafeBootString =
L"\\REGISTRY\\MACHINE\\SYSTEM\\CURRENTCONTROLSET\\CONTROL\\SAFEBOOT";
const PWCHAR CmpRegistryMachineSystemCurrentControlSetControlSessionManagerMemoryManagementString =
L"\\REGISTRY\\MACHINE\\SYSTEM\\CURRENTCONTROLSET\\CONTROL\\SESSION MANAGER\\MEMORY MANAGEMENT";
const PWCHAR CmpRegistryMachineSystemCurrentControlSetControlBootLogString =
L"\\REGISTRY\\MACHINE\\SYSTEM\\CURRENTCONTROLSET\\CONTROL\\BOOTLOG";
const PWCHAR CmpRegistryMachineSystemCurrentControlSetServicesEventLogString =
L"\\REGISTRY\\MACHINE\\SYSTEM\\CURRENTCONTROLSET\\SERVICES\\EVENTLOG";
const PWCHAR CmpRegistryUserString = L"\\REGISTRY\\USER";
const PWCHAR CmpRegistrySystemCloneString = L"\\REGISTRY\\MACHINE\\CLONE";
const PWCHAR CmpRegistrySystemFileNameString = L"SYSTEM";
const PWCHAR CmpRegistryPerflibString = L"\\REGISTRY\\MACHINE\\SOFTWARE\\MICROSOFT\\WINDOWS NT\\CURRENTVERSION\\PERFLIB";
const PWCHAR CmpProcessorControl = L"ProcessorControl";
const PWCHAR CmpControlSessionManager = L"Control\\Session Manager";
const PWCHAR CmpSymbolicLinkValueName = L"SymbolicLinkValue";
#ifdef _WANT_MACHINE_IDENTIFICATION
const PWCHAR CmpRegistryMachineSystemCurrentControlSetControlBiosInfoString =
L"\\REGISTRY\\MACHINE\\SYSTEM\\CURRENTCONTROLSET\\CONTROL\\BIOSINFO";
#endif
//
// N.B. The CLONE hive is left out of the machine Hive list if
// we will not be using it to clone the current control set,
// since that is that Hive's only purpose.
//
HIVE_LIST_ENTRY CmpMachineHiveList[] = {
{ L"HARDWARE", L"MACHINE\\", NULL, HIVE_VOLATILE , NULL, FALSE, FALSE, FALSE},
{ L"SECURITY", L"MACHINE\\", NULL, 0 , NULL, FALSE, FALSE, FALSE},
{ L"SOFTWARE", L"MACHINE\\", NULL, 0 , NULL, FALSE, FALSE, FALSE},
{ L"SYSTEM", L"MACHINE\\", NULL, 0 , NULL, FALSE, FALSE, FALSE},
{ L"DEFAULT", L"USER\\.DEFAULT", NULL, 0 , NULL, FALSE, FALSE, FALSE},
{ L"SAM", L"MACHINE\\", NULL, HIVE_NOLAZYFLUSH , NULL, FALSE, FALSE, FALSE},
#if CLONE_CONTROL_SET
{ L"CLONE", L"MACHINE\\", NULL, HIVE_VOLATILE , NULL, FALSE, FALSE, FALSE},
#endif
// { L"TEST", L"MACHINE\\", NULL, HIVE_NOLAZYFLUSH , NULL, FALSE, FALSE, FALSE},
{ NULL, NULL, 0, 0 , NULL, FALSE, FALSE, FALSE}
};
UCHAR SystemHiveFullPathBuffer[MAX_NAME];
UNICODE_STRING SystemHiveFullPathName;
//
// Master Hive
//
// The KEY_NODEs for \REGISTRY, \REGISTRY\MACHINE, and \REGISTRY\USER
// are stored in a small memory only hive called the Master Hive.
// All other hives have link nodes in this hive which point to them.
//
PCMHIVE CmpMasterHive = { 0 };
BOOLEAN CmpNoMasterCreates = FALSE; // Set TRUE after we're done to
// prevent random creates in the
// master hive, which is not backed
// by a file.
LIST_ENTRY CmpHiveListHead = { 0 }; // List of CMHIVEs
FAST_MUTEX CmpHiveListHeadLock; // used to protect the list above
//
// Addresses of object type descriptors:
//
POBJECT_TYPE CmpKeyObjectType = { 0 };
//
// Write-Control:
// CmpNoWrite is initially true. When set this way write and flush
// do nothing, simply returning success. When cleared to FALSE, I/O
// is enabled. This change is made after the I/O system is started
// AND autocheck (chkdsk) has done its thing.
//
BOOLEAN CmpNoWrite = TRUE;
//
// NtInitializeRegistry global status flags
//
//
// If CmFirstTime is TRUE, then NtInitializeRegistry has not yet been
// called to perform basic registry initialization
//
BOOLEAN CmFirstTime = TRUE;
//
// trick to allow paralel threads to access the registry
//
BOOLEAN CmpSpecialBootCondition = FALSE;
//
// If CmBootAcceptFirstTime is TRUE, then NtInitializeRegistry has not
// yet been called to accept the current Boot and save the boot
// control set as the LKG control set.
//
BOOLEAN CmBootAcceptFirstTime = TRUE;
//
// CmpWasSetupBoot indicates whether or not the boot
// is into text mode setup. If so, we do not turn
// on global quotas.
//
BOOLEAN CmpWasSetupBoot;
//
// Indicates whether the hives need to be loaded in memory
// and in scratch mode
//
BOOLEAN CmpMiniNTBoot = FALSE;
//
// Indicates whether the system hives need to be opened in a
// shared mode. Generally needed if we are booting WinPE (MiniNT)
// on network
//
BOOLEAN CmpShareSystemHives = FALSE;
//
// Where are we booting from
//
ULONG CmpBootType;
//
// Self healing hives control switch
//
BOOLEAN CmpSelfHeal = TRUE;
#ifdef ALLOC_DATA_PRAGMA
#pragma const_seg()
#pragma data_seg()
#endif
//
// ***** FIXED *****
//