public inbox for gcc-bugs@sourceware.org help / color / mirror / Atom feed
From: "rguenth at gcc dot gnu.org" <gcc-bugzilla@gcc.gnu.org> To: gcc-bugs@gcc.gnu.org Subject: [Bug target/114252] Introducing bswapsi reduces code performance Date: Wed, 06 Mar 2024 12:37:01 +0000 [thread overview] Message-ID: <bug-114252-4-itzzNgU9mX@http.gcc.gnu.org/bugzilla/> (raw) In-Reply-To: <bug-114252-4@http.gcc.gnu.org/bugzilla/> https://gcc.gnu.org/bugzilla/show_bug.cgi?id=114252 Richard Biener <rguenth at gcc dot gnu.org> changed: What |Removed |Added ---------------------------------------------------------------------------- CC| |rguenth at gcc dot gnu.org, | |vmakarov at gcc dot gnu.org --- Comment #4 from Richard Biener <rguenth at gcc dot gnu.org> --- Yes, the missing "detail" for the middle-end is that the uint32_t is actually 4 separate byte registers. And the 'int' argument to bswap32 requires 4 registers as well. So bswap on a value is just register shuffling, right? And thus this libcall will never be better than doing it inline as you probably cannot expect the incoming arguments and the outgoing return registers to be allocated in a way so no reg-reg moves remain? Of course since it's still SImode pseudos on RTL you might want to write an expander that populates 4 QImode pseudos from the SImode one and composes that back to a byte-swapped SImode one. Hoping register allocation can then elide everything again? I'd try to avoid using subregs if possible though using those would be easiest I think (but you might fall foul of RA similar to -fsplit-wide-types). Shifts and truncates/zero_extends are possibly superior. Who knows. Or split it only after reload and have the pattern consume one scratch you need for the register-register moves. Hey, maybe the RA itself can know how to allocate a bswap:SI optimally and "reload" it to be reg-reg moves ...
next prev parent reply other threads:[~2024-03-06 12:37 UTC|newest] Thread overview: 17+ messages / expand[flat|nested] mbox.gz Atom feed top 2024-03-06 10:01 [Bug tree-optimization/114252] New: " gjl at gcc dot gnu.org 2024-03-06 11:55 ` [Bug target/114252] " rguenth at gcc dot gnu.org 2024-03-06 11:59 ` rguenth at gcc dot gnu.org 2024-03-06 12:15 ` gjl at gcc dot gnu.org 2024-03-06 12:37 ` rguenth at gcc dot gnu.org [this message] 2024-03-06 16:12 ` gjl at gcc dot gnu.org 2024-03-06 17:18 ` rguenther at suse dot de 2024-03-07 7:45 ` rguenth at gcc dot gnu.org 2024-03-07 8:45 ` gjl at gcc dot gnu.org 2024-03-07 9:05 ` gjl at gcc dot gnu.org 2024-03-07 9:14 ` rguenth at gcc dot gnu.org 2024-03-07 9:42 ` rguenth at gcc dot gnu.org 2024-03-07 10:47 ` gjl at gcc dot gnu.org 2024-03-07 10:56 ` rguenth at gcc dot gnu.org 2024-03-07 14:12 ` gjl at gcc dot gnu.org 2024-03-07 15:02 ` pinskia at gcc dot gnu.org 2024-03-07 17:52 ` rguenther at suse dot de
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=bug-114252-4-itzzNgU9mX@http.gcc.gnu.org/bugzilla/ \ --to=gcc-bugzilla@gcc.gnu.org \ --cc=gcc-bugs@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: linkBe 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).