On Mon, 7 Oct 2024, Jakub Jelinek wrote:
> On Mon, Oct 07, 2024 at 08:59:56AM +0200, Richard Biener wrote:
> > The forwprop added optmization looks like it would match PHI-opt better,
> > but I'm fine with leaving it in forwprop. I do wonder whether instead
> > of adding a flag adding the actual values wanted as argument to
> > .SPACESHIP would allow further optimizations (maybe also indicating
> > cases "ignored")? Are those -1, 0, 1, 2 standard mandated values
> > or implementation defined (or part of the platform ABI)?
>
> They are implementation defined, -1, 0, 1, 2 is defined by libstdc++:
> using type = signed char;
> enum class _Ord : type { equivalent = 0, less = -1, greater = 1 };
> enum class _Ncmp : type { _Unordered = 2 };
> https://eel.is/c++draft/cmp#categories.pre-1 documents them as
> enum class ord { equal = 0, equivalent = equal, less = -1, greater = 1 }; //
> exposition only
> enum class ncmp { unordered = -127 }; //
> exposition only
> and now looking at it, LLVM's libc++ takes that literally and uses
> -1, 0, 1, -127. One can't use <=> operator without including <compare>
> which provides the enums, so I think if all we care about is libstdc++,
> then just hardcoding -1, 0, 1, 2 is fine, if we want to also optimize
> libc++ when used with gcc, we could support -1, 0, 1, -127 as another
> option.
> Supporting arbitrary 4 values doesn't make sense, at least on x86 the
> only reason to do the conversion to int in an optab is a good sequence
> to turn the flag comparisons to -1, 0, 1. So, either we do nothing
> more than the patch, or add handle both 2 and -127 for unordered,
> or add support for arbitrary value for the unordered case except
> -1, 0, 1 (then -1 could mean signed int, 1 unsigned int, 0 do the jumps
> and any other value what should be returned for unordered.
I see.
Thanks for the clarification. The patch OK still holds.
Richard.