diff options
author | Manman Ren <mren@apple.com> | 2012-06-07 22:39:10 +0000 |
---|---|---|
committer | Manman Ren <mren@apple.com> | 2012-06-07 22:39:10 +0000 |
commit | 2cdc8afccf10218189bc653bcd5ba368e2f9bdaa (patch) | |
tree | dd7f7923803cb4034399980e2b75722272aa6072 /llvm/test/CodeGen/X86/iabs.ll | |
parent | cb8cf4916f80d933181f85ea8b6d6738c3e3319e (diff) | |
download | bcm5719-llvm-2cdc8afccf10218189bc653bcd5ba368e2f9bdaa.tar.gz bcm5719-llvm-2cdc8afccf10218189bc653bcd5ba368e2f9bdaa.zip |
X86: optimize generated code for integer ABS
This patch will generate the following for integer ABS:
movl %edi, %eax
negl %eax
cmovll %edi, %eax
INSTEAD OF
movl %edi, %ecx
sarl $31, %ecx
leal (%rdi,%rcx), %eax
xorl %ecx, %eax
There exists a target-independent DAG combine for integer ABS, which converts
integer ABS to sar+add+xor. For X86, we match this pattern back to neg+cmov.
This is implemented in PerformXorCombine.
rdar://10695237
llvm-svn: 158175
Diffstat (limited to 'llvm/test/CodeGen/X86/iabs.ll')
-rw-r--r-- | llvm/test/CodeGen/X86/iabs.ll | 16 |
1 files changed, 10 insertions, 6 deletions
diff --git a/llvm/test/CodeGen/X86/iabs.ll b/llvm/test/CodeGen/X86/iabs.ll index a8ba0155fd1..9196cce1ae5 100644 --- a/llvm/test/CodeGen/X86/iabs.ll +++ b/llvm/test/CodeGen/X86/iabs.ll @@ -1,13 +1,17 @@ -; RUN: llc < %s -march=x86-64 -stats |& \ -; RUN: grep {5 .*Number of machine instrs printed} +; RUN: llc < %s -march=x86-64 | FileCheck %s ;; Integer absolute value, should produce something at least as good as: -;; movl %edi, %ecx -;; sarl $31, %ecx -;; leal (%rdi,%rcx), %eax -;; xorl %ecx, %eax +;; movl %edi, %eax +;; negl %eax +;; cmovll %edi, %eax ;; ret +; rdar://10695237 define i32 @test(i32 %a) nounwind { +; CHECK: test: +; CHECK: mov +; CHECK-NEXT: neg +; CHECK-NEXT: cmov +; CHECK-NEXT: ret %tmp1neg = sub i32 0, %a %b = icmp sgt i32 %a, -1 %abs = select i1 %b, i32 %a, i32 %tmp1neg |