public inbox for gcc-bugs@sourceware.org help / color / mirror / Atom feed
* [Bug target/41481] New: missed optimization in cse @ 2009-09-27 9:13 carrot at google dot com 2009-09-27 9:13 ` [Bug target/41481] " carrot at google dot com ` (2 more replies) 0 siblings, 3 replies; 4+ messages in thread From: carrot at google dot com @ 2009-09-27 9:13 UTC (permalink / raw) To: gcc-bugs Compile following code with options -Os -march=armv5te -mthumb, class A { public: int ah; unsigned field : 2; }; void foo(A* p) { p->ah = 1; p->field = 1; } We can get: mov r3, #1 // A str r3, [r0] ldrb r3, [r0, #4] mov r2, #3 bic r3, r3, r2 mov r2, #1 // B orr r3, r3, r2 strb r3, [r0, #4] @ sp needed for prologue bx lr Both instruction A and B load a constant 1 into register. We can load 1 into r1 in instruction A and use r1 when constant 1 is required. So instruction B can be removed. cse pass doesn't find this opportunity is because it needs all expressions to be of the same mode. But in rtl level the first 1 is in mode SI and the second 1 is in mode QI. Arm doesn't has any physical register of QI mode, so all of them are put into 32 bit physical register and causes redundant load of constant 1. -- Summary: missed optimization in cse Product: gcc Version: 4.5.0 Status: UNCONFIRMED Severity: normal Priority: P3 Component: target AssignedTo: unassigned at gcc dot gnu dot org ReportedBy: carrot at google dot com GCC build triplet: i686-linux GCC host triplet: i686-linux GCC target triplet: arm-eabi http://gcc.gnu.org/bugzilla/show_bug.cgi?id=41481 ^ permalink raw reply [flat|nested] 4+ messages in thread
* [Bug target/41481] missed optimization in cse 2009-09-27 9:13 [Bug target/41481] New: missed optimization in cse carrot at google dot com @ 2009-09-27 9:13 ` carrot at google dot com 2009-10-06 7:20 ` ramana at gcc dot gnu dot org 2009-12-12 1:05 ` rearnsha at gcc dot gnu dot org 2 siblings, 0 replies; 4+ messages in thread From: carrot at google dot com @ 2009-09-27 9:13 UTC (permalink / raw) To: gcc-bugs ------- Comment #1 from carrot at google dot com 2009-09-27 09:13 ------- Created an attachment (id=18662) --> (http://gcc.gnu.org/bugzilla/attachment.cgi?id=18662&action=view) test case -- http://gcc.gnu.org/bugzilla/show_bug.cgi?id=41481 ^ permalink raw reply [flat|nested] 4+ messages in thread
* [Bug target/41481] missed optimization in cse 2009-09-27 9:13 [Bug target/41481] New: missed optimization in cse carrot at google dot com 2009-09-27 9:13 ` [Bug target/41481] " carrot at google dot com @ 2009-10-06 7:20 ` ramana at gcc dot gnu dot org 2009-12-12 1:05 ` rearnsha at gcc dot gnu dot org 2 siblings, 0 replies; 4+ messages in thread From: ramana at gcc dot gnu dot org @ 2009-10-06 7:20 UTC (permalink / raw) To: gcc-bugs ------- Comment #2 from ramana at gcc dot gnu dot org 2009-10-06 07:20 ------- confirmed - FYI, the problem doesn't arise with !-mthumb. -- ramana at gcc dot gnu dot org changed: What |Removed |Added ---------------------------------------------------------------------------- Status|UNCONFIRMED |NEW Ever Confirmed|0 |1 Last reconfirmed|0000-00-00 00:00:00 |2009-10-06 07:20:28 date| | http://gcc.gnu.org/bugzilla/show_bug.cgi?id=41481 ^ permalink raw reply [flat|nested] 4+ messages in thread
* [Bug target/41481] missed optimization in cse 2009-09-27 9:13 [Bug target/41481] New: missed optimization in cse carrot at google dot com 2009-09-27 9:13 ` [Bug target/41481] " carrot at google dot com 2009-10-06 7:20 ` ramana at gcc dot gnu dot org @ 2009-12-12 1:05 ` rearnsha at gcc dot gnu dot org 2 siblings, 0 replies; 4+ messages in thread From: rearnsha at gcc dot gnu dot org @ 2009-12-12 1:05 UTC (permalink / raw) To: gcc-bugs -- rearnsha at gcc dot gnu dot org changed: What |Removed |Added ---------------------------------------------------------------------------- Severity|normal |enhancement http://gcc.gnu.org/bugzilla/show_bug.cgi?id=41481 ^ permalink raw reply [flat|nested] 4+ messages in thread
end of thread, other threads:[~2009-12-12 1:05 UTC | newest] Thread overview: 4+ messages (download: mbox.gz / follow: Atom feed) -- links below jump to the message on this page -- 2009-09-27 9:13 [Bug target/41481] New: missed optimization in cse carrot at google dot com 2009-09-27 9:13 ` [Bug target/41481] " carrot at google dot com 2009-10-06 7:20 ` ramana at gcc dot gnu dot org 2009-12-12 1:05 ` rearnsha at gcc dot gnu dot org
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).