mirror of
https://github.com/json-c/json-c.git
synced 2026-04-02 20:09:06 +08:00
Merge pull request #657 from stoeckmann/getrandom
Use GRND_NONBLOCK with getrandom.
This commit is contained in:
@@ -164,19 +164,21 @@ retry:
|
|||||||
|
|
||||||
static int get_getrandom_seed(void)
|
static int get_getrandom_seed(void)
|
||||||
{
|
{
|
||||||
DEBUG_SEED("get_dev_random_seed");
|
DEBUG_SEED("get_getrandom_seed");
|
||||||
|
|
||||||
int r;
|
int r;
|
||||||
ssize_t ret;
|
ssize_t ret;
|
||||||
|
|
||||||
do {
|
do {
|
||||||
ret = getrandom(&r, sizeof(r), 0);
|
ret = getrandom(&r, sizeof(r), GRND_NONBLOCK);
|
||||||
} while ((ret == -1) && (errno == EINTR));
|
} while ((ret == -1) && (errno == EINTR));
|
||||||
|
|
||||||
if (ret == -1)
|
if (ret == -1)
|
||||||
{
|
{
|
||||||
if (errno == ENOSYS) /* syscall not available in kernel */
|
if (errno == ENOSYS) /* syscall not available in kernel */
|
||||||
return -1;
|
return -1;
|
||||||
|
if (errno == EAGAIN) /* entropy not yet initialized */
|
||||||
|
return -1;
|
||||||
|
|
||||||
fprintf(stderr, "error from getrandom(): %s", strerror(errno));
|
fprintf(stderr, "error from getrandom(): %s", strerror(errno));
|
||||||
exit(1);
|
exit(1);
|
||||||
|
|||||||
Reference in New Issue
Block a user