| OLD | NEW |
| 1 ; RUN: opt < %s -rewrite-llvm-intrinsic-calls -S | FileCheck %s | 1 ; RUN: opt < %s -rewrite-llvm-intrinsic-calls -S | FileCheck %s |
| 2 ; RUN: opt < %s -rewrite-llvm-intrinsic-calls -S | FileCheck %s -check-prefix=CL
EANED | 2 ; RUN: opt < %s -rewrite-llvm-intrinsic-calls -S | FileCheck %s -check-prefix=CL
EANED |
| 3 ; Test the @llvm.prefetch part of the RewriteLLVMIntrinsics pass | 3 ; Test the @llvm.prefetch part of the RewriteLLVMIntrinsics pass |
| 4 | 4 |
| 5 declare void @llvm.prefetch(i8 *%ptr, i32 %rw, i32 %locality, i32 %cache_type) | 5 declare void @llvm.prefetch(i8 *%ptr, i32 %rw, i32 %locality, i32 %cache_type) |
| 6 | 6 |
| 7 ; No declaration or definition of llvm.prefetch() should remain. | 7 ; No declaration or definition of llvm.prefetch() should remain. |
| 8 ; CLEANED-NOT: @llvm.prefetch | 8 ; CLEANED-NOT: @llvm.prefetch |
| 9 | 9 |
| 10 define void @call_prefetch(i8 *%ptr, i32 %rw, i32 %locality, i32 %cache_type) { | 10 define void @call_prefetch(i8 *%ptr) { |
| 11 ; CHECK: call_prefetch | 11 ; CHECK: call_prefetch |
| 12 ; CHECK-NEXT: ret void | 12 ; CHECK-NEXT: ret void |
| 13 call void @llvm.prefetch(i8 *%ptr, i32 %rw, i32 %locality, i32 %cache_type) | 13 call void @llvm.prefetch(i8 *%ptr, i32 0, i32 0, i32 0) |
| 14 ret void | 14 ret void |
| 15 } | 15 } |
| 16 | 16 |
| 17 ; A more complex example with a number of calls in several BBs. | 17 ; A more complex example with a number of calls in several BBs. |
| 18 define void @multiple_calls(i8 *%ptr, i32 %rw, i32 %locality, i32 %cache_type) { | 18 define void @multiple_calls(i8 *%ptr) { |
| 19 ; CHECK: multiple_calls | 19 ; CHECK: multiple_calls |
| 20 entryblock: | 20 entryblock: |
| 21 ; CHECK: entryblock | 21 ; CHECK: entryblock |
| 22 ; CHECK-NEXT: br | 22 ; CHECK-NEXT: br |
| 23 call void @llvm.prefetch(i8 *%ptr, i32 %rw, i32 %locality, i32 %cache_type) | 23 call void @llvm.prefetch(i8 *%ptr, i32 1, i32 2, i32 1) |
| 24 br label %block1 | 24 br label %block1 |
| 25 block1: | 25 block1: |
| 26 ; CHECK: block1: | 26 ; CHECK: block1: |
| 27 ; CHECK-NEXT: br | 27 ; CHECK-NEXT: br |
| 28 call void @llvm.prefetch(i8 *%ptr, i32 %rw, i32 %locality, i32 %cache_type) | 28 call void @llvm.prefetch(i8 *%ptr, i32 0, i32 1, i32 0) |
| 29 br label %exitblock | 29 br label %exitblock |
| 30 exitblock: | 30 exitblock: |
| 31 ; CHECK: exitblock: | 31 ; CHECK: exitblock: |
| 32 ; CHECK-NEXT: ret void | 32 ; CHECK-NEXT: ret void |
| 33 call void @llvm.prefetch(i8 *%ptr, i32 %rw, i32 %locality, i32 %cache_type) | 33 call void @llvm.prefetch(i8 *%ptr, i32 1, i32 3, i32 1) |
| 34 ret void | 34 ret void |
| 35 } | 35 } |
| OLD | NEW |