ref: 4c76f46e25f32299c1ed1534c20b5bc65d1a7b7a
dir: /sys/src/cmd/unix/drawterm/libsec/nfastrand.c/
#include <u.h>
#include <libc.h>
#include <libsec.h>
#define Maxrand ((1UL<<31)-1)
ulong
nfastrand(ulong n)
{
ulong m, r;
/*
* set m to the maximum multiple of n <= 2^31-1
* so we want a random number < m.
*/
if(n > Maxrand)
abort();
m = Maxrand - Maxrand % n;
while((r = fastrand()) >= m)
;
return r%n;
}