В вычислениях , загрузка представляет собой процесс запуска компьютера . Это может быть инициировано аппаратным обеспечением, например нажатием кнопки, или программной командой. После включения центральный процессор (ЦП) компьютера не имеет программного обеспечения в своей основной памяти , поэтому некоторый процесс должен загрузить программное обеспечение в память, прежде чем его можно будет выполнить. Это может быть сделано с помощью оборудования или микропрограмм в ЦП или с помощью отдельного процессора в компьютерной системе.
Перезагрузка компьютера также называется перезагрузкой , которая может быть «жесткой», например, после выключения электропитания ЦП, или «мягкой», когда питание не отключается. В некоторых системах мягкая загрузка может опционально очистить оперативную память до нуля. Как аппаратная, так и программная загрузка может быть инициирована аппаратным обеспечением, например нажатием кнопки или программной командой. Загрузка завершается, когда рабочая система времени выполнения , обычно операционная система и некоторые приложения, достигает [nb 1] .
Процесс возврата компьютера из состояния сна (приостановки) не требует загрузки; однако восстановление его из состояния гибернации делает. Как минимум, некоторые встроенные системы не требуют заметной последовательности загрузки для начала работы и при включении могут просто запускать рабочие программы, которые хранятся в ПЗУ. Все вычислительные системы являются конечными автоматами , и перезагрузка может быть единственным способом вернуться в назначенное нулевое состояние из непреднамеренного заблокированного состояния.
Помимо загрузки операционной системы или автономной утилиты, в процессе загрузки также может быть загружена программа дампа хранилища для диагностики проблем в операционной системе.
Boot - это сокращение от bootstrap [1] [2] или bootstrap load и происходит от фразы « подтянуть себя за свои бутстрепы» . [3] [4] Использование обращает внимание на требование, что, если большая часть программного обеспечения загружается на компьютер другим программным обеспечением, уже запущенным на компьютере, должен существовать какой-то механизм для загрузки исходного программного обеспечения на компьютер. [5] Ранние компьютеры использовали множество специальных методов для загрузки небольшой программы в память для решения этой проблемы. Изобретение постоянной памяти(ROM) различных типов разрешили этот парадокс, позволив поставлять компьютеры с программой запуска, которую нельзя было стереть. Увеличение емкости ROM позволило реализовать все более сложные процедуры запуска.
История [ править ]
Существует множество различных методов загрузки короткой начальной программы в компьютер. Эти методы простираются от простого физического ввода до съемных носителей, которые могут содержать более сложные программы.
Примеры предварительной интегральной схемы [ править ]
Ранние компьютеры [ править ]
Ранние компьютеры 1940-х и 1950-х годов представляли собой единственные в своем роде инженерные разработки, на программирование которых уходили недели, и загрузка программы была одной из многих проблем, которые необходимо было решить. Ранний компьютер, ENIAC , не имел программы, хранящейся в памяти, но был настроен для каждой проблемы с помощью конфигурации соединительных кабелей. Начальная загрузка не применялась к ENIAC, чья аппаратная конфигурация была готова для решения проблем, как только было подано питание.
Система EDSAC , второй компьютер с хранимой программой, который будет построен, использовала пошаговые переключатели для передачи фиксированной программы в память при нажатии ее кнопки запуска. Программа, хранящаяся на этом устройстве, которую Дэвид Уиллер завершил в конце 1948 года, загружала дальнейшие инструкции с перфоленты и затем выполняла их. [6] [7]
Первые коммерческие компьютеры [ править ]
Первые программируемые компьютеры для коммерческой продажи, такие как UNIVAC I и IBM 701 [8], включали функции, упрощающие их работу. Обычно они включали инструкции, которые выполняли полную операцию ввода или вывода. Та же самая аппаратная логика может использоваться для загрузки содержимого перфокарты (наиболее типичных) или других носителей ввода, таких как магнитный барабан или магнитная лента , которые содержат программу начальной загрузки, путем нажатия одной кнопки. Эту концепцию загрузки называли по-разному для компьютеров IBM 1950-х и начала 1960-х годов, но IBM использовала термин «начальная загрузка программы» с IBM 7030 Stretch [9].и позже использовали его для своих линий мэйнфреймов, начиная с System / 360 в 1964 году.
IBM 701 компьютер (1952-1956) была кнопка «Загрузить» , который инициировал чтение первого 36-битового слова в основную память от перфокарту в считыватель карт , магнитную ленту в накопитель на магнитной ленте , или магнитный узел барабана , в зависимости от положения переключателя выбора нагрузки. Затем левое 18-битное полуслово выполнялось как инструкция, которая обычно считывала дополнительные слова в память. [10] [11] Затем была выполнена загруженная программа загрузки, которая, в свою очередь, загрузила более крупную программу с этого носителя в память без дальнейшей помощи человека-оператора. Термин «ботинок» используется в этом смысле по крайней мере с 1958 г. [12]
Другие компьютеры 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 (с. 1965) была кнопка «SYSTEM Bootload», при нажатии, причиненных одному из контроллеров ввода / вывода , чтобы загрузить программу 64 слов в память с диодом памяти только для чтения и доставить прерывание дела эту программу, чтобы начать работу. [14]
- Первая модель PDP-10 имела кнопку «READ IN», которая при нажатии сбрасывала процессор и запускала операцию ввода-вывода на устройстве, указанном переключателями на панели управления, считывая 36-битное слово, дающее целевой адрес и счетчик последующих чтений слов; когда чтение завершилось, процессор начал выполнение считанного кода, перейдя к последнему считанному слову. [15]
Примечательная разновидность этого есть на Burroughs B1700, где нет ни загрузочного ПЗУ, ни аппаратной операции IPL. Вместо этого после сброса системы она считывает и выполняет коды операций последовательно с ленточного накопителя, установленного на передней панели; это устанавливает загрузчик в ОЗУ, который затем запускается. Тем не менее, поскольку это делает мало предположений о системе, его также можно использовать для загрузки диагностических лент (процедура технического обслуживания), которые отображают понятный код на передней панели даже в случае серьезного сбоя ЦП.
IBM System / 360 и последующие [ править ]
В IBM System / 360 и его преемниках, включая текущие машины z / Architecture , процесс загрузки известен как начальная загрузка программы (IPL).
IBM придумала этот термин для 7030 (Stretch) , [9] возродила его для дизайна System / 360 и продолжает использовать его в этих средах сегодня. [16] В процессорах System / 360 IPL инициируется оператором компьютера путем выбора адреса устройства из трех шестнадцатеричных цифр (CUU; C = адрес канала ввода-вывода, UU = блок управления и адрес устройства [nb 2] ), за которым следует нажав кнопку ЗАГРУЗИТЬ . В моделях High End System / 360 , большинстве [nb 3] System / 370 и некоторых более поздних системах функции переключателей и кнопки LOAD моделируются с использованием выбираемых областей на экране графической консоли, часто [nb 4] иУстройство, подобное IBM 2250 или устройство, подобное IBM 3270 . Например, в System / 370 Model 158 последовательность клавиш 0-7-X (ноль, семь и X в указанном порядке) приводит к IPL с адреса устройства, который был введен в область ввода. Amdahl 470V / 6 и связанные с ними процессоры поддерживаются четыре шестнадцатеричных цифр на этих процессорах , которые имели дополнительный блок второго канала установлен, в общей сложности 32 каналов. Позже IBM также будет поддерживать более 16 каналов.
Функция IPL в System / 360 и ее преемниках, а также в ее совместимых устройствах, таких как Amdahl, считывает 24 байта из указанного оператором устройства в оперативную память, начиная с реального адреса с нуля. Вторая и третья группы из восьми байтов обрабатываются как командные слова канала (CCW) для продолжения загрузки программы запуска (первая CCW всегда моделируется ЦП и состоит из команды Read IPL, 02h , с объединением команд и подавлением неправильной длины. указание применяется). Когда команды канала ввода / вывода завершены, первая группа из восьми байтов загружается в слово состояния программы (PSW) процессора, и программа запуска начинает выполнение в месте, указанном этим PSW. [16]Устройство IPL обычно представляет собой дисковод, отсюда особое значение команды чтения-типа 02h , но точно такая же процедура также используется для IPL с других устройств ввода, таких как ленточные накопители или даже устройства чтения карт, в аппаратно-независимый способ, позволяющий, например, установить операционную систему на новый компьютер с магнитной ленты первоначального распространения ОС. Для дисковых контроллеров команда 02h также заставляет выбранное устройство искать цилиндр 0000h , головку 0000h , имитируя команду поиска цилиндра и головки, 07h , и искать запись 01h , имитируя команду Search ID Equal, 31h; поиск и поиск не моделируются контроллерами лент и карт, поскольку для этих классов устройств команда 02h является просто командой последовательного чтения, а не командой чтения IPL.
Диск, лента или колода карт должны содержать специальную программу для загрузки фактической операционной системы или автономной утилиты в основное хранилище, и для этой конкретной цели «Текст IPL» помещается на диск с помощью автономного DASDI (устройства хранения с прямым доступом. Initialization) или эквивалентную программу, работающую под управлением операционной системы, например ICKDSF, но ленты и колоды карт с возможностью IPL обычно распространяются с уже присутствующим «текстом IPL».
Миникомпьютеры [ править ]
Миникомпьютеры , начиная с PDP-5 и PDP-8 (1965) корпорации Digital Equipment Corporation (DEC), упростили конструкцию за счет использования ЦП для поддержки операций ввода и вывода. Это сэкономило средства, но сделало загрузку более сложной, чем нажатие одной кнопки. Миникомпьютеры обычно имели возможность переключать короткие программы, управляя набором переключателей на передней панели. Поскольку ранние миникомпьютеры использовали память на магнитных сердечниках , которая не теряла свою информацию при отключении питания, эти загрузчики оставались на месте, если их не стереть. Стирание иногда происходило случайно, когда ошибка программы вызывала цикл, который перезаписывал всю память.
Другие миникомпьютеры с такой простой формой загрузки включают серию Hewlett-Packard HP 2100 (середина 1960-х), оригинальный Data General Nova (1969) и DEC PDP-11 (1970).
Позже DEC добавила дополнительную постоянную память с диодной матрицей для PDP-11, в которой хранилась программа начальной загрузки объемом до 32 слов (64 байта). Он состоял из печатной платы M792, которая подключалась к Unibus и содержала матрицу 32 на 16 полупроводниковых диодов. После установки всех 512 диодов в памяти были все «единицы»; карта была запрограммирована отключением каждого диода, бит которого должен был быть "нулем". DEC также продавала версии карты серии BM792-Yx, предварительно запрограммированные для многих стандартных устройств ввода, просто исключая ненужные диоды. [17]
Следуя более старому подходу, более ранний PDP-1 имеет аппаратный загрузчик, так что оператору нужно всего лишь нажать переключатель «load», чтобы дать устройству чтения с бумажной ленты команду загрузить программу непосредственно в основную память. Data General Supernova использовала переключатели на передней панели, чтобы компьютер автоматически загружал инструкции в память с устройства, заданного переключателями данных на передней панели, а затем переходил к загруженному коду; у Nova 800 и 1200 был переключатель, который загружал программу в основную память из специальной постоянной памяти и переходил к ней. [18]
Примеры загрузчика ранних миникомпьютеров [ править ]
В миникомпьютере со считывателем бумажной ленты первая программа, запускаемая в процессе загрузки, загрузчик, будет считывать в основную память либо загрузчик второй ступени (часто называемый двоичным загрузчиком ), который может читать бумажную ленту с контрольной суммой, либо операционная система с внешнего носителя. Псевдокод для загрузчика может быть таким же простым, как следующие восемь инструкций:
- Установите регистр P на 9
- Убедитесь, что устройство чтения бумажной ленты готово
- Если не готовы, переходите к 2
- Считать байт от устройства чтения бумажной ленты до аккумулятора
- Сохранить аккумулятор по адресу в регистре P
- Если конец ленты, переходите к 9
- Увеличить регистр P
- Перейти к 2
Связанный пример основан на погрузчика для Nicolet Instrument Corporation миникомпьютер 1970 - х годов, с использованием бумажной ленты блок-ридер пуансона на Телетайпный Model 33 ASR телепринтера . Байты его загрузчика второй ступени считываются с бумажной ленты в обратном порядке.
- Установите регистр P на 106
- Убедитесь, что устройство чтения бумажной ленты готово
- Если не готовы, переходите к 2
- Считать байт от устройства чтения бумажной ленты до аккумулятора
- Сохранить аккумулятор по адресу в регистре P
- Уменьшить регистр P
- Перейти к 2
Длина загрузчика второй ступени такова, что последний байт перезаписывает ячейку 7. После выполнения инструкции в ячейке 6 ячейка 7 запускает выполнение загрузчика второй ступени. Затем загрузчик второй стадии ожидает, пока гораздо более длинная лента, содержащая операционную систему, будет помещена в устройство чтения ленты. Разница между загрузчиком начальной загрузки и загрузчиком второй ступени заключается в добавлении кода проверки для обнаружения ошибок чтения с бумажной ленты, что часто встречается при использовании относительно недорогого оборудования, работающего неполный рабочий день, такого как Teletype Model 33 ASR. (Friden Flexowriters были гораздо более надежными, но и относительно дорогими.)
Загрузка первых микрокомпьютеров [ править ]
Самые ранние микрокомпьютеры, такие как Altair 8800 (впервые выпущенный в 1975 году) и даже более ранняя аналогичная машина (на базе процессора Intel 8008) не имели аппаратного обеспечения начальной загрузки как такового. [19]При запуске ЦП будет видеть память, которая будет содержать исполняемый код, содержащий только двоичные нули - память очищалась путем сброса при включении питания. На лицевых панелях этих машин были тумблеры для ввода адресов и данных, по одному переключателю на бит слова памяти компьютера и адресной шины. Простые дополнения к оборудованию позволяли загружать с этих переключателей одну ячейку памяти за раз для хранения кода начальной загрузки. Тем временем ЦП не пытался выполнить содержимое памяти. После правильной загрузки ЦП был включен для выполнения кода начальной загрузки. Этот процесс был утомительным и не должен был содержать ошибок. [20]
Эпоха постоянной памяти только для чтения на интегральных схемах [ править ]
Процесс загрузки для миникомпьютеров и микрокомпьютеров [nb 5] был революционизирован благодаря введению постоянного запоминающего устройства для интегральных схем (ROM) с его многочисленными вариантами, включая программируемые по маске ROM , программируемые ROM (PROM), стираемые программируемые 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. , Apple 1, представленный в 1976 году, был оснащен микросхемами PROM, которые устраняли необходимость в передней панели для процесса загрузки (как в случае с Altair 8800) в коммерческом компьютере. Согласно объявлению Apple, «Больше никаких переключателей, никаких огней ... прошивка в PROMS позволяет вам вводить, отображать и отлаживать программы (все в шестнадцатеричном формате) с клавиатуры». [26]
Из-за высокой стоимости постоянной памяти в то время, серия Apple II загружала свои дисковые операционные системы, используя серию очень маленьких пошаговых шагов, каждый из которых передавал управление следующей фазе постепенно более сложного процесса загрузки. (См. Apple DOS: Загрузчик ). Поскольку дисковая операционная система очень мало полагалась на ПЗУ, оборудование также было чрезвычайно гибким и поддерживало широкий спектр настраиваемых механизмов защиты диска от копирования . (См. Взлом программного обеспечения: История .)
Некоторые операционные системы, в первую очередь системы Macintosh до 1995 года от Apple , настолько тесно связаны с их оборудованием, что невозможно изначально загрузить операционную систему, отличную от стандартной. Это противоположная крайность сценария с использованием переключателей, упомянутых выше; он очень негибкий, но относительно безошибочный и надежный, пока все оборудование работает нормально. Распространенным решением в таких ситуациях является разработка загрузчика, который работает как программа, принадлежащая стандартной ОС, которая захватывает систему и загружает альтернативную ОС. Этот метод был использован Apple для реализации A / UX Unix и скопирован различными бесплатными операционными системами и BeOS Personal Edition 5 .
Некоторые машины, такие как микрокомпьютер Atari ST , работали мгновенно, а операционная система выполнялась из ПЗУ.. Таким образом, извлечение ОС из вторичного или третичного хранилища было исключено как одна из характерных операций для начальной загрузки. Чтобы обеспечить автоматическую загрузку настроек системы, аксессуаров и другого вспомогательного программного обеспечения, флоппи-дисковод Atari считывался на наличие дополнительных компонентов во время процесса загрузки. Была задержка тайм-аута, которая давала время, чтобы вручную вставить дискету, пока система искала дополнительные компоненты. Этого можно было избежать, вставив чистый диск. Аппаратное обеспечение Atari ST также было спроектировано таким образом, чтобы слот для картриджей мог обеспечивать выполнение собственных программ для игровых целей в качестве наследства от унаследованных от Atari электронных игр; вставив Spectre GCRкартридж с системным ПЗУ Macintosh в игровом слоте и включение Atari, он мог «изначально загружать» операционную систему Macintosh, а не собственные TOS Atari .
IBM Personal Computer включены прошивки ПЗУ на основе называется BIOS ; одной из функций этой прошивки было выполнение самотестирования при включении машины, а затем считывание программного обеспечения с загрузочного устройства и его выполнение. Прошивка, совместимая с BIOS на персональном компьютере IBM, используется в компьютерах, совместимых с IBM PC . Интерфейс Extensible Firmware был разработан Intel, первоначально для Itanium -На машины, а затем также используется в качестве альтернативы BIOS в x86 -На машинах, в том числе Apple , Маков на базе процессоров Intel .
Рабочие станции Unix изначально имели встроенное ПО на основе ПЗУ конкретного производителя. Позднее Sun Microsystems разработала OpenBoot , позже известную как Open Firmware, которая включала интерпретатор Forth , причем большая часть прошивки была написана на Forth. Он был стандартизирован IEEE как стандарт IEEE 1275-1994; микропрограммное обеспечение , которое реализует этот стандарт был использован в PowerPC -А Маков и некоторые другие машины PowerPC на базе, а также Sun собственного SPARC -компьютеры. Спецификация Advanced RISC Computing определила другой стандарт прошивки, который был реализован на некоторых платформах MIPS и Alpha.машины и рабочие станции SGI Visual Workstation на базе x86.
Современные загрузчики [ править ]
Когда компьютер выключен, его программное обеспечение - «включая операционные системы, код приложений и данные» - остается в энергонезависимой памяти . Когда компьютер включен, он обычно не имеет операционной системы или ее загрузчика в оперативной памяти (RAM). Компьютер сначала выполняет относительно небольшую программу, хранящуюся в постоянном запоминающем устройстве (ПЗУ), вместе с небольшим объемом необходимых данных, чтобы получить доступ к энергонезависимому устройству или устройствам, с которых программы и данные операционной системы могут быть загружены в ОЗУ.
Небольшая программа, запускающая эту последовательность, называется загрузчиком начальной загрузки , начальной загрузкой или загрузчиком . Единственная задача этой небольшой программы - загружать другие данные и программы, которые затем выполняются из ОЗУ. Часто используются многоэтапные загрузчики, во время которых несколько программ возрастающей сложности загружаются одна за другой в процессе загрузки по цепочке .
Некоторые компьютерные системы после получения сигнала загрузки от человека-оператора или периферийного устройства могут загружать очень небольшое количество фиксированных инструкций в память в определенном месте, инициализировать по крайней мере один ЦП, а затем направлять ЦП на инструкции и запускать их исполнение. Эти инструкции обычно запускают операцию ввода с некоторого периферийного устройства (которое может переключаться оператором). Другие системы могут отправлять аппаратные команды непосредственно на периферийные устройства или контроллеры ввода-вывода, которые вызывают выполнение чрезвычайно простой операции ввода (например, «чтение нулевого сектора системного устройства в память, начиная с ячейки 1000»), эффективно загружая небольшой количество инструкций загрузчика в памяти; затем сигнал завершения от устройства ввода-вывода может использоваться для начала выполнения инструкций ЦП.
В компьютерах меньшего размера часто используются менее гибкие, но более автоматические механизмы загрузчика, обеспечивающие быстрый запуск компьютера с заданной конфигурацией программного обеспечения. Во многих настольных компьютерах, например, процесс самонастройки начинается с исполняющим программным обеспечением процессора , содержащимся в ПЗУ (например, BIOS из IBM PC ) в заранее определенный адресе (некоторые процессоры, включая Intel серию x86 предназначены для выполнения данного программного обеспечения после сброса без посторонней помощи). Это программное обеспечение содержит элементарные функции для поиска устройств, которые могут участвовать в загрузке, и загрузки небольшой программы из специального раздела (чаще всего загрузочного сектора ) наиболее многообещающего устройства, обычно начиная с фиксированноготочка входа, такая как начало сектора.
Загрузчик первой ступени [ править ]
Загрузчики могут сталкиваться со специфическими ограничениями, особенно по размеру; например, на IBM PC и совместимых, загрузочный сектор должен , как правило , работает только 32 КБ [27] [28] (впоследствии ослаблен до 64 КБ [29] ) системной памяти и использовать только инструкцию , поддерживаемый оригинал 8088 / 8086 процессоры. Первый этап загрузки PC погрузчиков (FSBL, загрузчик первого этапа) , расположенные на жестких дисках и съемных дисках должен вписываться в первые 446 байт в Master Boot Record , чтобы оставить место для 64 байт по умолчанию таблицы разделов с четыре записи раздела и двухбайтовая подпись загрузки, который BIOS требует для правильного загрузчика - или даже меньше, когда дополнительные функции, такие как более четырех записей разделов (до 16 по 16 байтов каждая), подпись диска (6 байтов), временная метка диска (6 байтов), Расширенное активное раздела (18 байт) или специальные мульти-загрузочные погрузчики должны поддерживаться, а в некоторых средах. В загрузочных записях томов с гибких и супертекстовых дисков до 59 байтов занято для расширенного блока параметров BIOS на томах FAT12 и FAT16, начиная с DOS 4.0, тогда как FAT32EBPB, представленный в DOS 7.1, требует даже 87 байтов, оставляя только 423 байта для загрузчика, если предположить, что размер сектора равен 512 байтам. Поэтому загрузочные секторы Microsoft традиционно накладывали определенные ограничения на процесс загрузки, например, загрузочный файл должен был располагаться в фиксированной позиции в корневом каталоге файловой системы и храниться в виде последовательных секторов, [30] [31] условия были соблюдены. of SYS
командой и немного ослаблен в более поздних версиях DOS. [31] [nb 6] Загрузчик смог загрузить первые три сектора файла в память, которая, как оказалось, содержала другой встроенный загрузчик, способный загрузить оставшуюся часть файла в память. [31] Когда Microsoft добавила LBAи поддержку FAT32, они даже переключились на загрузчик, охватывающий более двух физических секторов и использующий 386 инструкций по соображениям размера. В то же время другим производителям удалось втиснуть гораздо больше функций в один загрузочный сектор, не ослабляя исходных ограничений только на минимальную доступную память (32 КБ) и поддержку процессора (8088/8086). [nb 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 или Open Firmware , хотя обычно с ограниченной функциональностью оборудования и более низкой производительностью. [36]
Многие загрузчики (такие как GNU GRUB, rEFInd, Windows BOOTMGR, Syslinux и NTLDR в Windows NT / 2000 / XP) могут быть настроены так, чтобы предоставить пользователю несколько вариантов загрузки. Эти варианты могут включать разные операционные системы (для двойной или множественной загрузки с разных разделов или дисков), разные версии одной и той же операционной системы (в случае, если в новой версии возникают неожиданные проблемы), разные варианты загрузки операционной системы (например, загрузка в rescue или безопасный режим ), а также некоторые автономные программы, которые могут работать без операционной системы, такие как тестеры памяти (например, memtest86 + ), базовая оболочка (как в GNU GRUB) или даже игры (см. Список игр PC Booter ). [37]Некоторые загрузчики могут также загружать другие загрузчики; например, GRUB загружает BOOTMGR вместо прямой загрузки Windows. Обычно выбор по умолчанию предварительно выбирается с временной задержкой, в течение которой пользователь может нажать клавишу, чтобы изменить выбор; после этой задержки автоматически выполняется выбор по умолчанию, поэтому нормальная загрузка может происходить без взаимодействия.
Процесс загрузки можно считать завершенным, когда компьютер готов к взаимодействию с пользователем или операционная система способна запускать системные программы или прикладные программы.
Многие встроенные системы должны загружаться немедленно. Например, как правило, недопустимо подождать минуту для запуска цифрового телевидения или GPS-навигатора . Следовательно, такие устройства имеют программные системы в ПЗУ или флэш-памяти, поэтому устройство может сразу начать функционировать; требуется небольшая загрузка или ее отсутствие, поскольку загрузка может быть предварительно вычислена и сохранена в ПЗУ при создании устройства.
В больших и сложных системах могут быть процедуры загрузки, которые выполняются в несколько этапов, пока, наконец, операционная система и другие программы не будут загружены и готовы к выполнению. Поскольку операционные системы спроектированы так, что они никогда не запускаются и не останавливаются, загрузчик может загрузить операционную систему, сконфигурировать себя как простой процесс в этой системе, а затем безвозвратно передать управление операционной системе. Затем загрузчик завершается нормально, как и любой другой процесс.
Загрузка по сети [ править ]
Большинство компьютеров также могут загружаться по компьютерной сети . В этом сценарии операционная система хранится на диске сервера , и некоторые ее части передаются клиенту с использованием простого протокола, такого как упрощенный протокол передачи файлов (TFTP). После передачи этих частей операционная система берет на себя управление процессом загрузки.
Как и в случае загрузчика второго уровня, загрузка по сети начинается с использования общих методов доступа к сети, предоставляемых загрузочным ПЗУ сетевого интерфейса, которое обычно содержит образ среды предварительной загрузки (PXE). Никаких драйверов не требуется, но функциональность системы ограничена до тех пор, пока ядро операционной системы и драйверы не будут перенесены и запущены. В результате, как только загрузка из ПЗУ завершена, вполне возможно выполнить загрузку по сети в операционную систему, которая сама не имеет возможности использовать сетевой интерфейс.
Персональные компьютеры (ПК) [ править ]
Загрузочные устройства [ править ]
Загрузочное устройство - это устройство, с которого загружается операционная система. Прошивка UEFI или BIOS современного ПК поддерживает загрузку с различных устройств, обычно с локального твердотельного накопителя или жесткого диска через GPT или основную загрузочную запись (MBR) на таком приводе или диске, оптическом приводе (с использованием El Torito ), USB - запоминающее устройство ( FTL основанное флэш - диск, SD - карту или слот Multi-Media Card , USB жесткий диск, USB дисковод оптических дисков и т.д.), или плату сетевого интерфейса ( с использованием PXE). Более старые, менее распространенные в BIOS-загрузочные устройства включают в себя гибкие диски , Zip - диски и LS-120 дисков.
Обычно прошивка (UEFI или BIOS) позволяет пользователю настроить порядок загрузки . Если порядок загрузки установлен на «сначала DVD-привод; второй, жесткий диск», тогда микропрограмма будет пытаться загрузиться с DVD-привода, и если это не удается (например, из-за того, что в приводе нет DVD), он попытается загрузиться с локального жесткого диска.
Например, на ПК с Windows, установленной на жестком диске, пользователь может установить порядок загрузки, указанный выше, а затем вставить Linux Live CD , чтобы опробовать Linux без необходимости установки операционной системы на жесткий диск. водить машину. Это является примером двойной загрузки , в котором пользователь выбирает какую операционную систему , чтобы начать после того, как компьютер выполнил его при включении питания самотестирования (POST). В этом примере двойной загрузки пользователь выбирает, вставляя или удаляя DVD с компьютера, но чаще всего выбирают, какую операционную систему загружать, выбирая из меню диспетчера загрузки на выбранном устройстве, используя клавиатуру компьютера для выбрать изМеню загрузки BIOS или UEFI , или и то, и другое; в меню загрузки обычно можно войти, нажав клавиши F8или F12во время POST; В программу настройки BIOS обычно можно войти, нажав клавиши F2или DELво время процедуры POST. [38] [39]
Доступно несколько устройств, которые позволяют пользователю быстро загрузиться в то, что обычно является вариантом Linux для различных простых задач, таких как доступ в Интернет; примерами являются Splashtop и Latitude ON . [40] [41] [42]
Последовательность загрузки [ править ]
После запуска процессор x86 IBM-совместимого персонального компьютера выполняет в реальном режиме инструкцию, расположенную в векторе сброса (адрес физической памяти FFFF0h на 16-битных процессорах x86 [43] и FFFFFFF0h на 32-битных и 64-битных процессорах x86. [44] [45] ), обычно указывающий на точку входа микропрограммы ( UEFI или BIOS ) внутри ПЗУ. Эта ячейка памяти обычно содержит инструкцию перехода, которая передает выполнение в местоположение программы запуска микропрограммного обеспечения ( UEFI или BIOS ). Эта программа запускает самотестирование при включении.(POST) для проверки и инициализации необходимых устройств, таких как оперативная память ( DRAM ), шина PCI и устройства PCI (включая работающие встроенные дополнительные ПЗУ ). Одним из наиболее сложных шагов является настройка DRAM поверх SPD , что еще больше усложняется тем фактом, что на данный момент память очень ограничена.
После инициализации необходимого оборудования микропрограмма ( UEFI или BIOS ) просматривает предварительно настроенный список энергонезависимых запоминающих устройств («последовательность загрузочных устройств»), пока не найдет одно, которое является загрузочным. Загрузочное устройство MBR определяется как устройство, с которого можно читать, и где последние два байта первого сектора содержат слово с прямым порядком байтов AA55h , [nb 9], найденное как последовательность байтов 55h , AAh на диске (также известная как Загрузочная подпись MBR ), или если иным образом установлено, что код внутри сектора исполняется на компьютерах x86.
Как только BIOS обнаруживает загрузочное устройство, он загружает загрузочный сектор по линейному адресу 7C00h (обычно сегмент : смещение 0000h : 7C00h , [27], но некоторые BIOS ошибочно используют 07C0h : 0000h [ необходима цитата ] ) и передает выполнение загрузочному коду. В случае жесткого диска это называется основной загрузочной записью (MBR). Стандартный код MBR проверяет таблицу разделов MBR на наличие раздела, установленного как загрузочный [nb 10] (тот, у которого установлен активный флаг). Если активный раздел найден, код MBR загружает код загрузочного сектора из этого раздела, известный как Volume Boot Record (VBR), и выполняет его.
VBR часто зависит от операционной системы; однако, его главная функция заключается в загрузке и выполнить файл загрузчика операционной системы (например, io.sys
, ntldr
или bootmgr
) из активного раздела. Затем загрузчик загружает ядро ОС с запоминающего устройства.
Если активного раздела нет или загрузочный сектор активного раздела недействителен, MBR может загрузить вторичный загрузчик, который выберет раздел (часто через ввод пользователя) и загрузит его загрузочный сектор, который обычно загружает соответствующее ядро операционной системы. В некоторых случаях MBR может также попытаться загрузить вторичные загрузчики перед попыткой загрузки активного раздела. Если ничего не помогает, он должен вызвать прерывание BIOS INT 18h [29] [27] (за которым следует INT 19h на тот случай, если INT 18h вернется), чтобы вернуть управление BIOS, который затем попытается загрузиться. выключите другие устройства, попробуйте удаленную загрузку по сети. [27]
Большинство современных систем (более новые Apple Mac и более новые ПК ) используют UEFI . [46] [47]
В отличие от BIOS, UEFI (не устаревшая загрузка через CSM) не зависит от загрузочных секторов, система UEFI загружает загрузчик ( файл приложения EFI на USB-диске или в системном разделе EFI ) напрямую [48], а ядро ОС загружается с помощью загрузчик.
Другие виды загрузочных последовательностей [ править ]
Некоторые современные процессоры и микроконтроллеры (например, 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 («конфигурационное ПЗУ») при включении питания.
См. Также [ править ]
Поищите информацию о загрузке в Викисловаре, бесплатном словаре. |
- Загрузочный диск
- Буткит
- Сравнение загрузчиков
- Процесс запуска Linux
- Запуск Macintosh
- Микроперезагрузка
- Мультизагрузка
- Загрузка по сети
- RedBoot
- Самозагружающийся диск
- Процесс запуска Windows NT
- Процесс запуска Windows Vista
Заметки [ править ]
- ^ Включая демонов .
- ^ UU часто имел форму Uu, U = адрес блока управления, u = адрес устройства, но к некоторым блокам управления подключалось только 8 устройств; некоторые подключили более 16. Действительно, контроллер DASD 3830 предлагал в качестве опции адресацию 32 дисков.
- ^ За исключением 370/145 и 370/155, в которых использовалась консольная пишущая машинка 3210 или 3215.
- ^ Только S / 360 использовал 2250; 360/85 , 370/165 и 370/168 используется устройство клавиатуры / дисплеясовместимые с чемеще.
- ^ В IBM 1401 , IBM 7090 , IBM System / 360 и многие другие не требуют манипуляции взагрузчика. S / 360 имел хранилище только для чтения в большинстве моделей, хотя и не использовало встроенное хранилище.
- ^ Вруководстве для ПК DOS 5.0 неверно указано, что системные файлы больше не должны быть непрерывными. Однако для того, чтобы процесс загрузки работал, системные файлы по-прежнему должны занимать первые две записи каталога, а первые три сектора IBMBIO.COM по- прежнему должны храниться непрерывно. SYS продолжает заботиться об этих требованиях.
- ^ a b В качестве примера, хотя расширенная функциональность MBR и загрузочных секторов DR-DOS по сравнению с их аналогами MS-DOS / PC DOS все еще может быть достигнута с использованием обычных методов оптимизации кода до версии 7.05 , для добавления LBA , FAT32 и Для поддержки секторов 7.07 LOADER пришлось прибегнуть к самомодифицирующемуся коду , программированию на уровне кода операции , контролируемому использованию побочных эффектов , многоуровневому наложению данных / кода и алгоритмической обработке.методы сворачивания , чтобы сжать все в один физический сектор, поскольку это было требованием для обратной и кросс-совместимости с другими операционными системами в сценариях с несколькими загрузками и цепной загрузкой .
- ^ Есть одно исключение из правила, что DR-DOS VBR загружает весьфайл IBMBIO.COM в память: если файл IBMBIO.COM больше примерно 29 КБ, попытка загрузить весь файл в память приведет к загрузке загрузчик для перезаписи в стеке и переселен диска Таблица параметров (ЦСТ / FDPB). Следовательно, DR-DOS 7.07VBR загрузит в память только первые 29 КБ файла, полагаясь на другой загрузчик, встроенный в первую часть IBMBIO.COM, чтобы проверить это условие и при необходимости загрузить оставшуюся часть файла в память. Это не вызывает проблем совместимости, поскольку размер IBMBIO.COM никогда не превышал этот предел в предыдущих версиях без этого загрузчика. В сочетании со структурой с двумя входами это также позволяет загружать систему с помощью PC DOS VBR, который загружает в память только первые три сектора файла.
- ^ Подпись по смещению + 1FEh в загрузочных секторах - 55h AAh , то есть 55h по смещению + 1FEh и AAh по смещению + 1FFh . Поскольку прямой порядок байтов представление должно быть принято в контексте IBM PC совместимых машин, это можно записатьвиде 16-разрядного слова AA55h в программах для x86 процессоров (обратите внимание на выгружена порядок),то время как она должнабы быть написана как 55AAh в программах для других архитектур ЦП с прямым порядком байтовпредставление. Поскольку это много раз было перепутано в книгах и даже в исходных справочных документах Microsoft, в этой статье используется побайтовое представление на диске на основе смещения, чтобы избежать любой возможной неверной интерпретации.
- ^ Активный раздел может содержать загрузчик второго этапа , например, OS / 2 Boot Manager, а не ОС.
Ссылки [ править ]
- ^ "бутстрап" . Компьютерный словарь информационных технологий .
- ^ "Bootstrap" . Бесплатный словарь .
- ^ "Подтянитесь за бутстрепы" . Идиомы от The Free Dictionary . Проверено 7 октября 2019 .
- ^ "Определение начальной загрузки" . Технические условия . Проверено 2 октября 2019 .
- ^ "Подтяните себя ботинками" . Поиск фраз .
- ^ Кэмпбелл-Келли, Мартин (1980). «Программирование EDSAC». IEEE Annals of the History of Computing . 2 (1): 7–36. DOI : 10,1109 / mahc.1980.10009 .
- ^ Уилкс, Морис В .; Уилер, Дэвид Дж .; Гилл, Стэнли (1951). Подготовка программ для ЭЦП . Эддисон-Уэсли .
- ^ Бухгольц, Вернер (1953). «Системный дизайн компьютера IBM Type 701» (PDF) . Труды ИРЭ . 41 (10): 1273.
- ^ a b "IBM 7619 Exchange". Справочное руководство по системе обработки данных 7030 (PDF) . IBM. Август 1961. С. 125–127. A22-6530-2.
- ^ Принципы работы Тип 701 и связанное с ним оборудование (PDF) . IBM. 1953. с. 26 . Проверено 9 ноября 2012 .
- ^ От Гутенберга до Интернета , Джереми М. Норман, 2005, стр. 436, ISBN 0-930405-87-0
- ^ Оксфордский словарь английского языка . Оксфордский университет .
- ^ 650 Руководство по эксплуатации машины обработки данных магнитного барабана (PDF) . IBM. 1955. С. 49, 53–54.
- ^ Системное руководство GE-645 (PDF) . General Electric . Январь 1968 . Проверено 30 октября 2019 .
- ^ Справочное руководство по системе PDP-10, часть 1 (PDF) . Корпорация цифрового оборудования . 1969. С. 2–72 . Проверено 9 ноября 2012 .
- ^ a b z / Принципы работы архитектуры (PDF) . IBM . Сентябрь 2005. С. Глава 17 . Проверено 14 апреля 2007 .
- ^ Руководство по периферийным устройствам PDP-11 (PDF) . Корпорация цифрового оборудования . 1976. С. 4–25.
- ^ Как использовать компьютеры Nova (PDF) . Общие данные . Октябрь 1974 г. Раздел 2.8 «Загрузка программы».
- ^ "Старые компьютеры: Альтаир 8800b" . Проверено 10 декабря 2019 .
- ^ «Альтаир 8800 загружает 4K BASIC с бумажной ленты», видео Гленна Холмера
- ^ Чарамелла, Альберто . « Устройство для автоматической загрузки центральной памяти электронных процессоров». Патент США № 4,117,974. 1978-10-03. (представлен в 1975 г.)
- ^ Альберто Сиарамелла racconta иль brevetto дель boostrap дея компьютер concepito в CSELT [ Альберто Сиарамелла обсуждает патент на самонастройки компьютеров задуманных CSELT ] (на итальянском языке ).
- ^ Осборн, Адам ; Кейн, Джерри (1981). Руководство по 16-битному микропроцессору Osborne (PDF) . С. 5–27. ISBN 0-931988-43-8. Проверено 23 августа 2019 .
- ^ Руководство разработчика программного обеспечения для архитектур Intel 64 и IA-32 Том 3 (3A, 3B, 3C и 3D): Руководство по системному программированию (PDF) .
- ^ Осборн, Адам ; Кейн, Джерри. Osborne Руководство по 4- и 8-битным микропроцессорам . С. 10–20. ISBN 0-931988-42-X.
- ^ Apple Ad, Interface Age, октябрь 1976 г.
- ^ а б в г д Пол, Матиас Р. (1997-10-02) [1997-09-29]. «Caldera OpenDOS 7.01 / 7.02 Update Alpha 3 IBMBIO.COM - README.TXT и BOOT.TXT - Краткое описание того, как загружается OpenDOS» . Архивировано из оригинала на 2003-10-04 . Проверено 29 марта 2009 . [1]
- ↑ Сакамото, Масахико (13 мая 2010 г.). «Почему BIOS загружает MBR в 7C00h в x86?» . Glamenv-Septzen.net . Проверено 22 августа 2012 .
- ^ a b Compaq Computer Corporation; Phoenix Technologies Ltd; Корпорация Intel (11 января 1996 г.). «Спецификация загрузки BIOS 1.01» (PDF) . Проверено 21 декабря 2017 .
- ^ Збиковски, Марк ; Аллен, Пол ; Баллмер, Стив ; Борман, Рувим; Борман, Роб; Батлер, Джон; Кэрролл, Чак; Чемберлен, Марк; Челл, Дэвид; Коли, Майк; Кортни, Майк; Драйфус, Майк; Дункан, Рэйчел; Экхардт, Курт; Эванс, Эрик; Фермер, Рик; Гейтс, Билл ; Гири, Майкл; Гриффин, Боб; Хогарт, Дуг; Джонсон, Джеймс У .; Кермаани, Камель; Король, Адриан; Кох, Рид; Ландовски, Джеймс; Ларсон, Крис; Леннон, Томас; Липки, Дэн; Макдональд, Марк ; МакКинни, Брюс; Мартин, Паскаль; Мазерс, Эстель; Мэтьюз, Боб; Мелин, Дэвид; 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] )
- ^ a b c Чаппелл, Джефф (январь 1994 г.). «Глава 2: Системный след». В Шульмане, Эндрю; Педерсен, Аморетта (ред.). Внутреннее устройство DOS . Серия программирования Эндрю Шульман (1-е издание, 1-е изд.). Издательство Эддисон Уэсли . ISBN 978-0-201-60835-9.(xxvi + 738 + iv страниц, 3,5 дюйма [3] [4] ) Исправления: [5] [6] [7]
- ^ Рош, Винн Л. (1991-02-12). "DR DOS 5.0 - Лучшая операционная система?" . Журнал ПК . Vol. 10 шт. 3. п. 241-246, 257, 264, 266. Архивировано 25 июля 2019 года . Проверено 26 июля 2019 .
[…]
SYS
был улучшен в
DR DOS 5.0,
поэтому вам не нужно беспокоиться о том, что первый кластер останется свободным на диске, который вы хотите сделать загрузочным.
Системные файлы DR DOS могут быть расположены где угодно на диске, поэтому любой диск с достаточно свободным пространством можно настроить для загрузки вашей системы.
[…]
(NB. Источник приписывает это утилите SYS, хотя на самом деле это функция расширенного загрузчика начальной загрузки в загрузочном секторе. SYS просто помещает этот сектор на диск.) - ^ Пол, Маттиас Р. (2001-01-17). «FAT32 в DR-DOS» . opendos @ delorie . Архивировано 6 октября 2017 года . Проверено 6 октября 2017 .
[…]
Загрузочный сектор
DR-DOS
[…] ищет
файл IBMBIO.COM
(
DRBIOS.SYS
), а затем загружает * весь * файл в память, прежде чем
передать
ему управление. […]
- ↑ Пол, Матиас Р. (20 февраля 2002). «Не могу скопировать» . opendos @ delorie . Архивировано 6 октября 2017 года . Проверено 6 октября 2017 .
[…]
Загрузочный сектор
DR-DOS
загружает весь
файл
IBMBIO.COM
в память перед его выполнением. Его совершенно не заботит
файл
IBMDOS.COM
, который загружает IBMBIO.COM. […] Загрузочный сектор DR-DOS […] найдет […] файлы ядра, если они логически сохранены в корневом каталоге. Их физическое расположение на диске, и если они фрагментированы или нет, не имеет значения для загрузочного сектора DR-DOS. Следовательно, вы можете просто скопировать файлы ядра на диск (даже просто
COPY ), и как только загрузочный сектор станет сектором DR-DOS, он найдет и загрузит их. Конечно, сложно уместить все это всего в 512 байт, размер одного сектора, но это серьезное улучшение удобства, если вам нужно настроить систему DR-DOS, а также ключ к DR. -DOS multi-OS LOADER утилита для работы. В MS-DOS файлы ядра должны находиться в определенных местах, но файлы DR-DOS может быть в любом месте, так что вы не должны физически поменять их вокруг каждый раз при загрузке другой ОС. Кроме того, он позволяет обновлять систему DR-DOS, просто копируя файлы ядра поверх старых, нет необходимости в SYS , нет сложных процедур установки, как требуется для MS-DOS / PC DOS.. Вы даже можете хранить несколько файлов ядра DR-DOS под разными именами на одном диске, и LOADER будет переключаться между ними в соответствии с именами файлов, указанными в файле BOOT.LST . […]
- ^ Пол, Маттиас Р. (2017-08-14) [2017-08-07]. «Продолжение саги о Windows 3.1 в расширенном режиме на OmniBook 300» . MoHPC - Музей калькуляторов HP . Архивировано 6 октября 2017 года . Проверено 6 октября 2017 .
[…]
DR-DOS
FDISK
не только разбивает диск, но также может форматировать только что созданные тома и инициализировать их загрузочные секторы за один раз, поэтому нет риска случайно испортить неправильный том и нет необходимости в
FORMAT
/ S или
SYS
. После этого вы можете просто скопировать оставшиеся файлы DR-DOS, включая системные файлы. Важно знать, что в отличие от
MS-DOS / PC DOS , DR-DOS имеет «умные» загрузочные секторы, которые фактически «монтируют» файловую систему для поиска и загрузки системных файлов в корневой каталог, вместо того, чтобы ожидать их размещения в определенном месте. Физически системные файлы могут располагаться где угодно, а также могут быть фрагментированы. […]
- ^ «Глава 6 - Устранение неполадок при запуске и проблемах с диском» . Комплект ресурсов Windows NT Server . Microsoft. Архивировано из оригинала на 2007-05-15.
- ^ «Оттенок» . coreboot . Проверено 20 ноября 2010 .
- ^ «Список марок ПК с соответствующими горячими клавишами» . www.disk-image.com . Проверено 26 сентября 2020 .
- ^ «Как войти в BIOS на любом ПК: ключи доступа от производителя | Tom's Hardware» . www.tomshardware.com . Проверено 26 сентября 2020 .
- ^ Браун, Эрик (2008-10-02). «MontaVista Linux поддерживает функцию быстрой загрузки Dell» . linuxdevices.com . Проверено 20 ноября 2010 .
- ^ Ларабель, Майкл (2008-06-14). "SplashTop Linux для ноутбуков HP, Dell?" . Фороникс . Проверено 20 ноября 2010 .
- ^ «Instant-On IOS от Voodoo Envy (на базе Splashtop)» . YouTube . Проверено 20 ноября 2010 .
- ^ «Справочное руководство программиста iAPX 286» (PDF) . Intel . 1983. Раздел 5.3 ИНИЦИАЛИЗАЦИЯ СИСТЕМЫ, стр. 5-7 . Проверено 23 августа 2019 .
Поскольку регистр CS содержит F000 (тем самым определяя сегмент кода, начинающийся с физического адреса F0000), а указатель инструкции содержит FFF0, процессор выполнит свою первую инструкцию по физическому адресу FFFF0H.
- ^ "Справочное руководство программиста 80386" (PDF) . Intel. 1986. Раздел 10.2.3 Первые инструкции, с. 10-3 . Проверено 3 ноября 2013 .
После СБРОСА адресные строки A31-20 автоматически утверждаются для выборки команд. Этот факт вместе с начальными значениями CS: IP приводит к тому, что выполнение инструкции начинается с физического адреса FFFFFFF0H.
- ^ "Руководство разработчика программного обеспечения для архитектур Intel 64 и IA-32" (PDF) . Корпорация Intel . Май 2012 г. Раздел 9.1.4 Выполнено первое распоряжение, стр. 2611 . Проверено 23 августа 2012 .
Первая команда, которая выбирается и выполняется после аппаратного сброса, находится по физическому адресу FFFFFFF0h.
Этот адрес находится на 16 байт ниже самого верхнего физического адреса процессора.
EPROM, содержащий код инициализации программного обеспечения, должен находиться по этому адресу.
- ^ «Платформа Intel Innovation Framework для EFI» . Intel . Проверено 7 января 2008 .
- ^ "OpenBIOS - coreboot" . coreboot.org . Проверено 20 марта 2013 .
- ^ "UEFI - OSDev Wiki" . wiki.osdev.org . Проверено 26 сентября 2020 .
- ^ «Обзор - четыре этапа загрузчика» . ti.com . Техасские инструменты . 2013-12-05 . Проверено 25 января 2015 .