Use the new RNG for the networking stack
authorBarret Rhoden <brho@cs.berkeley.edu>
Thu, 4 Feb 2016 23:35:41 +0000 (18:35 -0500)
committerBarret Rhoden <brho@cs.berkeley.edu>
Thu, 4 Feb 2016 23:35:41 +0000 (18:35 -0500)
And remove the old version.

Signed-off-by: Barret Rhoden <brho@cs.berkeley.edu>
kern/drivers/dev/random.c
kern/include/ns.h
kern/src/net/devip.c
kern/src/net/tcp.c

index bba11d8..c06d2ef 100644 (file)
@@ -207,25 +207,3 @@ struct dev randomdevtab __devtab = {
        .power = devpower,
        .chaninfo = devchaninfo,
 };
-
-/* This is something used by the TCP stack.
- * I have no idea of why these numbers were chosen. */
-static uint32_t randn;
-
-static void seedrand(void)
-{
-       ERRSTACK(2);
-       if (!waserror()) {
-               _randomread((void *)&randn, sizeof(randn));
-               poperror();
-       }
-}
-
-int nrand(int n)
-{
-       if (randn == 0)
-               seedrand();
-       randn = randn * 1103515245 + 12345 + read_tsc();
-       return (randn >> 16) % n;
-}
-
index 3f22c8e..227bbb7 100644 (file)
@@ -792,7 +792,6 @@ char *nextelem(char *unused_char_p_t, char *);
 
 struct cname *newcname(char *unused_char_p_t);
 void notkilled(void);
-int nrand(int);
 uint32_t random_read(void *xp, uint32_t n);
 uint32_t urandom_read(void *xp, uint32_t n);
 uint64_t ns2fastticks(uint64_t);
index 32946f0..1c9362b 100644 (file)
@@ -916,7 +916,7 @@ static void setlport(struct conv *c)
                                *pp = 600;
                } else
                        while (*pp < 5000)
-                               *pp = nrand(1 << 15);
+                               urandom_read(pp, sizeof(*pp));
 
                found = 0;
                for (x = 0; x < p->nc; x++) {
index b5306c9..841919c 100644 (file)
@@ -1235,7 +1235,7 @@ int ntohtcp4(Tcp * tcph, struct block **bpp)
  */
 void tcpsndsyn(struct conv *s, Tcpctl * tcb)
 {
-       tcb->iss = (nrand(1 << 16) << 16) | nrand(1 << 16);
+       urandom_read(&tcb->iss, sizeof(tcb->iss));
        tcb->rttseq = tcb->iss;
        tcb->snd.wl2 = tcb->iss;
        tcb->snd.una = tcb->iss;
@@ -1508,7 +1508,7 @@ limbo(struct conv *s, uint8_t * source, uint8_t * dest, Tcp * seg, int version)
                lp->mss = seg->mss;
                lp->rcvscale = seg->ws;
                lp->irs = seg->seq;
-               lp->iss = (nrand(1 << 16) << 16) | nrand(1 << 16);
+               urandom_read(&lp->iss, sizeof(lp->iss));
        }
 
        if (sndsynack(s->p, lp) < 0) {
@@ -2680,7 +2680,7 @@ void tcpsendka(struct conv *s)
        seg.mss = 0;
        seg.ws = 0;
        if (tcpporthogdefense)
-               seg.seq = tcb->snd.una - (1 << 30) - nrand(1 << 20);
+               urandom_read(&seg.seq, sizeof(seg.seq));
        else
                seg.seq = tcb->snd.una - 1;
        seg.ack = tcb->rcv.nxt;