diff options
Diffstat (limited to 'arch')
-rw-r--r-- | arch/um/drivers/net_kern.c | 15 | ||||
-rw-r--r-- | arch/um/drivers/net_user.c | 30 | ||||
-rw-r--r-- | arch/um/include/net_user.h | 19 |
3 files changed, 46 insertions, 18 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 | } | ||
diff --git a/arch/um/include/net_user.h b/arch/um/include/net_user.h index 47ef7cb49a8e..cd19defbfefc 100644 --- a/arch/um/include/net_user.h +++ b/arch/um/include/net_user.h | |||
@@ -1,4 +1,4 @@ | |||
1 | /* | 1 | /* |
2 | * Copyright (C) 2002 Jeff Dike (jdike@karaya.com) | 2 | * Copyright (C) 2002 Jeff Dike (jdike@karaya.com) |
3 | * Licensed under the GPL | 3 | * Licensed under the GPL |
4 | */ | 4 | */ |
@@ -26,8 +26,8 @@ struct net_user_info { | |||
26 | 26 | ||
27 | extern void ether_user_init(void *data, void *dev); | 27 | extern void ether_user_init(void *data, void *dev); |
28 | extern void dev_ip_addr(void *d, unsigned char *bin_buf); | 28 | extern void dev_ip_addr(void *d, unsigned char *bin_buf); |
29 | extern void iter_addresses(void *d, void (*cb)(unsigned char *, | 29 | extern void iter_addresses(void *d, void (*cb)(unsigned char *, |
30 | unsigned char *, void *), | 30 | unsigned char *, void *), |
31 | void *arg); | 31 | void *arg); |
32 | 32 | ||
33 | extern void *get_output_buffer(int *len_out); | 33 | extern void *get_output_buffer(int *len_out); |
@@ -51,15 +51,6 @@ extern char *split_if_spec(char *str, ...); | |||
51 | 51 | ||
52 | extern int dev_netmask(void *d, void *m); | 52 | extern int dev_netmask(void *d, void *m); |
53 | 53 | ||
54 | #endif | 54 | extern void random_mac(unsigned char *addr); |
55 | 55 | ||
56 | /* | 56 | #endif |
57 | * Overrides for Emacs so that we follow Linus's tabbing style. | ||
58 | * Emacs will notice this stuff at the end of the file and automatically | ||
59 | * adjust the settings for this buffer only. This must remain at the end | ||
60 | * of the file. | ||
61 | * --------------------------------------------------------------------------- | ||
62 | * Local variables: | ||
63 | * c-file-style: "linux" | ||
64 | * End: | ||
65 | */ | ||