W ^ X - W^X

W ^ X ("написать xor выполнить", произносится W xor Икс) это безопасность особенность в операционные системы и виртуальные машины. Это объем памяти политика защиты, согласно которой каждый страница в процесс или ядро с адресное пространство может быть либо записываемым, либо исполняемый файл, но не то и другое одновременно. Без такой защиты программа может записывать (как данные "W") инструкции ЦП в область памяти, предназначенную для данных, а затем запускать (как исполняемый "X"; или читать-выполнять "RX") эти инструкции. Это может быть опасно, если автор памяти злонамерен. W ^ X - это Unix-подобная терминология для строгого использования общей концепции исполняемая защита пространства, управляемый через mprotect системный вызов.

W ^ X относительно прост на процессоры которые поддерживают детализированные разрешения страниц, такие как солнце с SPARC и SPARC64, AMD с AMD64, Hewlett Packard с PA-RISC, HP (первоначально Корпорация цифрового оборудования s) Альфа, и РУКА.

W ^ X также был применен к разрешениям на запись / выполнение файловой системы, чтобы уменьшить уязвимости записи файлов (как в памяти) и настойчивость злоумышленника.[1] Установление ограничений на права доступа к файлам также может закрыть пробелы в применении W ^ X, вызванные файлами с отображением памяти.[2][3] Полное запрещение использования произвольного нативного кода также может уменьшить уязвимости ядра и процессора, которые не проявляются через существующий код на компьютере.[4]

Совместимость

Некоторые ранние Intel 64 процессорам не хватало Бит NX требуется для W ^ X, но это появилось в более поздних чипах. На более ограниченных процессорах, таких как Intel i386, W ^ X требует использования CS сегмент кода предел как "линия на песке ", точка в адресном пространстве, выше которой выполнение запрещено и данные расположены, а ниже которой разрешено и размещаются исполняемые страницы. Эта схема использовалась в Exec Shield.[5]

Компоновщик изменения обычно требуются для отделения данных от кода (например, батуты которые необходимы для компоновщика и библиотека время выполнения функции). Переключатель, разрешающий микширование, обычно называется execstack в Unix-подобных системах[6]

W ^ X также может создать небольшую проблему для своевременная компиляция, который включает в себя интерпретатор, генерирующий машинный код на лету, а затем запускающий их. Простое решение, используемое большинством, в том числе Fire Fox, включает в себя просто выполнение страницы после того, как интерпретатор закончит писать машинный код, используя VirtualProtect в Windows или mprotect на юникс-лайках. Другое решение включает отображение одной и той же области памяти на двух страницах, одна с RW, а другая с RX.[7] Нет простого консенсуса относительно того, какое решение является более безопасным: сторонники последнего подхода считают, что разрешение на выполнение страницы, которая когда-либо была доступна для записи, разрушает точку W ^ X (существует SELinux политика для контроля таких операций, называемая allow_execmod) и что рандомизация разметки адресного пространства сделает безопасным использование обеих страниц в одном процессе. Сторонники первого подхода считают, что второй подход безопасен только тогда, когда две страницы отданы двум отдельным процессам, и межпроцессного взаимодействия будет дороже, чем звонок mprotect.

История

W ^ X был впервые реализован в OpenBSD 3.3, выпущенная в мае 2003 г. В 2004 г. Microsoft представила аналогичную функцию под названием DEP (Предотвращение выполнения данных ) в Windows XP. Подобные функции доступны и для других операционных систем, включая PaX и Exec Shield патчи для Linux, и NetBSD реализация PaX. В Red Hat Enterprise Linux (и автоматически CentOS ) версии 5 или ядром Linux 2.6.18-8, SELinux получил allow_execmem, allow_execheap, и allow_execmod политики, которые предоставляют W ^ X при отключении.

Хотя W ^ X (или DEP) на протяжении большей части своего существования защищал только пользовательские программы, в 2012 году Microsoft расширила его до ядра Windows на архитектурах x86 и ARM.[8] В конце 2014 - начале 2015 года W ^ X был добавлен в ядро ​​OpenBSD на архитектуре AMD64.[9] В начале 2016 года W ^ X был полностью реализован в ядре NetBSD AMD64 и частично в ядре i386.

Начиная с Fire Fox 46 в 2016 г. виртуальная машина Firefox для JavaScript также реализует политику W ^ X.[7]

Смотрите также

Рекомендации

  1. ^ "Применить ограничения execve () для API> 28".
  2. ^ "Новости ядра Зака".
  3. ^ "S.A.R.A. - новый многослойный LSM".
  4. ^ «Укрепление ядра Linux (серия 2.0.x)».
  5. ^ "i386 W ^ X". 17 апреля 2003 г.. Получено 19 июня, 2014.
  6. ^ execstack (8) – Linux Системное администрирование Руководство
  7. ^ а б "W ^ X JIT-код включен в Firefox". Получено 29 апреля, 2016.
  8. ^ «Улучшения защиты от эксплойтов в Win8».
  9. ^ «Защита W ^ X для ядра AMD64».

внешняя ссылка