From owner-freebsd-hackers Wed Feb 19 9:27:31 2003 Delivered-To: freebsd-hackers@freebsd.org Received: from mx1.FreeBSD.org (mx1.freebsd.org [216.136.204.125]) by hub.freebsd.org (Postfix) with ESMTP id 3D9DE37B401 for ; Wed, 19 Feb 2003 09:27:30 -0800 (PST) Received: from kientzle.com (h-66-166-149-50.SNVACAID.covad.net [66.166.149.50]) by mx1.FreeBSD.org (Postfix) with ESMTP id 3E14843F85 for ; Wed, 19 Feb 2003 09:27:29 -0800 (PST) (envelope-from kientzle@acm.org) Received: from acm.org (ugly.x.kientzle.com [66.166.149.51]) by kientzle.com (8.11.3/8.11.3) with ESMTP id h1JHR2p60523; Wed, 19 Feb 2003 09:27:02 -0800 (PST) (envelope-from kientzle@acm.org) Message-ID: <3E53BE66.4030609@acm.org> Date: Wed, 19 Feb 2003 09:27:02 -0800 From: Tim Kientzle Reply-To: kientzle@acm.org User-Agent: Mozilla/5.0 (X11; U; FreeBSD i386; en-US; rv:0.9.6) Gecko/20011206 X-Accept-Language: en-us, en MIME-Version: 1.0 To: Dag-Erling Smorgrav Cc: phk@phk.freebsd.dk, Paul Herman , Peter Jeremy , FreeBSD Hackers Subject: Re: arc4random() range References: <86890.1045646060@critter.freebsd.dk> Content-Type: text/plain; charset=us-ascii; format=flowed Content-Transfer-Encoding: 7bit Sender: owner-freebsd-hackers@FreeBSD.ORG Precedence: bulk List-ID: List-Archive: (Web Archive) List-Help: (List Instructions) List-Subscribe: List-Unsubscribe: X-Loop: FreeBSD.ORG Dag-Erling Smorgrav wrote: > phk@phk.freebsd.dk writes: > >>Well, I'm right in principle but wrong in current practice, at >>the very least make it: >> >>#define arc4random31() (arc4random() & RAND_MAX) >> > > or rather > > #define arc4random31() (arc4random() % (RAND_MAX + 1)) > > to avoid relying on RAND_MAX being one less than a power of two. > > DES > Nope. Because RAND_MAX is one less than a power of two, you run into integer overflow problems, which PHK's version avoids. Tim Kientzle To Unsubscribe: send mail to majordomo@FreeBSD.org with "unsubscribe freebsd-hackers" in the body of the message