public inbox for gcc-bugs@sourceware.org
help / color / mirror / Atom feed
* [Bug rtl-optimization/40327]  New: Use less instructions to add some constants to register
@ 2009-06-03  7:39 carrot at google dot com
  2009-06-03 10:36 ` [Bug target/40327] " steven at gcc dot gnu dot org
                   ` (5 more replies)
  0 siblings, 6 replies; 7+ messages in thread
From: carrot at google dot com @ 2009-06-03  7:39 UTC (permalink / raw)
  To: gcc-bugs

Compiling this simple function in thumb mode:

int add_const(int x)
{
 return x+400;
}

I got:

       mov     r1, #200
       lsl     r3, r1, #1
       add     r0, r0, r3

A better code sequence should be:

    add r0, r0, 200
    add r0, r0, 200

In order to apply this optimization, the constant should be less than 2 times
of the largest immediate value in the target ISA. So this optimization should
also useful to other architecture with limited immediate operand range.

It can also be applied to sub instruction.


-- 
           Summary: Use less instructions to add some constants to register
           Product: gcc
           Version: 4.5.0
            Status: UNCONFIRMED
          Severity: normal
          Priority: P3
         Component: rtl-optimization
        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=40327


^ permalink raw reply	[flat|nested] 7+ messages in thread

end of thread, other threads:[~2009-06-13 23:45 UTC | newest]

Thread overview: 7+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2009-06-03  7:39 [Bug rtl-optimization/40327] New: Use less instructions to add some constants to register carrot at google dot com
2009-06-03 10:36 ` [Bug target/40327] " steven at gcc dot gnu dot org
2009-06-03 10:58 ` steven at gcc dot gnu dot org
2009-06-09 22:06 ` rearnsha at gcc dot gnu dot org
2009-06-13 12:49 ` rearnsha at gcc dot gnu dot org
2009-06-13 13:04 ` rearnsha at gcc dot gnu dot org
2009-06-13 23:45 ` steven 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).