diff options
-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 |