diff options
author | Jeff Dike <jdike@addtoit.com> | 2006-09-29 04:58:53 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-09-29 12:18:04 -0400 |
commit | fade5d5461b0379b27ca96faf560d855d7a0ea8b (patch) | |
tree | e12b7753db8c4dcb7f5fd187062eb5e055526228 /arch | |
parent | 3b89af765cd62c1c3ca6c81adca45084f8840e06 (diff) |
[PATCH] uml: don't roll my own random MAC generator
Use the existing random_ether_addr() instead of cooking up my own
version. Pointed out by Dave Hollis and Jason Lunz.
Signed-off-by: Jeff Dike <jdike@addtoit.com>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'arch')
-rw-r--r-- | arch/um/drivers/net_kern.c | 4 | ||||
-rw-r--r-- | arch/um/drivers/net_user.c | 29 | ||||
-rw-r--r-- | arch/um/include/net_user.h | 2 |
3 files changed, 1 insertions, 34 deletions
diff --git a/arch/um/drivers/net_kern.c b/arch/um/drivers/net_kern.c index c067abbbfd97..16aa572325c9 100644 --- a/arch/um/drivers/net_kern.c +++ b/arch/um/drivers/net_kern.c | |||
@@ -310,9 +310,7 @@ static void setup_etheraddr(char *str, unsigned char *addr) | |||
310 | return; | 310 | return; |
311 | 311 | ||
312 | random: | 312 | random: |
313 | addr[0] = 0xfe; | 313 | random_ether_addr(addr) |
314 | addr[1] = 0xfd; | ||
315 | random_mac(addr); | ||
316 | } | 314 | } |
317 | 315 | ||
318 | static DEFINE_SPINLOCK(devices_lock); | 316 | static DEFINE_SPINLOCK(devices_lock); |
diff --git a/arch/um/drivers/net_user.c b/arch/um/drivers/net_user.c index 142bcb2c7c6a..f3a3f8a29c7a 100644 --- a/arch/um/drivers/net_user.c +++ b/arch/um/drivers/net_user.c | |||
@@ -259,32 +259,3 @@ char *split_if_spec(char *str, ...) | |||
259 | va_end(ap); | 259 | va_end(ap); |
260 | return str; | 260 | return str; |
261 | } | 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 99b3cea2dcdc..19f207cd70fe 100644 --- a/arch/um/include/net_user.h +++ b/arch/um/include/net_user.h | |||
@@ -50,6 +50,4 @@ extern char *split_if_spec(char *str, ...); | |||
50 | 50 | ||
51 | extern int dev_netmask(void *d, void *m); | 51 | extern int dev_netmask(void *d, void *m); |
52 | 52 | ||
53 | extern void random_mac(unsigned char *addr); | ||
54 | |||
55 | #endif | 53 | #endif |