From: Albert ARIBAUD <albert.u.boot@aribaud.net>
To: u-boot@lists.denx.de
Subject: [U-Boot] [PATCH 5/5] lib: Enable private libgcc by default
Date: Fri, 25 Mar 2016 07:37:25 +0100 [thread overview]
Message-ID: <20160325073725.0a7d3b03@lilith> (raw)
In-Reply-To: <20160325004942.GX23166@bill-the-cat>
Hello Tom,
On Thu, 24 Mar 2016 20:49:42 -0400, Tom Rini <trini@konsulko.com> wrote:
> On Thu, Mar 24, 2016 at 08:50:03AM +0100, Albert ARIBAUD wrote:
> > Hello Tom,
> >
> > On Wed, 23 Mar 2016 17:36:17 -0400, Tom Rini <trini@konsulko.com> wrote:
> > > On Wed, Mar 23, 2016 at 06:08:45PM +0100, Albert ARIBAUD wrote:
> > > > Hello Tom,
> > > >
> > > > On Wed, 23 Mar 2016 09:22:38 -0400, Tom Rini <trini@konsulko.com> wrote:
> > > > > On Wed, Mar 23, 2016 at 01:53:35PM +0100, Albert ARIBAUD wrote:
> > > > > > Hello Marek,
> > > > > >
> > > > > > On Sun, 20 Mar 2016 17:15:34 +0100, Marek Vasut <marex@denx.de> wrote:
> > > > > > > This patch decouples U-Boot binary from the toolchain on systems where
> > > > > > > private libgcc is available. Instead of pulling in functions provided
> > > > > > > by the libgcc from the toolchain, U-Boot will use it's own set of libgcc
> > > > > > > functions. These functions are usually imported from Linux kernel, which
> > > > > > > also uses it's own libgcc functions instead of the ones provided by the
> > > > > > > toolchain.
> > > > > > >
> > > > > > > This patch solves a rather common problem. The toolchain can usually
> > > > > > > generate code for many variants of target architecture and often even
> > > > > > > different endianness. The libgcc on the other hand is usually compiled
> > > > > > > for one particular configuration and the functions provided by it may
> > > > > > > or may not be suited for use in U-Boot. This can manifest in two ways,
> > > > > > > either the U-Boot fails to compile altogether and linker will complain
> > > > > > > or, in the much worse case, the resulting U-Boot will build, but will
> > > > > > > misbehave in very subtle and hard to debug ways.
> > > > > >
> > > > > > I don't think using private libgcc by default is a good idea.
> > > > > >
> > > > > > U-Boot's private libgcc is not a feature of U-Boot, but a fix for some
> > > > > > cases where a target cannot properly link with the libgcc provided by
> > > > > > the (specific release of the) GCC toolchain in use. Using private libgcc
> > > > > > to other cases than these does not fix or improve anything; those
> > > > > > other cases were working and did not require any fix in this respect.
> > > > >
> > > > > This isn't true, exactly. If using clang for example everyone needs to
> > > > > enable this code. We're also using -fno-builtin -ffreestanding which
> > > > > should limit the amount of interference from the toolchain. And we get
> > > > > that.
> > > >
> > > > You mean clang does not produce self-sustained binaries?
> > >
> > > clang does not provide "libgcc", so there's no -lgcc providing all of
> > > the functions that are (today) in:
> > > _ashldi3.S _ashrdi3.S _divsi3.S _lshrdi3.S _modsi3.S _udivsi3.S
> > > _umodsi3.S div0.S _uldivmod.S
> > > which aside from __modsi3 and __umodsi3 are all __aeabi_xxx
> >
> > (ok, that explains what you mean by AEABI functions -- those are
> > actually not functions defined by the AEABI, but functions that the GCC
> > folks prefixed with __aeabi.)
>
> No. For reference,
> http://infocenter.arm.com/help/topic/com.arm.doc.ihi0043d/IHI0043D_rtabi.pdf
> and chapter 4 is all about the support library. We are entirely in our
> right to do either of (a) use the compiler-provided library (b) provide
> our own implementation of what we need. The kernel opts for (b) and I
> would like us to follow that as well, consistently, rather than ad-hoc.
Kk, so you did not mean "whatever happens to be aeabi in libgcc, you
meant AEABI itself.
But then what you seek is is not a custom libgcc; it is controlled
AEABI support library.
I'm fine with that, since, contrary to libgcc, it has an external,
stable, definition.
But that is *unrelated* to libgcc, which is not described nor intended
as "AEABI support" -- libgcc exists in all architectures, even non-ARM,
and provides AEABI in the ARM case by accident -- or, more to the point,
by sub-optimal design IMO.
The right design for solving the problems raised by Marek is therefore
to rename U-Boot's "custom libgcc" as U-Boot's "AEABI support library"
and link U-Boot *first* against this AEABI support library, *then*
against GCC's libgcc.
Essentially, this 'hijacks' whatever is AEABI from libgcc while not
interfering with what is not AEABI (i.e. what is purely GCC/libgcc
internals).
That way,
0) U-Boot gets the stable and controlled AEABI support you want;
1) GCC keeps its somewhat stable but uncontrolled internal "generated
code / libgcc" interface;
2) U-Boot won't interfere with non-aeabi-related stuff in GCC+libgcc,
i.e. whatever ibgcc-related but non-AEABI-related changes occur in
a GCC release, we won't break them changes in non-AEABI ;
3) GCC+libgcc won't interfere with AEABI any more, i.e. whatever AEABI
breakages happen in a given GCC toolchain will not break U-Boot.
4) This design works with any ARM toolchain -- which is kind of evident
since it separates generic ARM EABI support from specific toolchain
support.
Comments welcome.
> --
> Tom
Amicalement,
--
Albert.
next prev parent reply other threads:[~2016-03-25 6:37 UTC|newest]
Thread overview: 40+ messages / expand[flat|nested] mbox.gz Atom feed top
2016-03-20 16:15 [U-Boot] [PATCH 1/5] arm: include: Import unified.h from Linux kernel Marek Vasut
2016-03-20 16:15 ` [U-Boot] [PATCH 2/5] arm: lib: Drop underscore from private libgcc filenames Marek Vasut
2016-04-09 18:34 ` Simon Glass
2016-03-20 16:15 ` [U-Boot] [PATCH 3/5] arm: lib: Sync libgcc shift operations Marek Vasut
2016-04-09 18:34 ` Simon Glass
2016-03-20 16:15 ` [U-Boot] [PATCH 4/5] arm: lib: Sync libgcc 32b division/modulo operations Marek Vasut
2016-04-09 18:34 ` Simon Glass
2016-03-20 16:15 ` [U-Boot] [PATCH 5/5] lib: Enable private libgcc by default Marek Vasut
2016-03-23 12:53 ` Albert ARIBAUD
2016-03-23 13:22 ` Tom Rini
2016-03-23 17:08 ` Albert ARIBAUD
2016-03-23 21:36 ` Tom Rini
2016-03-23 23:02 ` Sergey Kubushyn
2016-03-23 23:08 ` Tom Rini
2016-03-23 23:24 ` Sergey Kubushyn
2016-03-23 23:24 ` Marek Vasut
2016-03-23 23:47 ` Sergey Kubushyn
2016-03-23 23:49 ` Marek Vasut
2016-03-23 23:54 ` Sergey Kubushyn
2016-03-24 0:10 ` [U-Boot] [PATCH] arm: lib: Import __do_div64 from Linux Marek Vasut
2016-03-24 0:11 ` [U-Boot] [PATCH 5/5] lib: Enable private libgcc by default Marek Vasut
2016-03-24 2:28 ` Sergey Kubushyn
2016-03-24 18:18 ` Sergey Kubushyn
2016-03-24 18:43 ` Sergey Kubushyn
2016-03-24 19:04 ` Marek Vasut
2016-03-24 19:08 ` Sergey Kubushyn
2016-03-24 19:14 ` Marek Vasut
2016-03-24 22:25 ` Sergey Kubushyn
2016-03-24 0:13 ` Tom Rini
2016-03-24 0:36 ` Marek Vasut
2016-03-24 7:50 ` Albert ARIBAUD
2016-03-25 0:49 ` Tom Rini
2016-03-25 1:37 ` Sergey Kubushyn
2016-03-25 6:41 ` Albert ARIBAUD
2016-03-25 6:37 ` Albert ARIBAUD [this message]
2016-03-25 6:43 ` Albert ARIBAUD
2016-03-27 13:36 ` Tom Rini
2016-03-29 9:18 ` Albert ARIBAUD
2016-04-09 18:34 ` [U-Boot] [PATCH 1/5] arm: include: Import unified.h from Linux kernel Simon Glass
2016-04-28 0:28 ` Marek Vasut
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20160325073725.0a7d3b03@lilith \
--to=albert.u.boot@aribaud.net \
--cc=u-boot@lists.denx.de \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.