File: randombytes.c

package info (click to toggle)
librandombytes 0~20240318-3
  • links: PTS, VCS
  • area: main
  • in suites: trixie
  • size: 328 kB
  • sloc: ansic: 411; python: 340; sh: 137; makefile: 23
file content (42 lines) | stat: -rw-r--r-- 1,163 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
// version 20230126
// public domain
// djb

// automatic-alternatives 1 getrandom_wrapper.o getentropy_wrapper.o devurandom_wrapper.o

#include <unistd.h>
#include "getrandom_wrapper.h"
#include "getentropy_wrapper.h"
#include "devurandom_wrapper.h"
#include "randombytes.h"

static enum {
  use_nothing,
  use_getrandom,
  use_getentropy,
  use_devurandom
} use = use_nothing;

__attribute__((constructor))
static void startup(void)
{
  if (getrandom_wrapper_ready())  { use = use_getrandom;  return; }
  if (getentropy_wrapper_ready()) { use = use_getentropy; return; }
  if (devurandom_wrapper_ready()) { use = use_devurandom; return; }
}

void randombytes(void *x,long long xbytes)
{
  if (use == use_getrandom)  { getrandom_wrapper(x,xbytes);  return; }
  if (use == use_getentropy) { getentropy_wrapper(x,xbytes); return; }
  if (use == use_devurandom) { devurandom_wrapper(x,xbytes); return; }
  for (;;) pause();
}

const char *randombytes_source(void)
{
  if (use == use_getrandom)  return "kernel-getrandom";
  if (use == use_getentropy) return "kernel-getentropy";
  if (use == use_devurandom) return "kernel-devurandom";
  return "kernel-nothing";
}