public inbox for gentoo-dev@lists.gentoo.org
 help / color / mirror / Atom feed
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:


  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