Skip to content
This repository was archived by the owner on Mar 28, 2020. It is now read-only.

Commit 970d6e8

Browse files
committed
[X86] Add knownbits vector BSWAP test
In preparation for demandedelts support git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@286579 91177308-0d34-0410-b5e6-96231b3b80d8
1 parent 912c7ec commit 970d6e8

File tree

1 file changed

+22
-0
lines changed

1 file changed

+22
-0
lines changed

test/CodeGen/X86/known-bits-vector.ll

Lines changed: 22 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -305,3 +305,25 @@ define <4 x i32> @knownbits_mask_srem_shuffle_lshr(<4 x i32> %a0) nounwind {
305305
%4 = lshr <4 x i32> %3, <i32 22, i32 22, i32 22, i32 22>
306306
ret <4 x i32> %4
307307
}
308+
309+
define <4 x i32> @knownbits_mask_bswap_shuffle_shl(<4 x i32> %a0) nounwind {
310+
; X32-LABEL: knownbits_mask_bswap_shuffle_shl:
311+
; X32: # BB#0:
312+
; X32-NEXT: vpand {{\.LCPI.*}}, %xmm0, %xmm0
313+
; X32-NEXT: vpshufb {{.*#+}} xmm0 = xmm0[3,2,1,0,3,2,1,0,15,14,13,12,15,14,13,12]
314+
; X32-NEXT: vpslld $22, %xmm0, %xmm0
315+
; X32-NEXT: retl
316+
;
317+
; X64-LABEL: knownbits_mask_bswap_shuffle_shl:
318+
; X64: # BB#0:
319+
; X64-NEXT: vpand {{.*}}(%rip), %xmm0, %xmm0
320+
; X64-NEXT: vpshufb {{.*#+}} xmm0 = xmm0[3,2,1,0,3,2,1,0,15,14,13,12,15,14,13,12]
321+
; X64-NEXT: vpslld $22, %xmm0, %xmm0
322+
; X64-NEXT: retq
323+
%1 = and <4 x i32> %a0, <i32 32767, i32 -1, i32 -1, i32 32767>
324+
%2 = call <4 x i32> @llvm.bswap.v4i32(<4 x i32> %1)
325+
%3 = shufflevector <4 x i32> %2, <4 x i32> undef, <4 x i32> <i32 0, i32 0, i32 3, i32 3>
326+
%4 = shl <4 x i32> %3, <i32 22, i32 22, i32 22, i32 22>
327+
ret <4 x i32> %4
328+
}
329+
declare <4 x i32> @llvm.bswap.v4i32(<4 x i32>)

0 commit comments

Comments
 (0)