Microsoft начала переводить код Windows на Rust для защиты памяти

Microsoft начала переводить код Windows на Rust для защиты памяти

Microsoft начала переводить код Windows на Rust для защиты памяти

Microsoft переписывает системные библиотеки Windows на Rust, чтобы обеспечить лучшую защищённость памяти софта. Об этом заявил один из представителей руководства, отвечающий за безопасность операционной системы.

Дэвид Уэстон, также известный под ником «dwizzle», на мероприятии BlueHat IL 2023 (прошло в марте в Тель-Авиве) впервые рассказал о готовящемся переводе ключевых компонентов Windows на Rust.

«На деле уже через несколько недель или месяцев вы сможете получить ядро Windows на Rust. Наша основная задача — конвертировать отдельные “внутренности“ операционной системы с C++ на Rust», — объяснил Уэстон.

Более безопасный язык программирования привлёк команду Microsoft несколько лет назад. Тогда разработчики увидели возможность устранить ряд багов памяти с помощью с его помощью. Именно такой класс уязвимостей составил около 70% от всех пропатченных CVE-дыр с 2006 года.

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

Rust не раз хвалили такие гиганты, как Google. При этом авторы вредоносов тоже не гнушаются адаптировать свои программы: например, Linux-версию шифровальщика RansomExx под конец прошлого года переписали на Rust.

Баг macOS ломает TCP через 49 дней без перезагрузки

В macOS нашли редкий, но очень неприятный баг: если компьютер работает без перезагрузки примерно 49,7 дня, у него может постепенно умирать TCP. По версии исследователей, проблема связана с переполнением 32-битного счётчика времени в ядре XNU, который используется TCP-подсистемой.

После этого внутренние TCP-таймеры якобы перестают нормально обновляться, соединения в состоянии TIME_WAIT не очищаются, временные порты постепенно заканчиваются, и система в какой-то момент просто перестаёт устанавливать новые TCP-соединения.

При этом ping может продолжать работать, что делает сбой особенно странным. В Photon пишут, что заметили аномалию на своих macOS-машинах, которые круглосуточно используются для мониторинга iMessage-сервисов.

По их описанию, часть узлов после примерно 49 дней 17 часов 2 минут 47 секунд аптайма перестала открывать новые TCP-сессии. После перезагрузки всё возвращалось в норму, но таймер, по сути, запускался заново.

Авторы утверждают, что смогли воспроизвести поведение на двух машинах и связали его с переменной tcp_now в XNU. В открытом репозитории Apple действительно есть TCP-код ядра Darwin/XNU, где используются 32-битные значения времени и логика сравнения временных меток TCP, на которую ссылаются исследователи.

Поведения бага выглядит так: сначала ничего не ломается в лоб, но закрытые TCP-соединения перестают вовремя исчезать из TIME_WAIT. Затем их становится всё больше, временные порты забиваются, новые подключения начинают зависать в SYN_SENT, а сервисы, которым нужны новые TCP-сокеты, начинают сыпаться.

Если эта находка подтвердится, то для обычного пользователя баг вряд ли станет массовой проблемой: большинство устройств на macOS перезагружаются чаще (хотя бы из-за обновлений). А вот для долго работающих Mac mini, билд-серверов, CI/CD-ферм, удалённых рабочих станций и серверных компьютеров, которые могут жить без ребута неделями, история выглядит уже куда серьёзнее.

Если у вас есть компьютер на macOS, который работает неделями без перезагрузки и критичен для сервисов, мы бы посоветовали следить за его аптаймом.

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