From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (qmail 14156 invoked by alias); 18 Jan 2015 22:54:04 -0000 Mailing-List: contact gcc-bugs-help@gcc.gnu.org; run by ezmlm Precedence: bulk List-Id: List-Archive: List-Post: List-Help: Sender: gcc-bugs-owner@gcc.gnu.org Received: (qmail 14096 invoked by uid 48); 18 Jan 2015 22:54:00 -0000 From: "segher at gcc dot gnu.org" To: gcc-bugs@gcc.gnu.org Subject: [Bug target/43892] PowerPC suboptimal "add with carry" optimization Date: Sun, 18 Jan 2015 22:54:00 -0000 X-Bugzilla-Reason: CC X-Bugzilla-Type: changed X-Bugzilla-Watch-Reason: None X-Bugzilla-Product: gcc X-Bugzilla-Component: target X-Bugzilla-Version: 4.3.4 X-Bugzilla-Keywords: X-Bugzilla-Severity: enhancement X-Bugzilla-Who: segher at gcc dot gnu.org X-Bugzilla-Status: ASSIGNED X-Bugzilla-Priority: P3 X-Bugzilla-Assigned-To: segher at gcc dot gnu.org X-Bugzilla-Target-Milestone: --- X-Bugzilla-Flags: X-Bugzilla-Changed-Fields: Message-ID: In-Reply-To: References: Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit X-Bugzilla-URL: http://gcc.gnu.org/bugzilla/ Auto-Submitted: auto-generated MIME-Version: 1.0 X-SW-Source: 2015-01/txt/msg01768.txt.bz2 https://gcc.gnu.org/bugzilla/show_bug.cgi?id=43892 --- Comment #23 from Segher Boessenkool --- Do you know what addcc does? PowerPC does not have any instruction that behaves like it at all. So it would have to expand to a big fat sequence of instructions, that then hopefully are optimised to something sane later. Instead, the current code expands to something sane immediately. The problem for this testcase (as for all other similar "manual carry" cases) is that we need to replace the carry in our original patterns with (1 - carry). There is no good way to do that in combine, we would need to combine three insns, the first two of which are a parallel.