Загрузка - Booting

В вычисление, загрузка это процесс запуска компьютер. Это может быть инициировано аппаратное обеспечение например, нажатием кнопки или программного обеспечения команда. После включения компьютер центральное процессорное устройство (CPU) не имеет программного обеспечения основная память, поэтому некоторый процесс должен загрузить программное обеспечение в память, прежде чем его можно будет выполнить. Это может быть сделано аппаратно или прошивка в CPU или отдельным процессором в компьютерной системе.

Перезагрузка компьютера также называется перезагрузка, который может быть "сложным", например после того, как электрическое питание ЦП переключается с выключенного на включенное или "мягкое", когда питание не отключается. В некоторых системах мягкая загрузка может дополнительно очистить баран до нуля. Как аппаратная, так и программная загрузка может быть инициирована аппаратным обеспечением, например нажатием кнопки или программной командой. Загрузка завершена, когда рабочий система времени выполнения обычно Операционная система и некоторые приложения,[nb 1] достигается.

Процесс вывода компьютера из состояния спячка или же спать не требует загрузки. Как минимум, некоторые встроенные системы не требуют заметной последовательности загрузки для начала работы, а при включении могут просто запускать рабочие программы, хранящиеся в ПЗУ. Все вычислительные системы государственные машины, и перезагрузка может быть единственным способом вернуться в назначенное нулевое состояние из непреднамеренного заблокированного состояния.

Помимо загрузки операционной системы или автономной утилиты, в процессе загрузки также может загружаться программа дампа хранилища для диагностики проблем в операционной системе.

Ботинок это сокращение от бутстрап[1][2] или же начальная загрузка и происходит от фразы подтянуться за шнурки.[3][4] Использование обращает внимание на требование, согласно которому, если большая часть программного обеспечения загружается на компьютер другим программным обеспечением, уже запущенным на компьютере, должен существовать какой-то механизм для загрузки исходного программного обеспечения на компьютер.[5] Ранние компьютеры использовали множество специальных методов для загрузки небольшой программы в память для решения этой проблемы. Изобретение только для чтения памяти (ROM) различных типов разрешили этот парадокс, позволив поставлять компьютеры с программой запуска, которую невозможно стереть. Рост емкости ROM позволил реализовать все более сложные процедуры запуска.

История

Переключатели и кабели, используемые для программирования ENIAC (1946)

Существует множество различных методов загрузки короткой начальной программы в компьютер. Эти методы простираются от простого физического ввода до съемных носителей, которые могут содержать более сложные программы.

Примеры прединтегральных ПЗУ

Ранние компьютеры

Ранние компьютеры 1940-х и 1950-х годов представляли собой единственные в своем роде инженерные разработки, на программирование которых уходили недели, и загрузка программы была одной из многих проблем, которые необходимо было решить. Ранний компьютер, ENIAC, не имел программы, хранящейся в памяти, но был настроен для каждой проблемы с помощью конфигурации соединительных кабелей. Начальная загрузка не применялась к ENIAC, чья аппаратная конфигурация была готова для решения проблем сразу после подачи питания.

В EDSAC система, второй компьютер с хранимой программой, который будет построен, шаговые переключатели для передачи фиксированной программы в память при нажатии ее кнопки запуска. Программа хранится на этом устройстве, которое Дэвид Уиллер завершено в конце 1948 г., загружены дальнейшие инструкции из перфолента а затем казнил их.[6][7]

Первые коммерческие компьютеры

Первые программируемые компьютеры для коммерческой продажи, такие как UNIVAC I и IBM 701[8] включены функции, упрощающие их работу. Обычно они включали инструкции, которые выполняли полную операцию ввода или вывода. Та же аппаратная логика может использоваться для загрузки содержимого перфокарты (наиболее типичные) или другие средства ввода, такие как магнитный барабан или же магнитная лента, который содержал программу начальной загрузки, нажав одну кнопку. Эта концепция загрузки получила множество названий для IBM компьютеров 1950-х и начала 1960-х годов, но IBM использовала термин «начальная загрузка программы» с IBM 7030 Stretch[9] и позже использовали его для своих линий мэйнфреймов, начиная с Система / 360 в 1964 г.

Перфокарта начальной загрузки программы для IBM 1130 (1965)

В IBM 701 компьютер (1952–1956) имел кнопку «Загрузить», которая инициировала чтение первого 36-битный слово в основная память с перфокарты в картридер, магнитная лента в ленточный накопитель, или магнитный барабан, в зависимости от положения переключателя выбора нагрузки. Затем левое 18-битное полуслово выполнялось как инструкция, которая обычно считывала дополнительные слова в память.[10][11] Затем была выполнена загруженная программа загрузки, которая, в свою очередь, загрузила более крупную программу с этого носителя в память без дополнительной помощи человека-оператора. Термин «ботинок» используется в этом смысле по крайней мере с 1958 года.[12]

Консоль IBM System / 3 1970-х годов. Селекторный переключатель загрузки программ находится внизу слева; Переключатель загрузки программы находится внизу справа.

Другие компьютеры IBM той эпохи обладали схожими характеристиками. Например, IBM 1401 Система (ок. 1958) использовала кардридер для загрузки программы с перфокарты. 80 символов, хранящиеся на перфокарте, считывались в ячейки памяти с 001 по 080, затем компьютер переходил в ячейку памяти 001, чтобы прочитать свою первую сохраненную команду. Эта инструкция всегда была одинаковой: переместить информацию из этих первых 80 ячеек памяти в область сборки, где информация на перфокартах 2, 3, 4 и так далее может быть объединена для формирования сохраненной программы. Как только эта информация будет перемещена в зону сборки, машина перейдет к инструкции в ячейке 080 (чтение карты), и следующая карта будет считана, а ее информация обработана.

Другим примером был IBM 650 (1953), десятичная машина, которая имела группу из десяти 10-позиционных переключателей на панели управления, которые были адресованы как слово памяти (адрес 8000) и могли выполняться как инструкция. Таким образом, установка переключателей на 7004000400 и нажатие соответствующей кнопки приведет к считыванию первой карты в устройстве чтения карт в память (код операции 70), начиная с адреса 400, а затем перейдет к 400, чтобы начать выполнение программы на этой карте.[13]

Конкуренты IBM также предлагали загрузку программ одной кнопкой.

  • В CDC 6600 (ок. 1964 г.) мертвый старт панель со 144 тумблерами; выключатель глухого пуска ввел 12 слов с тумблеров в память периферийный процессор (PP) 0 и инициировал последовательность загрузки. PP 0 загрузил необходимый код в свою память, а затем инициализировал другие PP.
  • В GE 645 (c. 1965) была кнопка «SYSTEM BOOTLOAD», при нажатии которой один из контроллеров ввода / вывода загружал программу из 64 слов в память с диода. только для чтения памяти и доставить прерывание для запуска этой программы.[14]
  • Первая модель PDP-10 была кнопка «READ IN», при нажатии на которую она сбрасывала процессор и запускала операцию ввода-вывода на устройстве, указанном переключателями на панели управления, считывая 36-битное слово, дающее целевой адрес, и считая последующие чтения слова ; когда чтение завершилось, процессор начал выполнение считанного кода, перейдя к последнему считанному слову.[15]

Примечательная вариация этого находится на Берроуз B1700 где нет ни загрузочного ПЗУ, ни проводной операции IPL. Вместо этого после сброса системы она считывает и выполняет коды операций последовательно с ленточного накопителя, установленного на передней панели; это устанавливает загрузчик в ОЗУ, который затем запускается. Однако, поскольку это делает несколько предположений о системе, его также можно использовать для загрузки диагностических лент (программа технического обслуживания), которые отображают понятный код на Передняя панель даже в случае серьезного сбоя процессора.

IBM System / 360 и последователи

в IBM System / 360 и его преемников, включая нынешнюю z / Архитектура машины процесс загрузки известен как Начальная загрузка программы (IPL).

IBM ввела этот термин для обозначения 7030 (стрейч),[9] возродил его для дизайна System / 360 и продолжает использовать его в этих средах сегодня.[16] В процессорах System / 360 IPL инициируется оператором компьютера путем выбора адреса устройства из трех шестнадцатеричных цифр (CUU; C = адрес канала ввода-вывода, UU = блок управления и адрес устройства.[nb 2]) с последующим нажатием НАГРУЗКА кнопка. На высоком конце Система / 360 модели, большинство[№ 3] Система / 370 и в некоторых более поздних системах функции переключателей и кнопки ЗАГРУЗИТЬ моделируются с помощью выбираемых областей на экране графической консоли, часто[№ 4] ан IBM 2250 -подобное устройство или IBM 3270 -подобное устройство. Например, в System / 370 Model 158 последовательность клавиш 0-7-X (ноль, семь и X в этом порядке) приводит к IPL с адреса устройства, который был введен в область ввода. В Амдал 470V / 6 и связанные с ним ЦП поддерживали четыре шестнадцатеричных цифры на тех ЦП, в которых был установлен дополнительный блок второго канала, всего 32 канала. Позже IBM также будет поддерживать более 16 каналов.

Функция IPL в System / 360 и его преемниках, а также в его совместимых устройствах, таких как Amdahl, считывает 24 байта из указанного оператором устройства в оперативную память, начиная с реального адреса с нуля. Вторая и третья группы из восьми байтов рассматриваются как Командные слова канала (CCWs), чтобы продолжить загрузку программы запуска (первая CCW всегда моделируется ЦП и состоит из команды Read IPL, 02ч, с принудительным объединением команд и подавлением неправильного указания длины). Когда команды канала ввода-вывода завершены, первая группа из восьми байтов загружается в процессор. Слово состояния программы (PSW), и программа запуска начнет выполнение в месте, указанном этим PSW.[16] Устройство IPL обычно представляет собой дисковод, поэтому особое значение имеет 02ч read-type, но точно такая же процедура также используется для IPL с других устройств ввода, таких как ленточные накопители или даже устройства чтения карт, независимо от устройства, что позволяет, например, установить операционную систему на новеньком компьютере с магнитной ленты начального распространения ОС. Для контроллеров дисков 02ч команда также заставляет выбранное устройство искать цилиндр 0000ч, голова 0000ч, имитирующая команду поиска цилиндра и головки, 07ч, и для поиска записи 01ч, имитирующая команду Search ID Equal, 31ч; поиск и поиск не моделируются контроллерами лент и карт, поскольку для этих классов устройств 02ч Команда - это просто команда последовательного чтения, а не команда чтения IPL.

Диск, лента или колода карт должны содержать специальную программу для загрузки реальной операционной системы или автономной утилиты в основное хранилище, и для этой конкретной цели «Текст IPL» помещается на диск с помощью автономного DASDI (устройства хранения с прямым доступом. Initialization) или эквивалентную программу, работающую под управлением операционной системы, например ICKDSF, но ленты и колоды карточек с возможностью IPL обычно распространяются с уже присутствующим «текстом IPL».

Миникомпьютеры

Передняя панель PDP-8 / E с переключателями, используемыми для загрузки программы начальной загрузки

Миникомпьютеры, начиная с Корпорация цифрового оборудования (DEC) PDP-5 и PDP-8 (1965) упростил дизайн, используя ЦП для операций ввода и вывода. Это сэкономило средства, но сделало загрузку более сложной, чем нажатие одной кнопки. Миникомпьютеры обычно каким-то образом переключиться в короткие программы, управляя набором переключателей на передней панели. С тех пор, как первые миникомпьютеры использовали память на магнитном сердечнике, который не потерял свою информацию при отключении питания, эти загрузчики останутся на месте, если они не будут удалены. Стирание иногда происходило случайно, когда ошибка программы вызывала цикл, который перезаписывал всю память.

Другие миникомпьютеры с такой простой формой загрузки включают Hewlett-Packard HP 2100 серия (середина 1960-х), оригинал Данные General Nova (1969) и DEC's PDP-11 (1970).

Позже DEC добавила необязательный диодная матрица постоянная память для PDP-11, в которой хранилась программа начальной загрузки объемом до 32 слов (64 байта). Он состоял из печатной платы M792, которая вставлялась в Юнибус и содержал матрицу 32 на 16 полупроводниковых диодов. После установки всех 512 диодов в памяти были все «единицы»; карта была запрограммирована отключением каждого диода, бит которого должен был быть "нулем". DEC также продавала версии карты серии BM792-Yx, предварительно запрограммированные для многих стандартных устройств ввода, просто исключая ненужные диоды.[17]

Следуя более старому подходу, более ранний PDP-1 имеет аппаратный загрузчик, так что оператору нужно только нажать переключатель «нагрузка», чтобы дать команду бумажная лента считыватель для загрузки программы непосредственно в оперативную память. Data General Supernova использовала переключатели на передней панели, чтобы компьютер автоматически загружал инструкции в память с устройства, заданного переключателями данных на передней панели, а затем переходил к загруженному коду; у Nova 800 и 1200 был переключатель, который загружал программу в основную память из специальной постоянной памяти и переходил к ней.[18]

Примеры загрузчика ранних миникомпьютеров

В миникомпьютере со считывателем бумажной ленты первая программа, запускаемая в процессе загрузки, загрузчик, считывает в оперативную память либо загрузчик второй ступени (часто называемый Бинарный загрузчик), который мог читать бумажную ленту с контрольная сумма или операционная система с внешнего носителя. Псевдокод для загрузчика может быть так же просто, как следующие восемь инструкций:

  1. Установите регистр P на 9
  2. Убедитесь, что устройство чтения бумажной ленты готово
  3. Если не готовы, переходите к 2
  4. Считать байт от устройства чтения бумажной ленты до аккумулятора
  5. Сохраните аккумулятор по адресу в регистре P
  6. Если конец ленты, переходите к 9
  7. Увеличить регистр P
  8. Перейти к 2

Связанный пример основан на загрузчике для миникомпьютера Nicolet Instrument Corporation 1970-х годов, использующем устройство чтения-перфорации бумажной ленты на Телетайп Модель 33 ASR телетайп. Байты его загрузчика второй ступени считываются с бумажной ленты в обратном порядке.

  1. Установите регистр P на 106
  2. Убедитесь, что устройство чтения бумажной ленты готово
  3. Если не готовы, переходите к 2
  4. Считать байт с устройства чтения с бумажной ленты в аккумулятор
  5. Сохраните аккумулятор по адресу в регистре P
  6. Уменьшить регистр P
  7. Перейти к 2

Длина загрузчика второй ступени такова, что последний байт перезаписывает ячейку 7. После выполнения инструкции в ячейке 6 ячейка 7 начинает выполнение загрузчика второй ступени. Затем загрузчик второй ступени ожидает, пока гораздо более длинная лента с операционной системой будет помещена в устройство чтения ленты. Разница между загрузчиком начальной загрузки и загрузчиком второй ступени заключается в добавлении кода проверки для обнаружения ошибок чтения с бумажной ленты, что часто встречается при использовании относительно недорогого оборудования, работающего неполный рабочий день, такого как Teletype Model 33 ASR. (Friden Flexowriters были гораздо более надежными, но и сравнительно дорогими.)

Загрузка первых микрокомпьютеров

Самые ранние микрокомпьютеры, такие как Альтаир 8800 (выпущен впервые в 1975 году) и даже более ранняя аналогичная машина (на базе процессора Intel 8008) не имела оборудования для начальной загрузки как такового.[19] При запуске ЦП будет видеть память, которая будет содержать исполняемый код, содержащий только двоичные нули - память была очищена сбросом при включении питания. На передних панелях этих машин находились тумблеры для ввода адресов и данных, по одному переключателю на бит слова памяти компьютера и адресной шины. Простые дополнения к оборудованию позволяли загружать с этих переключателей одну ячейку памяти за раз для хранения кода начальной загрузки. Тем временем ЦП не мог пытаться выполнить содержимое памяти. После правильной загрузки ЦП был включен для выполнения кода начальной загрузки. Этот процесс был утомительным и не должен был содержать ошибок.[20]

Эра постоянной памяти на интегральных схемах

Intel 2708 EPROM «микросхема» на печатной плате.

Процесс загрузки миникомпьютеров и микрокомпьютеров[№ 5] была революционизирована введением интегральной схемы только для чтения памяти (ROM), с его многочисленными вариантами, включая запрограммированные по маске ПЗУ, программируемые ПЗУ (ВЫПУСКНОЙ ВЕЧЕР), стираемые программируемые ПЗУ (EPROM) и флэш-память. Эти позволили прошивка загрузочные программы, которые будут включены в состав компьютера. Введение (внешнего) ПЗУ произошло в итальянском разработчике телефонной коммутации, названном "Gruppi Speciali", запатентованном в 1975 г. Альберто Чьярамелла, научный сотрудник CSELT.[21] Gruppi Speciali, начиная с 1975 года, представляла собой полностью однокнопочную машину, загружающуюся в операционную систему из ПЗУ, состоящего из полупроводников, а не из ферритовых сердечников. Хотя устройство ПЗУ не было изначально встроено в компьютер Gruppi Speciali, из-за конструкции машины оно также позволяло однокнопочную загрузку ПЗУ на машинах, не предназначенных для этого (следовательно, это «устройство начальной загрузки» не зависело от архитектуры. ), например PDP-11. Также сохранялось состояние машины после выключения, что было еще одной важной функцией в конкурсе на переключение телефона.[22]

Как правило, каждый микропроцессор после сброса или включения питания выполняет процесс запуска, который обычно принимает форму «начать выполнение обнаруженного кода, начиная с определенного адреса» или «искать многобайтовый код по адресу конкретный адрес и перейдите в указанное место, чтобы начать выполнение ". Система, построенная с использованием этого микропроцессора, будет иметь постоянное ПЗУ, занимающее эти специальные места, так что система всегда начинает работать без помощи оператора. Например, Intel x86 процессоры всегда запускаются с выполнения инструкций, начинающихся с F000: FFF0,[23][24] в то время как для MOS 6502 Процессор инициализация начинается с чтения двухбайтового адреса вектора в $ FFFD (байт MS) и $ FFFC (байт LS) и перехода в это место для запуска кода начальной загрузки.[25]

Apple Inc. первый компьютер, Яблоко 1 представленный в 1976 году, он содержал микросхемы PROM, которые устраняли необходимость в передней панели для процесса загрузки (как в случае с Altair 8800) в коммерческом компьютере. Согласно объявлению Apple, «Больше никаких переключателей, никаких огней ... прошивка в PROMS позволяет вам вводить, отображать и отлаживать программы (все в шестнадцатеричном формате) с клавиатуры».[26]

Из-за стоимости постоянной памяти в то время Apple II серии загрузил свои дисковые операционные системы, используя серию очень маленьких пошаговых шагов, каждый из которых передает управление следующей фазе постепенно усложняющегося процесса загрузки. (Видеть Apple DOS: загрузчик ). Поскольку дисковая операционная система очень мало полагалась на ПЗУ, аппаратное обеспечение также было чрезвычайно гибким и поддерживало широкий спектр настраиваемых дисков. защита от копирования механизмы. (Видеть Взлом программного обеспечения: история.)

Некоторые операционные системы, особенно до 1995 г. Macintosh системы из яблоко, настолько тесно переплетены с их оборудованием, что невозможно изначально загрузить операционную систему, отличную от стандартной. Это противоположная крайность сценария с использованием переключателей, упомянутых выше; он очень негибкий, но относительно безошибочный и надежный, пока все оборудование работает нормально. Распространенным решением в таких ситуациях является разработка загрузчика, который работает как программа, принадлежащая стандартной ОС, которая захватывает систему и загружает альтернативную ОС. Этот метод использовался Apple для A / UX Реализация Unix и копируется различными бесплатными операционными системами и BeOS Personal Edition 5.

Некоторые машины, например Atari ST микрокомпьютер, были "мгновенными", при этом операционная система запускалась из ПЗУ. Таким образом, извлечение ОС из вторичного или третичного хранилища было исключено как одна из характерных операций для начальной загрузки. Чтобы обеспечить автоматическую загрузку настроек системы, аксессуаров и другого вспомогательного программного обеспечения, дисковод Atari считывался на наличие дополнительных компонентов в процессе загрузки. Была задержка тайм-аута, которая давала время, чтобы вручную вставить дискету, пока система ищет дополнительные компоненты. Этого можно было избежать, вставив чистый диск. Аппаратное обеспечение Atari ST также было спроектировано таким образом, чтобы слот для картриджей мог обеспечивать выполнение собственных программ для игровых целей как наследство от унаследованных от Atari электронных игр; вставив Призрак GCR картридж с системным ПЗУ Macintosh в игровом слоте и включение Atari, он мог «изначально загружать» операционную систему Macintosh, а не собственную TOS.

В Персональный компьютер IBM включенная прошивка на основе ПЗУ, называемая BIOS; одной из функций этой прошивки было выполнение самотестирование при включении когда машина была включена, а затем для чтения программного обеспечения с загрузочного устройства и его выполнения. Прошивка, совместимая с BIOS на персональном компьютере IBM, используется в Совместимость с IBM PC компьютеры. В Расширяемый интерфейс прошивки был разработан Intel, первоначально для Itanium -базированные машины, а позже также использовались как альтернатива BIOS в x86 -на базе машин, в том числе Apple Mac с процессорами Intel.

Рабочие станции Unix изначально была прошивка на основе ПЗУ от производителя. Sun Microsystems позже разработан OpenBoot, позже известная как Open Firmware, которая включала Четвертый интерпретатор, большая часть прошивки написана на Forth. Он был стандартизирован IEEE как стандарт IEEE 1275-1994; прошивка, реализующая этот стандарт, использовалась в PowerPC -основан Mac и некоторые другие машины на базе PowerPC, а также собственные SPARC -на базе компьютеров. В Расширенные вычисления RISC спецификация определила другой стандарт прошивки, который был реализован на некоторых MIPS на основе и Альфа на базе машин и SGI Visual Workstation рабочие станции на базе x86.

Современные загрузчики

Когда компьютер выключен, его программное обеспечение - «включая операционные системы, код приложений и данные» - остается на энергонезависимая память. Когда компьютер включен, на нем обычно не установлена ​​операционная система или ее загрузчик. оперативная память (БАРАН). Компьютер сначала выполняет относительно небольшую программу, хранящуюся в только для чтения памяти (ROM) вместе с небольшим объемом необходимых данных для доступа к энергонезависимому устройству или устройствам, с которых программы и данные операционной системы могут быть загружены в RAM.

Небольшая программа, запускающая эту последовательность, известна как загрузчик начальной загрузки, бутстрап или же загрузчик. Единственная задача этой небольшой программы - загрузить другие данные и программы, которые затем выполняются из ОЗУ. Часто используются многоэтапные загрузчики, во время которых несколько программ возрастающей сложности загружаются одна за другой в процессе загрузка цепи.

Некоторые компьютерные системы после получения сигнала загрузки от человека-оператора или периферийного устройства могут загружать очень небольшое количество фиксированных инструкций в память в определенном месте, инициализировать по крайней мере один ЦП, а затем направлять ЦП на инструкции и запускать их исполнение. Эти инструкции обычно запускают операцию ввода с некоторого периферийного устройства (которое может переключаться оператором). Другие системы могут отправлять аппаратные команды непосредственно на периферийные устройства или контроллеры ввода-вывода, которые вызывают выполнение чрезвычайно простой операции ввода (например, «чтение нулевого сектора системного устройства в память, начиная с ячейки 1000»), эффективно загружая небольшой количество инструкций загрузчика в памяти; затем сигнал завершения от устройства ввода-вывода может использоваться для начала выполнения инструкций ЦП.

Меньшие компьютеры часто используют менее гибкие, но более автоматические механизмы загрузчика, чтобы гарантировать, что компьютер запускается быстро и с предварительно определенной конфигурацией программного обеспечения. На многих настольных компьютерах, например, процесс начальной загрузки начинается с того, что ЦП выполняет программное обеспечение, содержащееся в ПЗУ (например, BIOS из IBM PC ) по заранее заданному адресу (некоторые процессоры, включая Intel x86 серии предназначены для запуска этого программного обеспечения после сброса без посторонней помощи). Это программное обеспечение содержит элементарные функции для поиска устройств, которые могут участвовать в загрузке, и загрузки небольшой программы из специального раздела (чаще всего загрузочный сектор ) наиболее перспективного устройства, обычно начиная с фиксированной входная точка например, начало сектора.

Загрузчик первой ступени

Загрузчики могут сталкиваться со специфическими ограничениями, особенно по размеру; например, на IBM PC и совместимых устройствах загрузочный сектор обычно занимает всего 32 КБ.[27][28] (позже уменьшено до 64 КБ[29]) системной памяти и используйте только инструкции, поддерживаемые оригинальным 8088 /8086 процессоры. Первая ступень загрузчиков ПК (FSBL, загрузчик первой ступени), расположенных на фиксированные диски и съемные диски должно поместиться в первые 446 байты из Главная загрузочная запись чтобы оставить место для 64-байтового по умолчанию таблица разделов с четырьмя записями раздела и двухбайтовым подпись загрузки, который BIOS требует для правильного загрузчика - или даже меньше, когда дополнительные функции, такие как более четырех записей разделов (до 16 по 16 байтов каждая), подпись диска (6 байт), a метка времени диска (6 байтов), Расширенный активный раздел (18 байт) или специальный мультизагрузка загрузчики также должны поддерживаться в некоторых средах. В дискета и суперфлоппи Объемные загрузочные записи, до 59 байт занято для Расширенный блок параметров BIOS на FAT12 и FAT16 тома начиная с DOS 4.0, тогда как FAT32 EBPB, представленный в DOS 7.1, требует даже 87 байтов, оставляя только 423 байта для загрузчика, если предположить, что размер сектора равен 512 байтам. Поэтому загрузочные секторы Microsoft традиционно накладывали определенные ограничения на процесс загрузки, например, загрузочный файл должен был находиться в фиксированной позиции в корневом каталоге файловой системы и храниться как последовательные секторы,[30][31] условия, о которых заботятся SYS команда и немного ослаблена в более поздних версиях DOS.[31][№ 6] Затем загрузчик смог загрузить первые три сектора файла в память, которая, как оказалось, содержала другой встроенный загрузчик, способный загрузить оставшуюся часть файла в память.[31] Когда Microsoft добавила LBA и поддержку FAT32, они даже перешли на загрузчик, два физических секторов и используя 386 инструкций по соображениям размера. В то же время другим поставщикам удалось втиснуть гораздо больше функциональности в один загрузочный сектор, не ослабляя исходных ограничений только на минимальную доступную память (32 КБ) и поддержку процессора (8088/8086).[№ 7] Например, загрузочные секторы DR-DOS могут найти загрузочный файл в файловой системе FAT12, FAT16 и FAT32 и загрузить его в память в целом через CHS или LBA, даже если файл не хранится в фиксированном месте и в последовательных секторах.[32][27][33][34][35][№ 8][№ 7]

Примеры загрузчиков первого уровня включают coreboot, Libreboot и Das U-Boot.

Загрузчик второй ступени

Загрузчики второй ступени, такие как GNU GRUB, REFInd, BOOTMGR, Syslinux, NTLDR или же BootX, сами не являются операционными системами, но могут правильно загружать операционную систему и передавать ей выполнение; впоследствии операционная система инициализируется и может загружать дополнительные драйверы устройств. Загрузчику второго уровня не нужны драйверы для собственной работы, но вместо этого он может использовать общие методы доступа к хранилищу, предоставляемые системной прошивкой, например BIOS или Открытая прошивка, хотя обычно с ограниченной функциональностью оборудования и более низкой производительностью.[36]

Многие загрузчики (например, GNU GRUB, Windows BOOTMGR и Windows NT / 2000 / XP NTLDR) могут быть настроены так, чтобы предоставить пользователю несколько вариантов загрузки. Эти варианты могут включать разные операционные системы (для двойная или мультизагрузка из разных разделов или дисков), разные версии одной и той же операционной системы (в случае, если новая версия имеет неожиданные проблемы), разные варианты загрузки операционной системы (например, загрузка в аварийную или безопасный режим ) и некоторые автономные программы, которые могут работать без операционной системы, например, тестеры памяти (например, memtest86 + ), базовую оболочку (как в GNU GRUB) или даже игры (см. Список игр PC Booter ).[37] Некоторые загрузчики могут также загружать другие загрузчики; например, GRUB загружает BOOTMGR вместо прямой загрузки Windows. Обычно выбор по умолчанию предварительно выбирается с временной задержкой, в течение которой пользователь может нажать клавишу, чтобы изменить выбор; после этой задержки автоматически выполняется выбор по умолчанию, поэтому нормальная загрузка может происходить без взаимодействия.

Процесс загрузки можно считать завершенным, когда компьютер готов к взаимодействию с пользователем или операционная система способна запускать системные программы или прикладные программы.

Много встроенные системы должен загрузиться немедленно. Например, подождав минуту цифровое телевидение или GPS-навигатор для начала вообще недопустимо. Поэтому такие устройства имеют программные системы в ПЗУ или флэш-память так что устройство может сразу начать работать; требуется небольшая загрузка или ее отсутствие, поскольку загрузка может быть предварительно вычислена и сохранена в ПЗУ при создании устройства.

В больших и сложных системах могут быть процедуры загрузки, которые выполняются в несколько этапов, пока, наконец, операционная система и другие программы не будут загружены и готовы к выполнению. Поскольку операционные системы спроектированы так, что они никогда не запускаются и не останавливаются, загрузчик может загрузить операционную систему, сконфигурировать себя как простой процесс в этой системе и затем безвозвратно передать управление операционной системе. Затем загрузчик завершается нормально, как и любой другой процесс.

Загрузка по сети

Большинство компьютеров также могут загружаться через компьютерная сеть. В этом сценарии операционная система хранится на диске сервер, и некоторые его части передаются клиенту с помощью простого протокола, такого как Простой протокол передачи файлов (TFTP). После того, как эти части были перенесены, операционная система берет на себя управление процессом загрузки.

Как и в случае загрузчика второго уровня, загрузка по сети начинается с использования общих методов доступа к сети, предоставляемых загрузочным ПЗУ сетевого интерфейса, которое обычно содержит Среда выполнения предварительной загрузки (PXE) изображение. Никаких драйверов не требуется, но функциональность системы ограничена до тех пор, пока ядро ​​операционной системы и драйверы не будут перенесены и запущены. В результате, как только загрузка из ПЗУ завершена, становится полностью возможным выполнить загрузку по сети в операционную систему, которая сама не имеет возможности использовать сетевой интерфейс.

Персональные компьютеры (ПК)

Загрузочные устройства

Windows To Go загрузочная флешка, Живой USB пример

Загрузочное устройство - это устройство, с которого загружается операционная система. Современный ПК UEFI или же BIOS прошивка поддерживает загрузку с различных устройств, обычно с локальных твердотельный накопитель или же привод жесткого диска через GPT или же Главная загрузочная запись (MBR) на таком диске или диске привод оптических дисков (с помощью Эль-Торито ), а USB массовое хранилище устройство (FTL -на основе флешки, SD Card или же слот для мультимедийных карт, Жесткий диск USB, дисковод оптических дисков USB и т. Д.) Или сетевую карту (с использованием PXE ). Старые, менее распространенные загрузочные устройства BIOS включают дисководы для гибких дисков, Zip диски, и LS-120 диски.

Обычно прошивка (UEFI или BIOS) позволяет пользователю настраивать порядок загрузки. Если порядок загрузки установлен на «сначала DVD-дисковод, а во-вторых, жесткий диск», микропрограмма попытается загрузиться с DVD-дисковода, и если это не удается (например, из-за того, что в дисководе нет DVD), он попытается загрузиться с локального жесткого диска.

Например, на ПК с Windows установлен на жесткий диск, пользователь может установить порядок загрузки, указанный выше, а затем вставить Linux Live CD чтобы попробовать Linux без установки операционной системы на жесткий диск. Это пример двойная загрузка, в котором пользователь выбирает, какую операционную систему запустить после того, как компьютер выполнил Самотестирование при включении (ПОЧТОВЫЙ). В этом примере двойной загрузки пользователь выбирает, вставляя или извлекая DVD из компьютера, но чаще всего выбирают, какую операционную систему загружать, выбирая из BIOS или же UEFI Меню загрузки с помощью клавиатуры компьютера; в меню загрузки обычно можно попасть, нажав F12 или же F11 ключи во время POST; то Настройка биоса обычно вводится нажатием F2 или же DEL ключи во время POST.[38][39]

Доступно несколько устройств, которые позволяют пользователю быстрая загрузка в то, что обычно является вариантом Linux для различных простых задач, таких как доступ в Интернет; примеры Splashtop и Локатор включен.[40][41][42]

Последовательность загрузки

А шестнадцатеричный дамп из FreeBSD загрузочная 0 MBR
Наградное программное обеспечение BIOS от 2000 года при загрузке

После запуска IBM-совместимый персональный компьютер x86 CPU, выполняется в реальный режим, инструкция находится по адресу сбросить вектор (адрес физической памяти FFFF0h на 16-битных процессорах x86[43] и FFFFFFF0h на 32-битных и 64-битных процессорах x86[44][45]), обычно указывая на прошивку (UEFI или же BIOS ) точка входа внутри ПЗУ. Эта ячейка памяти обычно содержит инструкцию перехода, которая передает выполнение в местоположение микропрограммы (UEFI или же BIOS ) пусковая программа. Эта программа запускает самотестирование при включении (POST) для проверки и инициализации необходимых устройств, таких как основная память (DRAM ), шину PCI и устройства PCI (включая работающие встроенные Дополнительные ПЗУ ). Один из наиболее сложных шагов - настройка DRAM поверх СПД, что еще больше усложняется тем, что на данный момент память очень ограничена.

После инициализации необходимого оборудования прошивка (UEFI или же BIOS ) проходит через предварительно настроенный список энергонезависимые запоминающие устройства («последовательность загрузочного устройства»), пока не будет найдено то, которое является загрузочным. Загрузочное устройство MBR определяется как устройство, с которого можно читать, и где последние два байта первого сектора содержат прямой порядок байтов слово AA55h,[№ 9] найдено как последовательность байтов 55ч, AAh на диске (также известный как Подпись загрузки MBR ), или если иным образом установлено, что код внутри сектора исполняется на компьютерах x86.

Как только BIOS обнаруживает загрузочное устройство, он загружает загрузочный сектор по линейному адресу. 7C00h (обычно сегмент:компенсировать 0000ч:7C00h,[27] но некоторые BIOS ошибочно используют 07C0h:0000ч[нужна цитата ]) и передает выполнение загрузочному коду. В случае жесткого диска это называется Главная загрузочная запись (MBR). Стандартный код MBR проверяет таблицу разделов MBR на наличие раздела, установленного как загрузочный[№ 10] (тот, у кого активный установлен флаг). Если активный раздел найден, код MBR загружает загрузочный сектор код из этого раздела, известный как Объем загрузочной записи (VBR) и выполняет его.

VBR часто зависит от операционной системы; однако его основная функция - загрузить и выполнить файл загрузчика операционной системы (например, io.sys, ntldr, или же bootmgr) из активного раздела. Затем загрузчик загружает Ядро ОС с запоминающего устройства.

Если нет активного раздела или загрузочный сектор активного раздела недействителен, MBR может загрузить вторичный загрузчик, который выберет раздел (часто через ввод пользователя) и загрузит его загрузочный сектор, который обычно загружает соответствующее ядро ​​операционной системы. В некоторых случаях MBR может также попытаться загрузить вторичные загрузчики перед попыткой загрузки активного раздела. Если ничего не помогает, он должен выдать INT 18ч[29][27] Вызов прерывания BIOS (за которым следует INT 19h на случай, если INT 18h вернется), чтобы вернуть управление BIOS, который затем попытается загрузиться с других устройств, попытайтесь удаленная загрузка через сеть.[27]

Некоторые системы (особенно новые Apple Mac и новее ПК ) использовать UEFI.[46][47]

В отличие от BIOS, UEFI (не Устаревшая загрузка через CSM) не полагается на загрузочные секторы, система UEFI загружает загрузчик (Приложение EFI файл в USB-диск или в Системный раздел EFI ) напрямую,[48] а ядро ​​ОС загружается загрузчиком.

Другие виды загрузочных последовательностей

Разблокированный Android загрузчик, показывая дополнительные доступные параметры

Некоторые современные процессоры и микроконтроллеры (например, TI OMAP ), а иногда даже DSP могут иметь загрузочное ПЗУ с загрузочным кодом, интегрированным непосредственно в их кремний, поэтому такой процессор может самостоятельно выполнять довольно сложную последовательность загрузки и загружать программы загрузки из различных источников, таких как флэш-память NAND, SD или MMC-карта и т. д. . Трудно встроить всю необходимую логику для работы с такими устройствами, поэтому в таких сценариях вместо этого используется интегрированное загрузочное ПЗУ. Использование загрузочного ПЗУ обеспечивает более гибкие последовательности загрузки, чем может обеспечить аппаратная логика. Например, загрузочное ПЗУ может попытаться выполнить загрузку из нескольких источников загрузки. Кроме того, загрузочное ПЗУ часто может загружать загрузчик или диагностическую программу через последовательные интерфейсы, например UART, SPI, USB и так далее. Эта функция часто используется для целей восстановления системы, когда по некоторым причинам обычное загрузочное программное обеспечение в энергонезависимой памяти было стерто, и ее также можно использовать для начального программирования энергонезависимой памяти, когда установлена ​​чистая энергонезависимая память и, следовательно, нет программного обеспечения. в системе пока нет.

Немного Встроенная система проекты могут также включать промежуточный этап последовательности загрузки в виде дополнительного кода, который загружается в систему. баран встроенным загрузочным ПЗУ. Дополнительный код, загруженный таким образом, обычно служит способом преодоления ограничений платформы, таких как небольшой объем оперативной памяти, поэтому выделенный основной загрузчик, такой как Das U-Boot, может быть загружен в качестве следующего шага в последовательности загрузки системы. Дополнительный код и этап последовательности загрузки обычно называют загрузчик вторичных программ (SPL).[49]

Также возможно получить контроль над системой с помощью интерфейса аппаратной отладки, такого как JTAG. Такой интерфейс может использоваться для записи программы загрузчика в загрузочную энергонезависимую память (например, флеш-память) путем указания ядру процессора выполнять необходимые действия для программирования энергонезависимой памяти. В качестве альтернативы интерфейс отладки может использоваться для загрузки некоторого диагностического или загрузочного кода в ОЗУ, а затем для запуска ядра процессора и указания ему выполнить загруженный код. Это позволяет, например, восстанавливать встроенные системы, в которых не осталось программного обеспечения ни на одном из поддерживаемых загрузочных устройств, а процессор не имеет встроенного загрузочного ПЗУ. JTAG - стандартный и популярный интерфейс; многие процессоры, микроконтроллеры и другие устройства производятся с интерфейсами JTAG (по состоянию на 2009 г.).

Некоторые микроконтроллеры предоставляют специальные аппаратные интерфейсы, которые нельзя использовать для произвольного управления системой или прямого запуска кода, но вместо этого они позволяют вставлять загрузочный код в загрузочную энергонезависимую память (например, флэш-память) с помощью простых протоколов. Затем на этапе производства такие интерфейсы используются для ввода загрузочного кода (и, возможно, другого кода) в энергонезависимую память. После сброса системы микроконтроллер начинает выполнять код, запрограммированный в его энергонезависимой памяти, точно так же, как обычные процессоры используют ПЗУ для загрузки. В частности, этот метод используется Atmel AVR микроконтроллеры, а также другие. Во многих случаях такие интерфейсы реализуются аппаратной логикой. В других случаях такие интерфейсы могут быть созданы программным обеспечением, работающим во встроенном загрузочном ПЗУ на кристалле. GPIO булавки.

Наиболее цифровые сигнальные процессоры иметь загрузку в последовательном режиме и загрузку в параллельном режиме, например интерфейс хост-порта (загрузка HPI)

В случае DSP в конструкции системы часто присутствует второй микропроцессор или микроконтроллер, который отвечает за общее поведение системы, обработку прерываний, обработку внешних событий, пользовательский интерфейс и т. Д., В то время как DSP предназначен только для задач обработки сигналов. . В таких системах DSP может быть загружен другим процессором, который иногда называют хост-процессор (давая имя хост-порту). Такой процессор также иногда называют владелец, поскольку он обычно сначала загружается из собственной памяти, а затем управляет общим поведением системы, включая загрузку DSP, а затем дальнейшее управление поведением DSP. DSP часто не имеет собственной загрузочной памяти и вместо этого полагается на хост-процессор, который предоставляет необходимый код. Наиболее известными системами с такой конструкцией являются сотовые телефоны, модемы, аудио- и видеоплееры и т. Д., В которых сосуществуют DSP и CPU / микроконтроллер.

Много FPGA чипы загружают свою конфигурацию из внешнего последовательного EEPROM («конфигурационное ПЗУ») при включении питания.

Смотрите также

Примечания

  1. ^ Включая демоны.
  2. ^ UU часто имел форму Uu, U = адрес блока управления, u = адрес устройства, но к некоторым блокам управления подключалось только 8 устройств; некоторые подключили более 16. Действительно, контроллер DASD 3830 предлагал в качестве опции адресацию 32 дисков.
  3. ^ За исключением 370/145 и 370/155, в которых использовалась консольная пишущая машинка 3210 или 3215.
  4. ^ Только S / 360 использовал 2250; то 360/85, 370/165 и 370/168 использовал клавиатуру / дисплей, не совместимый ни с чем другим.
  5. ^ В IBM 1401, IBM 7090, IBM System / 360 и многие другие не требуют ввода загрузчика. S / 360 имел хранилище только для чтения в большинстве моделей, хотя и не использовало встроенное.
  6. ^ В ПК DOS 5.0 В руководстве неправильно указано, что системные файлы больше не должны быть непрерывными. Однако для того, чтобы процесс загрузки работал, системные файлы должны занимать первые две записи каталога и первые три сектора IBMBIO.COM по-прежнему нужно хранить непрерывно. SYS продолжает заботиться об этих требованиях.
  7. ^ а б Например, расширенная функциональность DR-DOS MBR и загрузочные секторы по сравнению с их MS-DOS /ПК DOS аналоги могут быть получены с использованием обычных оптимизация кода методы до 7.05, для добавления LBA, FAT32 и ПОГРУЗЧИК поддержать 7.07 секторам пришлось прибегнуть к самомодифицирующийся код, код операции -уровневое программирование, контролируемое использование побочные эффекты, многоуровневые данные / код суперпозиция и алгоритмические складывание методы, чтобы сжать все в один физический сектор, поскольку это было требованием для назад - и кросс-совместимость с другими операционными системами в мультизагрузка и цепь нагрузки сценарии.
  8. ^ Есть одно исключение из правила: DR-DOS VBR загрузит весь IBMBIO.COM файл в память: если размер файла IBMBIO.COM превышает 29 КБ, попытка загрузить весь файл в память приведет к тому, что загрузчик загрузит перезаписывать то куча и переехал Таблица параметров диска (DPT / FDPB). Следовательно, DR-DOS 7.07 VBR загрузит в память только первые 29 КБ файла, полагаясь на другой загрузчик, встроенный в первую часть IBMBIO.COM, чтобы проверить это условие и при необходимости загрузить оставшуюся часть файла в память. Это не вызывает проблем совместимости, так как размер IBMBIO.COM никогда не превышал этот предел в предыдущих версиях без этого загрузчика. В сочетании с двойной структурой входа это также позволяет загружать систему ПК DOS VBR, который загружает в память только первые три сектора файла.
  9. ^ Подпись при зачете + 1FEh в загрузочных секторах есть 55ч AAh, то есть 55ч по смещению + 1FEh и AAh по смещению + 1FFh. С прямой порядок байтов представление должно рассматриваться в контексте IBM PC совместимые машины, это можно записать как 16-битное слово AA55h в программах для x86 процессоров (обратите внимание на порядок замены), тогда как это должно быть записано как 55ААч в программах для других архитектур ЦП с использованием прямой порядок байтов представление. Поскольку это много раз было перепутано в книгах и даже в исходных справочных документах Microsoft, в этой статье используется байтовое представление на диске на основе смещения, чтобы избежать любой возможной неверной интерпретации.
  10. ^ В активный раздел может содержать Загрузчик второй ступени, например, OS / 2 Boot Manager, а не ОС.

Рекомендации

  1. ^ "бутстрап". Компьютерный словарь информационных технологий.
  2. ^ "Бутстрап". Бесплатный словарь.
  3. ^ «Подтянитесь за шнурки». Идиомы от The Free Dictionary. Получено 2019-10-07.
  4. ^ «Определение начальной загрузки». Технические условия. Получено 2019-10-02.
  5. ^ "Подтяните себя за шнурки". Поиск фраз.
  6. ^ Кэмпбелл-Келли, Мартин (1980). «Программирование EDSAC». IEEE Annals of the History of Computing. 2 (1): 7–36. Дои:10.1109 / mahc.1980.10009.
  7. ^ Уилкс, Морис В.; Уилер, Дэвид Дж.; Гилл, Стэнли (1951). Подготовка программ для электронного цифрового компьютера. Эддисон-Уэсли.
  8. ^ Бухгольц, Вернер (1953). «Системный дизайн компьютера IBM Type 701» (PDF). Труды I.R.E.. 41 (10): 1273.
  9. ^ а б "IBM 7619 Exchange". Справочное руководство Система обработки данных 7030 (PDF). IBM. Август 1961. С. 125–127. A22-6530-2.
  10. ^ Принципы работы Тип 701 и связанное с ним оборудование (PDF). IBM. 1953. с. 26. Получено 2012-11-09.
  11. ^ От Гутенберга к Интернету, Джереми М. Норман, 2005, стр. 436, ISBN  0-930405-87-0
  12. ^ Оксфордский словарь английского языка. Оксфордский университет.
  13. ^ Магнитный барабан 650. инструкция по эксплуатации. (PDF). IBM. 1955. С. 49, 53–54.
  14. ^ Системное руководство GE-645 (PDF). General Electric. Январь 1968. Получено 2019-10-30.
  15. ^ Справочное руководство по системе PDP-10, часть 1 (PDF). Корпорация цифрового оборудования. 1969. С. 2–72.. Получено 2012-11-09.
  16. ^ а б z / Архитектура Принципы работы (PDF). IBM. Сентябрь 2005. С. Глава 17.. Получено 2007-04-14.
  17. ^ Руководство по периферийным устройствам PDP-11 (PDF). Корпорация цифрового оборудования. 1976. С. 4–25.
  18. ^ Как использовать компьютеры Nova (PDF). Общие данные. Октябрь 1974 г. Раздел 2.8 «Загрузка программы».
  19. ^ «Старые компьютеры: Альтаир 8800б». Получено 2019-12-10.
  20. ^ «Альтаир 8800 загружает 4K BASIC с бумажной ленты», видео Гленна Холмера
  21. ^ Чарамелла, Альберто. "Устройство для автоматической загрузки центральной памяти электронных процессоров. "Патент США № 4,117,974. 1978-10-03. (Подан в 1975 году).
  22. ^ Альберто Чьярамелла рассказал о расширении возможностей компьютера в CSELT [Альберто Чьярамелла обсуждает патент на начальную загрузку компьютеров, разработанный в CSELT] (на итальянском).
  23. ^ Осборн, Адам; Кейн, Джерри (1981). Руководство по 16-битному микропроцессору Osborne (PDF). С. 5–27. ISBN  0-931988-43-8. Получено 2019-08-23.
  24. ^ Руководство разработчика программного обеспечения для архитектур Intel 64 и IA-32 Том 3 (3A, 3B, 3C и 3D): Руководство по системному программированию (PDF).
  25. ^ Осборн, Адам; Кейн, Джерри. Osborne Руководство по 4- и 8-битным микропроцессорам. С. 10–20. ISBN  0-931988-42-X.
  26. ^ Apple Ad, Interface Age, октябрь 1976 г.
  27. ^ а б c d е Пол, Матиас Р. (1997-10-02) [1997-09-29]. "Caldera OpenDOS 7.01 / 7.02 Обновление Alpha 3 IBMBIO.COM - README.TXT и BOOT.TXT - Краткое описание того, как загружается OpenDOS". Архивировано из оригинал на 2003-10-04. Получено 2009-03-29. [1]
  28. ^ Сакамото, Масахико (13 мая 2010 г.). «Почему BIOS загружает MBR в 7C00h в x86?». Glamenv-Septzen.net. Получено 2012-08-22.
  29. ^ а б Compaq Computer Corporation; Phoenix Technologies Ltd; Корпорация Intel (11 января 1996 г.). "Спецификация загрузки BIOS 1.01" (PDF). Получено 2017-12-21.
  30. ^ Збиковски, Марк; Аллен, Пол; Баллмер, Стив; Борман, Рувим; Борман, Роб; Батлер, Джон; Кэрролл, Чак; Чемберлен, Марк; Челл, Дэвид; Коли, Майк; Кортни, Майк; Драйфус, Майк; Дункан, Рэйчел; Экхардт, Курт; Эванс, Эрик; Фермер, Рик; Гейтс, Билл; Гири, Майкл; Гриффин, Боб; Хогарт, Дуг; Джонсон, Джеймс У .; Кермаани, Камель; Король, Адриан; Кох, Рид; Ландовски, Джеймс; Ларсон, Крис; Леннон, Томас; Липки, Дэн; Макдональд, Марк; МакКинни, Брюс; Мартин, Паскаль; Мазерс, Эстель; Мэтьюз, Боб; Мелин, Дэвид; Mergentime, Чарльз; Невин, Рэнди; Ньюэлл, Дэн; Ньюэлл, Тани; Норрис, Дэвид; О'Лири, Майк; О'Рир, Боб; Олссон, Майк; Остерман, Ларри; Остлинг, Ридж; Пай, Сунил; Патерсон, Тим; Перес, Гэри; Питерс, Крис; Петцольд, Чарльз; Поллок, Джон; Рейнольдс, Аарон; Рубин, Дэррил; Райан, Ральф; Шульмейстер, Карл; Шах, Раджен; Шоу, Барри; Коротко, Энтони; Сливка, Бен; Смирл, Джон; Стиллмейкер, Бетти; Стоддард, Джон; Тиллман, Деннис; Уиттен, Грег; Юнт, Натали; Зек, Стив (1988). «Технические советники». Энциклопедия MS-DOS: версии с 1.0 по 3.2. Дункан, Рэй; Боствик, Стив; Бургойн, Кейт; Байерс, Роберт А.; Хоган, Том; Кайл, Джим; Летвин, Гордон; Петцольд, Чарльз; Рабинович, Чип; Томлин, Джим; Уилтон, Ричард; Волвертон, Ван; Вонг, Уильям; Вудкок, Джоанна (Полностью переработанная ред.). Редмонд, Вашингтон, США: Microsoft Press. ISBN  1-55615-049-0. LCCN  87-21452. OCLC  16581341. (xix + 1570 страниц; 26 см) (NB. Это издание было опубликовано в 1988 году после обширной переработки отозванного первого издания 1986 года другим коллективом авторов. [2] )
  31. ^ а б c Чаппелл, Джефф (январь 1994). «Глава 2: Системный след». В Шульмане, Эндрю; Педерсен, Аморетта (ред.). Внутреннее устройство DOS. Серия программирования Эндрю Шульман (1-е издание, 1-е изд.). Издательство Эддисон Уэсли. ISBN  978-0-201-60835-9. (xxvi + 738 + iv страницы, 3,5-дюймовые гибкие диски [3][4] ) Исправления: [5][6][7]
  32. ^ Рош, Винн Л. (1991-02-12). "DR DOS 5.0 - Лучшая операционная система?". Журнал ПК. Vol. 10 шт. 3. п. 241-246, 257, 264, 266. В архиве из оригинала на 2019-07-25. Получено 2019-07-26. […] SYS был улучшен под DR DOS 5.0 так что вам не нужно беспокоиться о том, чтобы оставить первый кластер свободным на диске, который вы хотите сделать загрузочным. Системные файлы DR DOS могут быть расположены где угодно на диске, поэтому любой диск с достаточно свободным пространством можно настроить для загрузки вашей системы. […] (NB. Источник приписывает это утилите SYS, хотя на самом деле это функция расширенного загрузчика начальной загрузки в загрузочном секторе. SYS просто помещает этот сектор на диск.)
  33. ^ Пол, Маттиас Р. (17 января 2001 г.). «FAT32 в DR-DOS». opendos @ delorie. В архиве с оригинала на 2017-10-06. Получено 2017-10-06. […] DR-DOS загрузочный сектор […] ищет IBMBIO.COM (DRBIOS.SYS ), а затем загружает * весь * файл в память, прежде чем передать ему управление. […]
  34. ^ Пол, Матиас Р. (20 февраля 2002 г.). "Не могу скопировать". opendos @ delorie. В архиве с оригинала на 2017-10-06. Получено 2017-10-06. […] DR-DOS загрузочный сектор загружает весь IBMBIO.COM файл в память перед его выполнением. Его совершенно не волнует IBMDOS.COM файл, который загружает IBMBIO.COM. […] Загрузочный сектор DR-DOS […] найдет […] файлы ядра, если они логически сохранены в корневом каталоге. Их физическое расположение на диске, и если они фрагментированы или нет, не имеет значения для загрузочного сектора DR-DOS. Следовательно, вы можете просто скопировать файлы ядра на диск (даже просто КОПИРОВАТЬ ), и как только загрузочный сектор станет сектором DR-DOS, он найдет и загрузит их. Конечно, сложно уместить все это всего в 512 байт, размер одного сектора, но это серьезное улучшение удобства, если вам нужно настроить систему DR-DOS, а также ключ к DR. -DOS мульти-ОС ПОГРУЗЧИК утилита для работы. В MS-DOS Файлы ядра должны находиться в определенных местах, но файлы DR-DOS могут находиться где угодно, поэтому вам не нужно физически менять местами их каждый раз при загрузке другой ОС. Кроме того, он позволяет обновлять систему DR-DOS, просто копируя файлы ядра поверх старых, без необходимости SYS, никаких сложных процедур настройки, необходимых для MS-DOS /ПК DOS. Вы даже можете хранить несколько файлов ядра DR-DOS под разными именами на одном диске, и LOADER будет переключаться между ними в соответствии с именами файлов, указанными в BOOT.LST файл. […]
  35. ^ Пол, Маттиас Р. (14.08.2017) [07.08.2017]. «Продолжающаяся сага о Windows 3.1 в расширенном режиме на OmniBook 300». MoHPC - Музей калькуляторов HP. В архиве с оригинала на 2017-10-06. Получено 2017-10-06. […] DR-DOS FDISK не только разбивает диск на разделы, но также может форматировать только что созданные тома и инициализировать их загрузочные секторы за один раз, поэтому нет риска случайно испортить неправильный том и не нужно ФОРМАТ / S или SYS. После этого вы можете просто скопировать оставшиеся файлы DR-DOS, включая системные файлы. Важно знать, что в отличие от MS-DOS /ПК DOS, DR-DOS имеет «умные» загрузочные секторы, которые фактически «монтируют» файловую систему для поиска и загрузки системных файлов в корневой каталог, вместо того, чтобы ожидать их размещения в определенном месте. Физически системные файлы могут располагаться где угодно, а также могут быть фрагментированы. […]
  36. ^ «Глава 6 - Устранение неполадок при запуске и проблемах с диском». Комплект ресурсов Windows NT Server. Microsoft. Архивировано из оригинал на 2007-05-15.
  37. ^ «Оттенок». coreboot. Получено 2010-11-20.
  38. ^ «Список марок ПК с соответствующими горячими клавишами». www.disk-image.com. Получено 2020-09-26.
  39. ^ «Как войти в BIOS на любом ПК: ключи доступа от производителя | Tom's Hardware». www.tomshardware.com. Получено 2020-09-26.
  40. ^ Браун, Эрик (2008-10-02). «MontaVista Linux поддерживает функцию быстрой загрузки Dell». linuxdevices.com. Получено 2010-11-20.
  41. ^ Ларабель, Майкл (2008-06-14). "SplashTop Linux для ноутбуков HP, Dell?". Фороникс. Получено 2010-11-20.
  42. ^ "Instant-On IOS от Voodoo Envy (на базе Splashtop)". YouTube. Получено 2010-11-20.
  43. ^ «Справочное руководство программиста iAPX 286» (PDF). Intel. 1983. Раздел 5.3 ИНИЦИАЛИЗАЦИЯ СИСТЕМЫ, с. 5-7. Получено 2019-08-23. Поскольку регистр CS содержит F000 (тем самым определяя сегмент кода, начинающийся с физического адреса F0000), а указатель инструкции содержит FFF0, процессор выполнит свою первую инструкцию по физическому адресу FFFF0H.
  44. ^ "Справочное руководство программиста 80386" (PDF). Intel. 1986. Раздел 10.2.3 Первые инструкции, с. 10-3. Получено 2013-11-03. После СБРОСА адресные строки A31-20 автоматически утверждаются для выборки команд. Этот факт вместе с начальными значениями CS: IP приводит к тому, что выполнение инструкции начинается с физического адреса FFFFFFF0H.
  45. ^ «Руководство разработчика программного обеспечения для архитектур Intel 64 и IA-32» (PDF). Корпорация Intel. Май 2012 г. Раздел 9.1.4 Выполнено первое распоряжение, стр. 2611. Получено 2012-08-23. Первая команда, которая выбирается и выполняется после аппаратного сброса, находится по физическому адресу FFFFFFF0h. Этот адрес находится на 16 байт ниже самого верхнего физического адреса процессора. EPROM, содержащий код инициализации программного обеспечения, должен находиться по этому адресу.
  46. ^ «Платформа Intel Innovation Framework для EFI». Intel. Получено 2008-01-07.
  47. ^ «OpenBIOS - coreboot». coreboot.org. Получено 2013-03-20.
  48. ^ «UEFI - OSDev Wiki». wiki.osdev.org. Получено 2020-09-26.
  49. ^ «Обзор - четыре этапа загрузчика». ti.com. Инструменты Техаса. 2013-12-05. Получено 2015-01-25.