Raw (as in ByteAddress) buffer accesses in DXIL must specify ElementIndex as undef, and Structured buffer accesses must specify a value. Ensure that we do this correctly in DXILResourceAccess, and enforce that the operations are valid in DXILOpLowering. Fixes #173316
79 lines
2.8 KiB
LLVM
79 lines
2.8 KiB
LLVM
; We use llc for this test so that we don't abort after the first error.
|
|
; RUN: not llc %s -o /dev/null 2>&1 | FileCheck %s
|
|
|
|
target triple = "dxil-pc-shadermodel6.6-compute"
|
|
|
|
declare void @f32_user(float)
|
|
|
|
; CHECK: error:
|
|
; CHECK-SAME: in function loadrawzero
|
|
; CHECK-SAME: Element index of raw buffer must be poison
|
|
define void @loadrawzero(i32 %offset) "hlsl.export" {
|
|
%buffer = call target("dx.RawBuffer", i8, 0, 0, 0)
|
|
@llvm.dx.resource.handlefrombinding(i32 0, i32 0, i32 1, i32 0, ptr null)
|
|
|
|
%load = call {float, i1}
|
|
@llvm.dx.resource.load.rawbuffer(
|
|
target("dx.RawBuffer", i8, 0, 0, 0) %buffer,
|
|
i32 %offset,
|
|
i32 0)
|
|
%data = extractvalue {float, i1} %load, 0
|
|
|
|
call void @f32_user(float %data)
|
|
|
|
ret void
|
|
}
|
|
|
|
; CHECK: error:
|
|
; CHECK-SAME: in function loadstructundef
|
|
; CHECK-SAME: Element index of structured buffer may not be poison
|
|
define void @loadstructundef(i32 %index) "hlsl.export" {
|
|
%buffer = call target("dx.RawBuffer", float, 0, 0, 0)
|
|
@llvm.dx.resource.handlefrombinding(i32 0, i32 0, i32 1, i32 0, ptr null)
|
|
|
|
%load = call {float, i1}
|
|
@llvm.dx.resource.load.rawbuffer(
|
|
target("dx.RawBuffer", float, 0, 0, 0) %buffer,
|
|
i32 %index,
|
|
i32 poison)
|
|
%data = extractvalue {float, i1} %load, 0
|
|
call void @f32_user(float %data)
|
|
|
|
ret void
|
|
}
|
|
|
|
; CHECK: error:
|
|
; CHECK-SAME: in function storerawzero
|
|
; CHECK-SAME: Element index of raw buffer must be poison
|
|
define void @storerawzero(i32 %offset, float %data) {
|
|
%buffer = call target("dx.RawBuffer", i8, 1, 0, 0)
|
|
@llvm.dx.resource.handlefrombinding(
|
|
i32 0, i32 0, i32 1, i32 0, ptr null)
|
|
|
|
call void @llvm.dx.resource.store.rawbuffer(
|
|
target("dx.RawBuffer", i8, 1, 0, 0) %buffer,
|
|
i32 %offset, i32 0, float %data)
|
|
|
|
ret void
|
|
}
|
|
|
|
; CHECK: error:
|
|
; CHECK-SAME: in function storestructundef
|
|
; CHECK-SAME: Element index of structured buffer may not be poison
|
|
define void @storestructundef(i32 %index, float %data) {
|
|
%buffer = call target("dx.RawBuffer", float, 1, 0, 0)
|
|
@llvm.dx.resource.handlefrombinding(
|
|
i32 0, i32 0, i32 1, i32 0, ptr null)
|
|
|
|
call void @llvm.dx.resource.store.rawbuffer(
|
|
target("dx.RawBuffer", float, 1, 0, 0) %buffer,
|
|
i32 %index, i32 poison, float %data)
|
|
|
|
ret void
|
|
}
|
|
|
|
declare { float, i1 } @llvm.dx.resource.load.rawbuffer.f32.tdx.RawBuffer_i8_0_0_0t(target("dx.RawBuffer", i8, 0, 0, 0), i32, i32)
|
|
declare { float, i1 } @llvm.dx.resource.load.rawbuffer.f32.tdx.RawBuffer_f32_0_0_0t(target("dx.RawBuffer", float, 0, 0, 0), i32, i32)
|
|
declare void @llvm.dx.resource.store.rawbuffer.tdx.RawBuffer_i8_1_0_0t.f32(target("dx.RawBuffer", i8, 1, 0, 0), i32, i32, float)
|
|
declare void @llvm.dx.resource.store.rawbuffer.tdx.RawBuffer_f32_1_0_0t.f32(target("dx.RawBuffer", float, 1, 0, 0), i32, i32, float)
|