public inbox for linux-ia64@vger.kernel.org
 help / color / mirror / Atom feed
* Re: [mpm@selenic.com: Re: buggy ia64_fls() ? (was Re: /dev/random
@ 2005-04-08 17:33 Andrew Morton
  2005-04-08 17:48 ` [mpm@selenic.com: Re: buggy ia64_fls() ? (was Re: /dev/random problem on 2.6.12-rc1)] Matt Mackall
                   ` (21 more replies)
  0 siblings, 22 replies; 23+ messages in thread
From: Andrew Morton @ 2005-04-08 17:33 UTC (permalink / raw)
  To: linux-ia64


I agree that ia64's fls() is broken.

So the random driver is presently busted on ia64?


Matt Mackall <mpm@selenic.com> wrote:
>
> Realized you're not on the cc list. This one's surprising.
> 
> ----- Forwarded message from Matt Mackall <mpm@selenic.com> -----
> 
> Date: Fri, 8 Apr 2005 09:27:46 -0700
> From: Matt Mackall <mpm@selenic.com>
> To: Simon Derr <Simon.Derr@bull.net>
> Cc: Yura Pakhuchiy <pakhuchiy@iptel.by>,
> 	Patrice Martinez <patrice.martinez@ext.bull.net>,
> 	linux-kernel@vger.kernel.org
> Subject: Re: buggy ia64_fls() ? (was Re: /dev/random problem on 2.6.12-rc1)
> 
> On Fri, Apr 08, 2005 at 02:12:04PM +0200, Simon Derr wrote:
> > I enabled the debug messages in random.c and I think I found the problem 
> > lying in the IA64 version of fls().
> 
> Good catch.
>  
> > It turns out that the generic and IA64 versions of fls() disagree:
> > 
> > (output from a small test program)
> > 
> >      x   ia64_fls(x)      generic_fls(x)
> > 
> > i=-1, t=0, ia64: -65535 et generic:0
> > i=0, t=1, ia64: 0 et generic:1
> > i=1, t=2, ia64: 1 et generic:2
> > i=2, t=4, ia64: 2 et generic:3
> > i=3, t=8, ia64: 3 et generic:4
> 
> Well PPC at least sez:
> 
> /*
>  * fls: find last (most-significant) bit set.
>  * Note fls(0) = 0, fls(1) = 1, fls(0x80000000) = 32.
>  */
> 
> And that agrees with the generic code (used by x86). So I think IA64
> is probably wrong here indeed. It's amazing that the other users of
> fls don't blow up spectacularly.
> 
> > I tried to fix it with an ia64 version that would give the same result as 
> > the generic version, but the kernel did not boot, I guess some functions 
> > rely on the ""broken"" ia64_fls() behaviour.
> > 
> > So I just changed fls() to use generic_fls() instead of ia64_fls().
> 
> If the "fixed" version didn't boot, how did the "alternate fixed"
> version boot?
> 
> -- 
> Mathematics is the supreme nostalgia of our time.
> 
> ----- End forwarded message -----
> 
> -- 
> Mathematics is the supreme nostalgia of our time.

^ permalink raw reply	[flat|nested] 23+ messages in thread

end of thread, other threads:[~2005-04-22  3:50 UTC | newest]

Thread overview: 23+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2005-04-08 17:33 [mpm@selenic.com: Re: buggy ia64_fls() ? (was Re: /dev/random Andrew Morton
2005-04-08 17:48 ` [mpm@selenic.com: Re: buggy ia64_fls() ? (was Re: /dev/random problem on 2.6.12-rc1)] Matt Mackall
2005-04-08 18:02 ` [mpm@selenic.com: Re: buggy ia64_fls() ? (was Re: /dev/random Andrew Morton
2005-04-08 19:05 ` David Mosberger
2005-04-08 20:46 ` [mpm@selenic.com: Re: buggy ia64_fls() ? (was Re: /dev/random problem on 2.6.12-rc1)] David Mosberger
2005-04-08 22:49 ` Matt Mackall
2005-04-08 23:01 ` David Mosberger
2005-04-08 23:02 ` Luck, Tony
2005-04-08 23:15 ` Matt Mackall
2005-04-08 23:17 ` Matt Mackall
2005-04-08 23:19 ` David Mosberger
2005-04-08 23:49 ` David Mosberger
2005-04-09  0:21 ` [mpm@selenic.com: Re: buggy ia64_fls() ? (was Re: /dev/random David Mosberger
2005-04-09  0:28 ` [mpm@selenic.com: Re: buggy ia64_fls() ? (was Re: /dev/random problem on 2.6.12-rc1)] Matt Mackall
2005-04-09  0:34 ` [mpm@selenic.com: Re: buggy ia64_fls() ? (was Re: /dev/random Arthur Kepner
2005-04-09  0:46 ` [mpm@selenic.com: Re: buggy ia64_fls() ? (was Re: /dev/random problem on 2.6.12-rc1)] Grant Grundler
2005-04-09  3:00 ` Grant Grundler
2005-04-09  4:05 ` David Mosberger
2005-04-09  4:32 ` David Mosberger
2005-04-09  5:09 ` [mpm@selenic.com: Re: buggy ia64_fls() ? (was Re: /dev/random David Mosberger
2005-04-09  5:16 ` [mpm@selenic.com: Re: buggy ia64_fls() ? (was Re: /dev/random problem on 2.6.12-rc1)] Grant Grundler
2005-04-09  6:00 ` David Mosberger
2005-04-22  3:50 ` [mpm@selenic.com: Re: buggy ia64_fls() ? (was Re: /dev/random Andrew Morton

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox