xref: /llvm-project/llvm/test/Transforms/SLPVectorizer/X86/small-graph-diff-block-instructions.ll (revision a3508e0246741851f06cb9ba86203be8d89febed)
1; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5
2; RUN: opt -S --passes=slp-vectorizer -mtriple=x86_64-unknown-linux-gnu -mattr=+avx512dq -slp-threshold=-99999 < %s | FileCheck %s
3
4define i32 @test(i32 %arg, i32 %arg1) {
5; CHECK-LABEL: define i32 @test(
6; CHECK-SAME: i32 [[ARG:%.*]], i32 [[ARG1:%.*]]) #[[ATTR0:[0-9]+]] {
7; CHECK-NEXT:  [[BB:.*:]]
8; CHECK-NEXT:    [[ZEXT:%.*]] = zext i32 [[ARG1]] to i64
9; CHECK-NEXT:    [[ZEXT2:%.*]] = zext i32 [[ARG]] to i64
10; CHECK-NEXT:    [[SEXT:%.*]] = sext i32 [[ARG]] to i64
11; CHECK-NEXT:    br label %[[BB3:.*]]
12; CHECK:       [[BB3]]:
13; CHECK-NEXT:    [[GETELEMENTPTR:%.*]] = getelementptr i64, ptr addrspace(1) null, i64 [[ZEXT]]
14; CHECK-NEXT:    [[GETELEMENTPTR4:%.*]] = getelementptr i64, ptr addrspace(1) null, i64 [[ZEXT2]]
15; CHECK-NEXT:    [[GETELEMENTPTR5:%.*]] = getelementptr i64, ptr addrspace(1) null, i64 [[SEXT]]
16; CHECK-NEXT:    [[ZEXT6:%.*]] = zext i32 0 to i64
17; CHECK-NEXT:    [[GETELEMENTPTR7:%.*]] = getelementptr i64, ptr addrspace(1) null, i64 [[ZEXT6]]
18; CHECK-NEXT:    ret i32 0
19;
20bb:
21  %zext = zext i32 %arg1 to i64
22  %zext2 = zext i32 %arg to i64
23  %sext = sext i32 %arg to i64
24  br label %bb3
25
26bb3:
27  %getelementptr = getelementptr i64, ptr addrspace(1) null, i64 %zext
28  %getelementptr4 = getelementptr i64, ptr addrspace(1) null, i64 %zext2
29  %getelementptr5 = getelementptr i64, ptr addrspace(1) null, i64 %sext
30  %zext6 = zext i32 0 to i64
31  %getelementptr7 = getelementptr i64, ptr addrspace(1) null, i64 %zext6
32  ret i32 0
33}
34