Системные вызовы, обеспечивающие энтропию - Entropy-supplying system calls

Системные вызовы, обеспечивающие энтропию находятся системные вызовы в Unix-подобный Операционная система ядра через который процессы может получать энтропийные или случайные данные. Первым из них был гетентропия, представил OpenBSD операционной системы в выпуске 5.6 (ноябрь 2014 г.) в качестве рефакторинга подхода sysctl (3) KERN_ARND, используемого с 1997 г.[1] Linux предлагает очень похожий системный вызов, getrandom, который был основан на гетентропия.[2] Впервые он был доступен в Linux 3.17, выпущенном в октябре 2014 года.[3] В июле 2015 г. Солярис представил слегка измененные версии гетентропия и getrandom.[4] В августе 2015 г. FreeBSD представил read_random системный вызов для получения случайных данных из ядра.[5]

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

Майкрософт Виндоус ' CryptGenRandom и Apple iOS с SecRandom API очень похожи. Однако они не реализованы как системные вызовы.

Мотивация

Традиционно Unix-подобные операционные системы предоставляют случайные данные через два псевдоустройства: / dev / случайный и / dev / urandom. Однако безопасное и надежное считывание случайных данных с этих устройств может быть трудным и сложным. Например, злоумышленник может помешать процессу доступа к псевдоустройствам, открыв все доступные файловые дескрипторы, или через аналогичную форму атака истощения ресурсов. Использование этих устройств также мешает отмена привилегии. Непривилегированным процессам часто отказывают в возможности открывать и читать файлы и устройства, а устройства случайности даже не видны хромированный процессы.

Сложность использования псевдоустройств случайности часто заставляет разработчиков использовать вместо них стандартные библиотечные функции. Некоторые из них, например Язык программирования C с rand (), случайный(), и drand48 (), очень небезопасны при использовании для криптографии или подобных приложений, потому что эти алгоритмы на самом деле детерминированы и были намеренно искажены для удовлетворения требований повторного использования начального числа через интерфейсы srand (), случайный (), и srand48 ().

Между этими вызовами существует значительная разница: гетентропия () гарантирует, что случайные числа будут возвращены немедленно, без какой-либо блокировки. Это требует оперативной поддержки, которая гарантирует инициализацию случайного потока данных при первой же возможности. Чтобы поощрить другие операционные системы следовать этой модели, getentropy () не может указывать на ошибки в приложении. Другие описанные здесь вызовы могут вместо этого возвращать ошибки или блокироваться неопределенно. Такая семантика блокировки была связана с серьезными проблемами.[6]

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

использование

Поскольку это быстрее и добавляет еще один уровень смешивания энтропии, обычно предлагается, чтобы процессы использовали данные этих системных вызовов через пользовательское пространство. криптографически безопасный генератор псевдослучайных чисел (CSPRNG) вместо того, чтобы назначать полученные данные напрямую переменным. Для этой цели стандартная библиотека OpenBSD C включает функцию arc4random, которые программы должны вызывать, когда им нужны случайные данные.[1] Нравиться гетентропия, arc4random также не может блокировать или возвращать ошибку.

Этот подход позволяет программе получать меньшую энтропию из ядра, не снижая силы случайных данных. В гетентропия системный вызов разработан на основе этого предположения, обеспечивая не более 256 байт на вызов.[1][7]

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

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

  1. ^ а б c "Справочная страница getentropy (2) OpenBSD". Страницы руководства OpenBSD. OpenBSD. Получено 27 мая 2016.
  2. ^ «[PATCH, RFC] random: ввести системный вызов getrandom (2)». LKML. 17 июля 2014 г.. Получено 30 декабря 2015.
  3. ^ «Linux 3.17». Новички в ядре Linux. Получено 30 декабря 2015.
  4. ^ Даррен, Моффат. "Новые системные вызовы Solaris: getentropy (2) и getrandom (2)". / dev / urandom. Oracle. Получено 3 января 2016.
  5. ^ "Ревизия r286839". svnweb.freebsd.org. FreeBSD. Получено 29 августа 2017.
  6. ^ «Блоки Python во время загрузки». Получено 28 апреля 2017.
  7. ^ "arc4random (3) страница руководства OpenBSD". Страницы руководства OpenBSD. OpenBSD. Получено 27 мая 2016.

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