Potential spiller improvement.

llvm-svn: 35228
This commit is contained in:
Evan Cheng 2007-03-20 22:22:38 +00:00
parent bacf4acf65
commit 3578dd61c6
1 changed files with 27 additions and 0 deletions

View File

@ -0,0 +1,27 @@
Common register allocation / spilling problem:
mul lr, r4, lr
str lr, [sp, #+52]
ldr lr, [r1, #+32]
sxth r3, r3
ldr r4, [sp, #+52]
mla r4, r3, lr, r4
can be:
mul lr, r4, lr
mov r4, lr
str lr, [sp, #+52]
ldr lr, [r1, #+32]
sxth r3, r3
mla r4, r3, lr, r4
and then "merge" mul and mov:
mul r4, r4, lr
str lr, [sp, #+52]
ldr lr, [r1, #+32]
sxth r3, r3
mla r4, r3, lr, r4
It also increase the likelyhood the store may become dead.