Прошивка - Firmware
В вычисление, прошивка[а] это особый класс компьютерное программное обеспечение который обеспечивает низкоуровневый контроль для конкретных устройств аппаратное обеспечение. Микропрограммное обеспечение может обеспечить стандартизированную операционную среду для более сложного программного обеспечения устройства (что позволяет аппаратная независимость ), или, для менее сложных устройств, действовать как полный Операционная система, выполняющий все функции управления, мониторинга и обработки данных. Типичные примеры устройств с прошивкой: встроенные системы, бытовая техника, компьютеры, компьютерная периферия и др. Почти все электронные устройства, помимо самых простых, содержат некоторую прошивку.
Прошивка хранится в энергонезависимая память такие устройства, как ПЗУ, EPROM, или же EEPROM (включая НЕ флэш-память ). В прошлом смена прошивки устройства редко или никогда не производилась в течение всего срока ее службы, но в настоящее время это обычная процедура; некоторые устройства памяти микропрограмм устанавливаются постоянно и не могут быть изменены после изготовления. Общие причины обновления прошивки включают исправление ошибок или добавление функций на устройство. Для этого требуется ПЗУ интегральные схемы должны быть заменены физически, или EPROM или флэш-память должны быть перепрограммированы с помощью специальной процедуры.[2] Прошивки типа BIOS персонального компьютера может содержать только элементарные базовые функции устройства и может предоставлять услуги только программному обеспечению более высокого уровня. Прошивка, такая как программа встроенной системы, может быть единственной программой, которая будет работать в системе и обеспечивать все ее функции.
До включения интегральных схем другие устройства с прошивкой включали дискретный полупроводник диодная матрица. В Компьютер наведения Apollo прошивка состояла из специально изготовленного основная память самолет под названием "память сердечника веревки ", где данные были сохранены путем физического пропуска проводов через (1) или вокруг (0) ядра, в котором хранится каждый бит данных.[3]
История
Ашер Оплер ввел термин «прошивка» в 1967 году. Датамация статья.[4] Первоначально это означало содержимое записываемого магазин управления (небольшая специализированная высокоскоростная память), содержащая микрокод который определил и реализовал компьютерные Набор инструкций, и его можно было перезагрузить, чтобы специализировать или модифицировать инструкции, которые центральное процессорное устройство (CPU) может выполняться. Первоначально прошивка контрастировала с оборудованием (сам ЦП) и программным обеспечением (обычные инструкции, выполняемые на ЦП). Он состоял не из машинных инструкций ЦП, а из микрокода нижнего уровня, участвующего в реализации машинных инструкций. Он существовал на границе между оборудованием и программным обеспечением; отсюда и название "прошивка". Со временем популярное использование расширило слово «прошивка», чтобы обозначить любую компьютерную программу, которая тесно связана с оборудованием, включая машинные инструкции процессора для BIOS, загрузчики начальной загрузки, или системы управления для простых электронные устройства например, микроволновая печь, дистанционное управление, или же компьютерная периферия.
Приложения
Персональные компьютеры
В некоторых отношениях различные компоненты прошивки так же важны, как и Операционная система в рабочем компе. Однако, в отличие от большинства современных операционных систем, микропрограммное обеспечение редко имеет хорошо развитый автоматический механизм обновления для исправления любых проблем с функциональностью, обнаруженных после доставки устройства.
BIOS может быть обновлен пользователем «вручную» с помощью небольшой служебной программы. Напротив, микропрограммное обеспечение на устройствах хранения (жестких дисках, DVD-дисках, флэш-памяти) редко обновляется, даже если для встроенного ПО используется флэш-память (а не ПЗУ); нет стандартизированных механизмов для определения или обновления версий прошивки.
Большинство компьютерных периферийных устройств являются компьютерами специального назначения. Такие устройства, как принтеры, сканеры, камеры и USB-накопители иметь внутреннюю прошивку; Некоторые устройства могут также допускать обновление прошивки на месте.
Некоторые недорогие периферийные устройства больше не содержат энергонезависимую память для микропрограмм и вместо этого полагаются на хост-систему для передачи программы управления устройством с дискового файла или компакт-диска.[5]
Потребительские товары
По состоянию на 2010 г.[Обновить], наиболее портативные музыкальные плееры поддержка обновления прошивки. Некоторые компании используют обновления прошивки для добавления новых воспроизводимых форматов файлов (кодеки ). Другие функции, которые могут измениться с обновлением прошивки, включают графический интерфейс или даже время автономной работы. Наиболее мобильные телефоны есть Прошивка по воздуху возможность обновления прошивки по тем же причинам; некоторые могут даже быть обновлены для улучшения приема или качества звука.
Автомобили
С 1996 г. большинство автомобили использовали бортовой компьютер и различные датчики для обнаружения механических проблем. По состоянию на 2010 г.[Обновить], современные автомобили также используют компьютерное управление антиблокировочные тормозные системы (ABS) и с компьютерным управлением блоки управления трансмиссией (TCU). Водитель также может получать информацию в тире во время вождения таким образом, например, показания расхода топлива и давления в шинах в режиме реального времени. Местные дилеры могут обновить прошивку большинства автомобилей.
Примеры
Примеры прошивки включают:
- В потребительских товарах:
- Системы хронометража и контроля для стиральные машины
- Управление атрибутами звука и видео, а также списком каналов в современных телевизоры
- В компьютерах:
- В BIOS встречается в более старых IBM-совместимых ПК
- В (U) EFI -совместимая прошивка, используемая на Itanium системы, на базе Intel Mac, и многие новые ПК
- Жесткий диск или же Твердотельный накопитель прошивка
- Видео BIOS из видеокарта
- Открытая прошивка, используется в SPARC -на базе компьютеров от Sun Microsystems и Корпорация Oracle, PowerPC -на базе компьютеров Apple и компьютеров от Genesi
- ARCS, используется в компьютерах от Силиконовая Графика
- Кикстарт, используемый в Amiga линейка компьютеров (ПОЧТОВЫЙ, аппаратный init + Подключи и играй автоконфигурация периферийных устройств, ядро, так далее.)
- RTAS (Службы абстракции времени выполнения), используемые на компьютерах из IBM
- В Общая среда прошивки (ДОВСЕ)
- В маршрутизаторы и брандмауэры:
- LibreCMC - 100% бесплатно программное обеспечение распределение роутера на основе Linux-libre ядро
- IPFire - ан Открытый исходный код распределение межсетевого экрана / маршрутизатора на основе Ядро Linux
- fli4l - дистрибутив межсетевого экрана / маршрутизатора с открытым исходным кодом на основе ядра Linux
- OpenWrt - дистрибутив межсетевого экрана / маршрутизатора с открытым исходным кодом на основе ядра Linux
- m0n0wall - встроенный межсетевой экран. FreeBSD
- В NAS системы:
Мигает
Мигает[6] включает перезапись существующей прошивки или данных, содержащихся в EEPROM (Такие как НЕ флэш-память ) модули, присутствующие в электронном устройстве, с новыми данными.[6] Это можно сделать для обновления устройства.[7] или для смены поставщика услуги, связанной с функцией устройства, например, переход от одного поставщика услуг мобильной связи к другому или установка новой операционной системы. Если микропрограмму можно обновить, это часто делается с помощью программы от поставщика и часто позволяет сохранить старую микропрограмму перед обновлением, чтобы ее можно было восстановить, если процесс не удастся или новая версия работает хуже. В качестве альтернативы инструментам поставщика были разработаны альтернативы с открытым исходным кодом, такие как flashrom.
Взлом прошивки
Иногда третьи стороны создают неофициальную новую или модифицированную («неоригинальную») версию прошивки, чтобы предоставить новые функции или разблокировать скрытые функции; это называется кастомная прошивка. Примером является Rockbox как замена прошивки для портативные медиаплееры. Есть много домашнее пиво проекты для различных устройств, которые часто открывают универсальные вычислительные возможности на ранее ограниченных устройствах (например, работающие Рок на плееры iPod ).
Для взлома прошивки обычно используется возможность обновления прошивки на многих устройствах для установки или запуска. Однако некоторым приходится прибегать к подвиги для запуска, потому что производитель попытался заблокировать оборудование, чтобы остановить его работу нелицензионный код.
Большинство хаков прошивки бесплатно программное обеспечение.
Взлом прошивки HDD
Московский Лаборатория Касперского обнаружил, что группа разработчиков именуется "Группа уравнений " разработал привод жесткого диска модификации прошивки для различных моделей накопителей, содержащие троянский конь Это позволяет хранить данные на диске в местах, которые не будут удалены, даже если диск будет отформатирован или очищен.[8] Хотя в отчете «Лаборатории Касперского» прямо не утверждается, что эта группа является частью США. Национальное Агенство Безопасности (NSA), данные, полученные из кода различного программного обеспечения Equation Group, позволяют предположить, что они являются частью NSA.[9][10]
Исследователи из «Лаборатории Касперского» назвали действия Equation Group наиболее продвинутой хакерской операцией из когда-либо обнаруженных, а также задокументировали около 500 случаев заражения, вызванных Equation Group как минимум в 42 странах.
Риски безопасности
Марк Шаттлворт, основатель компании Канонический, который поддерживает Ubuntu Linux распространение, описал проприетарный прошивки в качестве угрозы безопасности, говоря, что "прошивка на вашем устройстве является АНБ "лучший друг" и назвав прошивку "троянским конем монументальных размеров". Он утверждал, что некачественная, закрытый исходный код Прошивка представляет собой серьезную угрозу безопасности системы:[11] "Ваша самая большая ошибка состоит в том, чтобы предположить, что АНБ - единственное учреждение, злоупотребляющее этой позицией доверия - на самом деле, разумно предположить, что вся прошивка - это выгребная яма небезопасности, любезности высшей степени некомпетентности производителей и компетентности высшая степень от очень широкого круга таких агентств ». В качестве потенциального решения этой проблемы он призвал к декларативной прошивке, которая описывала бы «аппаратную связь и зависимости» и «не должна включать исполняемый код ".[12] Прошивка должна быть Открытый исходный код так что код можно проверить и проверить.
Хаки кастомных прошивок тоже ориентированы на инъекцию вредоносное ПО в такие устройства, как смартфоны или USB-устройства. Одна такая инъекция смартфона была продемонстрирована на ОС Symbian в MalCon,[13][14] а хакерское соглашение. Взлом прошивки USB-устройства под названием BadUSB был представлен на Черная шляпа США 2014 конференция,[15] демонстрируя, как флешка микроконтроллер можно перепрограммировать для подмены различных других типов устройств, чтобы взять под контроль компьютер, извлечь данные или шпионить за пользователем.[16][17] Другие исследователи безопасности работали над тем, как использовать принципы, лежащие в основе BadUSB,[18] выпускать в то же время исходный код хакерских инструментов, которые можно использовать для изменения поведения различных USB-устройств.[19]
Смотрите также
- Компьютерное железо
- Компьютерная программа
- Программного обеспечения
- Кастомная прошивка
- Двоичный blob
- Загрузчик
- Coreboot
- Микрокод
- Образ ROM
Примечания
Рекомендации
- ^ «Ciena - Руководство по сокращению». ciena.com. В архиве из оригинала 10 января 2016 г.. Получено 6 февраля 2016.
- ^ "Какая прошивка?". 23 января 2013 г.
- ^ Даг Спайсер (12 августа 2000 г.). "One Giant Leap: Компьютер наведения Аполлона". Доктор Доббс. Получено 24 августа, 2012.
- ^ Оплер, Ашер (январь 1967). «Программное обеспечение четвертого поколения». Датамация. 13 (1): 22–24.
- ^ Корбет, Джонатан; Рубини, Алессандро; Кроа-Хартман, Грег (2005). Драйверы устройств Linux. O'Reilly Media. п. 405. ISBN 0596005903.
- ^ а б "Прошивка прошивки". Tech-Faq.com. В архиве из оригинала 27 сентября 2011 г.. Получено 8 июля, 2011.
- ^ «Центр разработчиков HTC». HTC. Архивировано из оригинал 26 апреля 2011 г.. Получено 8 июля, 2011.
- ^ "Equation Group: коронный создатель кибершпионажа". Лаборатория Касперского. 16 февраля 2015 года. В архиве с оригинала 2 декабря 2015 года.
- ^ Дэн Гудин (февраль 2015 г.). «Как« всемогущие »хакеры, связанные с АНБ, прятались 14 лет и наконец были найдены». Ars Technica. В архиве из оригинала от 24.04.2016.
- ^ «Взлом: Kaspersky разоблачает всемирный взлом NSA практически всех прошивок жестких дисков». Daily Kos. 17 февраля 2015 года. В архиве с оригинала 25 февраля 2015 года.
- ^ Linux Magazine, выпуск 162, май 2014 г., стр.9
- ^ Шаттлворт, Марк (17 марта 2014 г.). «ACPI, прошивка и ваша безопасность». В архиве с оригинала 15 марта 2015 г.
- ^ "Мы скоро вернемся!". Malcon.org. Архивировано из оригинал на 2013-05-26. Получено 2013-06-14.
- ^ «Хакер сажает черный ход в прошивку Symbian». H-online.com. 2010-12-08. Архивировано из оригинал 21 мая 2013 г.. Получено 2013-06-14.
- ^ «Почему безопасность USB в корне нарушена». Wired.com. 2014-07-31. В архиве из оригинала от 03.08.2014. Получено 2014-08-04.
- ^ «BadUSB - Об аксессуарах, которые портят зло». BlackHat.com. В архиве из оригинала на 2014-08-08. Получено 2014-08-06.
- ^ Карстен Ноль; Саша Крисслер; Якоб Лелл (07.08.2014). «BadUSB - Об аксессуарах, которые превращают зло» (PDF). srlabs.de. В архиве (PDF) из оригинала на 19.10.2016. Получено 2014-08-23.
- ^ «Выпущено вредоносное ПО BadUSB - заразите миллионы USB-накопителей». The Hacking Post. Архивировано 6 октября 2014 года.. Получено 7 октября 2014.CS1 maint: неподходящий URL (связь)
- ^ «Непоправимое вредоносное ПО, которое заражает USB-накопители, теперь на свободе». ПРОВОДНОЙ. В архиве из оригинала 7 октября 2014 г.. Получено 7 октября 2014.
внешняя ссылка
- Служба прошивки от поставщика Linux, безопасный портал, который позволяет поставщикам оборудования загружать обновления прошивки
- BadUSB - Об аксессуарах, которые превращают зло на YouTube, Карстен Ноль и Якоб Лелл
- Phison 2251-03 (2303) Пользовательская прошивка и существующие исправления прошивки (BadUSB)