coreboot
Материал из Википедии — свободной энциклопедии
coreboot | |
Тип | Микропрограмма (BIOS) |
Разработчик | Ronald G Minnich |
ОС | |
Текущая версия | V2 |
Лицензия | GNU General Public License |
Сайт | www.coreboot.org |
coreboot (ранее LinuxBIOS) — проект по созданию свободного программного обеспечения, одобренный Free Software Foundation. Целью проекта является замена проприетарных и закрытых BIOS, используемых большинством персональных компьютеров, на легковесный BIOS, предназначенный исключительно для загрузки и запуска современных 32 и 64 разрядных операционных систем. Проект LinuxBIOS был начат зимой 1999 года в лаборатории Advanced Computing Laboratory в Лос-Аламосе (см. Лос-Аламосская национальная лаборатория). Результаты работы проекта распространяются на условиях GNU GPL.
В Википедии есть портал «Свободное программное обеспечение» |
Содержание |
[править] Общие сведения
Типичная задача coreboot — загружать ядро Linux, но, кроме этого, coreboot может загружать и запускать исполняемые файлы в формате ELF, например, etherboot, который способен загрузить Linux по сети Ethernet, или ADLO, который загружает Microsoft Windows NT 2000/XP. coreboot может загрузить практически любую операционную систему с любого поддерживаемого устройства, такого как Myrinet, QsNet, или SCSI.
coreboot производит инициализацию аппаратного обеспечения, которую не производит Linux, после чего передаёт управление Linux, предоставляя ему завершить инициализацию аппаратуры.
coreboot поддерживает платформы PowerPC и x86.
Уникальной особенностью coreboot является то, что версия coreboot для x86 начинает работать в 32-разрядном режиме после выполнения всего лишь шестнадцати инструкций процессора, в то время как типичные BIOS для платформы x86 работают исключительно в 16-разрядном режиме. Работа в 32-разрядном режиме делает загрузку с LinuxBIOS очень быстрой (в настоящее время рекорд холодного старта с LinuxBIOS составляет около 3 секунд).
Хотя в названии LinuxBIOS присутствовало слово Linux, LinuxBIOS мог грузить и другие ядра операционных систем. Например, LinuxBIOS мог напрямую грузить ядро Plan 9. Поэтому он был переименован в coreboot.
В то же время, LinuxBIOS нельзя использовать для запуска FreeBSD, так как ядро FreeBSD в начале своей работы использует вызовы BIOS, которые не поддерживаются LinuxBIOS.
[править] Разработка и отладка LinuxBIOS
Так как LinuxBIOS должен инициализировать аппаратуру, то он должен быть адаптирован для поддержки каждого системного контроллера (англ. chipset) и каждой платы на основе такого контроллера. Добавление поддержки какой-либо новой платы осложняется трудностями отладки: отладочная информация выводится с помощью тех или иных аппаратных средств, но как организовать вывод, когда средства вывода ещё не инициализированы?
LinuxBIOS использует несколько устройств и приёмов для упрощения отладки:
- Перед инициализацией ОЗУ, LinuxBIOS инициализирует последовательный интерфейс, который может быть использован для вывода отладочной информации на подключённый к нему эмулятор терминала.
- Используется POST Card, устройство, подключаемое к шине расширения компьютера и содержащее дисплей, который может выводить две цифры в шестнадцатеричной системе счисления. Программная работа с таким устройством довольно проста, например, на архитектуре x86 достаточно записать байт, который необходимо отобразить на индикаторе POST Card, по адресу 0x80 в адресном пространстве устройств ввода-вывода.
- Устройство BIOS Savior, представляющее собой две микросхемы ПЗУ, содержащие BIOS и возможность выбрать для работы одно из них. Более дорогой альтернативой такому устройству является использование программатора микросхем ПЗУ.
- Аппаратный эмулятор центрального процессора либо подключение к центральному процессору через интерфейс JTAG, позволяя таким образом знать результат работы каждой инструкции центрального процессора на самых ранних этапах работы компьютера.
[править] Инициализация ОЗУ
Наиболее сложной частью LinuxBIOS является код, который инициализирует ОЗУ и контроллер ОЗУ. Дело в том, что пока ОЗУ не инициализировано, его невозможно использовать. Очевидным способом инициализировать контроллер ОЗУ и саму оперативную память без обращений к ней является использование регистров общего назначения процессора. Для упрощения этой сложной задачи был разработан специальный компилятор языка C — romcc, который порождает код, не производящий обращений к ОЗУ при своей работе. С помощью romcc компилируется код, который инициализирует ОЗУ путём обращения к SPD ROM на модулях DIMM по шине SMBus. После выполнения данного кода ОЗУ может быть использовано.
[править] Смотрите также
- OpenBIOS
- Ноутбук за 100 долларов
[править] Ссылки
- Домашняя страница coreboot.org, а также wiki(англ.)
- Motherboards supported in coreboot v2(англ.)
- FreshMeat.net (англ.)
- Открытые системы BIOS для Linux
- LinuxBIOS: компьютер с Линуксом в сердце А. Кухар (aпрель 2004)
- Open BIOSes for Linux (англ.) IBM
- Google Linux BIOS(русск.) LOR 2006
- Интервью с Ronald G. Minnich, одним из основных разработчиков проекта LinuxBIOS(русск.) LOR 2007
- Работа с initng и upstart