NTLDR: различия между версиями

Материал из Википедии — свободной энциклопедии
Перейти к навигации Перейти к поиску
[непроверенная версия][отпатрулированная версия]
Содержимое удалено Содержимое добавлено
Процесс запуска: оформление, стилевые правки, пунктуация
м Описание: clean up, replaced: 2-го февраля → 2 февраля
 
(не показано 48 промежуточных версий 31 участника)
Строка 1: Строка 1:
{{Карточка программы
{{Карточка программы
|Имя = NTLDR
|Имя = NTLDR
|screenshot =
|screenshot =
|caption =
|caption =
|genre = [[Загрузчик операционной системы]]
|genre = [[Загрузчик операционной системы]]
|developer = ''[[Microsoft]]''
|developer = [[Microsoft]]
|operating_system = ''[[Windows NT]]'', [[Windows 2000|2000]], [[Windows XP|''XP'']], [[Windows Server 2003|''Server 2003'']]
|operating_system = [[Windows NT]], [[Windows 2000|2000]], [[Windows XP|XP]], [[Windows Server 2003|Server 2003]]
|latest_release_version =
|latest_release_version =
|latest_release_date =
|latest_release_date =
|license = [[Проприетарное программное обеспечение|Проприеритарная]]
|license = [[Проприетарное программное обеспечение|Проприетарная]]
}}
}}
'''NTLDR''' (сокращение от {{lang-en|NT Loader}}) — [[Загрузчик операционной системы|загрузчик операционных систем]] ''[[Windows NT]]'' и более поздних, за исключением ''[[Windows Vista]]'' и ''[[Windows 7]]''. ''NTLDR'' может быть запущен как с переносного устройства такого, как например, ''[[CD-ROM]]'' или [[USB flash drive|флэш-накопителя ''USB'']]), так и с [[жесткий диск|жесткого диска]]. ''NTLDR'' также способен загружать операционные системы, не основанные на технологии ''NT'', путём задания соответствующего [[загрузочный сектор|загрузочного сектора]] в отдельном файле<ref>{{cite web
'''NTLDR''' (сокращение от {{lang-en|NT Loader}}) — [[Загрузчик операционной системы|загрузчик операционных систем]] [[Windows NT]]. NTLDR может быть запущен как с переносного устройства, такого, как, например, [[CD-ROM]] или [[USB flash drive|флэш-накопителя USB]]), так и с [[жёсткий диск|жёсткого диска]]. NTLDR также способен загружать операционные системы, не основанные на технологии NT, путём задания соответствующего [[загрузочный сектор|загрузочного сектора]] в отдельном файле.<ref>{{cite web
| url = http://www.knoppix.ru/adv230404.shtml
|url = http://www.knoppix.ru/adv230404.shtml
| title = «Использование ''ntldr'' для загрузки ''Linux''»
|title = Использование ntldr для загрузки Linux
|deadurl = yes
| archiveurl = http://www.webcitation.org/61CRdwAKo
| archivedate = 2011-08-25
|accessdate = 2010-08-11
|archive-date = 2011-10-15
}}
|archive-url = https://web.archive.org/web/20111015062434/http://knoppix.ru/adv230404.shtml
</ref>. Для запуска ''NTLDR'' требуется, как минимум, наличие следующих двух файлов на активном разделе: ''NTLDR'', который собственно и содержит код загрузчика, и <code>[[boot.ini]]</code>, в котором записаны команды для формирования меню выбора системы и параметры для её запуска. Чтобы загружать операционные системы на базе ''[[Windows NT]]'', необходимо также наличие файла <code>[[ntdetect.com]]</code>.
}}</ref> Для запуска NTLDR требуется, как минимум, наличие следующих двух файлов на активном разделе: NTLDR, который, собственно, и содержит код загрузчика, и boot.ini, в котором записаны команды для формирования меню выбора системы и параметры для её запуска. Чтобы загружать операционные системы на базе Windows NT, необходимо также наличие файла [[ntdetect.com]].


== Процесс запуска ==
== Процесс запуска ==
При загрузке ''NTLDR'' выполняет следующие шаги:
При загрузке NTLDR выполняет следующие шаги:
# Переводит процессор в [[Unreal mode|«плоский»]] 32-битный режим работы ({{lang-en|32-bit flat memory mode}}).
# Переводит процессор в «[[Unreal mode|плоский]]» 32-битный режим работы ({{lang-en|32-bit flat memory mode}}).
# Организует доступ к текущей [[Файловая система|файловой системе]].
# Организует доступ к текущей [[Файловая система|файловой системе]].
# Если присутствует файл <code>[[Гибернация (операционные системы)|hiberfil.sys]]</code> и загрузчик обнаруживает образ [[Гибернация (операционные системы)|спящего режима]], содержимое образа загружается в оперативную память, и система восстанавливается в предыдущее состояние.
# Если присутствует файл [[Гибернация (операционные системы)|hiberfil.sys]] и загрузчик обнаруживает образ спящего режима, содержимое образа загружается в оперативную память, и система восстанавливается в предыдущее состояние.
# В противном случае, он читает файл <code>boot.ini</code> и выводит пользователю соответствующее меню для выбора запускаемой операционной системы. Если была выбрана не система семейства ''Windows NT'' (например, ''[[Windows 98]]''), тогда он загружает файл, указанный в <code>boot.ini</code> (<code>bootsect.dos</code>, если не указан иной файл, являющийся полноценной [[загрузочный сектор|загрузочной записью]]), и управление передаётся этому файлу, либо он загружает операционную систему на базе ''[[DOS]]''. Если же была выбрана система на базе ''Windows NT'', то запускается программа <code>[[ntdetect.com]]</code>, которая собирает информацию о составе оборудования.
# В противном случае, он читает файл boot.ini и выводит пользователю соответствующее меню для выбора запускаемой операционной системы. Если была выбрана не система семейства Windows NT (например, [[Windows 98]]), тогда он загружает файл, указанный в boot.ini (bootsect.dos, если не указан иной файл, являющийся полноценной [[загрузочный сектор|загрузочной записью]]), и управление передаётся этому файлу, либо он загружает операционную систему на базе [[DOS]]. Если же была выбрана система на базе Windows NT, то запускается программа [[ntdetect.com]], которая собирает информацию о составе оборудования.
# Запускает файл <code>[[ntoskrnl.exe]]</code> (ядро операционной системы), передавая ему собранную информацию о составе оборудования, после чего происходит собственно запуск операционной системы.
# Запускает файл [[ntoskrnl.exe]] (ядро операционной системы), передавая ему собранную информацию о составе оборудования, после чего происходит собственно запуск операционной системы.


== Boot.ini ==
=== Настройки ===
[[Файл:NTLDR.png|thumb|350px|Локализованная версия загрузчика]]
[[Файл:NTLDR.png|thumb|350px|Локализованная версия загрузчика]]
Как уже было сказано, NTLDR позволяет пользователю выбрать желаемую операционную систему для запуска из обычного меню; также, для операционных систем Windows NT и более поздних, могут быть указаны дополнительные опции загрузки ядра. Все эти настройки хранятся в файле ''[[boot.ini]]'', который должен находиться в корне того же логического диска, что и ''NTLDR''.
Как уже было сказано, NTLDR позволяет пользователю выбрать желаемую операционную систему для запуска из меню; также, для операционных систем Windows NT и более поздних, могут быть указаны дополнительные опции загрузки ядра. Все эти настройки хранятся в файле boot.ini, который должен находиться в корне того же [[Логический диск|логического диска]], что и NTLDR.


Для формирования меню, показанного выше, был использован файл boot.ini следующего содержания:
=== Пример файла [[boot.ini]] ===
<source lang=ini>
Для формирования меню, показанного выше, был использован файл ''[[boot.ini]]'' следующего содержания:
<pre>
[boot loader]
[boot loader]
timeout=30
timeout=30
Строка 40: Строка 40:
multi(0)disk(0)rdisk(0)partition(2)\WINDOWS="Microsoft Windows XP Professional RU" /noexecute=optin /fastdetect
multi(0)disk(0)rdisk(0)partition(2)\WINDOWS="Microsoft Windows XP Professional RU" /noexecute=optin /fastdetect
C:\="Microsoft Windows"
C:\="Microsoft Windows"
</pre>
</source>
В секции <code>boot loader</code> параметр <code>timeout</code> указывает время в секундах, в течение которого будет отображаться данное меню. Если установить значение 0, то меню отображаться не будет и сразу запустится операционная система, заданная в параметре <code>default</code>. В данном примере параметр равен 30 — значит, у пользователя будет 30 секунд для выбора операционной системы из предложенного списка.


=== Разрешённые опции загрузки ядра ===
Если указать в секции ''[boot loader]'' параметр ''timeout'' равным 0, то загрузочное меню отображаться будет бесконечно,а если данный параметр сделать равным 1, то сразу запустится операционная система, заданная в параметре ''default''.


==== Windows NT ====
=== Разрешённые опции загрузки ядра NT ===
==== Для Windows NT ====
{{col-begin}}
{{col-begin}}
{{col-3}}
{{col-3}}
* /3GB
* <code>/3GB</code>
* /BASEVIDEO
* <code>/BASEVIDEO</code>
* /BAUDRATE=число
* <code>/BAUDRATE</code>=<code>число</code>
* /CRASHDEBUG
* <code>/CRASHDEBUG</code>
* /DEBUG
* <code>/DEBUG</code>
* /DEBUGPORT=COMn
* <code>/DEBUGPORT</code>=<code>COMn</code>
{{col-3}}
{{col-3}}
* /HAL=имя_файла
* <code>/HAL</code>=<code>имя_файла</code>
* /KERNEL=имя_файла
* <code>/KERNEL</code>=<code>имя_файла</code>
* /MAXMEM=nn
* <code>/MAXMEM</code>=<code>nn</code>
* /NODEBUG
* <code>/NODEBUG</code>
* /NOSERIALMICE:COMn
* <code>/NOSERIALMICE:COMn</code>
* /NUMPROC=число
* <code>/NUMPROC</code>=<code>число</code>
{{col-3}}
{{col-3}}
* /ONECPU
* <code>/ONECPU</code>
* /PCILOCK
* <code>/PCILOCK</code>
* /SOS
* <code>/SOS</code>
* /WIN95
* <code>/WIN95</code>
* /WIN95DO
* <code>/WIN95DO</code>
{{col-end}}
{{col-end}}


==== Для Windows 2000 ====
==== Windows 2000 ====
{{col-begin}}
{{col-begin}}
{{col-3}}
{{col-3}}
* /3GB
* <code>/3GB</code>
* /BASEVIDEO
* <code>/BASEVIDEO</code>
* /BAUDRATE=число
* <code>/BAUDRATE</code>=<code>число</code>
* /BOOTLOG
* <code>/BOOTLOG</code>
* /CRASHDEBUG
* <code>/CRASHDEBUG</code>
* /DEBUG
* <code>/DEBUG</code>
{{col-3}}
{{col-3}}
* /DEBUGPORT=COMn
* <code>/DEBUGPORT</code>=<code>COMn</code>
* /FASTDETECT:COMn
* <code>/FASTDETECT:COMn</code>
* /HAL=имя_файла
* <code>/HAL</code>=<code>имя_файла</code>
* /KERNEL=имя_файла
* <code>/KERNEL</code>=<code>имя_файла</code>
* /MAXMEM=nn
* <code>/MAXMEM</code>=<code>nn</code>
{{col-3}}
{{col-3}}
* /NODEBUG
* <code>/NODEBUG</code>
* /NUMPROC=число
* <code>/NUMPROC</code>=<code>число</code>
* /PAE
* <code>/PAE</code>
* /SAFEBOOT:параметр
* <code>/SAFEBOOT:параметр</code>
* /SOS
* <code>/SOS</code>
{{col-end}}
{{col-end}}


==== Для Windows XP и 2003 ====
==== Windows XP и 2003 ====
{{col-begin}}
{{col-begin}}
{{col-3}}
{{col-3}}
* /3GB
* <code>/3GB</code>
* /BASEVIDEO
* <code>/BASEVIDEO</code>
* /BAUDRATE=число
* <code>/BAUDRATE</code>=<code>число</code>
* /BOOTLOG
* <code>/BOOTLOG</code>
* /BOOTLOGO
* <code>/BOOTLOGO</code>
* /BREAK
* <code>/BREAK</code>
* /BURNMEMORY=число
* <code>/BURNMEMORY</code>=<code>число</code>
* /CHANNEL
* <code>/CHANNEL</code>
* /CLKLVL
* <code>/CLKLVL</code>
* /CMDCONS
* <code>/CMDCONS</code>
* /CRASHDEBUG
* <code>/CRASHDEBUG</code>
* /DEBUG
* <code>/DEBUG</code>
* /DEBUGPORT=COMn
* <code>/DEBUGPORT</code>=<code>COMn</code>
* /EXECUTE
* <code>/EXECUTE</code>
* /FASTDETECT:COMn
* <code>/FASTDETECT:COMn</code>
{{col-3}}
{{col-3}}
* /INTAFFINITY
* <code>/INTAFFINITY</code>
* /HAL=имя_файла
* <code>/HAL</code>=<code>имя_файла</code>
* /KERNEL=имя_файла
* <code>/KERNEL</code>=<code>имя_файла</code>
* /LASTKNOWNGOOD
* <code>/LASTKNOWNGOOD</code>
* /MAXMEM=nn
* <code>/MAXMEM</code>=<code>nn</code>
* /MAXPROCSPERCLUSTER=
* <code>/MAXPROCSPERCLUSTER</code>=
* /MININT
* <code>/MININT</code>
* /NODEBUG
* <code>/NODEBUG</code>
* /NOEXECUTE=уровень_политики
* <code>/NOEXECUTE</code>=<code>уровень_политики</code>
* /NOGUIBOOT
* <code>/NOGUIBOOT</code>
* /NOLOWMEM
* <code>/NOLOWMEM</code>
* /NOPAE
* <code>/NOPAE</code>
* /NOSERIALMICE=COMn
* <code>/NOSERIALMICE</code>=<code>COMn</code>
* /NUMPROC=число
* <code>/NUMPROC</code>=<code>число</code>
{{col-3}}
{{col-3}}
* /ONECPU
* <code>/ONECPU</code>
* /PAE
* <code>/PAE</code>
* /PCILOCK
* <code>/PCILOCK</code>
* /RDPATH=
* <code>/RDPATH</code>=
* /REDIRECT
* <code>/REDIRECT</code>
* /SAFEBOOT:параметр
* <code>/SAFEBOOT:параметр</code>
* /SCSIORDINAL:параметр
* <code>/SCSIORDINAL:параметр</code>
* /SDIBOOT=
* <code>/SDIBOOT</code>=
* /SOS
* <code>/SOS</code>
* /TIMERES=
* <code>/TIMERES</code>=
* /USERVA
* <code>/USERVA</code>
* /WIN95
* <code>/WIN95</code>
* /WIN95DOS
* <code>/WIN95DOS</code>
* /YEAR=
* <code>/YEAR</code>=
{{col-end}}
{{col-end}}


==== Описание ====
== Описания параметров ==
* /3GB — Этот параметр появился в третьем сервис паке для NT 4.0 и существует на всех более поздних версиях. Этот ключ поменяет стандартное распределение между пользователем и системой карты виртуальной адресации NT, то есть пользователь получит в свое распоряжение 3GB, а система 1GB. Предоставление большей виртуальной памяти прикладным программам, интенсивно использующим память подобно серверам баз данных может улучшать их производительность. Однако, чтобы приложение смогло использовать это преимущество, оно должно быть помечено как приложение 3GB-aware (обычно такие приложения, например MS SQL 2000 имеют соответствующую настройку в параметрах).
* <code>/3GB</code> — ключ меняет стандартное распределение между приложением и системой [[Виртуальная память|виртуальной адресации]] Windows NT, то есть приложение получит в своё распоряжение 3 гигабайта памяти, а система — один. Предоставление большей виртуальной памяти прикладным программам, интенсивно использующим память, подобно серверам баз данных, может улучшить их производительность. Однако, чтобы приложение смогло использовать это преимущество, оно должно быть помечено как приложение 3GB-aware. Этот параметр появился в [[Windows NT 4.0#Пакеты обновления|третьем пакете обновления для Windows NT 4.0]] и существует на всех более поздних версиях.
* <code>/BASEVIDEO</code> — ключ заставляет систему использовать стандартный драйвер [[VGA]] в графическом режиме.

* <code>/BAUDRATE=число</code> — ключ включает режим отладки ядра и определяет скорость порта (по умолчанию 19200 бод), по которой будет подключаться удаленный узел [[Отладчик|отладки]]. При установке этого параметра автоматически включается параметр <code>/DEBUG</code>. Пример: <code>/BAUDRATE=115200</code>.
* /BASEVIDEO — Заставляет NT использовать стандартный драйвер VGA в режиме GUI.
* <code>/BOOTLOG</code> — ключ включает режим записи протокола загрузки в файл <code>[[Переменные среды|%SYSTEMROOT%]]\NTBTLOG.TXT</code>. В протокол записываются детали загрузки драйверов. Пример протокола:

* /BAUDRATE=number — Включает режим отладки ядра и определяет скорость порта по умолчанию (19200) по которой будет подключаться удаленный узел отладки. При установке этого параметра автоматически включается параметр /DEBUG. Например: /BAUDRATE=115200.

* /BOOTLOG — Определение этого ключа позволяет NT записать последовательность загруки в лог файл в %SystemRoot%\NTBTLOG.TXT. В лог файле описывается детально какой драйвер загружен или не загружен при загрузке ОС. Например, что-то вроде этого:
<pre>
<pre>
Microsoft (R) Windows NT (R) Version 5.0
Microsoft (R) Windows NT (R) Version 5.0
Loaded driver WINNT\System32\Ntoskrnl.exe
Loaded driver WINNT\System32\Ntoskrnl.exe
Loaded driver WINNT\System32\hal.dll
Loaded driver WINNT\System32\hal.dll
Loaded driver WINNT\System32\BOOTVID.dll
Loaded driver WINNT\System32\BOOTVID.dll
Loaded driver pci.sys
Loaded driver pci.sys
Loaded driver isapnp.sys
Loaded driver isapnp.sys
Loaded driver intelide.sys
Loaded driver intelide.sys
</pre>
</pre>
* <code>/BURNMEMORY</code> — эта опция заставит систему использовать меньшее количество оперативной памяти, чем физически доступное системе. Значение задаётся в мегабайтах. Пример: <code>/BURNMEMORY=128</code> указывает системе не использовать 128 мегабайт оперативной памяти. Microsoft рекомендует использовать эту опцию вместо <code>/MAXMEM</code> для воспроизведения поведения системы и приложений в условиях нехватки оперативной памяти.
* <code>/CHANNEL</code> — используется совместно с параметрами <code>/DEBUG</code> и <code>/DEBUGPORT</code> в целях поддержки порта [[IEEE 1394]].
* <code>/CRASHDEBUG</code> — загружает отладчик ядра в память, где он остается до тех пор, пока не возникнет ошибка ядра.
* <code>/DEBUG</code> — загружает отладчик ядра в память. Этот параметр может быть активирован в любой момент из удаленного отладчика, расположенного на компьютере, который подключен к последовательному порту локального компьютера. В отличие от параметра <code>/CRASHDEBUG</code>, при использовании параметра <code>/DEBUG</code> [[последовательный порт]] всегда работает как порт отладки. Этот режим используется, если в работе системы регулярно возникают ошибки.<ref>{{cite web
|url = https://support.microsoft.com/ru-ru/kb/833721
|title = Параметры, используемые в файле boot.ini в Windows XP и Windows Server 2003
|year = 6 июня 2006
|accessdate = 2007-05-02
|work = PressPass
|publisher = Microsoft
|deadurl = yes
|archive-date = 2011-09-06
|archive-url = https://web.archive.org/web/20110906073416/http://support.microsoft.com/kb/833721/ru
}}</ref>
* <code>/DEBUGPORT=COMx</code> — задаёт COM-порт для отладки.
* <code>/EXECUTE</code> — отключает [[предотвращение выполнения данных]] и [[PAE|Physical Address Extension]] в Windows Server 2003 (SP1)<ref>{{Cite web |url=https://msdn.microsoft.com/en-us/library/ff556257.aspx |title=/execute (Windows Drivers)<!-- Заголовок добавлен ботом --> |access-date=2016-11-28 |archive-date=2016-11-29 |archive-url=https://web.archive.org/web/20161129023811/https://msdn.microsoft.com/en-us/library/ff556257.aspx |deadlink=no }}</ref>
* <code>/FASTDETECT[:COMn]</code> — ключ заставляет ntdetect.com пропустить поиск оборудования на определённых COM-портах при загрузке Windows 2000. Можно указывать номера последовательных портов, для которых надо отключить поиск устройств, через запятую. При пропуске значения параметра поиск устройств будет отключен для всех портов.
* <code>/HAL=имя_файла</code> — задаёт [[слой аппаратных абстракций]]. Явное указание параметра переопределяет значение, указанное при установке. Например, таким образом, можно проводить [[тестирование программного обеспечения]] на предмет работоспособности в системах с разным количеством ядер [[Центральный процессор|центрального процессора]], не прибегая к [[Установка Windows|переустановке]] Windows NT или использованию [[Виртуальная машина|виртуальных машин]].
* <code>/INTAFFINITY</code> — определяет использование многопроцессорного слоя аппаратных абстракций (HALMPS.DLL) для распределения прерываний, например, назначение [[Прерывание|прерывания]] в многопроцессорной системе только процессору, имеющему высший приоритет. Без этого ключа слой аппаратных абстракций обычным образом разрешает всем процессорам получать прерывание.
* <code>/KERNEL=имя_файла</code> — указывает загрузчику, какое ядро следует загружать. Например, <code>/KERNEL=[[Ntoskrnl#ntkrnlmp.exe|ntkrnlmp.exe]]</code> — загрузка многопроцессорного ядра с памятью меньше 3 ГБ.
* <code>/MAXMEM</code> — Эта опция ограничивает для NT использование памяти. Число в Мбайт. Пример: <code>/MAXMEM=32</code> ограничил бы NT 32МБ системной памяти.
* <code>/MAXPROCSPERCLUSTER</code> — многопроцессорный HAL в Win2K (HALMPS.DLL) имеет способность к работе с многопроцессорными системами, которые составлены из кластеров, в свою очередь, состоящих из малых мультипроцессорных систем. Например, если имеется 8-процессорная система, которая составлена из двух 4-процессорных кластеров, то ID каждого процессора должен быть определен ориентируемым кластером через HAL. Размер максимального кластера — 4, и значение по умолчанию — 0 (система не основана на кластерах). Пример: <code>/MAXPROCSPERCLUSTER=3</code>.
* <code>/NODEBUG</code> — запрещает использование любой отладочной информации.
* <code>/NOEXECUTE</code> — определяет уровень [[Data Execution Prevention|DEP]]<ref>{{cite web
|url = https://support.microsoft.com/ru-ru/kb/875352
|title = Подробное описание функции предотвращения выполнения данных, входящей в состав Windows XP с пакетом обновлений 2 (SP2), Windows XP Tablet PC Edition 2005 и Windows Server 2003
|date = 2006-10-25
|work = PressPass
|publisher = Microsoft
|accessdate = 2007-05-02
|deadurl = yes
|archive-date = 2011-08-23
|archive-url = https://web.archive.org/web/20110823072921/http://support.microsoft.com/kb/875352/ru
}}</ref> (появилась начиная с Windows XP SP2). Может принимать четыре значения AlwaysOn, AlwaysOff, OptIn и OptOut.
** <code>OptIn</code> — данное значение используется по умолчанию. На компьютерах, оснащенных процессорами с поддержкой DEP, функция DEP включена по умолчанию для ограниченного числа системных файлов и программ. При этом по умолчанию защищаются только системные файлы Windows.
** <code>OptOut</code> — по умолчанию функция DEP включена для всех процессов. В диалоговом окне Система панели управления можно вручную создать список приложений, для которых следует отключить DEP. Специалисты по информационным технологиям могут воспользоваться пакетом средств обеспечения совместимости приложений (Application Compatibility Toolkit), чтобы отключить функцию DEP для одной или нескольких программ. При этом вступают в силу исправления, обеспечивающие совместимость программ, для функции DEP.
** <code>AlwaysOn</code> — функция DEP включается для всей системы. Все процессы работают с выполнением проверок DEP. В этом режиме нельзя отключить функцию DEP для отдельных приложений. Исправления, обеспечивающие совместимость программ, для функции DEP в силу не вступают. Программы, для которых с помощью пакета средств обеспечения совместимости приложений было отключено использование функции DEP, также работают с выполнением проверок DEP.
** <code>AlwaysOff</code> — функция DEP отключена для всей системы, независимо от наличия аппаратной поддержки DEP. Процессор не работает в режиме PAE, если в файле Boot.ini не указан параметр /PAE.
* <code>/NOGUIBOOT</code> — Когда эта опция задана, VGA-драйвер, ответственный за представление графики во время загрузки Win2K, не инициализируется. Этот драйвер используется для отображения на экране монитора процесса загрузки и, как правило, для отображения [[Синий экран смерти|Blue Screen]], таким образом включение этой опции в boot.ini сделает всё это невозможным.
* <code>/NOPAE</code> — загружает версию ядра NT без расширения физических адресов ([[Physical Address Extension|PAE]]).
* <code>/NOSERIALMICE</code> — отключает обнаружение мыши, подключенной к последовательному COM-порту (портам).
* <code>/NUMPROC</code> — допускается только число указанных центральных процессоров. Пример: /NUMPROC=2 на системе с 4 процессорами заставит 2 из этих 4 процессоров простаивать под NT.
* <code>/ONECPU</code> — эта опция указывает NT использовать только один процессор мультипроцессорной системы.
* <code>/PAE</code> — загружает версию ядра NT с расширением физических адресов ([[Physical Address Extension|PAE]]).
* <code>/PCILOCK</code> — запрещает Windows NT динамически назначать IO-/IRQ-ресурсы на PCI-устройства и оставляет конфигурацию BIOS.
* <code>/PERFMEM</code> и <code>/PERFPAGES</code> — эти опции не поддерживаются в final release, так как они используются NT для резервирования физической памяти для Basic Block Testing (BBT). Существует только одно известное упоминание о BBT на сайте Microsoft: судебное дело США против Microsoft от 2 февраля 1999 года. В нём рассказывается о том, как Jim Allchin отвечал под присягой на вопросы по поводу BBT. Он сказал, что BBT — вещь, оптимизирующая производительность системы. Microsoft использует её в пререлизах, для того чтобы минимизировать количество страниц памяти. <code>/PERFMEM</code> определяет резервирование физической памяти в MB, а <code>/PERFPAGES</code> — количество страниц памяти. Эти параметры не должны присутствовать совместно. Место для BBT резервируется в Thread Environment Block (TEB) каждого потока. На самом деле точно не известно, как конкретно влияет каждый из параметров на работу системы.
* <code>/SAFEBOOT</code> — используется крайне редко, так как выполняет те же действия, что и при нажатии F8 для загрузки в безопасном режиме NTLDR. Но Вы можете определить один из трех дополнительных ключей: <code>MINIMAL</code>, <code>NETWORK</code>, или <code>DSREPAIR</code>. <code>MINIMAL</code> и <code>NETWORK</code> отвечают за загрузку ОС в безопасном режиме без и с поддержкой сети соответственно. В безопасном режиме NT загружает только драйверы и сервисы, описанные по имени или группе в Minimal или Network-ключах реестра: <code>[HKLM\System\CurrentControlSet\Control\SafeBoot]</code>. Ключ <code>DSREPAIR</code> (Directory Services Repair) указывает NT, что необходимо грузиться в режиме, который восстанавливает Active Directory из резервной копии. Дополнительная опция, которую можно определить, — <code>ALTERNATESHELL</code>. Она указывает ядру NT, какую программу, описанную в реестре <code>[HKLM\System\CurrentControlSet\Control\SafeBoot\AlternateShell]</code>, использовать в качестве графической оболочки, взамен Explorer, используемого по умолчанию.
* <code>/SOS</code> — заставляет NT выдавать во время загрузки всю информацию относительно того, какие драйверы загружены, и насколько успешно.
* <code>/TIMERES</code> — на многопроцессорном HAL (HALMPS.DLL) эта опция установит разрешающую способность системного таймера. Параметр — число в сотнях наносекунд, его значение будет установлено ближайшим меньшим, который поддерживает HAL. Заданная по умолчанию разрешающая способность — 7,8 мс. Пример: <code>/TIMERES=9000</code> установил бы таймер на разрешение в 0,98 мс.
* <code>/USE8254</code> — этот параметр предназначен для систем со старым BIOS. Он говорит NT HAL, что необходимо использовать 8254 чип таймера в качестве основного.
* <code>/USEPMTIMER</code> — параметр указывает на то, что операционные системы Windows XP и Windows Server 2003 используют параметры таймера PM-TIMER, а не параметры счетчика отметок времени, если процессор поддерживает параметры таймера PM_TIMER<ref>{{Cite web |url=https://support.microsoft.com/ru-ru/kb/895980 |title=Программы, использующие функцию QueryPerformanceCounter могут работать плохо в Windows Server 2000, Windows Server 2003 и Windows XP |access-date=2016-11-28 |archive-date=2016-05-28 |archive-url=https://web.archive.org/web/20160528195723/https://support.microsoft.com/ru-ru/kb/895980 |deadlink=no }}</ref>.
* <code>/USERVA=xxxx</code> — параметр позволяет выполнять тонкую настройку объёма виртуальной памяти для режима пользователя и виртуальной памяти системы в семействе Windows Server 2003. Он используется совместно с параметром <code>/3GB</code> в файле Boot.ini и позволяет варьировать объём виртуальной памяти в режиме пользователя в пределах между 2 и 3 ГБ, а разницу (3072 за вычетом xxxx) отдавать обратно режиму ядра.
* <code>/YEAR</code> — опция, очевидно, предназначена для проверки на соответствие [[Проблема 2000 года|Y2K]]. Определение этого параметра говорит ядру NT, что необходимо игнорировать год, сообщаемый системным таймером компьютера, и вместо этого использовать определенный в boot.ini. Таким образом, год, используемый в boot.ini, воздействует на все программное обеспечение в системе, включая ядро NT. Пример: <code>/YEAR=2001</code>. Примечание: эта опция доступна только на NT 4.0 SP4 и Windows 2000.


== См. также ==
* /BURNMEMORY — Эта опция заставит NT «забыть» все ограничения относительно указанного объёма памяти, типа /MAXMEM. Значение в МБАЙТ. Пример: /BURNMEMORY=128 указал бы системе — отбрось 128МБ физической памяти на машине как непригодные.
* [[Coreboot]]

* [[Начальная загрузка компьютера]]
* /CHANNEL — Используется совместно с параметрами /debug и /debugport в целях поддержки порта IEEE 1394.

* /CRASHDEBUG — Загружает отладчик ядра в память, где он остается до тех пор, пока не возникнет ошибка ядра.

* /DEBUG — Загружает отладчик ядра в память. Этот параметр может быть активирован в любой момент из удаленного отладчика, расположенного на компьютере, который подключен к последовательному порту локального компьютера. В отличие от параметра /CRASHDEBUG, при использовании параметра /DEBUG последовательный порт всегда работает как порт отладки. Используйте этот режим, если в работе системы регулярно возникают ошибки.<ref>{{cite web
| url = http://support.microsoft.com/kb/833721/ru
| title = Параметры, используемые в файле Boot.ini в Windows XP и Windows Server 2003
| year = [[June 06]] [[2006]]
| accessdate = 2007-05-02
| work = PressPass
| publisher = Microsoft
| archiveurl = http://www.webcitation.org/61CReb18X
| archivedate = 2011-08-25
}}
</ref>

* /DEBUGPORT=COMx — Задает COM порт для отладки.

* /EXECUTE — отключает Data Execution Prevention (DEP) и Physical Address Extension (PAE) в Windows Server 2003 (SP1) <ref>[http://msdn.microsoft.com/en-us/library/aa468631.aspx Content Moved (Windows)<!-- Заголовок добавлен ботом -->]</ref>

* /FASTDETECT[:COMn] — Если у вас стоит две или более операционных систем от Microsoft, то при процессе загрузки используется NTDETECT.COM от самой старшей версии. В Win2K инициализация параллельных и последовательных устройств осуществляется с помощью plug-and-play драйверов устройств, но NT 4.0 в этом смысле полностью полагается на NTDETECT.COM. Таким образом, определяя параметр FASTDETECT, как раз в том месте, где NTDETECT производит инициализацию оборудования при загрузке NT 4.0, ключ заставляет NTDETECT пропустить эти вещи при загрузке Win2K. Установщик Win2K автоматически распознает наличие второй установленной системы и прописывает этот параметр в [[boot.ini|BOOT.INI]] автоматически. Можно указывать номера последовательных портов, для которых надо отключить поиск устройств, через запятую. При пропуске параметра COM поиск устройств будет отключен для всех портов.

* /HAL=имя_файла — Задаёт [[Hardware abstraction layer|слой аппаратных абстракций]]. Явное указание параметра HAL переопределяет значение, указанное при установке. Например, таким образом, можно проводить [[Тестирование программного обеспечения|тестирование ПО]] на предмет работоспособности в системах с разным количеством ядер [[Процессор|ЦП]], не прибегая к [[Установка Windows|переустановке]] [[Windows NT|NT-ОС]] и использованию [[Виртуальная машина|виртуальных машин]].

* /INTAFFINITY — Ключ определяет использование многопроцессорного HAL (HALMPS.DLL) для распределения прерываний, например назначение прерывания в многопроцессорной системе только процессору, имеющему высший приоритет. Без этого ключа HAL обычным образом разрешает всем процессорам получать IRQ.

* /KERNEL=имя_файла — Указывает загрузчику какое ядро следует загружать. Например, /KERNEL=[[Ntoskrnl#ntkrnlmp.exe|ntkrnlmp.exe]] — загрузка многопроцессорного ядра с памятью меньше 3 ГБ.

* /MAXMEM — Эта опция ограничивает для NT использование памяти. Число в МБайт. Пример: /MAXMEM:32 ограничил бы NT 32МБ системной памяти.

* /MAXPROCSPERCLUSTER — Многопроцессорный HAL в Win2K (HALMPS.DLL) имеет способность к работе с многопроцессорными системами, которые составлены из кластеров в свою очередь состоящих из малых мультипроцессорных систем. Например, если имеется 8-процессорная система, которая составлена из двух 4-процессорных кластеров, то ID каждого процессора должен быть определен ориентируемым кластером через HAL. Размер максимального кластера — 4, и значение по умолчанию — 0 (система не основана на кластерах). Пример: /MAXPROCSPERCLUSTER=3.

* /NODEBUG — Запрещает использование любой отладочной информации.

* /NOEXECUTE — Определяет уровень [[Data Execution Prevention|DEP]]<ref>{{cite web
| url = http://support.microsoft.com/kb/875352/ru
| title = Подробное описание функции предотвращения выполнения данных, входящей в состав Windows XP с пакетом обновлений 2 (SP2), Windows XP Tablet PC Edition 2005 и Windows Server 2003
| year = [[October 25]] [[2006]]
| accessdate = 2007-05-02
| work = PressPass
| publisher = Microsoft
| archiveurl = http://www.webcitation.org/61CRfVVxD
| archivedate = 2011-08-25
}}
</ref> (появилась начиная с 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|BOOT.INI]] сделает все это невозможным.

* /NOPAE — Загружает версию ядра NT без расширения физических адресов ([[Physical Address Extension|PAE]]).

* /NOSERIALMICE — [COMx | COMx, y, z :] — Отключает обнаружение мыши, подключенной к последовательному COM порту (портам).

* /NUMPROC — Допускается только число указанных центральных процессоров. Пример: /NUMPROC=2 на системе с 4 процессорами заставит 2 из этих 4 процессоров простаивать под NT.

* /ONECPU — эта опция указывает NT, использовать только один процессор мультипроцессорной системы.

* /PAE — Загружает версию ядра NT с расширением физических адресов ([[Physical Address Extension|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 — Параметр /usepmtimer указывает на то, что операционные системы Windows XP и Windows Server 2003 используют параметры таймера PM-TIMER, а не параметры счетчика отметок времени, если процессор поддерживает параметры таймера PM_TIMER .

Дополнительные сведения о параметре /usepmtimer см. в следующей статье базы знаний Майкрософт:
[http://support.microsoft.com/kb/895980/ 895980]

* /USERVA — Параметр /userva=xxxx позволяет выполнять тонкую настройку объёма виртуальной памяти для режима пользователя и виртуальной памяти системы в семействе Windows Server 2003. Он используется совместно с параметром /3GB в файле Boot.ini и позволяет варьировать объём виртуальной памяти в режиме пользователя в пределах между 2 и 3 ГБ, а разницу (3,072 за вычетом xxxx) отдавать обратно режиму ядра.

* /YEAR — опция очевидно предназначена для проверки на соответствие [[Проблема 2000 года|Y2K]]. Определение этого параметра говорит ядру NT, что необходимо игнорировать год, сообщаемый системным таймером компьютера, и вместо этого использовать определенный в [[boot.ini|BOOT.INI]]. Таким образом, год, используемый в [[boot.ini|BOOT.INI]], воздействует на все программное обеспечение в системе, включая ядро NT. Пример: /YEAR=2001. Примечание: эта опция доступна только на NT 4.0 с 4 Сервис паком и Windows 2000.


== Примечания ==
== Примечания ==
{{примечания}}
{{примечания}}

== См. также ==
* [[Загрузчик ОС]]
* [[Начальная загрузка компьютера]]
; Загручики Linux
* [[LILO]]
* [[GRUB]]
* [[Das U-Boot]]


== Ссылки ==
== Ссылки ==
* [http://support.microsoft.com/kb/875352/ru Подробное описание функции предотвращения выполнения данных]
* [https://support.microsoft.com/ru-ru/kb/875352 Подробное описание функции предотвращения выполнения данных] {{Wayback|url=https://support.microsoft.com/ru-ru/kb/875352 |date=20110823072921 }}{{ref-ru}}
* [http://support.microsoft.com/kb/289022 Редактирование файла Boot.ini в Windows XP]
* [https://support.microsoft.com/ru-ru/kb/323427 Редактирование файла boot.ini в Windows Server 2003] {{Wayback|url=https://support.microsoft.com/ru-ru/kb/323427 |date=20160710011518 }}{{ref-ru}}
* [http://support.microsoft.com/kb/314081 Назначение файла Boot.ini в Windows XP]
* [https://support.microsoft.com/ru-ru/kb/314081 Назначение файла boot.ini в Windows XP]{{ref-ru}}
* [http://support.microsoft.com/kb/833721/ru Параметры, используемые в файле Boot.ini в Windows XP и Windows Server 2003]
* [https://support.microsoft.com/ru-ru/kb/833721 Параметры, используемые в файле boot.ini в Windows XP и Windows Server 2003] {{Wayback|url=https://support.microsoft.com/ru-ru/kb/833721 |date=20110906073416 }}{{ref-ru}}
* [http://support.microsoft.com/kb/895980/ Возможная проблема с многоядерными и многопроцессорными системами (Программы, использующие функцию QueryPerformanceCounter может нарушаться в Windows Server 2000, Windows Server 2003 и Windows XP)]
* [[RDTSC|Команда процессара RDTSC и ограничения её использования на новых(многопроцессорных) системах]]


{{Компоненты Microsoft Windows}}
{{Компоненты Microsoft Windows}}
Строка 269: Строка 227:
[[Категория:Стандартные приложения Windows]]
[[Категория:Стандартные приложения Windows]]
[[Категория:Загрузчики операционных систем]]
[[Категория:Загрузчики операционных систем]]
[[Категория:Microsoft Windows]]

[[de:NT-Loader]]
[[en:NTLDR]]
[[es:NTLDR]]
[[fa:NTLDR]]
[[fr:NTLDR]]
[[it:NTLDR]]
[[ja:NTLDR]]
[[ko:NTLDR]]
[[pl:NTLDR]]
[[pt:NTLDR]]
[[sv:NTLDR]]
[[uk:NTLDR]]
[[zh:NTLDR]]

Текущая версия от 06:23, 17 января 2024

NTLDR
Скриншот программы NTLDR
Тип Загрузчик операционной системы
Разработчик Microsoft
Операционные системы Windows NT, 2000, XP, Server 2003
Лицензия Проприетарная

NTLDR (сокращение от англ. NT Loader) — загрузчик операционных систем Windows NT. NTLDR может быть запущен как с переносного устройства, такого, как, например, CD-ROM или флэш-накопителя USB), так и с жёсткого диска. NTLDR также способен загружать операционные системы, не основанные на технологии NT, путём задания соответствующего загрузочного сектора в отдельном файле.[1] Для запуска NTLDR требуется, как минимум, наличие следующих двух файлов на активном разделе: NTLDR, который, собственно, и содержит код загрузчика, и boot.ini, в котором записаны команды для формирования меню выбора системы и параметры для её запуска. Чтобы загружать операционные системы на базе Windows NT, необходимо также наличие файла ntdetect.com.

Процесс запуска

[править | править код]

При загрузке NTLDR выполняет следующие шаги:

  1. Переводит процессор в «плоский» 32-битный режим работы (англ. 32-bit flat memory mode).
  2. Организует доступ к текущей файловой системе.
  3. Если присутствует файл hiberfil.sys и загрузчик обнаруживает образ спящего режима, содержимое образа загружается в оперативную память, и система восстанавливается в предыдущее состояние.
  4. В противном случае, он читает файл boot.ini и выводит пользователю соответствующее меню для выбора запускаемой операционной системы. Если была выбрана не система семейства Windows NT (например, Windows 98), тогда он загружает файл, указанный в boot.ini (bootsect.dos, если не указан иной файл, являющийся полноценной загрузочной записью), и управление передаётся этому файлу, либо он загружает операционную систему на базе DOS. Если же была выбрана система на базе Windows NT, то запускается программа ntdetect.com, которая собирает информацию о составе оборудования.
  5. Запускает файл 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, то меню отображаться не будет и сразу запустится операционная система, заданная в параметре default. В данном примере параметр равен 30 — значит, у пользователя будет 30 секунд для выбора операционной системы из предложенного списка.

Разрешённые опции загрузки ядра

[править | править код]
  • /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 — эта опция заставит систему использовать меньшее количество оперативной памяти, чем физически доступное системе. Значение задаётся в мегабайтах. Пример: /BURNMEMORY=128 указывает системе не использовать 128 мегабайт оперативной памяти. Microsoft рекомендует использовать эту опцию вместо /MAXMEM для воспроизведения поведения системы и приложений в условиях нехватки оперативной памяти.
  • /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-драйвер, ответственный за представление графики во время загрузки Win2K, не инициализируется. Этот драйвер используется для отображения на экране монитора процесса загрузки и, как правило, для отображения Blue Screen, таким образом включение этой опции в boot.ini сделает всё это невозможным.
  • /NOPAE — загружает версию ядра NT без расширения физических адресов (PAE).
  • /NOSERIALMICE — отключает обнаружение мыши, подключенной к последовательному 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 из резервной копии. Дополнительная опция, которую можно определить, — ALTERNATESHELL. Она указывает ядру NT, какую программу, описанную в реестре [HKLM\System\CurrentControlSet\Control\SafeBoot\AlternateShell], использовать в качестве графической оболочки, взамен Explorer, используемого по умолчанию.
  • /SOS — заставляет NT выдавать во время загрузки всю информацию относительно того, какие драйверы загружены, и насколько успешно.
  • /TIMERES — на многопроцессорном HAL (HALMPS.DLL) эта опция установит разрешающую способность системного таймера. Параметр — число в сотнях наносекунд, его значение будет установлено ближайшим меньшим, который поддерживает HAL. Заданная по умолчанию разрешающая способность — 7,8 мс. Пример: /TIMERES=9000 установил бы таймер на разрешение в 0,98 мс.
  • /USE8254 — этот параметр предназначен для систем со старым BIOS. Он говорит NT HAL, что необходимо использовать 8254 чип таймера в качестве основного.
  • /USEPMTIMER — параметр указывает на то, что операционные системы Windows XP и Windows Server 2003 используют параметры таймера PM-TIMER, а не параметры счетчика отметок времени, если процессор поддерживает параметры таймера PM_TIMER[5].
  • /USERVA=xxxx — параметр позволяет выполнять тонкую настройку объёма виртуальной памяти для режима пользователя и виртуальной памяти системы в семействе Windows Server 2003. Он используется совместно с параметром /3GB в файле Boot.ini и позволяет варьировать объём виртуальной памяти в режиме пользователя в пределах между 2 и 3 ГБ, а разницу (3072 за вычетом xxxx) отдавать обратно режиму ядра.
  • /YEAR — опция, очевидно, предназначена для проверки на соответствие Y2K. Определение этого параметра говорит ядру NT, что необходимо игнорировать год, сообщаемый системным таймером компьютера, и вместо этого использовать определенный в boot.ini. Таким образом, год, используемый в boot.ini, воздействует на все программное обеспечение в системе, включая ядро NT. Пример: /YEAR=2001. Примечание: эта опция доступна только на NT 4.0 SP4 и Windows 2000.

Примечания

[править | править код]
  1. Использование ntldr для загрузки Linux. Дата обращения: 11 августа 2010. Архивировано из оригинала 15 октября 2011 года.
  2. Параметры, используемые в файле boot.ini в Windows XP и Windows Server 2003. PressPass. Microsoft (6 июня 2006). Дата обращения: 2 мая 2007. Архивировано из оригинала 6 сентября 2011 года.
  3. /execute (Windows Drivers). Дата обращения: 28 ноября 2016. Архивировано 29 ноября 2016 года.
  4. Подробное описание функции предотвращения выполнения данных, входящей в состав Windows XP с пакетом обновлений 2 (SP2), Windows XP Tablet PC Edition 2005 и Windows Server 2003. PressPass. Microsoft (25 октября 2006). Дата обращения: 2 мая 2007. Архивировано из оригинала 23 августа 2011 года.
  5. Программы, использующие функцию QueryPerformanceCounter могут работать плохо в Windows Server 2000, Windows Server 2003 и Windows XP. Дата обращения: 28 ноября 2016. Архивировано 28 мая 2016 года.