xref: /llvm-project/llvm/test/Transforms/SLPVectorizer/X86/cmp-diff-sized.ll (revision 3c3ea7e751bc18cc8598955bcd853d3c34ffee2d)
1aebf0855SAlexey Bataev; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
2aebf0855SAlexey Bataev; RUN: opt < %s -passes=slp-vectorizer -S -mtriple=x86_64--- | FileCheck %s
3aebf0855SAlexey Bataev
4aebf0855SAlexey Bataevdefine void @test(ptr noalias %a, ptr %b) {
5aebf0855SAlexey Bataev; CHECK-LABEL: @test(
6aebf0855SAlexey Bataev; CHECK-NEXT:    [[PA1:%.*]] = getelementptr inbounds i64, ptr [[A:%.*]], i32 64
7aebf0855SAlexey Bataev; CHECK-NEXT:    [[A1:%.*]] = load i64, ptr [[PA1]], align 8
8aebf0855SAlexey Bataev; CHECK-NEXT:    [[PB1:%.*]] = getelementptr inbounds i64, ptr [[B:%.*]], i32 64
9aebf0855SAlexey Bataev; CHECK-NEXT:    [[B1:%.*]] = load i64, ptr [[PB1]], align 8
10*3c3ea7e7SAlexey Bataev; CHECK-NEXT:    [[TMP1:%.*]] = load <2 x i32>, ptr [[A]], align 4
11*3c3ea7e7SAlexey Bataev; CHECK-NEXT:    [[TMP2:%.*]] = load <2 x i32>, ptr [[B]], align 4
12aebf0855SAlexey Bataev; CHECK-NEXT:    [[C1:%.*]] = icmp eq i64 [[B1]], [[A1]]
13*3c3ea7e7SAlexey Bataev; CHECK-NEXT:    [[TMP3:%.*]] = icmp eq <2 x i32> [[TMP1]], [[TMP2]]
14aebf0855SAlexey Bataev; CHECK-NEXT:    ret void
15aebf0855SAlexey Bataev;
16aebf0855SAlexey Bataev  %pa1 = getelementptr inbounds i64, ptr %a, i32 64
17aebf0855SAlexey Bataev  %pa2 = getelementptr inbounds i32, ptr %a, i32 1
18aebf0855SAlexey Bataev  %a0 = load i32, ptr %a, align 4
19aebf0855SAlexey Bataev  %a1 = load i64, ptr %pa1, align 8
20aebf0855SAlexey Bataev  %a2 = load i32, ptr %pa2, align 4
21aebf0855SAlexey Bataev  %pb1 = getelementptr inbounds i64, ptr %b, i32 64
22aebf0855SAlexey Bataev  %pb2 = getelementptr inbounds i32, ptr %b, i32 1
23aebf0855SAlexey Bataev  %b0 = load i32, ptr %b, align 4
24aebf0855SAlexey Bataev  %b1 = load i64, ptr %pb1, align 8
25aebf0855SAlexey Bataev  %b2 = load i32, ptr %pb2, align 4
26aebf0855SAlexey Bataev  %c0 = icmp eq i32 %a0, %b0
27aebf0855SAlexey Bataev  %c1 = icmp eq i64 %b1, %a1
28aebf0855SAlexey Bataev  %c2 = icmp eq i32 %b2, %a2
29aebf0855SAlexey Bataev  ret void
30aebf0855SAlexey Bataev}
31