Skip to content

Commit 662d1cb

Browse files
committed
[X86] Add test case for Issue #78109
1 parent 82d2181 commit 662d1cb

File tree

1 file changed

+23
-0
lines changed

1 file changed

+23
-0
lines changed

llvm/test/CodeGen/X86/pr78109.ll

Lines changed: 23 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2+
; RUN: llc < %s -mtriple=x86_64-- -mcpu=x86-64 | FileCheck %s --check-prefixes=SSE
3+
; RUN: llc < %s -mtriple=x86_64-- -mcpu=x86-64-v2 | FileCheck %s --check-prefixes=SSE
4+
; RUN: llc < %s -mtriple=x86_64-- -mcpu=x86-64-v3 | FileCheck %s --check-prefixes=AVX
5+
; RUN: llc < %s -mtriple=x86_64-- -mcpu=x86-64-v4 | FileCheck %s --check-prefixes=AVX
6+
7+
; FIXME: Failure to recognise undef elements in constant foldable splats
8+
define <4 x i32> @PR78109() {
9+
; SSE-LABEL: PR78109:
10+
; SSE: # %bb.0:
11+
; SSE-NEXT: movaps {{.*#+}} xmm0 = [1,1,1,1]
12+
; SSE-NEXT: retq
13+
;
14+
; AVX-LABEL: PR78109:
15+
; AVX: # %bb.0:
16+
; AVX-NEXT: vbroadcastss {{.*#+}} xmm0 = [1,1,1,1]
17+
; AVX-NEXT: retq
18+
%shuffle.1 = shufflevector <4 x i32> <i32 7, i32 7, i32 0, i32 7>, <4 x i32> zeroinitializer, <4 x i32> <i32 2, i32 2, i32 1, i32 1> ; <0, 0, 7, 7>
19+
%shift = lshr <4 x i32> %shuffle.1, <i32 0, i32 0, i32 1, i32 0> ; <0, 0, 3, 7>
20+
%shuffle.2 = shufflevector <4 x i32> %shift, <4 x i32> zeroinitializer, <4 x i32> <i32 2, i32 2, i32 0, i32 0> ; <3, 3, 0, 0>
21+
%shuffle.3 = shufflevector <4 x i32> %shuffle.2, <4 x i32> <i32 1, i32 1, i32 1, i32 1>, <4 x i32> <i32 2, i32 6, i32 3, i32 7> ; <0, 1, 0, 1>
22+
ret <4 x i32> %shuffle.3
23+
}

0 commit comments

Comments
 (0)