summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/BranchFolding.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2007-04-11 05:32:27 +0000
committerChris Lattner <sabre@nondot.org>2007-04-11 05:32:27 +0000
commit65786b078c61356dd6fbfdb81198179ee3eb1794 (patch)
treefd37ff18dafab0d8cbce7759516b434641c265b0 /llvm/lib/CodeGen/BranchFolding.cpp
parent05362ffdce313334085299232fa0305e868604ee (diff)
downloadbcm5719-llvm-65786b078c61356dd6fbfdb81198179ee3eb1794.tar.gz
bcm5719-llvm-65786b078c61356dd6fbfdb81198179ee3eb1794.zip
Teach the codegen to turn [aez]ext (setcc) -> selectcc of 1/0, which often
allows other simplifications. For example, this compiles: int isnegative(unsigned int X) { return !(X < 2147483648U); } Into this code: x86: movl 4(%esp), %eax shrl $31, %eax ret arm: mov r0, r0, lsr #31 bx lr thumb: lsr r0, r0, #31 bx lr instead of: x86: cmpl $0, 4(%esp) sets %al movzbl %al, %eax ret arm: mov r3, #0 cmp r0, #0 movlt r3, #1 mov r0, r3 bx lr thumb: mov r2, #1 mov r1, #0 cmp r0, #0 blt LBB1_2 @entry LBB1_1: @entry cpy r2, r1 LBB1_2: @entry cpy r0, r2 bx lr Testcase here: test/CodeGen/Generic/ispositive.ll llvm-svn: 35883
Diffstat (limited to 'llvm/lib/CodeGen/BranchFolding.cpp')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud