diff options
Diffstat (limited to 'arch/um/drivers')
-rw-r--r-- | arch/um/drivers/net_kern.c | 15 | ||||
-rw-r--r-- | arch/um/drivers/net_user.c | 30 |
2 files changed, 41 insertions, 4 deletions
diff --git a/arch/um/drivers/net_kern.c b/arch/um/drivers/net_kern.c index bd1178fa4e9a..684a1ef93c87 100644 --- a/arch/um/drivers/net_kern.c +++ b/arch/um/drivers/net_kern.c | |||
@@ -753,7 +753,8 @@ int setup_etheraddr(char *str, unsigned char *addr) | |||
753 | int i; | 753 | int i; |
754 | 754 | ||
755 | if(str == NULL) | 755 | if(str == NULL) |
756 | return(0); | 756 | goto random; |
757 | |||
757 | for(i=0;i<6;i++){ | 758 | for(i=0;i<6;i++){ |
758 | addr[i] = simple_strtoul(str, &end, 16); | 759 | addr[i] = simple_strtoul(str, &end, 16); |
759 | if((end == str) || | 760 | if((end == str) || |
@@ -761,7 +762,7 @@ int setup_etheraddr(char *str, unsigned char *addr) | |||
761 | printk(KERN_ERR | 762 | printk(KERN_ERR |
762 | "setup_etheraddr: failed to parse '%s' " | 763 | "setup_etheraddr: failed to parse '%s' " |
763 | "as an ethernet address\n", str); | 764 | "as an ethernet address\n", str); |
764 | return(0); | 765 | goto random; |
765 | } | 766 | } |
766 | str = end + 1; | 767 | str = end + 1; |
767 | } | 768 | } |
@@ -769,9 +770,15 @@ int setup_etheraddr(char *str, unsigned char *addr) | |||
769 | printk(KERN_ERR | 770 | printk(KERN_ERR |
770 | "Attempt to assign a broadcast ethernet address to a " | 771 | "Attempt to assign a broadcast ethernet address to a " |
771 | "device disallowed\n"); | 772 | "device disallowed\n"); |
772 | return(0); | 773 | goto random; |
773 | } | 774 | } |
774 | return(1); | 775 | return 1; |
776 | |||
777 | random: | ||
778 | addr[0] = 0xfe; | ||
779 | addr[1] = 0xfd; | ||
780 | random_mac(addr); | ||
781 | return 1; | ||
775 | } | 782 | } |
776 | 783 | ||
777 | void dev_ip_addr(void *d, unsigned char *bin_buf) | 784 | void dev_ip_addr(void *d, unsigned char *bin_buf) |
diff --git a/arch/um/drivers/net_user.c b/arch/um/drivers/net_user.c index 107c5e43fa00..142bcb2c7c6a 100644 --- a/arch/um/drivers/net_user.c +++ b/arch/um/drivers/net_user.c | |||
@@ -12,6 +12,7 @@ | |||
12 | #include <string.h> | 12 | #include <string.h> |
13 | #include <sys/socket.h> | 13 | #include <sys/socket.h> |
14 | #include <sys/wait.h> | 14 | #include <sys/wait.h> |
15 | #include <sys/time.h> | ||
15 | #include "user.h" | 16 | #include "user.h" |
16 | #include "user_util.h" | 17 | #include "user_util.h" |
17 | #include "kern_util.h" | 18 | #include "kern_util.h" |
@@ -258,3 +259,32 @@ char *split_if_spec(char *str, ...) | |||
258 | va_end(ap); | 259 | va_end(ap); |
259 | return str; | 260 | return str; |
260 | } | 261 | } |
262 | |||
263 | void random_mac(unsigned char *addr) | ||
264 | { | ||
265 | struct timeval tv; | ||
266 | long n; | ||
267 | unsigned int seed; | ||
268 | |||
269 | gettimeofday(&tv, NULL); | ||
270 | |||
271 | /* Assume that 20 bits of microseconds and 12 bits of the pid are | ||
272 | * reasonably unpredictable. | ||
273 | */ | ||
274 | seed = tv.tv_usec | (os_getpid() << 20); | ||
275 | srandom(seed); | ||
276 | |||
277 | /* Don't care about endianness here - switching endianness | ||
278 | * just rearranges what are hopefully random numbers. | ||
279 | * | ||
280 | * Assume that RAND_MAX > 65536, so random is called twice and | ||
281 | * we use 16 bits of the result. | ||
282 | */ | ||
283 | n = random(); | ||
284 | addr[2] = (n >> 8) & 255; | ||
285 | addr[3] = n % 255; | ||
286 | |||
287 | n = random(); | ||
288 | addr[4] = (n >> 8) & 255; | ||
289 | addr[5] = n % 255; | ||
290 | } | ||