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 --]
next prev parent 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