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