[RFC][PATCH] powerpc/64be: use ELFv2 ABI for big endian kernels

Segher Boessenkool segher at kernel.crashing.org
Thu Nov 24 23:27:13 AEDT 2016


On Thu, Nov 24, 2016 at 04:37:50PM +1100, Oliver O'Halloran wrote:
> On Thu, Nov 24, 2016 at 1:38 AM, Segher Boessenkool
> <segher at kernel.crashing.org> wrote:
> > On Thu, Nov 24, 2016 at 12:08:40AM +1100, Nicholas Piggin wrote:
> >> Question, are there any fundamental reasons we shouldn't use the ELFv2
> >> ABI to build big endian kernels if the compiler supports it?
> >
> > No one uses ELFv2 for BE in production, and it isn't thoroughly tested
> > at all, not even regularly tested.  "Not supported", as far as GCC is
> > concerned (or any of the distros AFAIK).
> 
> Is this actually unsupported by gcc?

It may or may not work.  We of course try to keep it working, or make
it work if it doesn't now.  But it isn't regularly tested, and it isn't
a target that is considered for the release criteria (see
https://gcc.gnu.org/gcc-7/criteria.html -- powerpc64{,le}-linux, i.e.
ABIv1 for BE, ABIv2 for LE).

It is supported as in, "it is a feature a user can enable".  It is
unsupported as in, "we do not know if it works".

> The ppc64 musl libc port is ABI v2 only so they use it on BE too.

Interesting!  I've never seen a PowerPC musl in the wild though.

> Buildroot forces ABI v2 to be used
> for all of userspace when musl is selected as the libc for this reason
> so it's not completely used in the wild. It's still pretty niche
> though...

The point remains that the kernel will be the only non-niche user of
ABIv2 on BE if they choose to use it.  I don't expect many problems,
but it is uncharted territory.  YMMV, etc.

We (GCC) of course will be happy if you (Linux) wants to be guinea pig
for this.  But don't say we didn't warn you ;-)


Segher


More information about the Linuxppc-dev mailing list