Try to gather entropy from /dev/random.

This commit is contained in:
wkj 2004-04-21 03:06:03 +00:00
parent 551445b92c
commit 60d3db8e6b

21
src/lib9/truerand.c Normal file
View file

@ -0,0 +1,21 @@
#include <u.h>
#include <libc.h>
ulong
truerand(void)
{
int i, n;
uchar buf[sizeof(ulong)];
static int randfd = -1;
if(randfd < 0){
randfd = open("/dev/random", OREAD);
fcntl(randfd, F_SETFD, FD_CLOEXEC);
}
if(randfd < 0)
sysfatal("can't open /dev/random: %r");
for(i=0; i<sizeof(buf); i += n)
if((n = readn(randfd, buf+i, sizeof(buf)-i)) < 0)
sysfatal("can't read /dev/random: %r");
return *((ulong*)buf);
}