Re: [PATCH] drm/amdgpu: Re-enable DCN for 64-bit powerpc
From: Segher Boessenkool
Date: Mon Jul 25 2022 - 20:37:55 EST
Hi!
On Mon, Jul 25, 2022 at 03:40:40PM -0700, Guenter Roeck wrote:
> On 7/25/22 13:42, Segher Boessenkool wrote:
> >>What I'm wondering is if the compiler is getting confused between
> >>standard and long doubles when they are both the same bit length...
> >
> >The compiler emits the same code (DFmode things, double precision float)
> >in both cases, and it itself does not see any difference anymore fairly
> >early in the pipeline. Compare to int and long on most 32-bit targets,
> >both are SImode, the compiler will not see different types anymore:
> >there *are* no types, except in the compiler frontend.
> >
> >It only happens for powerpc64le things, and not for powerpc64 builds.
> >
> >It is probably a GCC problem. I don't see what forces the GCC build
> >here to use 64-bit long double either btw? Compilers build via buildall
> >have all kinds of unnecessary things disabled, but not that, not
> >directly at least.
>
> From what little documentation I can find, there appears to be
> "--with-long-double-128" and "--with-long-double-format=ieee".
> That looks like something that would need to be enabled, not disabled.
Look in the GCC toplevel configure.ac for (some of!) the actual rules
(and some more in config.gcc, and there are more at different levels).
If your target is not *-linux* you likely end up with a 64-bit long
double by default, and if it is, you do. But it depends on various
things configure can determine about your C library. buildall uses
--without-headers, but something makes GCC still use 128-bit long
double on powerpc64-linux, but it uses 64-bit on powerpc64le-linux.
Curious. I suppose things work better on Linux userland when you do
not use the spartan build flags buildall uses :-)
If you set it explicitly (--with-long-double-128) it just works.
> FWIW, depending on compiler build options such as the above for kernel
> builds seems to be a little odd to me,
Yes. It should be (and was!) possible to build the kernel with pretty
much any compiler. Usual were *-linux* compilers of course, but *-elf
also works, and for powerpc in particular any kind of biarch or not
"just works".
> and I am not sure I'd want to
> blame gcc if the kernel wants to be built with 128-bit floating point
> as default. At the very least, that should be documented somewhere,
> and if possible the kernel should refuse to build if the compiler build
> options don't meet the requirements.
It always was the rule that the kernel did not use floating point at
all. If that is changed it can no longer be built on targets that use
soft float for example (they need libgcc, which the kernel build is
allergic to for some reason). It is non-trivial to handle floating
point in the kernel itself as well of course (mostly arch stuff).
The problem here was that some objects are built with soft float and
some with hard float, incompatible ABIs that ld does not want to link
together (without further coercing).
Segher