mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-10-29 23:12:55 +01:00
b035f9f3e4
This commit adds intrinsics and codegen support for the surface read/write and texture read instructions that take an explicit sampler parameter. Codegen operates on image handles at the PTX level, but falls back to direct replacement of handles with kernel arguments if image handles are not enabled. Note that image handles are explicitly disabled for all target architectures in this change (to be enabled later). llvm-svn: 205907
21 lines
724 B
LLVM
21 lines
724 B
LLVM
; RUN: llc < %s -march=nvptx -mcpu=sm_20 | FileCheck %s
|
|
|
|
target triple = "nvptx-unknown-nvcl"
|
|
|
|
declare i32 @llvm.nvvm.suld.1d.i32.trap(i64, i32)
|
|
|
|
; CHECK: .entry foo
|
|
define void @foo(i64 %img, float* %red, i32 %idx) {
|
|
; CHECK: suld.b.1d.b32.trap {%r[[RED:[0-9]+]]}, [foo_param_0, {%r{{[0-9]+}}}]
|
|
%val = tail call i32 @llvm.nvvm.suld.1d.i32.trap(i64 %img, i32 %idx)
|
|
; CHECK: cvt.rn.f32.s32 %f[[REDF:[0-9]+]], %r[[RED]]
|
|
%ret = sitofp i32 %val to float
|
|
; CHECK: st.f32 [%r{{[0-9]+}}], %f[[REDF]]
|
|
store float %ret, float* %red
|
|
ret void
|
|
}
|
|
|
|
!nvvm.annotations = !{!1, !2}
|
|
!1 = metadata !{void (i64, float*, i32)* @foo, metadata !"kernel", i32 1}
|
|
!2 = metadata !{void (i64, float*, i32)* @foo, metadata !"rdwrimage", i32 0}
|