This commit adds an intrinsic that will read from an image buffer. We chose to match the name of the DXIL intrinsic for simplicity in clang. We cannot reuse the existing openCL readimage function because that is not a reserved name in HLSL. I considered trying to refactor generateReadImageInst, so that we could share code between the two implementations. However, most of the code in generateReadImageInst is concerned with trying to figure out which type of image read is being done. Once we factor out the code that will be common, then we end up with just a single call to the MIRBuilder being common.
51 lines
2.5 KiB
LLVM
51 lines
2.5 KiB
LLVM
; RUN: llc -O0 -mtriple=spirv64-unknown-unknown %s -o - | FileCheck %s --check-prefix=CHECK-SPIRV
|
|
|
|
; CHECK-SPIRV: OpCapability StorageImageReadWithoutFormat
|
|
|
|
; CHECK-SPIRV: %[[#IntTy:]] = OpTypeInt
|
|
; CHECK-SPIRV: %[[#IVecTy:]] = OpTypeVector %[[#IntTy]]
|
|
; CHECK-SPIRV: %[[#FloatTy:]] = OpTypeFloat
|
|
; CHECK-SPIRV: %[[#FVecTy:]] = OpTypeVector %[[#FloatTy]]
|
|
; CHECK-SPIRV: OpImageRead %[[#IVecTy]]
|
|
; CHECK-SPIRV: OpImageRead %[[#FVecTy]]
|
|
|
|
;; __kernel void kernelA(__read_only image3d_t input) {
|
|
;; uint4 c = read_imageui(input, (int4)(0, 0, 0, 0));
|
|
;; }
|
|
;;
|
|
;; __kernel void kernelB(__read_only image3d_t input) {
|
|
;; float4 f = read_imagef(input, (int4)(0, 0, 0, 0));
|
|
;; }
|
|
|
|
define dso_local spir_kernel void @kernelA(target("spirv.Image", void, 2, 0, 0, 0, 0, 0, 0) %input) {
|
|
entry:
|
|
%input.addr = alloca target("spirv.Image", void, 2, 0, 0, 0, 0, 0, 0), align 8
|
|
%c = alloca <4 x i32>, align 16
|
|
%.compoundliteral = alloca <4 x i32>, align 16
|
|
store target("spirv.Image", void, 2, 0, 0, 0, 0, 0, 0) %input, ptr %input.addr, align 8
|
|
%0 = load target("spirv.Image", void, 2, 0, 0, 0, 0, 0, 0), ptr %input.addr, align 8
|
|
store <4 x i32> zeroinitializer, ptr %.compoundliteral, align 16
|
|
%1 = load <4 x i32>, ptr %.compoundliteral, align 16
|
|
%call = call spir_func <4 x i32> @_Z12read_imageui14ocl_image3d_roDv4_i(target("spirv.Image", void, 2, 0, 0, 0, 0, 0, 0) %0, <4 x i32> noundef %1)
|
|
store <4 x i32> %call, ptr %c, align 16
|
|
ret void
|
|
}
|
|
|
|
declare spir_func <4 x i32> @_Z12read_imageui14ocl_image3d_roDv4_i(target("spirv.Image", void, 2, 0, 0, 0, 0, 0, 0) %0, <4 x i32> noundef %1)
|
|
|
|
define dso_local spir_kernel void @kernelB(target("spirv.Image", void, 2, 0, 0, 0, 0, 0, 0) %input) {
|
|
entry:
|
|
%input.addr = alloca target("spirv.Image", void, 2, 0, 0, 0, 0, 0, 0), align 8
|
|
%f = alloca <4 x float>, align 16
|
|
%.compoundliteral = alloca <4 x i32>, align 16
|
|
store target("spirv.Image", void, 2, 0, 0, 0, 0, 0, 0) %input, ptr %input.addr, align 8
|
|
%0 = load target("spirv.Image", void, 2, 0, 0, 0, 0, 0, 0), ptr %input.addr, align 8
|
|
store <4 x i32> zeroinitializer, ptr %.compoundliteral, align 16
|
|
%1 = load <4 x i32>, ptr %.compoundliteral, align 16
|
|
%call = call spir_func <4 x float> @_Z11read_imagef14ocl_image3d_roDv4_i(target("spirv.Image", void, 2, 0, 0, 0, 0, 0, 0) %0, <4 x i32> noundef %1)
|
|
store <4 x float> %call, ptr %f, align 16
|
|
ret void
|
|
}
|
|
|
|
declare spir_func <4 x float> @_Z11read_imagef14ocl_image3d_roDv4_i(target("spirv.Image", void, 2, 0, 0, 0, 0, 0, 0) %0, <4 x i32> noundef %1)
|