diff options
Diffstat (limited to 'test/CodeGen/X86/test-nofold.ll')
-rw-r--r-- | test/CodeGen/X86/test-nofold.ll | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/test/CodeGen/X86/test-nofold.ll b/test/CodeGen/X86/test-nofold.ll new file mode 100644 index 0000000..f1063dc --- /dev/null +++ b/test/CodeGen/X86/test-nofold.ll @@ -0,0 +1,42 @@ +; RUN: llc < %s -march=x86 -mcpu=yonah | FileCheck %s +; rdar://5752025 + +; We want: +; CHECK: movl 4(%esp), %ecx +; CHECK-NEXT: andl $15, %ecx +; CHECK-NEXT: movl $42, %eax +; CHECK-NEXT: cmovel %ecx, %eax +; CHECK-NEXT: ret +; +; We don't want: +; movl 4(%esp), %eax +; movl %eax, %ecx # bad: extra copy +; andl $15, %ecx +; testl $15, %eax # bad: peep obstructed +; movl $42, %eax +; cmovel %ecx, %eax +; ret +; +; We also don't want: +; movl $15, %ecx # bad: larger encoding +; andl 4(%esp), %ecx +; movl $42, %eax +; cmovel %ecx, %eax +; ret +; +; We also don't want: +; movl 4(%esp), %ecx +; andl $15, %ecx +; testl %ecx, %ecx # bad: unnecessary test +; movl $42, %eax +; cmovel %ecx, %eax +; ret + +define i32 @t1(i32 %X) nounwind { +entry: + %tmp2 = and i32 %X, 15 ; <i32> [#uses=2] + %tmp4 = icmp eq i32 %tmp2, 0 ; <i1> [#uses=1] + %retval = select i1 %tmp4, i32 %tmp2, i32 42 ; <i32> [#uses=1] + ret i32 %retval +} + |