NTLDR
| Тип | |
|---|---|
| Разработчик | |
| Операционная система | |
| Последняя версия | |
| Лицензия |
NTLDR (сокращение от англ. NT Loader) в загрузчик операционных систем Windows NT и более поздних, за исключением Windows Vista и Windows 7. NTLDR может быть запущен как с переносного устройства такого, как например, CD-ROM или флэш-накопителя USB), так и с жесткого диска. NTLDR также способен загружать операционные системы, не основанные на технологии NT, путём задания соответствующего загрузочного сектора в отдельном файле[1]. Для запуска NTLDR требуется, как минимум, наличие следующих двух файлов на активном разделе: NTLDR, который собственно и содержит код загрузчика, и boot.ini, в котором записаны команды для формирования меню выбора системы и параметры для её запуска. Чтобы загружать операционные системы на базе Windows NT, необходимо также наличие файла ntdetect.com.
Содержание |
[править] Процесс запуска
При загрузке NTLDR выполняет следующие шаги:
- Переводит процессор в «плоский» 32-битный режим работы (англ. 32-bit flat memory mode).
- Организует доступ к текущей файловой системе.
- Если присутствует файл
hiberfil.sysи загрузчик обнаруживает образ спящего режима, содержимое образа загружается в оперативную память, и система восстанавливается в предыдущее состояние. - В противном случае, он читает файл
boot.iniи выводит пользователю соответствующее меню для выбора запускаемой операционной системы. Если была выбрана не система семейства Windows NT (например, Windows 98), тогда он загружает файл, указанный вboot.ini(bootsect.dos, если не указан иной файл, являющийся полноценной загрузочной записью), и управление передаётся этому файлу, либо он загружает операционную систему на базе DOS. Если же была выбрана система на базе Windows NT, то запускается программаntdetect.com, которая собирает информацию о составе оборудования. - Запускает файл
ntoskrnl.exe(ядро операционной системы), передавая ему собранную информацию о составе оборудования, после чего происходит собственно запуск операционной системы.
[править] Настройки
Как уже было сказано, NTLDR позволяет пользователю выбрать желаемую операционную систему для запуска из меню; также, для операционных систем Windows NT и более поздних, могут быть указаны дополнительные опции загрузки ядра. Все эти настройки хранятся в файле boot.ini, который должен находиться в корне того же логического диска, что и NTLDR.
Для формирования меню, показанного выше, был использован файл boot.ini следующего содержания:
[boot loader] timeout=30 default=multi(0)disk(0)rdisk(0)partition(3)\WINDOWS [operating systems] multi(0)disk(0)rdisk(0)partition(3)\WINDOWS="Windows Server 2003, Enterprise RU" /noexecute=optout /fastdetect multi(0)disk(0)rdisk(0)partition(2)\WINDOWS="Microsoft Windows XP Professional RU" /noexecute=optin /fastdetect C:\="Microsoft Windows"
Если указать в секции boot loader параметр timeout равным 0, то загрузочное меню отображаться будет бесконечно, а если данный параметр сделать равным 1, то сразу запустится операционная система, заданная в параметре default.
[править] Разрешённые опции загрузки ядра
[править] Для Windows NT
|
|
|
[править] Для Windows 2000
|
|
|
[править] Для Windows XP и 2003
|
|
[править] Описания параметров
/3GBв ключ меняет стандартное распределение между приложением и системой виртуальной адресации Windows NT, то есть приложение получит в свое распоряжение 3 гигабайта памяти, а система один. Предоставление большей виртуальной памяти прикладным программам, интенсивно использующим память подобно серверам баз данных, может улучшить их производительность. Однако, чтобы приложение смогло использовать это преимущество, оно должно быть помечено как приложение 3GB-aware. Этот параметр появился в третьем пакете обновления для Windows NT 4.0 и существует на всех более поздних версиях./BASEVIDEOв ключ заставляет систему использовать стандартный драйвер VGA в графическом режиме./BAUDRATE=числов ключ включает режим отладки ядра и определяет скорость порта (по умолчанию 19200 бод), по которой будет подключаться удаленный узел отладки. При установке этого параметра автоматически включается параметр/DEBUG. Пример:/BAUDRATE=115200./BOOTLOGв ключ включает режим записи протокола загрузки в файл%SYSTEMROOT%\NTBTLOG.TXT. В протокол записываются детали загрузки драйверов. Пример протокола:
Microsoft (R) Windows NT (R) Version 5.0
Loaded driver WINNT\System32\Ntoskrnl.exe
Loaded driver WINNT\System32\hal.dll
Loaded driver WINNT\System32\BOOTVID.dll
Loaded driver pci.sys
Loaded driver isapnp.sys
Loaded driver intelide.sys
/BURNMEMORYв эта опция заставит систему не обращать внимания на ограничения относительно указанного объёма памяти, например,/MAXMEM. Значение задаётся в мегабайтах. Пример:/BURNMEMORY=128указал бы системе в отбрось 128МБ физической памяти на машине как непригодные[противоречие]./CHANNELв используется совместно с параметрами/DEBUGи/DEBUGPORTв целях поддержки порта IEEE 1394./CRASHDEBUGв загружает отладчик ядра в память, где он остается до тех пор, пока не возникнет ошибка ядра./DEBUGв загружает отладчик ядра в память. Этот параметр может быть активирован в любой момент из удаленного отладчика, расположенного на компьютере, который подключен к последовательному порту локального компьютера. В отличие от параметра/CRASHDEBUG, при использовании параметра/DEBUGпоследовательный порт всегда работает как порт отладки. Этот режим используется, если в работе системы регулярно возникают ошибки[2]./DEBUGPORT=COMxв Задает порт COM для отладки./EXECUTEв отключает предотвращение выполнения данных и Physical Address Extension в Windows Server 2003 (SP1)[3]/FASTDETECT[:COMn]в ключ заставляетntdetect.comпропустить поиск оборудования на определённых портах COM при загрузке Windows 2000. Можно указывать номера последовательных портов, для которых надо отключить поиск устройств, через запятую. При пропуске значения параметра поиск устройств будет отключен для всех портов./HAL=имя_файлав задаёт слой аппаратных абстракций. Явное указание параметра переопределяет значение, указанное при установке. Например, таким образом, можно проводить тестирование программного обеспечения на предмет работоспособности в системах с разным количеством ядер центрального процессора, не прибегая к переустановке Windows NT или использованию виртуальных машин./INTAFFINITYв определяет использование многопроцессорного слоя аппаратных абстракций (HALMPS.DLL) для распределения прерываний, например, назначение прерывания в многопроцессорной системе только процессору, имеющему высший приоритет. Без этого ключа слой аппаратных абстракций обычным образом разрешает всем процессорам получать прерывание./KERNEL=имя_файлав указывает загрузчику какое ядро следует загружать. Например,/KERNEL=ntkrnlmp.exeв загрузка многопроцессорного ядра с памятью меньше 3 ГБ./MAXMEMв Эта опция ограничивает для NT использование памяти. Число в МБайт. Пример:/MAXMEM=32ограничил бы NT 32МБ системной памяти.
/MAXPROCSPERCLUSTERв Многопроцессорный HAL в Win2K (HALMPS.DLL) имеет способность к работе с многопроцессорными системами, которые составлены из кластеров в свою очередь состоящих из малых мультипроцессорных систем. Например, если имеется 8-процессорная система, которая составлена из двух 4-процессорных кластеров, то ID каждого процессора должен быть определен ориентируемым кластером через HAL. Размер максимального кластера в 4, и значение по умолчанию в 0 (система не основана на кластерах). Пример:/MAXPROCSPERCLUSTER=3.
/NODEBUGв Запрещает использование любой отладочной информации.
/NOEXECUTEв Определяет уровень DEP[4] (появилась начиная с Windows XP SP2). Может принимать четыре значения AlwaysOn, AlwaysOff, OptIn и OptOut.OptInв данное значение используется по умолчанию. На компьютерах, оснащенных процессорами с поддержкой DEP, функция DEP включена по умолчанию для ограниченного числа системных файлов и программ. При этом по умолчанию защищаются только системные файлы Windows.OptOutв по умолчанию функция DEP включена для всех процессов. В диалоговом окне Система панели управления можно вручную создать список приложений, для которых следует отключить DEP. Специалисты по информационным технологиям могут воспользоваться пакетом средств обеспечения совместимости приложений (Application Compatibility Toolkit), чтобы отключить функцию DEP для одной или нескольких программ. При этом вступают в силу исправления, обеспечивающие совместимость программ, для функции DEP.AlwaysOnв Функция DEP включается для всей системы. Все процессы работают с выполнением проверок DEP. В этом режиме нельзя отключить функцию DEP для отдельных приложений. Исправления, обеспечивающие совместимость программ, для функции DEP в силу не вступают. Программы, для которых с помощью пакета средств обеспечения совместимости приложений было отключено использование функции DEP, также работают с выполнением проверок DEP.AlwaysOffв Функция DEP отключена для всей системы, независимо от наличия аппаратной поддержки DEP. Процессор не работает в режиме PAE, если в файле Boot.ini не указан параметр /PAE.
/NOGUIBOOTв Когда эта опция задана, VGA video драйвер, ответственный за представление графики в течение процесса загрузки Win2Kв™s не инициализируется. Вообще этот драйвер используется для отображения на экране монитора процесса загрузки, и как правило для отображения Blue Screen, таким образом включение этой опции в BOOT.INI сделает все это невозможным.
/NOPAEв Загружает версию ядра NT без расширения физических адресов (PAE).
/NOSERIALMICEв [COMx | COMx, y, z :] в Отключает обнаружение мыши, подключенной к последовательному COM порту (портам).
/NUMPROCв Допускается только число указанных центральных процессоров. Пример: /NUMPROC=2 на системе с 4 процессорами заставит 2 из этих 4 процессоров простаивать под NT.
/ONECPUв эта опция указывает NT, использовать только один процессор мультипроцессорной системы.
/PAEв Загружает версию ядра NT с расширением физических адресов (PAE).
/PCILOCKв Запрещает Windows NT динамически назначать IO/IRQ ресурсы на PCI устройства и оставляет конфигурацию BIOS.
/PERFMEMи/PERFPAGESв Эти ключи не поддерживаются в final release операционных систем, так как они используются NT для резервирования физической памяти для Basic Block Testing (BBT). Существует только одно известное упоминание о BBT на сайте Microsoft: судебное дело США против Microsoft от 2-ого февраля 1999 года. В нём рассказывается о том как Jim Allchin отвечал под присягой на вопросы по поводу BBT. Он сказал, что BBT в вещь оптимизирующая производительность системы. Microsoft использует её в пререлизах, для того чтобы минимизировать количество страниц памяти./PERFMEMопределяет резервирование физической памяти в MB, а/PERFPAGESв количество страниц памяти. Эти параметры не должны присутствовать совместно. Место для BBT резервируется в Thread Environment Block (TEB) каждого потока. На самом деле точно не известно как конкретно влияет каждый из параметров на работу системы.
/SAFEBOOTв Используется крайне редко, так как выполняет те же действия, что и при нажатии F8 для загрузки в безопасном режиме NTLDR. Но Вы можете определить один из трех дополнительных ключей:MINIMAL,NETWORK, илиDSREPAIR.MINIMALиNETWORKотвечают за загрузку ОС в безопасном режиме без и с поддержкой сети соответственно. В безопасном режиме NT загружает только драйвера и сервисы, описанные по имени или группе в Minimal или Network ключах реестра:[HKLM\System\CurrentControlSet\Control\SafeBoot]. КлючDSREPAIR(Directory Services Repair) указывает NT, что необходимо грузиться в режиме, который восстанавливает Active Directory из backupв™а. Дополнительная опция, которую можно определить вALTERNATESHELL. Она указывает ядру NT, какую программу, описанную в реестре[HKLM\System\CurrentControlSet\Control\SafeBoot\AlternateShell]использовать в качестве графической оболочки, взамен используемого по умолчанию Explorerв™а.
/SOSв Заставляет NT выдавать во время загрузки всю информацию относительно того, какие драйверы загружены, и насколько успешно.
/TIMERESв На многопроцессорном HAL (HALMPS.DLL) эта опция установит разрешающую способность системного таймера. Параметр в число в сотнях наносекунд, его значение будет установлено ближайшим меньшим, который поддерживает HAL. Заданная по умолчанию разрешающая способность в 7.8ms. Пример:/TIMERES=9000установил бы таймер на разрешение в 0,98ms.
/USE8254в Этот параметр предназначен для систем со старым BIOS. Он говорит NT HAL, что необходимо использовать 8254 чип таймера в качестве основного.
/USEPMTIMERв Параметр указывает на то, что операционные системы Windows XP и Windows Server 2003 используют параметры таймера PM-TIMER, а не параметры счетчика отметок времени, если процессор поддерживает параметры таймера PM_TIMER .
Дополнительные сведения о параметре /usepmtimer см. в следующей статье базы знаний Майкрософт: 895980
/USERVA=xxxxв Параметр позволяет выполнять тонкую настройку объёма виртуальной памяти для режима пользователя и виртуальной памяти системы в семействе Windows Server 2003. Он используется совместно с параметром/3GBв файле Boot.ini и позволяет варьировать объём виртуальной памяти в режиме пользователя в пределах между 2 и 3 ГБ, а разницу (3,072 за вычетом xxxx) отдавать обратно режиму ядра.
/YEARв опция очевидно предназначена для проверки на соответствие Y2K. Определение этого параметра говорит ядру NT, что необходимо игнорировать год, сообщаемый системным таймером компьютера, и вместо этого использовать определенный в BOOT.INI. Таким образом, год, используемый в BOOT.INI, воздействует на все программное обеспечение в системе, включая ядро NT. Пример:/YEAR=2001. Примечание: эта опция доступна только на NT 4.0 SP4 и Windows 2000.
[править] Примечания
- в‘ «Использование ntldr для загрузки Linux». Архивировано из первоисточника 25 августа 2011.
- в‘ «Параметры, используемые в файле
boot.iniв Windows XP и Windows Server 2003». PressPass. Microsoft (06 июня 2006 года). Архивировано из первоисточника 25 августа 2011. Проверено 2 мая 2007. - в‘ [содержимое удалено]
- в‘ Подробное описание функции предотвращения выполнения данных, входящей в состав Windows XP с пакетом обновлений 2 (SP2), Windows XP Tablet PC Edition 2005 и Windows Server 2003. PressPass. Microsoft (October 25 2006). Архивировано из первоисточника 25 августа 2011. Проверено 2 мая 2007.
[править] См. также
[править] Ссылки
- Подробное описание функции предотвращения выполнения данных (рус.)
- «Редактирование файла
boot.iniв Windows XP» - «Назначение файла
boot.iniв Windows XP» - «Параметры, используемые в файле
boot.iniв Windows XP и Windows Server 2003» (рус.)