diff options
| author | Benjamin Kramer <benny.kra@googlemail.com> | 2011-01-02 19:44:58 +0000 |
|---|---|---|
| committer | Benjamin Kramer <benny.kra@googlemail.com> | 2011-01-02 19:44:58 +0000 |
| commit | 2fdea4c8f1e89f36548a92bb68f003a40c07372c (patch) | |
| tree | 8370a3b6024f8875ae1bf58af5087c581576db81 /llvm/lib/CodeGen/LiveInterval.cpp | |
| parent | 68b7bb95d48d1b2dfabcb33447e6a1f1b3928f8e (diff) | |
| download | bcm5719-llvm-2fdea4c8f1e89f36548a92bb68f003a40c07372c.tar.gz bcm5719-llvm-2fdea4c8f1e89f36548a92bb68f003a40c07372c.zip | |
Lower the i8 extension in memset to a multiply instead of a potentially long series of shifts and ors.
We could implement a DAGCombine to turn x * 0x0101 back into logic operations
on targets that doesn't support the multiply or it is slow (p4) if someone cares
enough.
Example code:
void test(char *s, int a) {
__builtin_memset(s, a, 4);
}
before:
_test: ## @test
movzbl 8(%esp), %eax
movl %eax, %ecx
shll $8, %ecx
orl %eax, %ecx
movl %ecx, %eax
shll $16, %eax
orl %ecx, %eax
movl 4(%esp), %ecx
movl %eax, 4(%ecx)
movl %eax, (%ecx)
ret
after:
_test: ## @test
movzbl 8(%esp), %eax
imull $16843009, %eax, %eax ## imm = 0x1010101
movl 4(%esp), %ecx
movl %eax, 4(%ecx)
movl %eax, (%ecx)
ret
llvm-svn: 122707
Diffstat (limited to 'llvm/lib/CodeGen/LiveInterval.cpp')
0 files changed, 0 insertions, 0 deletions

