mailing list of musl libc
 help / color / mirror / code / Atom feed
From: Jens Gustedt <jens.gustedt@inria.fr>
To: musl@lists.openwall.com
Cc: Nadav Har'El <nyh@cloudius-systems.com>
Subject: Re: Re: drand48() gives wrong sequence?
Date: Sun, 21 Sep 2014 16:23:51 +0200	[thread overview]
Message-ID: <1411309431.4884.187.camel@eris.loria.fr> (raw)
In-Reply-To: <1411307823.4884.185.camel@eris.loria.fr>

[-- Attachment #1: Type: text/plain, Size: 1444 bytes --]

Am Sonntag, den 21.09.2014, 15:57 +0200 schrieb Jens Gustedt:
> Am Sonntag, den 21.09.2014, 15:45 +0200 schrieb Jens Gustedt:
> > Am Sonntag, den 21.09.2014, 14:27 +0100 schrieb Justin Cormack:
> > > Hmm, just checked on a non-OSv Musl system and get the same result as
> > > you. I also checked on NetBSD and FreeBSD and they give the same
> > > result as glibc, so I think there must be a Musl bug.
> > 
> > In __rand48_step there is this line
> > 
> > 	x = xi[0] | xi[1]<<16 | xi[2]+0ULL<<32;
> > 
> > on arch with 16bit int this would be UB, no? Do we have such archs,
> > still?
> 
> Thinking of it, it is UB even on platforms with 32bit if the high
> order bit in the unsigned short is set. We then have
> 
> unsigned short --> int --> shifted value inside int --> unsigned long
> 
> So we better shouldn't do that in any case.

Changing the code as I indicated early (adding these "casts") seems to
fix the problem for me.

In fact the problem didn't occur directly with your initial seed, but
simply with the default value of the multiplicator "A", which has bit
16 set.

I prepare a patch.

Jens


-- 
:: INRIA Nancy Grand Est ::: AlGorille ::: ICube/ICPS :::
:: ::::::::::::::: office Strasbourg : +33 368854536   ::
:: :::::::::::::::::::::: gsm France : +33 651400183   ::
:: ::::::::::::::: gsm international : +49 15737185122 ::
:: http://icube-icps.unistra.fr/index.php/Jens_Gustedt ::



[-- Attachment #2: This is a digitally signed message part --]
[-- Type: application/pgp-signature, Size: 198 bytes --]

  reply	other threads:[~2014-09-21 14:23 UTC|newest]

Thread overview: 7+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2014-09-21 11:45 Nadav Har'El
2014-09-21 12:02 ` Jens Gustedt
     [not found] ` <CANEVyjv9wwEBibFjqV7XTLzBU2BLvpVPzvxig7ArGceOfpzY7w-JsoAwUIsXosN+BqQ9rBEUg@public.gmane.org>
2014-09-21 13:27   ` Justin Cormack
2014-09-21 13:45     ` Jens Gustedt
2014-09-21 13:57       ` Jens Gustedt
2014-09-21 14:23         ` Jens Gustedt [this message]
2014-09-21 12:20 Nadav Har'El
2014-09-21 12:40 ` Jens Gustedt

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=1411309431.4884.187.camel@eris.loria.fr \
    --to=jens.gustedt@inria.fr \
    --cc=musl@lists.openwall.com \
    --cc=nyh@cloudius-systems.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://git.vuxu.org/mirror/musl/

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).