From: "Martin Liška" <mliska@suse.cz>
To: Daniel Kiss <Daniel.Kiss@arm.com>, "gcc@gcc.gnu.org" <gcc@gcc.gnu.org>
Cc: Pavel Iliin <Pavel.Iliin@arm.com>
Subject: Re: [RFC] Function Multi Versioning on Arm
Date: Tue, 19 Jul 2022 12:01:09 +0200 [thread overview]
Message-ID: <c4afc2d1-2e21-efb0-cfed-eddd7c361289@suse.cz> (raw)
In-Reply-To: <45073915-9D33-4097-9CFD-FFBCB9CE1A44@arm.com>
On 7/18/22 12:36, Daniel Kiss via Gcc wrote:
> Hello,
>
> We are going to add Function Multiversioning [1] support to Arm architectures.
> The specification is made public as beta[2] to ensure toolchain that follows Arm
> C Language Extension will implement it in the same way.
>
> A few tweaks considered to make the developers' life easier.
> Since the `target` attribute is used widely on Arm, we would like to introduce a
> new attribute `target_version` to avoid confusion and possible deployment
> problems. The `target_clones` attribute will be supported too. Also the “default”
> version to be made optional.
>
> We are looking for feedback on the specification (reply, github works too).
>
> Thanks so much,
> Daniel
>
> [1] https://gcc.gnu.org/onlinedocs/gcc/Function-Multiversioning.html
> [2] https://github.com/ARM-software/acle/blob/main/main/acle.md#function-multi-versioning
>
Hello.
Thanks for working on the feature, it will be nice to cover the gap in between x86_64 and powerpc,
which implement the FMV feature.
As the person who's been involved with the current MVC code in the GCC, I have a few comments/questions
about it:
1) both i386 and Powerpc also allow specifying an equivalent to -march (like `arch=bdver2`),
in Arm case it seems to me only individual features are considered
2) about 'target_version' attribute - I like the idea as one can have a completely independent
function implementation optimized for an ISA;
note it's very close to 'target' attribute (supported in C++), where one needs to provide
a resolver and have the pretty same functionality (see e.g. gcc/testsuite/g++.target/i386/mv1.C).
However, the feature does not work in C and you will have the very same problem with target_version
attribute (multiple functions with the same declaration):
mv1.c:76:1: error: redefinition of ‘foo’
76 | foo ()
| ^~~
3) If you will implement 'target_version' attribute, I would like to see it available also for the
existing targets supporting MVC
4) A small note about the mangling, the existing i386 naming scheme looks like:
...
_Z3foov.avx2_ssse3
...
5) Can you please define how will you evaluate priorities for a situation where multiple features
are used (e.g. dotprod+sm)?
Note we face the very same problem on i386, where it's very hard to specify a priority
for the family of avx512 features. That said, an optional priority specifier might be possible.
6) Note that as opposed to i385 and Powerpc, we don't allow a combination of ISA flags for target_clone
attribute (like sse2+avx512f).
7) FMV may be disabled in compile time by a compiler flag. In this case the default version shall be used.
I would like to see the functionality also target agnostic.
Anyway, looking forward to the Arm implementation.
Hope the comments are constructive.
Cheers,
Martin
next prev parent reply other threads:[~2022-07-19 10:01 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2022-07-18 10:36 Daniel Kiss
2022-07-19 10:01 ` Martin Liška [this message]
2022-07-21 17:49 ` Daniel Kiss
2022-07-22 8:12 ` Martin Liška
2022-07-22 8:40 ` Daniel Kiss
2022-07-25 14:17 ` Martin Liška
2022-11-23 12:28 ` Martin Liška
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=c4afc2d1-2e21-efb0-cfed-eddd7c361289@suse.cz \
--to=mliska@suse.cz \
--cc=Daniel.Kiss@arm.com \
--cc=Pavel.Iliin@arm.com \
--cc=gcc@gcc.gnu.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).