X-Git-Url: http://git.ozlabs.org/?p=ppp.git;a=blobdiff_plain;f=pppd%2Fmagic.c;h=9e95994953812e52dbeecd253f9bc23fbc08f26f;hp=18c00bb2f9b8bbed21f3d387405a2b357c6bd4d0;hb=aeb204dccc12e94006cada67d68a7a6783e11ab6;hpb=9398ab236f55e271a76f803abc07c8b34bf272e3 diff --git a/pppd/magic.c b/pppd/magic.c index 18c00bb..9e95994 100644 --- a/pppd/magic.c +++ b/pppd/magic.c @@ -18,53 +18,70 @@ */ #ifndef lint -static char rcsid[] = "$Id: magic.c,v 1.2 1994/09/01 00:25:19 paulus Exp $"; +static char rcsid[] = "$Id: magic.c,v 1.6 1996/04/04 03:58:41 paulus Exp $"; #endif #include +#include #include #include #include "pppd.h" #include "magic.h" -static uint32 next; /* Next value to return */ - -extern uint32 gethostid __ARGS((void)); -extern long random __ARGS((void)); -extern void srandom __ARGS((int)); - +extern long mrand48 __P((void)); +extern void srand48 __P((long)); /* * magic_init - Initialize the magic number generator. * - * Computes first magic number and seed for random number generator. * Attempts to compute a random number seed which will not repeat. - * The current method uses the current hostid and current time. + * The current method uses the current hostid, current process ID + * and current time, currently. */ -void magic_init() +void +magic_init() { - struct timeval tv; - - next = gethostid(); - if (gettimeofday(&tv, NULL)) { - perror("gettimeofday"); - exit(1); - } - next ^= (uint32) tv.tv_sec ^ (uint32) tv.tv_usec; + long seed; + struct timeval t; - srandom((int) next); + gettimeofday(&t, NULL); + seed = gethostid() ^ t.tv_sec ^ t.tv_usec ^ getpid(); + srand48(seed); } - /* * magic - Returns the next magic number. */ -uint32 magic() +u_int32_t +magic() { - uint32 m; + return (u_int32_t) mrand48(); +} - m = next; - next = (uint32) random(); - return (m); +#ifdef NO_DRAND48 +/* + * Substitute procedures for those systems which don't have + * drand48 et al. + */ + +double +drand48() +{ + return (double)random() / (double)0x7fffffffL; /* 2**31-1 */ } + +long +mrand48() +{ + return random(); +} + +void +srand48(seedval) +long seedval; +{ + srandom((int)seedval); +} + +#endif