[PATCH] powerpc/lib/sstep: Fix count leading zeros instructions

Segher Boessenkool segher at kernel.crashing.org
Tue Oct 10 01:20:53 AEDT 2017


On Mon, Oct 09, 2017 at 01:49:26PM +0000, David Laight wrote:
> From: Sandipan Das
> > Sent: 09 October 2017 12:07
> > According to the GCC documentation, the behaviour of __builtin_clz()
> > and __builtin_clzl() is undefined if the value of the input argument
> > is zero. Without handling this special case, these builtins have been
> > used for emulating the following instructions:
> >   * Count Leading Zeros Word (cntlzw[.])
> >   * Count Leading Zeros Doubleword (cntlzd[.])
> > 
> > This fixes the emulated behaviour of these instructions by adding an
> > additional check for this special case.
> 
> Presumably the result is undefined because the underlying cpu
> instruction is used - and it's return value is implementation defined.

It is undefined because the result is undefined, and the compiler
optimises based on that.  The return value of the builtin is undefined,
not implementation defined.

The patch is correct.


Segher


More information about the Linuxppc-dev mailing list