Заточенные под Apple M1 вредоносы — они уже здесь

Заточенные под Apple M1 вредоносы — они уже здесь

Заточенные под Apple M1 вредоносы — они уже здесь

В ноябре прошлого года Apple представила новые линейки MacBook Pro, MacBook Air и Mac Mini 2020, ставшие первыми устройствами купертиновцев, оснащёнными Apple M1, системой на кристалле ARM-архитектуры. Спустя несколько месяцев авторы отдельных вредоносных программ уже адаптировали свои разработки под новое железо.

Издание Wired обсудило новые версии вредоносов под Apple M1 с Патриком Уордлом, известным исследователем в области кибербезопасности. Уордл специализируется на изучении зловредов, разработанных под операционную систему macOS.

Что такого важного в ARM-процессорах и почему все так воодушевились и одновременно обеспокоились выходом Apple M1? Всё дело в том, что такие CPU используют архитектуру набора команд (Instruction Set Architecture, ISA), отличную от привычных нам десктопных x86-процессоров.

Софт, разработанный для одной архитектуры, не сможет без помощи работать на другой ISA. В своих устройствах Apple решила этот вопрос просто — добавила систему Rosetta, которая автоматически преобразует приложение для использования с процессором Apple.

Каким же боком тут вредоносы, спросите вы? Дело в том, что авторам зловредных программ совсем необязательно писать свой софт именно под Apple M1. Большинство существующих macOS-вредоносов могут спокойно работать через ту же Rosetta 2.

Тем не менее у кастомной разработки специально под Apple M1 есть и свои плюсы. Ну, скажем, чем более отточен и производителен код вредоноса, тем лучше у того получится скрываться от пользователя.

Патрик Уордл разобрал один из образцов вредоносной программы для Apple M1 здесь. Как выяснил специалист, на новый семпл «ругаются» 24 антивируса на VirusTotal. Семь из них увидели в зловреде признаки семейства адваре Pirrit.

Pirrit — очень старая программа, которая начинала как вредонос для Windows, однако позже авторы портировали её под macOS. Помимо стандартного поведения нежелательной программы, Pirrit успешно использует уход от детектирования в системе жертвы.

Проводник Windows падал не из-за Microsoft, виноват оказался деинсталлятор

Инженер Microsoft Рэймонд Чен рассказал любопытную историю отладки загадочных падений Проводника. Сначала всё выглядело так, будто в Windows внезапно появился неприятный баг. Но виновником оказалась вовсе не Microsoft, а сторонний деинсталлятор.

Проблема проявилась как резкий всплеск сбоев Проводника. Инженеры начали изучать дампы и заметили странную деталь: падала 32-битная версия программы, запущенная на 64-битных системах Windows.

Такая версия Проводника всё ещё есть в Windows ради совместимости со старыми приложениями. Обычно современные системы почти не используют этот путь. Но в данном случае сторонний деинсталлятор каким-то образом заставлял систему обращаться именно к этому устаревшему компоненту.

Дальше выяснилось, что деинсталлятор некорректно работал с системными API: использовал неправильное соглашение о вызовах функций и неверно обрабатывал параметры стека. Из-за этого при каждой неудачной операции данные из стека удалялись неправильно.

Поскольку процесс повторялся в цикле, повреждение памяти постепенно накапливалось. В какой-то момент указатель стека уезжал в область активного кода, и Проводник падал.

Со стороны всё выглядело как типичная системная ошибка: софт снова и снова аварийно завершал работу, создавая ощущение, что проблема в самой Windows. На деле операционная система лишь показывала последствия ошибки в стороннем ПО.

Чен напомнил важную вещь: в экосистеме Windows с миллиардами устройств и огромным количеством приложений далеко не каждый сбой компонента Microsoft означает баг в Windows. Сторонние программы тоже могут ломать системные процессы, особенно если неправильно используют низкоуровневые API.

RSS: Новости на портале Anti-Malware.ru