Follow @Openwall on Twitter for new release announcements and other news
[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Date: Mon, 8 Feb 2016 15:30:51 -0500
From: David Edelsohn <dje.gcc@...il.com>
To: Rich Felker <dalias@...c.org>
Cc: musl@...ts.openwall.com
Subject: Re: Re: musl libc for PPC64

On Mon, Feb 8, 2016 at 3:18 PM, Rich Felker <dalias@...c.org> wrote:
> On Mon, Feb 08, 2016 at 12:48:48PM -0500, David Edelsohn wrote:
>> On Mon, Feb 8, 2016 at 11:51 AM, Rich Felker <dalias@...c.org> wrote:
>> > On Mon, Feb 08, 2016 at 05:17:58PM +0100, Szabolcs Nagy wrote:
>> >> * David Edelsohn <dje.gcc@...il.com> [2016-02-08 09:43:08 -0500]:
>> >> > What work is necessary to enable basic musl libc support for PPC64
>> >> > Linux Little Endian?
>> >>
>> >> once the abi is clear (is long double ieee128?) the arch specific
>> >> parts of musl need to be ported for ARCH=powerpc64.
>> >
>> > IIRC one of the powerpc64 ABIs uses function descriptors rather than
>> > normal function pointers. If so that may affect a few details in the
>> > dynamic linker and may require some changes to non-arch-specific code,
>> > but since we have SH/FDPIC all the basic framework for function
>> > descriptors should be there already.
>>
>> PPC64LE Linux is little endian and does not use function descriptors.
>
> OK. I've been looking more and this is what's called the "ELFv2 ABI"
> for ppc64, I believe. Is it possible to use ELFv2 ABI with big endian
> targets? It looks like support is there on the toolchain side but I'm
> not sure if we would run into problems. The reason I'm asking is that
> there's probably also interest in older BE ppc64 systems and I think
> it makes more sense to use the same musl port/ABI for both
> endiannesses if at all possible rather than doing two separate ones.

The future direction for Linux on PPC64 is little endian.  I was
trying to simplify things because of your comments about multiple
ABIs.

The original PPC64 ABI could (and has) operated in little endian mode,
and the new PPC64 ELFv2 ABI could operate in big endian mode.  But the
entire PowerPC software ecosystem and all Linux distros are
distributed with PPC64 big endian ABI using function descriptors and
little endian ABI using ELFv2.

>> > Also to clarify what you asked about long double ABI, if ieee128
>> > (quad) is not used, the compiler needs to be built to use plain double
>> > (ieee64 double) for long double instead of using ibm double-double.
>>
>> GCC can use IEEE64 or IEEE128 for long double.
>
> OK. Then the choice of which to use depends mainly on whether there's
> current or future hardware that would do IEEE128 natively. If so we
> should probably choose an ABI that supports it even if in the
> short-term (or for the baseline ISA) it requires soft-float code to be
> linked; that's how AArch64 is doing it. But if native IEEE128 support
> is not available and not planned for future hardware, doing it as
> soft-float "just because" is probably not as good idea.

IBM has announced that the next generation of the processor will
support native IEEE128 floating point in hardware.  There will be
software emulation for the current processors.  Support is included in
the forthcoming GCC 6.

>> Is there any internal interest from the musl libc community for PPC64
>> support that IBM could sponsor with a financial bounty on
>> bountysource.com?
>
> I would suspect so.

If anyone is interested, please contact me privately.

Thanks, David

Powered by blists - more mailing lists

Confused about mailing lists and their use? Read about mailing lists on Wikipedia and check out these guidelines on proper formatting of your messages.