Pull to refresh
2K+
316
Николай Шлей@CodeRush

Firmware Security Engineer

686
Subscribers
Send message
Да там социальной инженерии простейшей хватит за глаза, скорее всего. На самом деле, прошивка у Acer чаще всего настолько дырявая, что заморачиваться обращением в Support мало кто захочет.
Добавлю еще, что на некоторых системах (на вот этом Acer тестовом, к примеру) есть возможность сброса пароля звонком в Acer Support, где нужно будет доказать, что машина не украдена, а затем назвать набор цыфр, которые отображаются на экране после 3 неудачных попыток ввода пароля. В ответ они пришлют другой набор, и если ответ правильный, то драйвер UnlockPwd этот самый пароль сотрет.
Хитрый план, не знал, спасибо, сейчас поправлю.
Стирание NVRAM при помощи программатора, либо подсистемой Crisis Recovery прошивки — два стандартных способа, которые помогают в случае, если PKpriv или пароль утеряны. Если доступ к PKpriv есть, отключить SecureBoot можно удалением переменной PK вызовом SetVariable с нужными параметрами из любой загруженной ОС.
Про безопасность SecureBoot и атаки на него я уже ранее писал, здесь больше про то, как им взять и начать пользоваться.
Безопасность SecureBoot держится на безопасности NVRAM, т.е. для нее необходимо, чтобы к содержимому NVRAM нельзя было получить доступ каким-то обходным способом, а не стандартными GetVariable/SetVariable, и по умолчанию на обеих ноутбуках это не так (прошивки уязвимы к атакам на S3 BootScript, что позволяет записать свой код в микросхему, что позволяет стартовать раньше SecureBoot, т.е. толку от него без защиты остального — ноль без палочки).
Безопасность любой системы определяется по самому слабому звену, поэтому вместе с SecureBoot нужно использовать и другие способы защиты прошивки, теорию о которых я описывал в вышеупомянутом цикле, а практику показывал на ZeroNights 2015.
Если вы простой пользователь и хотите, чтобы о безопасности вашей прошивки подумал вендор — покупайте системы HP или Dell, несмотря на все их недостатки, конкретно с защитой прошивок там все намного лучше, чем у конкурентов.
Скорее не об аудитории, а о темах, которые там обсуждаются. GT, за вычетом космонавтики и железа — это такой новый «Чулан», куда переехала политота, войны с РосКомПозором, «Гляньте чуваки, какой новый гаджет на кикстартере» и прочее вот такое. Да, теперь там пишут и про разработку собственных устройств, и про FPGA, но только и исключительно по воле «кровавой одменистрации», а основной набор тем из топа по прежнему примерно такой, как перечислен выше. От того и отношение к ресурсу соотвествующее.
Влезу немного со своим рылом в калышный ряд, но Хабр перестал быть тортом не потому, что с него ушли создатели инфошума, а в основном потому, что администрация волевым решением унесла на GT все железячные топики, будь это DIY, программирование МК или промышленная автоматика — все на GT, к обзорам умных браслетов и прочей ерунде для гиков. В результате мы потеряли посты DIHALT'а, dlinyj, и кучи других товарищей, а в замен получили очередные 100500 статей о преимуществах C# над C++. Этот перенос — та самая соломинка, сломавшая спину моему писательскому верблюду. Написал все, что не мог не написать, еще напишу статью или пару статей про SecureBoot, так как обещал, ну и все, дальше только стендэлон на английском, как у d_olex.
Проблема в том, что если лампочки Hue еще можно заменить на что-то похожее (особенно если 16 миллионов цветов не нужны), то хаб менять вообще не на что — он объективно лучше, чем другие ZLL-хабы вроде GE Wink. Есть еще интересный Samsung SmartThings, но пока его сложно купить вне Великобритании, а для управления линейкой Hue ему все равно нужен Hue Bridge.
В общем, хорошо, что они одумались, но посмотреть на какой-нибудь RaspBee все же теперь стоит, если еще не.
Был момент, когда на amazon.de было 1,5 звезды, 2 дня назад, как раз между анонсом сертификационной программы Friends of Hue и отказом от блокировки. Теперь минусовать не за что, народ меняет отзывы обратно.
Хочешь сделать людям хорошо — сделай сначала плохо, а потом верни как было.
В этот раз DRM'о внедрить не получилось, народ обрушил рейтинги Hue Starter Kit на amazon.com и amazon.de практически до 1, а Philips встала в один ряд с Sony, Keurig и FTDI, но ничего — через пару месяцев или лет они попробуют еще раз, по еще какой-нибудь выдуманной причине.
Там даже исследования никакие не нужны, на самом деле. Адекваной реализации стоит ожидать только на серверных платах, на которых этот самый IOMMU нужен не для безопасности, а для проброса PCIe-устройств в виртуальные окружения. Все остальные системы, производимые массово, имеют IOMMU либо отключеным (чаще всего), либо настроеным по умолчанию (и защиты прошивки и/или ранних стадий загрузки ОС от DMA-атак такая настройка не предполагает).
Короче: если существует опасность вышеуказанных атак, то лучше все внешние порты с DMA, OROMами и/или Bus Master'ингом отключить, желательно аппаратно.
Для безопасного использования внешних PCIe-устройств необходима поддержка, правильная настройка и использование IOMMU (у Intel он называется VT-d, поддерживается далеко не всеми процессорами, требуется для защиты от доступа к физической памяти ПК при помощи DMA, инициированного прошивкой внешнего PCIe-устройства) и SecureBoot (чтобы защитить систему от загрузки вредоносного Option ROM во время старта).
А теперь поднимите руки, у кого обе эти технологии хотя бы включены, я уже не говорю про правильно настроены…
Классная станция, дай ТНБ каждому ремонтнику такую.
Понятно, что настоящие джедаи умудряются проделать то же самое в гараже, используя строительный фен и помощь такой-то матери, но с хорошим инструментом и работать приятнее, и на выходе получается не 30% брака, а 0,3%.
Зря автор не упомянул конкурс P-H-C и его победителя — семейство алгоритмов Argon2.
С тех, что с используют протокол AHCI — без проблем, для прошивки это обычное SATA-устройство, для тех, что используют протокол NVMe нужен DXE-драйвер, который на новых матернских платах уже имеется, а на старые его можно попробовать добавить, но без гарантии положительного результата.
А потом вот эти же люди говорят, что у открытого сообщества нормальные программы не получаются.
Я веду открытый проект с 2013 года, один, на языке и технологиях приличной давности (C++/Qt4). Его не скачивают миллионы и он не нужен каждому хипстеру, но он решает свою задачу. В этом году я неспеша меняю в нем движок, т.к. за пару лет требования изменились, в следующем году буду дорабатывать UI, глядишь лет через 5 со старта проекта из него выйдет что-то путное. А вот эти «по открытому проекту в год» — это большо про «помотросил, и бросил», чем про решение задачи, мне кажется.
Прошивку на нем тоже починить будет практически невозможно в случае ее падения — там BootGuard с прошитым в чипсет ключом, и обе флешки для EC и UEFI — в корпусе TFBGA24, т.е. их просто так не снять и не прошить без специального оборудования.
У меня есть доступ к исходному коду этого модуля, но картины это не меняет, т.к. интерпретатор EBC на данный момент собирается только под три вышеупомянутых архитектуры, и для ARM и PowerPC просто не реализован еще.
1. Понятно, что писать можно и нетрудно, непонятно только, зачем. Мне тоже приходится писать на ассемблере там, где PIC не завезли (пользуясь случаем, шлю разработчикам архитектуры amd64 охапку лучей добра за RIP-относительную адресацию), но вот так брать и писать на нем программу для UEFI Shell — больше похоже на фанатизм, дух старой школы и вот это все. :)
2. EBC пока не реализован ни на каких архитетурах, кроме i386, amd64 и Itanium, да и компилятор дают только за деньги, так что толку от него крайне немного.
3. Спасибо.

Information

Rating
Does not participate
Date of birth
Registered
Activity

Specialization

Инженер встраиваемых систем, Системный инженер
Ведущий