xref: /llvm-project/llvm/test/Transforms/SLPVectorizer/extractlements-gathered-first-node.ll (revision 706e71076e0276747e7ae94e3f8a7f73a45e5b6e)
1; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 4
2; RUN: %if x86-registered-target %{ opt -S --passes=slp-vectorizer -slp-threshold=-99999 -mtriple=x86_64-unknown-linux-gnu < %s | FileCheck %s %}
3; RUN: %if aarch64-registered-target %{ opt -S --passes=slp-vectorizer -slp-threshold=-99999 -mtriple=aarch64-unknown-linux-gnu < %s | FileCheck %s %}
4
5define void @test() {
6; CHECK-LABEL: define void @test() {
7; CHECK-NEXT:  bb:
8; CHECK-NEXT:    [[TMP0:%.*]] = extractelement <4 x i32> zeroinitializer, i32 0
9; CHECK-NEXT:    [[TMP1:%.*]] = extractelement <2 x i32> zeroinitializer, i32 0
10; CHECK-NEXT:    [[ICMP:%.*]] = icmp ult i32 [[TMP0]], [[TMP1]]
11; CHECK-NEXT:    ret void
12;
13bb:
14  %0 = extractelement <4 x i32> zeroinitializer, i32 0
15  %1 = extractelement <2 x i32> zeroinitializer, i32 0
16  %icmp = icmp ult i32 %0, %1
17  ret void
18}
19