public inbox for gentoo-dev@lists.gentoo.org
 help / color / mirror / Atom feed
From: Ulrich Mueller <ulm@gentoo.org>
To: Manoj Gupta <manojgupta@google.com>
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 16:32:24 +0200	[thread overview]
Message-ID: <w6ga7b8s1vr.fsf@kph.uni-mainz.de> (raw)
In-Reply-To: <CAH=QcsjVD67uipu8HDcOYo-O6CW45YsFXiZ3dHrSfbk5ov3YYg@mail.gmail.com> (Manoj Gupta's message of "Fri, 13 Sep 2019 07:11:03 -0700")

[-- Attachment #1: Type: text/plain, Size: 1819 bytes --]

>>>>> 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"* ]]

>> +}
>> +
>>  # @FUNCTION: tc-ld-disable-gold
>>  # @USAGE: [toolchain prefix]
>>  # @DESCRIPTION:

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 487 bytes --]

  reply	other threads:[~2019-09-13 14:32 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 [this message]
2019-09-13 14:38     ` Manoj Gupta
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=w6ga7b8s1vr.fsf@kph.uni-mainz.de \
    --to=ulm@gentoo.org \
    --cc=gentoo-dev@lists.gentoo.org \
    --cc=manojgupta@google.com \
    /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