| // RUN: mlir-translate -mlir-to-llvmir %s | FileCheck %s |
| |
| llvm.func @prefetch_L1(%gen_ptr: !llvm.ptr, %local_ptr: !llvm.ptr<5>, %global_ptr: !llvm.ptr<1>) { |
| // CHECK-LABEL: define void @prefetch_L1(ptr %0, ptr addrspace(5) %1, ptr addrspace(1) %2) { |
| // CHECK-NEXT: call void @llvm.nvvm.prefetch.L1(ptr %0) |
| // CHECK-NEXT: call void @llvm.nvvm.prefetch.local.L1(ptr addrspace(5) %1) |
| // CHECK-NEXT: call void @llvm.nvvm.prefetch.global.L1(ptr addrspace(1) %2) |
| // CHECK-NEXT: ret void |
| // CHECK-NEXT: } |
| nvvm.prefetch level = L1, %gen_ptr : !llvm.ptr<0> |
| nvvm.prefetch level = L1, %local_ptr : !llvm.ptr<5> |
| nvvm.prefetch level = L1, %global_ptr : !llvm.ptr<1> |
| llvm.return |
| } |
| |
| llvm.func @prefetch_L2(%gen_ptr: !llvm.ptr, %local_ptr: !llvm.ptr<5>, %global_ptr: !llvm.ptr<1>) { |
| // CHECK-LABEL: define void @prefetch_L2(ptr %0, ptr addrspace(5) %1, ptr addrspace(1) %2) { |
| // CHECK-NEXT: call void @llvm.nvvm.prefetch.L2(ptr %0) |
| // CHECK-NEXT: call void @llvm.nvvm.prefetch.local.L2(ptr addrspace(5) %1) |
| // CHECK-NEXT: call void @llvm.nvvm.prefetch.global.L2(ptr addrspace(1) %2) |
| // CHECK-NEXT: ret void |
| // CHECK-NEXT: } |
| nvvm.prefetch level = L2, %gen_ptr : !llvm.ptr<0> |
| nvvm.prefetch level = L2, %local_ptr : !llvm.ptr<5> |
| nvvm.prefetch level = L2, %global_ptr : !llvm.ptr<1> |
| llvm.return |
| } |
| |
| llvm.func @prefetch_L2_eviction_priority(%global_ptr: !llvm.ptr<1>) { |
| // CHECK-LABEL: define void @prefetch_L2_eviction_priority(ptr addrspace(1) %0) { |
| // CHECK-NEXT: call void @llvm.nvvm.prefetch.global.L2.evict.last(ptr addrspace(1) %0) |
| // CHECK-NEXT: call void @llvm.nvvm.prefetch.global.L2.evict.normal(ptr addrspace(1) %0) |
| // CHECK-NEXT: ret void |
| // CHECK-NEXT: } |
| nvvm.prefetch level = L2, evict_priority = evict_last, %global_ptr : !llvm.ptr<1> |
| nvvm.prefetch level = L2, evict_priority = evict_normal, %global_ptr : !llvm.ptr<1> |
| llvm.return |
| } |
| |
| llvm.func @prefetch_L1_uniform(%gen_ptr: !llvm.ptr) { |
| // CHECK-LABEL: define void @prefetch_L1_uniform(ptr %0) { |
| // CHECK-NEXT: call void @llvm.nvvm.prefetchu.L1(ptr %0) |
| // CHECK-NEXT: ret void |
| // CHECK-NEXT: } |
| nvvm.prefetch level = L1 uniform, %gen_ptr : !llvm.ptr |
| llvm.return |
| } |
| |
| llvm.func @prefetch_tensormap(%gen_ptr: !llvm.ptr, %const_ptr: !llvm.ptr<4>) { |
| // CHECK-LABEL: define void @prefetch_tensormap(ptr %0, ptr addrspace(4) %1) { |
| // CHECK-NEXT: call void @llvm.nvvm.prefetch.tensormap.p0(ptr %0) |
| // CHECK-NEXT: call void @llvm.nvvm.prefetch.tensormap.p4(ptr addrspace(4) %1) |
| // CHECK-NEXT: %3 = addrspacecast ptr %0 to ptr addrspace(101) |
| // CHECK-NEXT: call void @llvm.nvvm.prefetch.tensormap.p101(ptr addrspace(101) %3) |
| // CHECK-NEXT: ret void |
| // CHECK-NEXT: } |
| nvvm.prefetch tensormap, %gen_ptr : !llvm.ptr |
| nvvm.prefetch tensormap, %const_ptr: !llvm.ptr<4> |
| nvvm.prefetch tensormap in_param_space, %gen_ptr : !llvm.ptr |
| llvm.return |
| } |