diff options
| author | Simon Pilgrim <llvm-dev@redking.me.uk> | 2019-02-10 15:46:32 +0000 |
|---|---|---|
| committer | Simon Pilgrim <llvm-dev@redking.me.uk> | 2019-02-10 15:46:32 +0000 |
| commit | 06a61b0b2b38ff47fc8bdee37ce4e089a821bc9f (patch) | |
| tree | 932dbf3e310bcabf35ef5a5058bde497c82c04b0 | |
| parent | d1307ec4ccb1dcf8b08ff23b10cc6399ed0cdc7e (diff) | |
| download | bcm5719-llvm-06a61b0b2b38ff47fc8bdee37ce4e089a821bc9f.tar.gz bcm5719-llvm-06a61b0b2b38ff47fc8bdee37ce4e089a821bc9f.zip | |
[X86] Add masked variable tests for funnel undef/zero argument combines
I've avoided 'modulo' masks as we'll SimplifyDemandedBits those in the future, and we just need to check that the shift variable is 'in range'
llvm-svn: 353644
| -rw-r--r-- | llvm/test/CodeGen/X86/funnel-shift.ll | 90 |
1 files changed, 90 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/X86/funnel-shift.ll b/llvm/test/CodeGen/X86/funnel-shift.ll index 55c1b3ca9ee..531885d3e9d 100644 --- a/llvm/test/CodeGen/X86/funnel-shift.ll +++ b/llvm/test/CodeGen/X86/funnel-shift.ll @@ -378,6 +378,28 @@ define i32 @fshl_i32_undef0(i32 %a0, i32 %a1) nounwind { ret i32 %res } +define i32 @fshl_i32_undef0_msk(i32 %a0, i32 %a1) nounwind { +; X32-SSE2-LABEL: fshl_i32_undef0_msk: +; X32-SSE2: # %bb.0: +; X32-SSE2-NEXT: movl {{[0-9]+}}(%esp), %eax +; X32-SSE2-NEXT: movl {{[0-9]+}}(%esp), %ecx +; X32-SSE2-NEXT: andl $7, %ecx +; X32-SSE2-NEXT: # kill: def $cl killed $cl killed $ecx +; X32-SSE2-NEXT: shldl %cl, %eax, %eax +; X32-SSE2-NEXT: retl +; +; X64-AVX2-LABEL: fshl_i32_undef0_msk: +; X64-AVX2: # %bb.0: +; X64-AVX2-NEXT: movl %esi, %ecx +; X64-AVX2-NEXT: andl $7, %ecx +; X64-AVX2-NEXT: # kill: def $cl killed $cl killed $ecx +; X64-AVX2-NEXT: shldl %cl, %edi, %eax +; X64-AVX2-NEXT: retq + %m = and i32 %a1, 7 + %res = call i32 @llvm.fshl.i32(i32 undef, i32 %a0, i32 %m) + ret i32 %res +} + define i32 @fshl_i32_undef0_cst(i32 %a0) nounwind { ; X32-SSE2-LABEL: fshl_i32_undef0_cst: ; X32-SSE2: # %bb.0: @@ -412,6 +434,29 @@ define i32 @fshl_i32_undef1(i32 %a0, i32 %a1) nounwind { ret i32 %res } +define i32 @fshl_i32_undef1_msk(i32 %a0, i32 %a1) nounwind { +; X32-SSE2-LABEL: fshl_i32_undef1_msk: +; X32-SSE2: # %bb.0: +; X32-SSE2-NEXT: movl {{[0-9]+}}(%esp), %eax +; X32-SSE2-NEXT: movl {{[0-9]+}}(%esp), %ecx +; X32-SSE2-NEXT: andl $7, %ecx +; X32-SSE2-NEXT: # kill: def $cl killed $cl killed $ecx +; X32-SSE2-NEXT: shldl %cl, %eax, %eax +; X32-SSE2-NEXT: retl +; +; X64-AVX2-LABEL: fshl_i32_undef1_msk: +; X64-AVX2: # %bb.0: +; X64-AVX2-NEXT: movl %esi, %ecx +; X64-AVX2-NEXT: movl %edi, %eax +; X64-AVX2-NEXT: andl $7, %ecx +; X64-AVX2-NEXT: # kill: def $cl killed $cl killed $ecx +; X64-AVX2-NEXT: shldl %cl, %eax, %eax +; X64-AVX2-NEXT: retq + %m = and i32 %a1, 7 + %res = call i32 @llvm.fshl.i32(i32 %a0, i32 undef, i32 %m) + ret i32 %res +} + define i32 @fshl_i32_undef1_cst(i32 %a0) nounwind { ; X32-SSE2-LABEL: fshl_i32_undef1_cst: ; X32-SSE2: # %bb.0: @@ -464,6 +509,29 @@ define i32 @fshr_i32_undef0(i32 %a0, i32 %a1) nounwind { ret i32 %res } +define i32 @fshr_i32_undef0_msk(i32 %a0, i32 %a1) nounwind { +; X32-SSE2-LABEL: fshr_i32_undef0_msk: +; X32-SSE2: # %bb.0: +; X32-SSE2-NEXT: movl {{[0-9]+}}(%esp), %eax +; X32-SSE2-NEXT: movl {{[0-9]+}}(%esp), %ecx +; X32-SSE2-NEXT: andl $7, %ecx +; X32-SSE2-NEXT: # kill: def $cl killed $cl killed $ecx +; X32-SSE2-NEXT: shrdl %cl, %eax, %eax +; X32-SSE2-NEXT: retl +; +; X64-AVX2-LABEL: fshr_i32_undef0_msk: +; X64-AVX2: # %bb.0: +; X64-AVX2-NEXT: movl %esi, %ecx +; X64-AVX2-NEXT: movl %edi, %eax +; X64-AVX2-NEXT: andl $7, %ecx +; X64-AVX2-NEXT: # kill: def $cl killed $cl killed $ecx +; X64-AVX2-NEXT: shrdl %cl, %eax, %eax +; X64-AVX2-NEXT: retq + %m = and i32 %a1, 7 + %res = call i32 @llvm.fshr.i32(i32 undef, i32 %a0, i32 %m) + ret i32 %res +} + define i32 @fshr_i32_undef0_cst(i32 %a0) nounwind { ; X32-SSE2-LABEL: fshr_i32_undef0_cst: ; X32-SSE2: # %bb.0: @@ -498,6 +566,28 @@ define i32 @fshr_i32_undef1(i32 %a0, i32 %a1) nounwind { ret i32 %res } +define i32 @fshr_i32_undef1_msk(i32 %a0, i32 %a1) nounwind { +; X32-SSE2-LABEL: fshr_i32_undef1_msk: +; X32-SSE2: # %bb.0: +; X32-SSE2-NEXT: movl {{[0-9]+}}(%esp), %eax +; X32-SSE2-NEXT: movl {{[0-9]+}}(%esp), %ecx +; X32-SSE2-NEXT: andl $7, %ecx +; X32-SSE2-NEXT: # kill: def $cl killed $cl killed $ecx +; X32-SSE2-NEXT: shrdl %cl, %eax, %eax +; X32-SSE2-NEXT: retl +; +; X64-AVX2-LABEL: fshr_i32_undef1_msk: +; X64-AVX2: # %bb.0: +; X64-AVX2-NEXT: movl %esi, %ecx +; X64-AVX2-NEXT: andl $7, %ecx +; X64-AVX2-NEXT: # kill: def $cl killed $cl killed $ecx +; X64-AVX2-NEXT: shrdl %cl, %edi, %eax +; X64-AVX2-NEXT: retq + %m = and i32 %a1, 7 + %res = call i32 @llvm.fshr.i32(i32 %a0, i32 undef, i32 %m) + ret i32 %res +} + define i32 @fshr_i32_undef1_cst(i32 %a0) nounwind { ; X32-SSE2-LABEL: fshr_i32_undef1_cst: ; X32-SSE2: # %bb.0: |

