From: Manoj Gupta <manojgupta@google.com>
To: Ulrich Mueller <ulm@gentoo.org>
Cc: gentoo-dev@lists.gentoo.org
Subject: Re: [gentoo-dev] Re: [PATCH] toolchain-funcs: Add tc-ld-is-lld helper.
Date: Fri, 13 Sep 2019 07:38:50 -0700 [thread overview]
Message-ID: <CAH=QcsgNQOVnSXpzcmkFAX+R4vC8Fq9cRSZz+CLCMG-i7v0oaA@mail.gmail.com> (raw)
In-Reply-To: <w6ga7b8s1vr.fsf@kph.uni-mainz.de>
On Fri, Sep 13, 2019 at 7:32 AM Ulrich Mueller <ulm@gentoo.org> wrote:
>
> >>>>> On Fri, 13 Sep 2019, Manoj Gupta wrote:
>
> >> LLD is a new linker for LLVM project.
> >> Add tc-ld-is-lld helper to be able to detect it.
> >>
> >> Signed-off-by: Manoj Gupta <manojgupta@google.com>
> >> ---
> >> eclass/toolchain-funcs.eclass | 30 ++++++++++++++++++++++++++++++
> >> 1 file changed, 30 insertions(+)
> >>
> >> diff --git a/eclass/toolchain-funcs.eclass b/eclass/toolchain-funcs.eclass
> >> index 7bd90bb4e4a..e358d484417 100644
> >> --- a/eclass/toolchain-funcs.eclass
> >> +++ b/eclass/toolchain-funcs.eclass
> >> @@ -453,6 +453,36 @@ tc-ld-is-gold() {
> >> return 1
> >> }
> >>
> >> +# @FUNCTION: tc-ld-is-lld
> >> +# @USAGE: [toolchain prefix]
> >> +# @DESCRIPTION:
> >> +# Return true if the current linker is set to lld.
> >> +tc-ld-is-lld() {
> >> + local out
> >> +
> >> + # First check the linker directly.
> >> + out=$($(tc-getLD "$@") --version 2>&1)
>
> Why 2>&1 here, and not 2>/dev/null?
>
> >> + if [[ ${out} == *"LLD"* ]] ; then
> >> + return 0
> >> + fi
> >> +
> >> + # Then see if they're selecting lld via compiler flags.
> >> + # Note: We're assuming they're using LDFLAGS to hold the
> >> + # options and not CFLAGS/CXXFLAGS.
> >> + local base="${T}/test-tc-lld"
> >> + cat <<-EOF > "${base}.c"
> >> + int main() { return 0; }
> >> + EOF
> >> + out=$($(tc-getCC "$@") ${CFLAGS} ${CPPFLAGS} ${LDFLAGS} -Wl,--version "${base}.c" -o "${base}" 2>&1)
>
> Ditto.
>
> >> + rm -f "${base}"*
> >> + if [[ ${out} == *"LLD"* ]] ; then
> >> + return 0
> >> + fi
> >> +
> >> + # No lld here!
> >> + return 1
>
> The previous 6 lines could be shortened to one:
> [[ ${out} == *"LLD"* ]]
Thanks for the review. I did it this way to make this an exact copy of
tc-ld-is-gold function above it except the LLD checks.
Should I also change the tc-ld-is-gold function?
>
> >> +}
> >> +
> >> # @FUNCTION: tc-ld-disable-gold
> >> # @USAGE: [toolchain prefix]
> >> # @DESCRIPTION:
next prev parent reply other threads:[~2019-09-13 14:39 UTC|newest]
Thread overview: 8+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-09-12 11:32 [gentoo-dev] [PATCH] toolchain-funcs: Add tc-ld-is-lld helper Manoj Gupta
2019-09-13 14:11 ` [gentoo-dev] " Manoj Gupta
2019-09-13 14:32 ` Ulrich Mueller
2019-09-13 14:38 ` Manoj Gupta [this message]
2019-09-13 14:53 ` Ulrich Mueller
2019-09-13 18:46 ` Sergei Trofimovich
2019-09-13 18:44 ` Sergei Trofimovich
2019-09-13 18:47 ` Manoj Gupta
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='CAH=QcsgNQOVnSXpzcmkFAX+R4vC8Fq9cRSZz+CLCMG-i7v0oaA@mail.gmail.com' \
--to=manojgupta@google.com \
--cc=gentoo-dev@lists.gentoo.org \
--cc=ulm@gentoo.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