Date: Wed, 5 Feb 2003 20:56:25 +0200 (EET) From: Narvi <narvi@haldjas.folklore.ee> To: phk@FreeBSD.ORG Cc: "Andrey A. Chernov" <ache@nagual.pp.ru>, Mark Murray <mark@grondar.org>, Doug Barton <DougB@FreeBSD.ORG>, Kris Kennaway <kris@obsecurity.org>, <current@FreeBSD.ORG> Subject: Re: rand() is broken Message-ID: <20030205205444.S43637-100000@haldjas.folklore.ee> In-Reply-To: <31532.1044211424@critter.freebsd.dk>
next in thread | previous in thread | raw e-mail | index | archive | help
On Sun, 2 Feb 2003 phk@FreeBSD.ORG wrote:
> In message <20030202183826.GA66487@nagual.pp.ru>, "Andrey A. Chernov" writes:
> >On Sun, Feb 02, 2003 at 19:32:50 +0100, phk@freebsd.org wrote:
> >>
> >> Anyway, last time we discussed this, I think we stuck with the rand()
> >> we had because we feared that people were using it's repeatable well
> >> documented sequence of random numbers in regression testing.
> >
> >As documented, it must be repeatable across the calls for same seed, that
> >is all. It not means repeatable accross platforms or across different OS
> >versions. In fact it is already not repeatable across different OS'es, so
> >regression is limited. Also, regression must not stop bugs fixing progress
> >in anycase.
>
> Our manual pages do not comprehensively list all compatibility
> concerns or concessions, waving our manpage about does not address
> the concern.
>
> As I said, I don't know how big a concern this is. But last time
> it was enough of a concern to make us keep rand() as it was.
>
man srand on another system (for what its worth) says:
The rand() function uses a multiplicative congruential
random-number generator with period 2**32 that returns suc-
cessive pseudo-random numbers in the range of 0 to RAND_MAX
(defined in <stdlib.h>).
The srand() function uses the argument seed as a seed for a
new sequence of pseudo-random numbers to be returned by sub-
sequent calls to rand(). If srand() is then called with the
same seed value, the sequence of pseudo-random numbers will
be repeated. If rand() is called before any calls to
srand() have been made, the same sequence will be generated
as when srand() is first called with a seed value of 1.
> Please surf the mail-archives to find the discussion, it contained
> a lot of good arguments from both sides, arguments which should
> be thought about before changing rand().
>
> --
> Poul-Henning Kamp | UNIX since Zilog Zeus 3.20
> phk@FreeBSD.ORG | TCP/IP since RFC 956
> FreeBSD committer | BSD since 4.3-tahoe
> Never attribute to malice what can adequately be explained by incompetence.
>
> To Unsubscribe: send mail to majordomo@FreeBSD.org
> with "unsubscribe freebsd-current" in the body of the message
>
To Unsubscribe: send mail to majordomo@FreeBSD.org
with "unsubscribe freebsd-current" in the body of the message
Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?20030205205444.S43637-100000>
