BIOS (, ; акроним для Базовая система ввода / вывода и также известный как системный BIOS, ROM BIOS или PC BIOS ) - это прошивка, используемая для выполнения аппаратной инициализации во время загрузки процесса ( запуск при включении), а также для предоставления служб времени выполнения систем и программ. Микропрограмма BIOS предустановлена на системной плате персонального компьютера и является первым программным продуктом, который запускается при включении. Название происходит от системы ввода / вывода, используемой в операционной системе CP / M в 1975 году. Первоначально BIOS проприетарный для IBM PC был реконструирован некоторыми компаниями (такими как Phoenix Technologies ), стремящимися создать совместимые системы. интерфейс этой исходной системы служит де-факто стандартом.
BIOS на современном ПК инициализирует и тестирует компоненты оборудования системы и загружает загрузчик с запоминающего устройства, которое затем инициализирует операционную систему. В эпоху DOS BIOS, предоставляющий прерывания BIOS для клавиатуры, дисплея и других устройств ввода / вывода (I / O), которые стандартизировали интерфейс к прикладным программам и операционной системе. Более поздние операционные системы не используют вызовы прерывания BIOS загрузки.
Большинство реализаций BIOS специально разработаны для работы с конкретным компьютером или моделью материнской платы путем взаимодействия с различными устройствами, составляющими дополнительные системы набор микросхем. Первоначально прошивка BIOS хранилась в микросхеме ROM на материнской плате ПК. В компьютерных современных системах содержимое BIOS хранится во флэш-памяти , поэтому его можно перезаписать, не снимать чип с материнской платы. Это позволяет пользователям легко обновлять прошивку BIOS, чтобы можно было добавить новые функции или исправить ошибки, но это также возможность установить конечные ошибки компьютера руткитами BIOS . Более того, неудачное обновление BIOS может заблокировать материнскую плату.
Унифицированный расширяемый интерфейс микропрограмм (UEFI) является преемником устаревшей BIOS для ПК, направленной на устранение его технических ограничений.
/ * CP / MBASICI / OSYSTEM (BIOS) АВТОРСКИЕ ПРАВА (C) ГЭРИ А. КИЛДАЛЛ ИЮНЬ 1975 * / […] / * BASICDISKOPERATI NGSYSTEM (BDOS) АВТОРСКИЕ ПРАВА (C) ГЭРИ А. КИЛДАЛЛ ИЮНЬ, 1975 * /— Выдержка из заголовка файла BDOS.PLM в PL / M исходном коде CP / M 1.1 или 1.2 для Лаборатории Лоуренса Ливермора (LLL)
Термин BIOS (базовая система ввода / вывода) был создан Гэри Килдаллом и впервые появился в CP / M операционной системы 1975 года, описывающей машинно-зависимую часть CP / M, загружаемую во время загрузки, которая взаимодействует с напрямую оборудованием. (В ПЗУ машины CP / M обычно есть только простой загрузчик.)
Версии MS-DOS, PC DOS или DR -DOS содержат файл, называемый по-разному: «IO.SYS », «IBMBIO.COM », «IBMBIO.SYS» или «DRBIOS.SYS» "; Этот файл как известен «DOS BIOS» (также известный как «система ввода-вывода DOS») и содержит аппаратную часть нижнего уровня операционной системы. Вместе с базовым аппаратно-зависимым, но не зависящим от системы «System BIOS», который находится в ROM, он представляет собой аналог «CP / M BIOS ».
BIOS, изначально проприетарный для IBM PC, был переработан некоторых раздельных систем (такими как Phoenix Technologies ) в поисках совместимых систем.
С появлением машин PS / 2 IBMелила системную BIOS на части реального и защищенного режима. Часть реального режима была использована для обратной совместимости с операционными системами, такими как DOS, и поэтому была названа "CBIOS" (от "Compatibility BIOS"), тогда как "ABIOS" (от "Advanced BIOS"), специально предоставляющая новые интерфейсы. Подходит для многозадачных операционных систем, таких как OS / 2.
В BIOS оригинального IBM PC и XT не было интерактивного пользовательского интерфейса. Коды ошибок или сообщения отображались на экране, или генерировалась закодированная серия звуков, сигнализирующих об ошибках, когда самотестирование приении (POST) не дошло до момента успешной инициализации адаптера видесподилея. Параметры на IBM PC и XT установились переключателями и перемычками на основные плате и включенными. Примерно с середины 1990-х годов для ПЗУ BIOS стало типичное включение «служебной программы настройки BIOS» (BCU) или «служебной программы настройки BIOS», доступ к которой осуществляется при включении системы с помощью набора клавиш. Эта программа позволяет установить параметры конфигурации системы того типа, который ранее устанавливался с помощью DIP-переключателей, через систему интерактивного меню, управляемую с клавиатуры. В промежуточном периоде IBM-совместимые ПК, включая IBM AT, сохраняли параметры в ОЗУ с резервным питанием и использовали загрузочную программу конфигурации на диске, а не в ПЗУ, чтобы установить параметры конфигурации, содержащиеся в этой памяти. Диск входил в комплект поставки компьютера, и в случае его утери системы изменить нельзя. То же самое в целом применимо к компьютеру с шиной EISA, для которой программа называлась EISA Configuration Utility (ECU).
Современный компьютер, совместимый с Wintel, настройка программы установки, по сути не отличавшуюся от резидентных в ПЗУ утилит BIOS конца 1990-х годов; пользователь может параметры настроить оборудование с помощью клавиатуры и видеодисплея. Кроме того, когда возникают ошибки во время загрузки, современный BIOS обычно отображает удобные настройки пользователя, сообщения об ошибках, часто представленные в виде всплывающих окон в стиле TUI, и предлагает войти в программу BIOS или игнорировать ошибку и продолжайте, если возможно. Вместо ОЗУ с резервным питанием современной машины Wintel может хранить параметры конфигурации BIOS во флэш-ПЗУ, возможно, в том же флэш-ПЗУ, в котором находится сам BIOS.
Ранние процессоры Intel запускались с физического адреса 000FFFF0h. Системы с более поздними процессорами системы логику для запуска BIOS из системного ПЗУ.
Если система только что была включена или была нажата кнопка сброса («холодная перезагрузка»), выполнено полное самотестирование при включении (POST). Если были нажаты Ctrl + Alt + Delete («теплая загрузка»), специальное значение флага, хранящееся в энергонезависимой памяти BIOS («CMOS »), проверенной BIOS, позволяет обойти длительные POST и обнаружение памяти.
POST идентифицирует и инициализирует системные устройства, такие как CPU, RAM, контроллеры прерываний, контроллеры DMA, набор микросхем, видеокарта, клавиатура, жесткий диск, оптический дискод и другие аппаратное обеспечение.
Ранние компьютеры IBM имели в POST подпрограмму, которая загружала программу в ОЗУ через клавиатуру и запускала ее. Эта функция для заводских испытаний или диагностических целей.
После завершения сканирования дополнительного ПЗУ и вызова всех модулей ПЗУ с действующими контрольными суммами или сразу после процедуры POST в версии BIOS, которая не выполняет поиск дополнительных ПЗУ, вызывает BIOS INT 19h, чтобы начать процесс загрузки. После загрузки загруженных программ также вызвать INT 19h для перезагрузки системы, но они должны быть осторожны, чтобы отключить другие асинхронные аппаратные процессы, которые могут мешать перезагрузке BIOS, иначе система может зависнуть или дать сбой во время перезагрузки..
Когда вызывается INT 19h, BIOS пытается найти программное обеспечение программного обеспечения на «загрузочном устройстве», таком как жесткий диск, дискета. диск, CD или DVD. Он загружает и обеспечивает первое найденное загрузочное программное обеспечение, передавая ему контроль над ПК.
BIOS использует загрузочные устройства, установленные в EEPROM, CMOS RAM или, на самых ранних ПК, DIP-переключатели. BIOS проверяет каждое устройство, чтобы увидеть его, загружая первый сектор (загрузочный сектор ). Если сектор не может быть прочитан, BIOS переходит к следующему устройству. Если сектор прочитан успешно, некоторые BIOS будут также проверять сигнатуру загрузочного сектора 0x55 0xAA в последних двух байтах сектора (длина 512 байт), прежде чем принимать загрузочный сектор и считать устройство загрузочным сектором.
Когда загрузочное устройство найдено, BIOS передает управление загруженному сектору. BIOS не интерпретирует содержимое загрузочного сектора, кроме, возможно, проверки подписи загрузочного сектора в последних двух байтах. Интерпретация структур данных, таких как таблицы разделов и блоки параметров BIOS, выполняется программами в самом исполняемом процессе или другими программами.
Недисковое устройство, такое как сетевой адаптер, загрузиться с помощью процедуры, которая определяет его дополнительным ПЗУ или эквивалентом, встроенным в ПЗУ BIOS материнской платы. Таким образом, дополнительные ПЗУ также могут включить процесс включения, определяемый ПЗУ BIOS материнской платы, или заменять его.
Пользователь может выбрать приоритет загрузки, реализованный в BIOS. Например, на большинстве компьютеров есть загрузочный жесткий диск, но обычно есть съемный носитель с более высоким приоритетом загрузки, поэтому пользователь может вызвать загрузку съемного диска.
В большинстве современных BIOS порядок установки может быть настроен пользователь. В старых версиях BIOS можно выбрать ограниченный приоритет загрузки; в самой ранней версии BIOS реализована схема с фиксированным приоритетом: сначала приводы гибких дисков, а затем фиксированные диски (то есть жесткие диски), и, как правило, никакие другие загрузочные устройства не поддерживались, при условии этих правил установленными дополнительными ПЗУ. BIOS на ранних версиях ПК также обычно загружается только с первого диска гибких дисков или первого жесткого диска, даже если было установлено два диска.
При использовании загрузки с оптических носителей El Torito оптический привод фактически имитирует 3,5-дюймовую гибкую дискету высокой плотности для загрузки в BIOS. Чтение «первого сектора» компакт-диска -ROM или DVD-ROM - это не просто определенная операция, как на гибком диске или жестком диске. Более того, носителя затрудняет запись полезной загрузочной программы в одном секторе. Загрузочная виртуальная дискета может предоставить программное обеспечение, обеспечивающее доступ к оптическому носителю в его собственном формате.
На исходном IBM PC и XT, если загрузочный диск не был найден, ROM BASIC был запущен вызовом INT 18h. Несколько программ использовали BASIC в ROM, производители ПК клонов не использовали его; тогда компьютер, которому не удалось загрузить с диска, отображал «No ROM BASIC» и останавливался (в ответ на INT 18h).
Более поздние компьютеры отображали сообщение типа «Загрузочный диск не найден»; Некоторые предлагали вставить диск и подключить. Современный BIOS может ничего не отображать или может автоматически входить в служебную программу настройки BIOS при сбое процесса загрузки.
Среда для программы очень проста: ЦП находится в реальном режиме, а регистры общего назначения и сегментные регистры не используются, за исключением SS, SP, CS и DL.. CS: IP всегда указывает на физический адрес 0x07C00
. Какие ценности на самом деле имеют CS и IP, точно не определено. Некоторые BIOS используют CS: IP 0x0000: 0x7C00
, в то время как другие могут использовать 0x07C0: 0x0000
. Загрузите программу на эту фиксированную программу. DL может содержать номер привода, используемый с INT 13h загрузочного устройства. SS: SP указывает на допустимый стек, предположительно достаточно велик для поддержки аппаратных прерываний, но в остальном SS и SP не указано. (Должен быть уже настроен для прерывания, и прерывания должны быть разрешены для прерывания системного таймера, BIOS всегда использует, по крайней мере, для поддержания счетчика времени дня и которое он инициализирует во время POST, чтобы быть активным и для работы клавиатуры. Клавиатура работает, даже если служба BIOS не вызывается; она используется и помещается в 15-символьный буфер опережающего ввода, поддерживаемый BIOS.) Программа загрузки должна установить свой собственный стек, поскольку размер стека, установленного BIOS, неизвестен и его расположение также является переменным; хотя программа может исследовать стек по умолчанию, исследуя SS: SP, проще и короче просто безоговорочно установить новый стек.
Во время загрузки доступны все службы BIOS, а память под адресом 0x00400
содержит таблицу векторов прерываний. BIOS POST инициализировал системные таймеры, контроллер (ы) прерываний, контроллер (ы) DMA и другое оборудование материнской платы / микросхем по мере необходимости, чтобы привести все службы BIOS в состояние готовности. Обновление DRAM для всей системной DRAM в обычной памяти и расширенной памяти, но не обязательно в расширенной памяти, настроено и выполнено. Векторы прерываний , прерывания BIOS, установлены так, чтобы указывать на соответствующие точки входа в BIOS, системные аппаратные прерывания для устройств, инициализированные BIOS, были установлены так, чтобы указывать на ISR, предоставляя, и некоторые другие прерывания, в том числе те, которые генерирует BIOS для перехвата программ, были установлены на фиктивный ISR по умолчанию, который немедленно возвращается. BIOS поддерживает зарезервированный блок системной ОЗУ по адресам 0x00400–0x004FF
с включенными в деятельность, инициализированными во время POST. Вся память по адресу 0x00500
и выше может скачать программу; он может даже перезаписаться.
Периферийные карты, такие как некоторые контроллеры жестких дисков и некоторые видеоадаптеры, имеют собственное расширение BIOS дополнительные ПЗУ, которые обеспечивают дополнительные функции для BIOS. Код в этих расширениях запускается до того, как BIOS загрузчика системы с запоминающего устройства. Эти ПЗУ обычно тестируют и инициализируют оборудование, добавляют новые службы BIOS, а также дополняют или заменяют службы BIOS их собственными версиями этих служб. Например, контроллер SCSI обычно имеет ПЗУ расширения BIOS, которое поддерживает жестких дисков, подключенных через этот контроллер. Некоторые видеокарты имеют ПЗУ расширения, которые заменяют видеосервисы BIOS материнской платы собственными видеосервисами. ПЗУ BIOS обеспечивает полный контроль над машиной. Расширенное ПЗУ может в основном ввести другую операционную систему. Функционирование IBM-совместимой компьютерной системы можно полностью изменить, удалив или вставив карту адаптера (или микросхему ПЗУ), которая содержит ПЗУ расширения BIOS.
BIOS материнской платы обычно содержит код для доступа к аппаратным компонентам, для начальной загрузки системы, такой как клавиатура, дисплей и хранилище. Кроме того, сменные адаптерные карты, такие как SCSI, RAID, сетевые карты и видеоплаты, часто содержат собственный BIOS (например, Video BIOS ), дополнительный или заменяя системный код BIOS для данного компонента. Даже устройства, встроенные в материнскую плату, могут вести себя подобным образом; их дополнительные ПЗУ могут храниться как отдельный код на основной микросхеме флэш-памяти BIOS и обновляться либо вместе с основным BIOS, либо отдельно от него.
Для дополнительной карты требуется дополнительное ПЗУ, если карта не поддерживается основным BIOS и карта должна быть инициализирована или сделана доступной через службы BIOS до загрузки операционной системы (обычно это означает, что требуется в процессе начальной загрузки). Даже если это не требуется, дополнительное ПЗУ может позволить использовать карту адаптера без загрузки программного обеспечения драйвера с запоминающего устройства после начала загрузки - с дополнительным ПЗУ на загрузку драйвера не требуется времени, драйвер не занимает пространство в ОЗУ или на жестком диске, а программное обеспечение драйвера в ПЗУ всегда остается с устройством, поэтому их нельзя случайно разделить. Кроме того, если ПЗУ находится на карте, как периферийное оборудование, так и программное обеспечение драйвера, предоставленные ПЗУ, устанавливаются вместе без дополнительных усилий для установки программного обеспечения. Дополнительным преимуществом ПЗУ на некоторых ранних системах ПК (в частности, включая IBM PCjr) было то, что ПЗУ было быстрее, чем ОЗУ основной системы. (В современных системах все обстоит наоборот, и код BIOS ROM обычно копируется («затеняется») в RAM, поэтому он будет работать быстрее.)
Существует множество методов и утилит для проверки содержимое различных BIOS материнской платы и ПЗУ расширения, таких как Microsoft DEBUG или процедура загрузки Unix dd.
Если ПЗУ расширения желает изменить способ загрузки системы (например, из сетевое устройство или адаптер SCSI, для которого BIOS не имеет кода драйвера), он может использовать спецификацию загрузки BIOS (BBS) API, чтобы зарегистрировать свою способность делать это. После регистрации ПЗУ расширения с использованием API BBS пользователь может выбрать один из доступных вариантов загрузки из пользовательского интерфейса BIOS. Вот почему большинство реализаций BIOS для ПК, совместимых с BBS, не позволяют пользователю войти в пользовательский интерфейс BIOS, пока ПЗУ расширения не завершат выполнение и не зарегистрируются в BBS API. Спецификацию можно загрузить с веб-сайта архитектуры компонентов ACPI (Advanced Configuration and Power Interface ). Официальное название - Спецификация загрузки BIOS (версия 1.01, 11 января 1996 г.).
Кроме того, если ПЗУ расширения желает изменить способ загрузки системы в одностороннем порядке, оно может просто перехватить INT 19h или другие прерывания, обычно вызываемые из прерывание 19h, такое как INT 13h, дисковая служба BIOS, чтобы перехватить процесс загрузки BIOS. Затем он может заменить процесс загрузки BIOS одним из своих собственных или просто изменить последовательность загрузки, вставив в нее свои собственные загрузочныедействия, не позволяя BIOS создавать как устройства загрузочные, или и то, и другое. До того, как была опубликована спецификация загрузки BIOS, это был единственный способ для ПЗУ расширения реализовать возможность для устройств, поддерживаемых для собственного BIOS материнской платы.
После материнской платы BIOS завершает свой POST, большинство версий BIOS ищут дополнительные модули ПЗУ, также называемые ПЗУ расширения BIOS, и их исполняющие. BIOS материнской платы сканирует расширенные ПЗУ в части «области верхней памяти » (часть адресного реального пространства режима x86 по адресу 0xA0000 и выше) и запускает каждое найденное ПЗУ по порядку. Для обнаружения включения ПЗУ ISA с отображением памяти реализация BIOS сканирует адресное пространство реального режима с 0x0C0000
до 0x0F0000
на 2 KiB границ, ищем двухбайтовую подпись ПЗУ: 0x55, за которым следует 0xAA. В допустимом ПЗУ расширения за этой подписью один байт, указывающий 512-байтовые блоки, которые ПЗУ расширения занимает в реальной памяти, следующее количество - это точка входа дополнительное ПЗУ (также известная как его "смещение входа"). Вычисляется контрольная сумма число 512-байтовых блоков, и, если в ПЗУ имеется допустимая контрольная сумма, BIOS передает управление по адресу входа, который в обычном ПЗУ расширения BIOS должен быть началом процедуры инициализации расширения.
На этом этапе код ПЗУ расширения берет на себя, как правило, тестирует и инициализирует оборудование, которое он управляет, и регистрирует прерывания для использования приложениями после загрузки. Он может использовать BIOS (в том числе предоставляемые ранее инициализированными дополнительными ПЗУ) для предоставления службы интерфейса конфигурации, отображения диагностической информации или любых других действий, которые ему требуются. Возможно, что дополнительное ПЗУ не вернется в BIOS, полностью прервав последовательную загрузку BIOS.
Дополнительное ПЗУ обычно должно возвращаться в BIOS после завершения процесса инициализации. Как только (и если) дополнительное ПЗУ возвращается, BIOS продолжает поиск дополнительных ПЗУ, вызывая каждое из них при обнаружении, пока не будет просканирована вся область дополнительного ПЗУ в пространстве.
Дополнительные ПЗУ обычно находятся на платах адаптеров. Однако исходный ПК и, возможно, ПК XT, имеют на материнской плате запасное гнездо ПЗУ («системная плата» в терминах IBM), которое можно вставить дополнительное ПЗУ, а четыре ПЗУ, содержащие интерпретатор БЕЙСИК, могут также быть удалены и заменены пользовательскими ПЗУ, которые могут быть дополнительными ПЗУ. IBM PCjr уникален ПК тем, что имеет два слота для картриджей ПЗУ на передней панели. Картриджи в этих слотах соответствуют той же области верхней памяти, которая используется для дополнительных ПЗУ, и картриджи могут содержать дополнительные модули ПЗУ, которые распознают BIOS. Картриджи также могут содержать другие типы модулей ROM, такие как программы BASIC, которые обрабатываются по-другому. Один картридж PCjr может содержать несколько модулей ПЗУ типов, которые могут храниться вместе в одной микросхеме ПЗУ.
ПЗУ BIOS настраивается для оборудования конкретного производителя, что позволяет использовать низкоуровневые службы (например, чтение клавишных инструментов или секторов дискету) в стандартизированный способ работы с программами, включая операционные системы. Например, IBM PC может иметь монохромный или цветной дисплей с адаптером (с использованием разных карт памяти и оборудования), но для отображения символов на экране отображается единственный стандартный системный вызов BIOS . указанное положение в текстовом режиме или графическом режиме.
BIOS предоставляет небольшую библиотеку базовых функций ввода / вывода для работы с периферийными устройствами (такими как клавиатура, элементарные функции отображения текста и графики и т. д.). При использовании MS-DOS доступ к службам BIOS может выполняться прикладной программой (или MS-DOS) путем выполнения программы прерывания INT 13h для доступа к дисковым функциям или выполнения одного из ряда других заданных прерываний BIOS. для доступа к видеодисплею, клавиатуре, кассете и другие функции устройства.
Операционные системы и программное обеспечение, разработанные для замены этой программной функциональности микропрограмм, замену программных интерфейсов для прикладного программного обеспечения. Приложения могут также поставлять эти услуги себе. Это началось еще в 1980-х годах под MS-DOS, когда программисты заметили, что использование видеоуслуг BIOS для отображения графики было очень медленным. Чтобы увеличить скорость вывода изображения на экран, многие программы обходят BIOS и напрямую программируют оборудование видеодисплея. Другие программы графики, в частности, но не исключительно в демонстрационной сцене, заметили, что существуют технические возможности видеоадаптеров ПК, которые не поддерживаются IBM BIOS и не могут быть использованы без обхода. AT-система AT-совместимый BIOS работал в Intel реальном режиме, операционные системы, которые работали в защищенном режиме процессора 286 и более поздних версий, требовали драйверов устройств, совместимых с работой в защищенном режиме, для замены служб BIOS.
В современной ПК под управлением современных операционных (таких как Windows и Linux ) используются вызовы прерываний BIOS только во время загрузки и загрузки операционных систем. Перед отображением первого графического экрана системы ввода и вывода обычно обрабатываются через BIOS. Меню, такое как текстовое меню Windows, позволяет пользователям выбирать операционную систему для загрузки, загружаться в безопасном режиме или использовать последнюю удачную конфигурацию, отображается через BIOS и получает ввод с клавиатуры через BIOS.
Большинство современных ПК по-прежнему загружают и запускают устаревшие операционные системы, такие как MS-DOS или DR-DOS, которые полагаются в BIOS для их консольного и дискового ввода-вывода, при условии, что система имеет прошивка, совместимая с BIOS или BIOS, что не обязательно для компьютеров на базе UEFI.
Процессоры Intel получили перепрограммируемый микрокод, начиная с микроархитектуры P6. Процессоры AMD имеют перепрограммируемый микрокод с момента К7 Микроархитектура. BIOS содержит патчи микрокода процессора, исправляющие ошибки в исходном микрокоде процессора; микрокод загружается в память процессора SRAM, поэтому перепрограммирование не является постоянным, поэтому загрузка обновлений выполняется каждый раз при приборе системы. Без перепрограммируемого микрокода потребовалась бы дорогостоящая замена процессора; например, ошибка Pentium FDIV обернулась дорогостоящим фиаско для Intel, поскольку потребовала отзыва продукта, поскольку дефектный микрокод процессора процессора Pentium нельзя было перепрограммировать. Операционные системы также могут обновлять микрокод основного процессора .
Modern BIOS (UEFI ) включают Intel Management Engine, Процессор безопасности платформы AMD и встроенное ПО Видео BIOS.
Некоторые BIOS содержат таблицу описания лицензирования программного обеспечения (SLIC), цифровую подпись, помещенную в BIOS испытательного оборудования (OEM), например Делл. SLIC вставляется в таблицу данных ACPI и не содержит активного кода.
Производители компьютеров, распространяющие OEM-версию Microsoft Windows и прикладного программного обеспечения Microsoft, могут использовать SLIC для аутентификации лицензирования лицензирования на установочном диске OEM Windows и систему диск восстановления, дополнительное программное обеспечение Windows. Системы с SLIC можно активировать с помощью ключа продукта OEM, и они проверяют сертификат OEM в формате XML по SLIC в BIOS в качестве средства самоактивации (см. Предварительная установка с блокировкой системы, SLP). Если пользователь выполняет новую установку Windows, он должен владеть OEM-ключом (SLP, так и COA), так и цифровым сертификатом для своего SLIC, чтобы обойти активацию. Этого можно добиться, если пользователь выполнит восстановление с использованием созданного настроенного OEM. Опытные пользователи могут скопировать необходимые файлы сертификатов из образа OEM, расшифровать ключ продукта SLP, а затем выполнить активацию SLP вручную. Взломщики для неоригинальных дистрибутивов Windows обычно редактируют SLIC или эмулируют его, чтобы обойти активацию Windows.
Некоторые реализации BIOS позволяют разгон, действие, при котором ЦП настроен на более высокую тактовую частоту, чем указано значение для гарантированных возможностей. Однако разгон может снизить надежность системы на недостаточно охлаждаемых компьютерах и в целом сократить срок службы компонентов. Неправильно выполненный разгон также может привести к такому быстрому перегреву компонентов, что они механически разрушатся.
Некоторые старые операционные системы, например MS-DOS, полагаться на BIOS для выполнения многих задач ввода / вывода на ПК.
Вызов реального режима служб BIOS напрямую неэффективно для защищенного режима (и длинный режим ) операционных систем. Вызовы прерывания BIOS используются не современными многозадачными операционными системами после их первоначальной загрузки.
В 1990-х годах BIOS предоставлял некоторые интерфейсы для операционных систем Microsoft Windows и Linux, например Advanced Power Management (APM), Устаревшие Plug and Play (Legacy PnP), Интерфейс управления рабочим столом (DMI), PCI BIOS и Спецификация многопроцессора (MPS). Начиная с 2000-х годов, BIOS предоставляет интерфейсы ACPI и SMBIOS для современных систем.
После загрузки операционных систем, Код режима управления системой все еще работает в SMRAM. С 2010 года технология BIOS находится в процессе перехода к UEFI.
Исторически BIOS в IBM PC и XT не имел встроенного пользовательского интерфейса.. Версии BIOS на более ранней ПК (XT-класс) не настраивались программно; вместо этого устанавливают параметры с помощью DIP-переключателей на материнской плате. Более поздние компьютеры, включая все IBM-совместимые процессоры 80286, энергонезависимую память BIOS с питанием от батарей (микросхему CMOS RAM), которая содержала BIOS. Эти параметры, такие как тип видеоадаптера, размер памяти и параметры жесткого диска, можно настроить только путем запуска программы конфигурации с диска, а не встроенного в ПЗУ. Специальная «справочная дискета» была вставлена в IBM AT для настройки таких параметров, как размер памяти.
В ранних версиях BIOS не было паролей или параметров выбора загрузочного устройства. В BIOS была жестко запрограммирована загрузка с первого диска гибких дисков или, если это не удалось, с первого жесткого диска. Управление доступом в раннюю машинух класса AT осуществляется с помощью физического переключателя с замком (что было несложно преодолеть, если корпус компьютера можно было открыть). Любой, кто мог включить компьютер, мог его загрузить.
Позже компьютеры класса 386 интегрировать утилиту настройки BIOS в ПЗУ с кодом BIOS; Эти компьютеры обычно загружаются в утилиту, которую выполняет BIOS при включенном переключателе или комбинации клавиш.
Утилита настройки Award BIOS на стандартном ПКСовременная утилита настройки BIOS с пользовательским интерфейсом на основе меню (UI), доступ к которому осуществляется нажатием клавиш на клавиатуре при запуске ПК. Обычно ключявляется на короткое время во время раннего запуска, например: «Нажмите F1, чтобы войти в настройки CMOS». Фактический ключ зависит от конкретного оборудования. Функции, представленные в утилите настройки BIOS, обычно включают:
Современный экран настройки BIOS часто содержит Состояние работоспособности ПК или Мониторинг оборудования, который напрямую взаимодействует с микросхемой аппаратного монитора на материнской плате. Это дает возможность контролировать центральный процессор и температуру корпуса, напряжение, обеспечиваемое блоком питания, а также отслеживание и скорости вращения вентиляторов, подключенных к материнской плате.
После запуска системы мониторинга оборудования и управление вентилятором компьютера обычно выполняется непосредственно микросхемой аппаратного монитора, которая может быть отдельной микросхемой, подключенной через I²C или SMBus, или входят в состав решения Super I / O, подключенного через Low Pin Count (LPC). Некоторые операционные системы, такие как NetBSD с envsys и OpenBSD с sysctl hw.sensors, имеют интегрированный интерфейс с аппаратными мониторами, которые обычно сделано без какого-либо опыта с BIOS.
Однако в определенных обстоятельствах BIOS также использует информацию о мониторинге оборудования через ACPI, и в этом случае операционная система может использовать ACPI для мониторинга оборудования; это делается, например, на некоторых материнских платах ASUSTeK с функцией AI Booster.
В современном ПК BIOS хранится в перезаписываемой памяти, что позволяет заменять и содержимое содержимого. Такую перезапись содержимого иногда называют перепрошивкой, основанной на обычном использовании типа EEPROM, технически известной как «flash EEPROM», а в просторечии - «flash-память». Это можно сделать с помощью специальной программы или с помощью POST способом BIOS на жестком диске или USB-накопителе. Файл, такое содержимое, иногда называют «образом BIOS». BIOS может быть новой перепрошивки для обновлений до более новой версии, чтобы исправить ошибки или обеспечить повышенную производительность или поддержку нового оборудования, или может потребоваться операция перепрошивки для исправления поврежденного BIOS
Исходный BIOS IBM PC (и кассета BASIC) хранился в запрограммированном на маске только для чтения микросхемы памяти (ROM) в разъемах на материнской плате. ПЗУ могут быть заменены, но не употребляющими. Чтобы обеспечить возможность обновлений, многие совместимые компьютеры использовали перепрограммируемые устройства памяти BIOS, такие как EPROM, EEPROM и более поздние версии флэш-память (обычно NOR flash ) устройств. По словам Роберта Бравера, производитель BIOS Micro Firmware, президента микросхемы Flash BIOS стали обычным явлением примерно в 1995 году, поскольку микросхемы электрически стираемого PROM (EEPROM) дешевле и проще в программировании, чем стандартные ультрафиолетовые Стираемые микросхемы ПРОМ (СППЗУ ). Микросхемы флэш-памяти программируются (и перепрограммируются) внутри схем, тогда как микросхемы СППЗУ необходимо удалить с материнской платы для перепрограммирования. Обновлены версии BIOS, чтобы использовать версии новых версий оборудования и исправить ошибки в предыдущих версиях BIOS.
Начиная с IBM AT, поддерживаемые аппаратные часы устанавливаются через BIOS. У него был бит века, который позволял вручную изменить век, когда наступил 2000 год. Большинство версий BIOS, созданных в 1995 году, и почти все версии BIOS 1997 года поддерживали 2000 год, автоматически устанавливаются бит века, когда часы показывают за полночь 31 декабря 1999 года.
Первые микросхемы флэш-памяти были подключены к шине ISA. С 1998 года, флэш-память BIOS была перемещена на шину LPC, функциональную замену ISA, после новой реализации, известной как «концентратор микропрограмм» (FWH). В 2006 году появились первые системы с поддержкой последовательного периферийного интерфейса (SPI), и флэш-память BIOS снова переместилась.
Размер BIOS и емкость ПЗУ, EEPROM или других носителей, которых он может храниться, со временем увеличивалось по мере добавления новых функций в код; Сейчас существуют версии BIOS размером до 16 мегабайт. Для сравнения, исходный BIOS IBM PC содержался в ПЗУ с маской 8 КиБ. Некоторые современные материнские платы включают в себя даже более крупные микросхемы NAND флэш-память, которые представляют собой целые компактные операционные системы, такие как некоторые дистрибутивы Linux. Например, некоторые материнские платы ASUS включаютли Splashtop OS, встроенную в их микросхемы флэш-памяти NAND. Однако идея включения системы вместе с BIOS в ПЗУ ПК не нова; в 1980-х Microsoft предложила вариант ПЗУ для MS-DOS, и он был включен в ПЗУ некоторых клонов ПК, таких как Tandy 1000 HX.
Другой тип микросхемы прошивки был обнаружен на IBM PC AT и ранние совместимые. В AT интерфейс клавиатуры управлялся микроконтроллером с собственной программируемой памятью. На IBM AT это было устройство с 40-контактным разъемом, в то время как некоторые производители использовали версию этого чипа с EPROM, которая напоминала EPROM. Этому контроллеру также была назначена функция шлюз A20 для управления памятью диапазона в один мегабайт; время от времени требовалось обновление этой «BIOS клавиатуры», чтобы использовать преимущества программного обеспечения, которое могло использовать верхнюю память.
BIOS может содержать такие компоненты, как справочный код памяти (MRC), который отвечает за синхронизацию памяти и соответствующие настройки оборудования.
Компания | AwardBIOS | AMIBIOS | Insyde | SeaBIOS |
---|---|---|---|---|
Лицензия | Собственная | Собственная | Собственная | LGPL v3 |
Поддерживаемая / разработанная | Да | Да | Да | Да |
32-битные вызовы PCI BIOS | Да | Да | Да | Да |
AHCI | Да | Да | Да | Да |
APM | Да | Да | Да (1.2) | Да (1.2) |
BBS | Да | Да | Да | Да |
Меню загрузки | Да | Да | Да | Да |
Сжатие | Да (LHA ) | Да (LHA) | Да (RLE) | Да (LZMA) |
CMOS | Да | Да | Да | Да |
EDD | Да | Да | Да | Да (3.0) |
ESCD | Да | Да | ? | Нет |
Прошивка из ПЗУ | ? | Да | ? | Нет |
Язык | Сборка | Сборка | Сборка | C |
LBA | Да (48) | Да (48) | Да | Да ( 48) |
Многопроцессорная Спецификация | Да | Да | Да | Да |
Дополнительное ПЗУ | Да | Да | Да | Да |
Пароль | Да | Да | Да | Нет |
PMM | ? | Да | ? | Да |
Настройки экрана | Да | Да | Да | Нет |
SMBIOS | Да | Да | Да | Да (2.4) |
Заставка | Да (EPA) | Да (PCX ) | Да | Да (BMP, JPG) |
TPM | Неизвестно | Неизвестно | Неизвестно | Некоторые |
USB загрузка | Да | Да | Да | Да |
USB-концентратор | ? | ? | ? | Да |
USB-клавиатура | Да | Да | Да | Да |
USB-мышь | Да | Да | Да | Да |
IBM опубликовала полные списки BIOS для своих исходных ПК, ПК XT, ПК AT и других современных моделей ПК в приложении к Техническому справочному руководству IBM PC для каждого типа компьютеров. Результатом публикации списков BIOS является то, что любой может точно увидеть, что делает окончательный BIOS и как он это делает.
В мае 1984 года Phoenix Software Associates выпустила свой первый ROM-BIOS, который позволил OEM-производителям создать практически полностью совместимые клоны без необходимости перепроектировать BIOS IBM PC самостоятельно, как это сделала Compaq. для Portable, помогая стимулировать рост индустрии совместимых с ПК и продажи версий DOS других производителей. Первая версия BIOS American Megatrends (AMI) была выпущена в 1986 году.
Новые стандарты, внедренные в BIOS, обычно не содержат полной общедоступной документации или каких-либо списков BIOS. В результате узнать подробности о многих дополнениях к BIOS сторонних производителей не так просто, как об основных службах BIOS.
Большинство поставщиков материнских плат для ПК лицензируют «ядро» BIOS и набор инструментов у третьей коммерческой стороны, известной как «независимый поставщик BIOS» или IBV. Затем производитель материнской платы настраивает этот BIOS в соответствии со своим оборудованием. По этой причине обновленные BIOS обычно можно получить напрямую от производителя материнской платы. Основные поставщики BIOS включают American Megatrends (AMI), Insyde Software, Phoenix Technologies и Byosoft. Бывшие поставщики включают Award Software и Microid Research, которые были приобретены Phoenix Technologies в 1998 году; Позже Phoenix отказалась от бренда Award. General Software, которую также приобрела Phoenix в 2007 году, продавала BIOS для встраиваемых систем на базе процессоров Intel.
Сообщество разработчиков ПО с открытым исходным кодом активизировало свои усилия по разработке замены проприетарных BIOS и их будущих воплощений на аналог с открытым исходным кодом через libreboot, coreboot и OpenBIOS / Открыть проекты микропрограмм. AMD предоставила информацию о продуктах для некоторых наборов микросхем, а Google спонсирует проект. Материнские платы производитель Tyan предлагает coreboot рядом со стандартным BIOS в линейке материнских плат Opteron. MSI и Gigabyte Technology последовали их примеру с MSI K9ND MS-9282 и MSI K9SD MS-9185 соответственно. модели M57SLI-S4.
EEPROM и флэш-память имеют преимущество, поскольку они могут быть легко обновлены пользователя; Производители обычно выпускают обновления BIOS для своих продуктов, улучшения совместимости и устранения ошибок. Однако это преимущество имело риск того, что неправильно выполненное или прерванное обновление BIOS может сделать компьютер или устройство непригодным для использования. Чтобы избежать этих ситуаций, более поздние версии BIOS использовать «загрузочный блок»; часть BIOS, которая запускается первой и должна обновляться отдельно. Этот код проверяет, не повреждена ли остальная часть BIOS (используя hash контрольные суммы или другие методы), прежде чем передать ему управление. Если загрузочный блок обнаруживает какое-либо повреждение в основном в BIOS, он обычно предупреждает пользователя о том, что процесс восстановления должен быть инициирован загрузкой со съемного носителя (дискета, компакт-диск или флэш чтобы-накопитель USB), пользователь мог попробовать перепрошиваем BIOS снова. Некоторые материнские платы имеют копию BIOS (иногда называемые платами DualBIOS) для восстановления после сбоев BIOS.
Существует как минимум пять известных вирусов, атакующих BIOS, два из которых предназначены для демонстрационных целей. Первым, найденным в дикой природе, был Меброми, предназначенный для китайских пользователей.
Первым вирусом BIOS был BIOS Meningitis, который вместо стирания микросхем BIOS заразил их. BIOS Meningitis относительно безвреден по сравнению с таким вирусом, как CIH
. Второй вирус BIOS был CIH, также известный как «Chernobyl Virus», который смог стереть содержимое флэш-памяти BIOS на совместимые чипсеты. CIH появился в середине 1998 года и стал активным в апреле 1999 года. Часто зараженные компьютеры больше загружались, и людям приходилось извлекать микросхему флэш-ПЗУ из материнской платы и перепрограммировать ее. CIH нацелился на широко распространенный в то время набор микросхем для материнских плат Intel i430TX и воспользовался тем фактом, что операционные системы Windows 9x, также широко распространенные в то время, позволяли прямой аппаратный доступ всем программам.
Современные системы не уязвимы для CIH из-за использования множества наборов микросхем, несовместимых с набором микросхем Intel i430TX, а также с другими типами микросхем флэш-ПЗУ. Существует также дополнительная защита от случайной перезаписи BIOS в виде загрузочных блоков, которые защищены от случайной перезаписи, или систем, оснащенных двойным или четырехъядерным BIOS, которые в случае сбоя использовать копию BIOS. Кроме того, все современные операционные системы, такие как FreeBSD, Linux, macOS, Windows NT на основе ОС Windows, например Windows 2000, Windows XP и новее не позволяют программам пользовательского режима иметь прямой доступ к оборудованию.
В результате с 2008 года CIH становится практически безвредными, в худшем случае вызывая зараженные файлы и запуская антивирусное программное обеспечение. Однако другие вирусы BIOS остаются возможными; Мобильные приложения для большинства пользователей Windows без UAC Windows Vista / 7 запускают все с помощью современных приложений CIH-подобный вирус в принципе может получить доступ к оборудованию без предварительного использования эксплойта. Операционная система OpenBSD не позволяет всем пользователям получить этот доступ, и патч grsecurity для ядра Linux также предотвращает этот прямой доступ к оборудованию, разница в том, что злоумышленнику требуется намного более сложный эксплойт на уровне ядра или перезагрузка
Второй вирус BIOS был предложен Джоном Хисманом, главным консультантом по безопасности британской компании Программное обеспечение безопасности нового поколения. В 2006 году на конференции Black Hat Security Conference он показал, как повышать эффективность и читать физическую память, используя обычные процедуры, которые заменили обычные функции ACPI, хранящиеся во флэш-памяти.
Третий вирус BIOS был метод, названный «Постоянное заражение BIOS». Он появился в 2009 году на конференции по безопасности CanSecWest в Ванкувере и на конференции по безопасности SyScan в Сингапуре. Исследователи и Альфредо Ортега из Core Security Technologies применяли, как вставлять вредоносный код в процедуры декомпрессии в BIOS, практически полный контроль над ПК при запуске, даже до загрузки системы операционной системы. Доказательство концепции не использует недостаток в реализации BIOS, а включает только обычные процедуры перепрограммирования BIOS. Таким образом, для этого требуется физический доступ к машине или чтобы пользователь был root. Несмотря на эти требования, Ортега признаны серьезные последствия открытия, сделанного им и Сакко: «Мы можем исправить драйвер, чтобы полностью работающий руткит. У нас даже есть код, который может удалить или отключить небольшой антивирус ».
Mebromi - это троян, нацеленный на компьютеры с AwardBIOS, Microsoft Windows и антивирусным ПО от двух китайских компаний : Rising Антивирус и антивирус Jiangmin KV. Меброми устанавливает руткит, который заражает главную загрузочную запись.
. В интервью с 60 минут в декабре 2013 года Дебора Планкетт, директор по обеспечению информации в США Агентство национальной безопасности заявила АНБ обнаружило и предотвратило возможную атаку BIOS со стороны иностранного государства, направленную на финансовую систему США. В программе цитируются анонимные источники, утверждающие, что это был китайский заговор. Однако последующие статьи в The Guardian, The Atlantic, Wired и The Register опровергли утверждения АНБ.
С 2011 года устаревшая BIOS ПК заменяется более сложным Extensible Firmware Interface (EFI) во многих новых машинах. EFI - это спецификация, которая заменяет интерфейс времени выполнения устаревшего BIOS. Первоначально написал для архитектуры Intel Itanium , EFI теперь доступен для платформы x86 и x86-64 ; разработка спецификации осуществляется Единый форум EFI, отраслевой специальной группой по интересам. Загрузка EFI поддерживалась только в версиях Microsoft Windows, поддерживающих GPT, ядро Linux 2.6.1 и новее, и macOS в Mac на базе Intel. По состоянию на 2014 год новое оборудование для ПК в основном поставляется с прошивкой UEFI. Архитектура защиты от руткитов также может препятствовать запуску в системе изменений собственного программного обеспечения пользователя, что делает UEFI спорным устаревшим устаревшим BIOS в сообществе открытого оборудования.
Другие альтернативы функциональности «Legacy BIOS» в мире x86 включают coreboot и libreboot.
Некоторые серверы и рабочие станции используют платформенно-зависимую Open Прошивка ( IEEE-1275) на основе языка программирования Форт ; он входит в состав компьютеров Sun SPARC, линейки IBM RS / 6000 и других систем PowerPC, таких как материнские платы CHRP, а также OLPC XO-1.
на базе x86. По крайней мере, с 2015 года Apple удалила поддержку устаревших версий BIOS с компьютеров MacBook Pro. Таким образом, утилита BIOS больше не поддерживает устаревший вариант и выводит сообщение «Устаревший режим не поддерживается в этой системе». В 2017 году Intel объявила, что к 2020 году прекратит поддержку устаревшей версии BIOS. С 2019 года новые OEM-компьютеры на платформе Intel больше не устаревшей версии.
На Викискладе есть носители, относящиеся к BIOS. |
Найдите BIOS в Wiktionary, бесплатном словаре. |