Rust в UEFI: создание утилиты для сохранения изображения BIOS

Традиционные языки для разработки BIOS – C и ассемблер, но Rust становится все более востребованным. Разработка BIOS схожа с embedded-разработкой: сложная отладка, взаимодействие с аппаратурой, поиск документации. При этом есть и свои преимущества: высокая тактовая частота, большой объем памяти. Современным стандартом для программ запускаемых при старте компьютера является UEFI, заменивший BIOS.
Rust в UEFI: создание утилиты для сохранения изображения BIOS
Изображение носит иллюстративный характер

Для создания EFI-утилит на Rust используется крейт uefi-rs. Он предоставляет необходимые инструменты, включая макросы и обертки для таблиц UEFI. Утилита сохраняет изображение заставки BIOS, расположенной в Boot Graphics Record Table (BGRT), в файл. Таблица BGRT содержит указатель на изображение в памяти.

Для доступа к BGRT, потребовалась разработка собственной обертки для ACPI протокола, так как не все протоколы поддерживаются uefi-rs. Протокол ACPI позволяет получить доступ к таблицам, включая BGRT. Функция get_acpi_table возвращает заголовок таблицы, а также требуемую таблицу.

Для нахождения таблицы BGRT, был разработан обобщенный метод locate_table_by_signature. Структура EfiAcpiBootGraphicsResourceTable описывает формат таблицы BGRT. В итоге, полученные данные изображения из таблицы BGRT сохраняются в файл на диске.


Новое на сайте

19949Трихнукагигур: вулкан, в магматическую камеру которого можно спуститься 19947Почему четыре уязвимости в SimpleHelp, Samsung и D-Link стали обязательными к устранению... 19946Малярия управляла нашими предками: куда пускали комары, туда и шли люди? 19945Как выжить в чужой сети: вирус FIRESTARTER, который не уничтожить перезагрузкой? 19944Дамба через Берингов пролив спасёт океанские течения? 19943Чья кружка потерялась в Испании почти два тысячелетия назад? 19942Почему ваш зелёный дашборд лжёт вам о реальной безопасности? 19941Уязвимость в Microsoft Entra ID позволяла захватить любой сервисный принципал 19940Дыра в роботе: как Hugging Face проигнорировала собственный урок безопасности 19939Чернобыль унёс мир на край пропасти — что мы знаем спустя десятилетия? 19938Зачем чат-ботам нужно в шесть раз меньше памяти, если качество не страдает? 19936Почему музыка будущего звучит как прошлое? 19935Как ректальный осмотр остановил аритмию: что это говорит о медицине?
Ссылка