From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: by sourceware.org (Postfix, from userid 48) id EC5CC3857C63; Fri, 30 Jul 2021 23:37:26 +0000 (GMT) DKIM-Filter: OpenDKIM Filter v2.11.0 sourceware.org EC5CC3857C63 From: "llvm at rifkin dot dev" To: gcc-bugs@gcc.gnu.org Subject: [Bug c++/101701] New: GCC optimization and code generation for if-else chains vs ternary chains vs a switch Date: Fri, 30 Jul 2021 23:37:26 +0000 X-Bugzilla-Reason: CC X-Bugzilla-Type: new X-Bugzilla-Watch-Reason: None X-Bugzilla-Product: gcc X-Bugzilla-Component: c++ X-Bugzilla-Version: 12.0 X-Bugzilla-Keywords: X-Bugzilla-Severity: normal X-Bugzilla-Who: llvm at rifkin dot dev 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 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: Fri, 30 Jul 2021 23:37:27 -0000 https://gcc.gnu.org/bugzilla/show_bug.cgi?id=3D101701 Bug ID: 101701 Summary: GCC optimization and code generation for if-else chains vs ternary chains vs a switch Product: gcc Version: 12.0 Status: UNCONFIRMED Severity: normal Priority: P3 Component: c++ Assignee: unassigned at gcc dot gnu.org Reporter: llvm at rifkin dot dev Target Milestone: --- I'm looking at an example of three equivalent functions implemented with if-else chains, ternary chains, and a switch. Gcc is not compiling them equivalently: https://godbolt.org/z/8cjGr7M7W. For the if-else chain, gcc does not optimize away the jumps. For the ternary chain, gcc does its codegen well. For the switch, gcc also does its codegen well but there is an extra mov instruction compared to the ternary chain. I don't think it's idealistic to say these should compile equivalently - if someone told me to prefer one over the other for performance reasons I'd dismiss it as a micro-optimization. Clang does not do this perfectly either at the moment. This bug is probably miscategorized. I am not sure the correct category for= it.=