Browse Source

Merge pull request #657 from stoeckmann/getrandom

Use GRND_NONBLOCK with getrandom.
tags/json-c-0.16-20220414
Eric Hawicz GitHub 5 years ago
parent
commit
cf30cba4ac
No known key found for this signature in database GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 4 additions and 2 deletions
  1. +4
    -2
      random_seed.c

+ 4
- 2
random_seed.c View File

@@ -164,19 +164,21 @@ retry:

static int get_getrandom_seed(void)
{
DEBUG_SEED("get_dev_random_seed");
DEBUG_SEED("get_getrandom_seed");

int r;
ssize_t ret;

do {
ret = getrandom(&r, sizeof(r), 0);
ret = getrandom(&r, sizeof(r), GRND_NONBLOCK);
} while ((ret == -1) && (errno == EINTR));

if (ret == -1)
{
if (errno == ENOSYS) /* syscall not available in kernel */
return -1;
if (errno == EAGAIN) /* entropy not yet initialized */
return -1;

fprintf(stderr, "error from getrandom(): %s", strerror(errno));
exit(1);


Loading…
Cancel
Save