diff options
| author | Chris Lattner <sabre@nondot.org> | 2010-01-11 04:05:13 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2010-01-11 04:05:13 +0000 |
| commit | 0a85420409670db429b1d70a1801f0a543541b3a (patch) | |
| tree | bdce77cf9fe295f2c031e0d38189a8407fa81bc1 /llvm/lib/Bitcode/Reader/BitcodeReader.cpp | |
| parent | 12bd8992b3eca2abb2f391dfbd14791117d09fe5 (diff) | |
Extend CanEvaluateZExtd to handle and/or/xor more aggressively in the
BitsToClear case. This allows it to promote expressions which have an
and/or/xor after the lshr, promoting cases like test2 (from PR4216)
and test3 (random extample extracted from a spec benchmark).
clang now compiles the code in PR4216 into:
_test_bitfield: ## @test_bitfield
movl %edi, %eax
orl $194, %eax
movl $4294902010, %ecx
andq %rax, %rcx
orl $32768, %edi
andq $39936, %rdi
movq %rdi, %rax
orq %rcx, %rax
ret
instead of:
_test_bitfield: ## @test_bitfield
movl %edi, %eax
orl $194, %eax
movl $4294902010, %ecx
andq %rax, %rcx
shrl $8, %edi
orl $128, %edi
shlq $8, %rdi
andq $39936, %rdi
movq %rdi, %rax
orq %rcx, %rax
ret
which is still not great, but is progress.
llvm-svn: 93145
Diffstat (limited to 'llvm/lib/Bitcode/Reader/BitcodeReader.cpp')
0 files changed, 0 insertions, 0 deletions
