From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: by sourceware.org (Postfix, from userid 48) id 937F1384B820; Wed, 10 Mar 2021 15:54:27 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org 937F1384B820 From: "ktkachov at gcc dot gnu.org" To: gcc-bugs@gcc.gnu.org Subject: [Bug middle-end/99520] New: Failure to detect bswap pattern Date: Wed, 10 Mar 2021 15:54:27 +0000 X-Bugzilla-Reason: CC X-Bugzilla-Type: new X-Bugzilla-Watch-Reason: None X-Bugzilla-Product: gcc X-Bugzilla-Component: middle-end X-Bugzilla-Version: unknown X-Bugzilla-Keywords: missed-optimization X-Bugzilla-Severity: normal X-Bugzilla-Who: ktkachov at gcc dot gnu.org X-Bugzilla-Status: UNCONFIRMED X-Bugzilla-Resolution: X-Bugzilla-Priority: P3 X-Bugzilla-Assigned-To: unassigned at gcc dot gnu.org X-Bugzilla-Target-Milestone: --- X-Bugzilla-Flags: X-Bugzilla-Changed-Fields: bug_id short_desc product version bug_status keywords bug_severity priority component assigned_to reporter target_milestone Message-ID: Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: quoted-printable X-Bugzilla-URL: http://gcc.gnu.org/bugzilla/ Auto-Submitted: auto-generated MIME-Version: 1.0 X-BeenThere: gcc-bugs@gcc.gnu.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: Gcc-bugs mailing list List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , X-List-Received-Date: Wed, 10 Mar 2021 15:54:27 -0000 https://gcc.gnu.org/bugzilla/show_bug.cgi?id=3D99520 Bug ID: 99520 Summary: Failure to detect bswap pattern Product: gcc Version: unknown Status: UNCONFIRMED Keywords: missed-optimization Severity: normal Priority: P3 Component: middle-end Assignee: unassigned at gcc dot gnu.org Reporter: ktkachov at gcc dot gnu.org Target Milestone: --- #include uint32_t endian_fix32( uint32_t x ){ return (x<<24) + ((x<<8)&0xff0000) + ((x>>8)&0xff00) + (x>>24); } For aarch64 clang manages to optimise it to: endian_fix32(unsigned int): // @endian_fix32(unsigned = int) rev w0, w0 ret GCC doesn't: endian_fix32(unsigned int): lsl w1, w0, 8 lsr w2, w0, 8 and w2, w2, 65280 lsr w3, w0, 24 and w1, w1, 16711680 add w0, w3, w0, lsl 24 orr w1, w1, w2 add w0, w1, w0 ret Is there something missing in the bswap pass?=