xref: /llvm-project/llvm/test/CodeGen/DirectX/RawBufferLoad-error64.ll (revision cba9bd5cb07717daabcddd9850957b3a1cfe3e47)
1; We use llc for this test so that we don't abort after the first error.
2; RUN: not llc %s -o /dev/null 2>&1 | FileCheck %s
3
4target triple = "dxil-pc-shadermodel6.2-compute"
5
6declare void @v4f64_user(<4 x double>)
7
8; Can't load 64 bit types directly until SM6.3 (byteaddressbuf.Load<int64_t4>)
9; CHECK: error:
10; CHECK-SAME: in function loadv4f64_byte
11; CHECK-SAME: Cannot create RawBufferLoad operation: Invalid overload type
12define void @loadv4f64_byte(i32 %offset) "hlsl.export" {
13  %buffer = call target("dx.RawBuffer", i8, 0, 0, 0)
14      @llvm.dx.resource.handlefrombinding.tdx.RawBuffer_i8_0_0_0(
15          i32 0, i32 0, i32 1, i32 0, i1 false)
16
17  %load = call {<4 x double>, i1} @llvm.dx.resource.load.rawbuffer.v4i64(
18      target("dx.RawBuffer", i8, 0, 0, 0) %buffer, i32 %offset, i32 0)
19  %data = extractvalue {<4 x double>, i1} %load, 0
20
21  call void @v4f64_user(<4 x double> %data)
22
23  ret void
24}
25