public inbox for crossgcc@sourceware.org
 help / color / mirror / Atom feed
From: Alexey Neyman <stilor@att.net>
To: crossgcc@sourceware.org
Subject: Re: binutils executables capture paths from build machine
Date: Sat, 06 Jan 2018 19:58:00 -0000	[thread overview]
Message-ID: <df30423c-03a9-af66-5a64-7fc2f6c7031e@att.net> (raw)
In-Reply-To: <20180106192755.GA3536@femur>

On 01/06/2018 11:27 AM, Steven Taschuk wrote:
> Hi!  I'm using crosstool-ng 1.23.0 to make a cross-native toolchain,
> and am a bit confused about the configuration and install of the
> binutils executables.
>
> I've understood correctly, the bash function do_binutils_for_host
> configures binutils with --prefix=${CT_PREFIX_DIR} and installs the
> executables with make install.  This procedure results in paths from
> the build machine being embedded in the binaries, in at least two
> places: the use of BINDIR at binutils-2.28/bfd/plugin.c:337; and
> the various uses of DEBUGDIR in binutils-2.28/bfd/dwarf2.c (where
> DEBUGDIR=${libdir}/debug; see binutils-2.28/bfd/configure.ac:108).

It is not just that. Also, NLS code embeds some build-time paths into 
the code, etc. The problem is that we don't know where the toolchain 
will be located and many configure scripts "automagically" find 
headers/libraries based on the value of $prefix. It may be possible to 
work this around by adding separate --with-foo=PATH options to each an 
every component's configure invocation. But this would be quite time 
consuming and hard to maintain (as the list of such options is likely to 
change from release to release).

So strictly speaking, the toolchain is only guaranteed to work if it is 
later installed at the exact location of CT_PREFIX_DIR. In practice, it 
seems to work fine even if it is relocated (but I haven't tested 
features like LTO with "relocated" toolchain).

For Canadian, the build-to-target cross toolchain is installed in a 
separate location inside a temporary directory; CT_PREFIX_DIR is used as 
the host toolchain (and should, therefore, match the path where the 
toolchain will be placed on the host - but again, in practice it doesn't 
seem to matter much).

Regards,
Alexey.

>
> I would have expected that, for a cross-native (or, for that matter,
> Canadian) build, binutils would be configured with --prefix=/usr or
> something, then installed with make DESTDIR=${CT_SYSROOT_DIR} install,
> for later transfer to the host.  That's what do_binutils_for_target
> does, but it seems to build and install only libiberty and libbfd,
> not the executables.
>
> For builds with build!=host, how should binutils executables be built?
>
> (Context: I'm developing a small reproducible and self-reproducing
> Linux distribution, which requires making a reproducible cross-native
> toolchain.  I also think there are some similar issues in the gcc
> executables, but haven't tracked those down yet.)
>

  reply	other threads:[~2018-01-06 19:58 UTC|newest]

Thread overview: 3+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2018-01-06 19:25 Steven Taschuk
2018-01-06 19:58 ` Alexey Neyman [this message]
2018-01-07 17:23   ` Steven Taschuk

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=df30423c-03a9-af66-5a64-7fc2f6c7031e@att.net \
    --to=stilor@att.net \
    --cc=crossgcc@sourceware.org \
    /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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).