GETENTROPY(3) | Руководство программиста Linux | GETENTROPY(3) |
ИМЯ¶
getentropy - заполнение буфера случайными байтами
СИНТАКСИС¶
#include <unistd.h>
int getentropy(void *buffer, size_t length);
Требования
макроса
тестирования
свойств
для glibc (см.
feature_test_macros(7)):
getentropy():
ОПИСАНИЕ¶
Функция getentropy() записывает length байт высококачественных случайных данных в буфер, начинающийся в области, указанной в buffer. Максимально разрешенное значение аргумента length равно 256.
Успешный вызов getentropy() всегда предоставляет затребованное число байт энтропии.
ВОЗВРАЩАЕМОЕ ЗНАЧЕНИЕ¶
В случае успеха функция возвращает 0. В случае ошибки возвращается -1, а errno устанавливается в соответствующее значение.
ОШИБКИ¶
- EFAULT
- Часть или весь буфер, указанный в buffer и length, не является валидной адресуемой памятью.
- EIO
- Значение length больше 256.
- EIO
- При попытке перезаписать buffer случайными данными произошла ошибка.
- ENOSYS
- Данная версия ядра не имеет реализации системного вызова getrandom(2), необходимого для реализации данной функции.
ВЕРСИИ¶
Функция getentropy() впервые появилась в glibc 2.25.
СООТВЕТСТВИЕ СТАНДАРТАМ¶
Эта функция является нестандартной. Она также присутствует в OpenBSD.
ЗАМЕЧАНИЯ¶
Функция getentropy() реализована через вызов getrandom(2).
Следует учитывать, что в glibc обертка делает getrandom(2) точкой отмены, а точкой отмены getentropy() не является.
Функция getentropy() также объявлена в <sys/random.h> (для получения этого объявления из заголовочного файла макроса тестирования свойств не требуется).
Вызов getentropy() может блокировать работу, если система только что загрузилась и ядро ещё не успело набрать достаточно случайных событий для инициализации пула энтропии. В этом случае getentropy() продолжает блокировать работу даже при обработке сигнала и вернёт управление только после завершения инициализации пула энтропии.
СМ. ТАКЖЕ¶
ЗАМЕЧАНИЯ¶
Эта страница является частью проекта Linux man-pages версии 4.16. Описание проекта, информацию об ошибках и последнюю версию этой страницы можно найти по адресу https://www.kernel.org/doc/man-pages/.
ПЕРЕВОД¶
Русский перевод этой страницы руководства был сделан Azamat Hackimov <azamat.hackimov@gmail.com>, Dmitry Bolkhovskikh <d20052005@yandex.ru>, Vladislav <ivladislavefimov@gmail.com>, Yuri Kozlov <yuray@komyakino.ru> и Иван Павлов <pavia00@gmail.com>
Этот перевод является бесплатной документацией; прочитайте Стандартную общественную лицензию GNU версии 3 или более позднюю, чтобы узнать об условиях авторского права. Мы не несем НИКАКОЙ ОТВЕТСТВЕННОСТИ.
Если вы обнаружите ошибки в переводе этой страницы руководства, пожалуйста, отправьте электронное письмо на man-pages-ru-talks@lists.sourceforge.net.
15 сентября 2017 г. | Linux |