net: Move MAC-seeded rand out of bootp.c
authorJoe Hershberger <joe.hershberger@ni.com>
Wed, 23 May 2012 07:57:58 +0000 (07:57 +0000)
committerJoe Hershberger <joe.hershberger@ni.com>
Wed, 23 May 2012 19:19:22 +0000 (14:19 -0500)
Make the MAC-seeded random number generator available to /net in
general.  MAC-seeded rand will be needed by link-local as well, so
give it an interface.

Signed-off-by: Joe Hershberger <joe.hershberger@ni.com>
Acked-by: Simon Glass <sjg@chromium.org>
net/Makefile
net/bootp.c
net/bootp.h
net/net_rand.c [new file with mode: 0644]
net/net_rand.h [new file with mode: 0644]

index 0544f6bacd02c4e32138c6042637ff18c88698a2..5901046eea51f5730356419d6e6f98fcbea4d18f 100644 (file)
@@ -31,6 +31,7 @@ COBJS-$(CONFIG_CMD_NET)  += bootp.o
 COBJS-$(CONFIG_CMD_DNS)  += dns.o
 COBJS-$(CONFIG_CMD_NET)  += eth.o
 COBJS-$(CONFIG_CMD_NET)  += net.o
+COBJS-$(CONFIG_BOOTP_RANDOM_DELAY) += net_rand.o
 COBJS-$(CONFIG_CMD_NFS)  += nfs.o
 COBJS-$(CONFIG_CMD_RARP) += rarp.o
 COBJS-$(CONFIG_CMD_SNTP) += sntp.o
index d0a7da248e4e9c57251548bbafb82b5568384698..0185e5667c18df078584b4c13a8c317dfd350209 100644 (file)
@@ -12,6 +12,7 @@
 #include <command.h>
 #include <net.h>
 #include "bootp.h"
+#include "net_rand.h"
 #include "tftp.h"
 #include "nfs.h"
 #ifdef CONFIG_STATUS_LED
@@ -37,9 +38,6 @@
 
 ulong          BootpID;
 int            BootpTry;
-#ifdef CONFIG_BOOTP_RANDOM_DELAY
-ulong          seed1, seed2;
-#endif
 
 #if defined(CONFIG_CMD_DHCP)
 dhcp_state_t dhcp_state = INIT;
@@ -584,6 +582,9 @@ BootpRequest(void)
        uchar *pkt, *iphdr;
        struct Bootp_t *bp;
        int ext_len, pktlen, iplen;
+#ifdef CONFIG_BOOTP_RANDOM_DELAY
+       ulong i, rand_ms;
+#endif
 
        bootstage_mark_name(BOOTSTAGE_ID_BOOTP_START, "bootp_start");
 #if defined(CONFIG_CMD_DHCP)
@@ -591,60 +592,16 @@ BootpRequest(void)
 #endif
 
 #ifdef CONFIG_BOOTP_RANDOM_DELAY               /* Random BOOTP delay */
-       unsigned char bi_enetaddr[6];
-       int   reg;
-       ulong tst1, tst2, sum, m_mask, m_value = 0;
-
-       if (BootpTry == 0) {
-               /* get our mac */
-               eth_getenv_enetaddr("ethaddr", bi_enetaddr);
-
-               debug("BootpRequest => Our Mac: ");
-               for (reg = 0; reg < 6; reg++)
-                       debug("%x%c", bi_enetaddr[reg], reg == 5 ? '\n' : ':');
-
-               /* Mac-Manipulation 2 get seed1 */
-               tst1 = 0;
-               tst2 = 0;
-               for (reg = 2; reg < 6; reg++) {
-                       tst1 = tst1 << 8;
-                       tst1 = tst1 | bi_enetaddr[reg];
-               }
-               for (reg = 0; reg < 2; reg++) {
-                       tst2 = tst2 | bi_enetaddr[reg];
-                       tst2 = tst2 << 8;
-               }
+       if (BootpTry == 0)
+               srand_mac();
 
-               seed1 = tst1^tst2;
-
-               /* Mirror seed1*/
-               m_mask = 0x1;
-               for (reg = 1; reg <= 32; reg++) {
-                       m_value |= (m_mask & seed1);
-                       seed1 = seed1 >> 1;
-                       m_value = m_value << 1;
-               }
-               seed1 = m_value;
-               seed2 = 0xB78D0945;
-       }
-
-       /* Random Number Generator */
-       for (reg = 0; reg <= 0; reg++) {
-               sum = seed1 + seed2;
-               if (sum < seed1 || sum < seed2)
-                       sum++;
-               seed2 = seed1;
-               seed1 = sum;
-
-               if (BootpTry <= 2) {    /* Start with max 1024 * 1ms */
-                       sum = sum >> (22-BootpTry);
-               } else {        /*After 3rd BOOTP request max 8192 * 1ms */
-                       sum = sum >> 19;
-               }
-       }
+       if (BootpTry <= 2)      /* Start with max 1024 * 1ms */
+               rand_ms = rand() >> (22 - BootpTry);
+       else            /* After 3rd BOOTP request max 8192 * 1ms */
+               rand_ms = rand() >> 19;
 
-       printf("Random delay: %ld ms...\n", sum);
-       for (reg = 0; reg < sum; reg++)
+       printf("Random delay: %ld ms...\n", rand_ms);
+       for (i = 0; i < rand_ms; i++)
                udelay(1000); /*Wait 1ms*/
 
 #endif /* CONFIG_BOOTP_RANDOM_DELAY */
index ce7373454eedd9ec1f82bb3e0586d38a8e90a4e2..bf4e8756a16e0814daf9e401b5dbb0dfc7da2a92 100644 (file)
@@ -63,9 +63,6 @@ struct Bootp_t {
 extern ulong   BootpID;                /* ID of cur BOOTP request      */
 extern char    BootFile[128];          /* Boot file name               */
 extern int     BootpTry;
-#ifdef CONFIG_BOOTP_RANDOM_DELAY
-extern ulong   seed1, seed2;           /* seed for random BOOTP delay  */
-#endif
 
 
 /* Send a BOOTP request */
diff --git a/net/net_rand.c b/net/net_rand.c
new file mode 100644 (file)
index 0000000..5387aba
--- /dev/null
@@ -0,0 +1,68 @@
+/*
+ *     Based on LiMon - BOOTP.
+ *
+ *     Copyright 1994, 1995, 2000 Neil Russell.
+ *     (See License)
+ *     Copyright 2000 Roland Borde
+ *     Copyright 2000 Paolo Scaffardi
+ *     Copyright 2000-2004 Wolfgang Denk, wd@denx.de
+ */
+
+#include <common.h>
+#include <net.h>
+#include "net_rand.h"
+
+static ulong seed1, seed2;
+
+void srand_mac(void)
+{
+       ulong tst1, tst2, m_mask;
+       ulong m_value = 0;
+       int reg;
+       unsigned char bi_enetaddr[6];
+
+       /* get our mac */
+       eth_getenv_enetaddr("ethaddr", bi_enetaddr);
+
+       debug("BootpRequest => Our Mac: ");
+       for (reg = 0; reg < 6; reg++)
+               debug("%x%c", bi_enetaddr[reg], reg == 5 ? '\n' : ':');
+
+       /* Mac-Manipulation 2 get seed1 */
+       tst1 = 0;
+       tst2 = 0;
+       for (reg = 2; reg < 6; reg++) {
+               tst1 = tst1 << 8;
+               tst1 = tst1 | bi_enetaddr[reg];
+       }
+       for (reg = 0; reg < 2; reg++) {
+               tst2 = tst2 | bi_enetaddr[reg];
+               tst2 = tst2 << 8;
+       }
+
+       seed1 = tst1^tst2;
+
+       /* Mirror seed1*/
+       m_mask = 0x1;
+       for (reg = 1; reg <= 32; reg++) {
+               m_value |= (m_mask & seed1);
+               seed1 = seed1 >> 1;
+               m_value = m_value << 1;
+       }
+       seed1 = m_value;
+       seed2 = 0xb78d0945;
+}
+
+unsigned long rand(void)
+{
+       ulong sum;
+
+       /* Random Number Generator */
+       sum = seed1 + seed2;
+       if (sum < seed1 || sum < seed2)
+               sum++;
+       seed2 = seed1;
+       seed1 = sum;
+
+       return sum;
+}
diff --git a/net/net_rand.h b/net/net_rand.h
new file mode 100644 (file)
index 0000000..c98db64
--- /dev/null
@@ -0,0 +1,26 @@
+/*
+ *     Copied from LiMon - BOOTP.
+ *
+ *     Copyright 1994, 1995, 2000 Neil Russell.
+ *     (See License)
+ *     Copyright 2000 Paolo Scaffardi
+ */
+
+#ifndef __NET_RAND_H__
+#define __NET_RAND_H__
+
+#define RAND_MAX 0xffffffff
+
+/*
+ * Seed the random number generator using the eth0 MAC address
+ */
+void srand_mac(void);
+
+/*
+ * Get a random number (after seeding with MAC address)
+ *
+ * @return random number
+ */
+unsigned long rand(void);
+
+#endif /* __NET_RAND_H__ */