blob: c6ce82737d0b15fdcb29e53eee82de7f804b7405 [file] [log] [blame]
Tyler Nowicki9d268e12015-06-11 23:23:17 +00001// RUN: %clang_cc1 -triple x86_64-apple-darwin -std=c++11 -emit-llvm -o - %s | FileCheck %s
2
3// Verify assume_safety vectorization is recognized.
4void vectorize_test(int *List, int Length) {
Tyler Nowicki54c020d2015-07-27 20:10:20 +00005// CHECK: define {{.*}} @_Z14vectorize_test
Tyler Nowicki9d268e12015-06-11 23:23:17 +00006// CHECK: [[LOAD1_IV:.+]] = load i32, i32* [[IV1:[^,]+]], {{.*}}!llvm.mem.parallel_loop_access ![[LOOP1_ID:[0-9]+]]
7// CHECK-NEXT: [[LOAD1_LEN:.+]] = load i32, i32* [[LEN1:.+]], {{.*}}!llvm.mem.parallel_loop_access ![[LOOP1_ID]]
8// CHECK-NEXT: [[CMP1:.+]] = icmp slt i32[[LOAD1_IV]],[[LOAD1_LEN]]
Tyler Nowicki54c020d2015-07-27 20:10:20 +00009// CHECK-NEXT: br i1[[CMP1]], label %[[LOOP1_BODY:[^,]+]], label %[[LOOP1_END:[^,]+]]
10#pragma clang loop vectorize(assume_safety) interleave(disable) unroll(disable)
Tyler Nowicki9d268e12015-06-11 23:23:17 +000011 for (int i = 0; i < Length; i++) {
Tyler Nowicki54c020d2015-07-27 20:10:20 +000012 // CHECK: [[RHIV1:.+]] = load i32, i32* [[IV1]], {{.*}}!llvm.mem.parallel_loop_access ![[LOOP1_ID]]
Richard Smith9e67b992016-09-26 23:49:47 +000013 // CHECK-DAG: [[CALC1:.+]] = mul nsw i32[[RHIV1]], 2
14 // CHECK-DAG: [[SIV1:.+]] = load i32, i32* [[IV1]]{{.*}}!llvm.mem.parallel_loop_access ![[LOOP1_ID]]
15 // CHECK-DAG: [[INDEX1:.+]] = sext i32[[SIV1]] to i64
16 // CHECK-DAG: [[ARRAY1:.+]] = load i32*, i32** [[LIST1:.*]], {{.*}}!llvm.mem.parallel_loop_access ![[LOOP1_ID]]
17 // CHECK-DAG: [[PTR1:.+]] = getelementptr inbounds i32, i32*[[ARRAY1]], i64[[INDEX1]]
18 // CHECK: store i32[[CALC1]], i32*[[PTR1]], {{.*}}!llvm.mem.parallel_loop_access ![[LOOP1_ID]]
Tyler Nowicki54c020d2015-07-27 20:10:20 +000019 // CHECK-NEXT: br label [[LOOP1_INC:[^,]+]]
Tyler Nowicki9d268e12015-06-11 23:23:17 +000020 List[i] = i * 2;
Tyler Nowicki54c020d2015-07-27 20:10:20 +000021
22 // CHECK: br label [[LOOP1_COND:[^,]+]], !llvm.loop ![[LOOP1_HINTS:[0-9]+]]
Tyler Nowicki9d268e12015-06-11 23:23:17 +000023 }
Tyler Nowicki9d268e12015-06-11 23:23:17 +000024}
25
26// Verify assume_safety interleaving is recognized.
27void interleave_test(int *List, int Length) {
Tyler Nowicki54c020d2015-07-27 20:10:20 +000028// CHECK: define {{.*}} @_Z15interleave_test
Tyler Nowicki9d268e12015-06-11 23:23:17 +000029// CHECK: [[LOAD2_IV:.+]] = load i32, i32* [[IV2:[^,]+]], {{.*}}!llvm.mem.parallel_loop_access ![[LOOP2_ID:[0-9]+]]
30// CHECK-NEXT: [[LOAD2_LEN:.+]] = load i32, i32* [[LEN2:.+]], {{.*}}!llvm.mem.parallel_loop_access ![[LOOP2_ID]]
31// CHECK-NEXT: [[CMP2:.+]] = icmp slt i32[[LOAD2_IV]],[[LOAD2_LEN]]
Tyler Nowicki54c020d2015-07-27 20:10:20 +000032// CHECK-NEXT: br i1[[CMP2]], label %[[LOOP2_BODY:[^,]+]], label %[[LOOP2_END:[^,]+]]
33#pragma clang loop interleave(assume_safety) vectorize(disable) unroll(disable)
Tyler Nowicki9d268e12015-06-11 23:23:17 +000034 for (int i = 0; i < Length; i++) {
Tyler Nowicki54c020d2015-07-27 20:10:20 +000035 // CHECK: [[RHIV2:.+]] = load i32, i32* [[IV2]], {{.*}}!llvm.mem.parallel_loop_access ![[LOOP2_ID]]
Richard Smith9e67b992016-09-26 23:49:47 +000036 // CHECK-DAG: [[CALC2:.+]] = mul nsw i32[[RHIV2]], 2
37 // CHECK-DAG: [[SIV2:.+]] = load i32, i32* [[IV2]]{{.*}}!llvm.mem.parallel_loop_access ![[LOOP2_ID]]
38 // CHECK-DAG: [[INDEX2:.+]] = sext i32[[SIV2]] to i64
39 // CHECK-DAG: [[ARRAY2:.+]] = load i32*, i32** [[LIST2:.*]], {{.*}}!llvm.mem.parallel_loop_access ![[LOOP2_ID]]
40 // CHECK-DAG: [[PTR2:.+]] = getelementptr inbounds i32, i32*[[ARRAY2]], i64[[INDEX2]]
41 // CHECK: store i32[[CALC2]], i32*[[PTR2]], {{.*}}!llvm.mem.parallel_loop_access ![[LOOP2_ID]]
Tyler Nowicki54c020d2015-07-27 20:10:20 +000042 // CHECK-NEXT: br label [[LOOP2_INC:[^,]+]]
Tyler Nowicki9d268e12015-06-11 23:23:17 +000043 List[i] = i * 2;
Tyler Nowicki54c020d2015-07-27 20:10:20 +000044
45 // CHECK: br label [[LOOP2_COND:[^,]+]], !llvm.loop ![[LOOP2_HINTS:[0-9]+]]
Tyler Nowicki9d268e12015-06-11 23:23:17 +000046 }
Tyler Nowicki9d268e12015-06-11 23:23:17 +000047}
48
Tyler Nowicki54c020d2015-07-27 20:10:20 +000049// CHECK: ![[LOOP1_HINTS]] = distinct !{![[LOOP1_HINTS]], ![[INTERLEAVE_1:[0-9]+]], ![[INTENABLE_1:[0-9]+]], ![[UNROLL_DISABLE:[0-9]+]]}
50// CHECK: ![[INTERLEAVE_1]] = !{!"llvm.loop.interleave.count", i32 1}
Tyler Nowicki9d268e12015-06-11 23:23:17 +000051// CHCCK: ![[INTENABLE_1]] = !{!"llvm.loop.vectorize.enable", i1 true}
Tyler Nowicki54c020d2015-07-27 20:10:20 +000052// CHECK: ![[UNROLL_DISABLE]] = !{!"llvm.loop.unroll.disable"}
53// CHECK: ![[LOOP2_HINTS]] = distinct !{![[LOOP2_HINTS]], ![[WIDTH_1:[0-9]+]], ![[INTENABLE_1]], ![[UNROLL_DISABLE]]}
54// CHECK: ![[WIDTH_1]] = !{!"llvm.loop.vectorize.width", i32 1}