Add basic supports of storage textures on D3D12
This patch adds the basic supports of read-only and write-only storage textures on D3D12. The subresource tracking and barriers on the subresources used as read-only and write-only storage textures are not included in this patch. BUG=dawn:267 TEST=dawn_end2end_tests Change-Id: Ie29a3a9962cd1a79217bc87815ed0bd27623e3a8 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/21140 Reviewed-by: Austin Eng <enga@chromium.org> Commit-Queue: Jiawei Shao <jiawei.shao@intel.com>
This commit is contained in:
parent
458ab1bf7f
commit
e8bf706d16
|
@ -115,7 +115,11 @@ namespace dawn_native { namespace d3d12 {
|
||||||
viewAllocation.OffsetFrom(viewSizeIncrement, bindingOffsets[bindingIndex]));
|
viewAllocation.OffsetFrom(viewSizeIncrement, bindingOffsets[bindingIndex]));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case wgpu::BindingType::SampledTexture: {
|
|
||||||
|
// Readonly storage is implemented as SRV so it can be used at the same time as a
|
||||||
|
// sampled texture.
|
||||||
|
case wgpu::BindingType::SampledTexture:
|
||||||
|
case wgpu::BindingType::ReadonlyStorageTexture: {
|
||||||
auto* view = ToBackend(GetBindingAsTextureView(bindingIndex));
|
auto* view = ToBackend(GetBindingAsTextureView(bindingIndex));
|
||||||
auto& srv = view->GetSRVDescriptor();
|
auto& srv = view->GetSRVDescriptor();
|
||||||
d3d12Device->CreateShaderResourceView(
|
d3d12Device->CreateShaderResourceView(
|
||||||
|
@ -133,9 +137,16 @@ namespace dawn_native { namespace d3d12 {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
case wgpu::BindingType::WriteonlyStorageTexture: {
|
||||||
|
TextureView* view = ToBackend(GetBindingAsTextureView(bindingIndex));
|
||||||
|
D3D12_UNORDERED_ACCESS_VIEW_DESC uav = view->GetUAVDescriptor();
|
||||||
|
d3d12Device->CreateUnorderedAccessView(
|
||||||
|
ToBackend(view->GetTexture())->GetD3D12Resource(), nullptr, &uav,
|
||||||
|
viewAllocation.OffsetFrom(viewSizeIncrement, bindingOffsets[bindingIndex]));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case wgpu::BindingType::StorageTexture:
|
case wgpu::BindingType::StorageTexture:
|
||||||
case wgpu::BindingType::ReadonlyStorageTexture:
|
|
||||||
case wgpu::BindingType::WriteonlyStorageTexture:
|
|
||||||
UNREACHABLE();
|
UNREACHABLE();
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
|
@ -166,9 +166,21 @@ namespace dawn_native { namespace d3d12 {
|
||||||
wgpu::BufferUsage::Storage);
|
wgpu::BufferUsage::Storage);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case wgpu::BindingType::StorageTexture:
|
|
||||||
case wgpu::BindingType::ReadonlyStorageTexture:
|
case wgpu::BindingType::ReadonlyStorageTexture:
|
||||||
|
ToBackend(static_cast<TextureView*>(mBindings[index][binding])
|
||||||
|
->GetTexture())
|
||||||
|
->TrackUsageAndTransitionNow(commandContext,
|
||||||
|
kReadonlyStorageTexture);
|
||||||
|
break;
|
||||||
|
|
||||||
case wgpu::BindingType::WriteonlyStorageTexture:
|
case wgpu::BindingType::WriteonlyStorageTexture:
|
||||||
|
ToBackend(static_cast<TextureView*>(mBindings[index][binding])
|
||||||
|
->GetTexture())
|
||||||
|
->TrackUsageAndTransitionNow(commandContext,
|
||||||
|
wgpu::TextureUsage::Storage);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case wgpu::BindingType::StorageTexture:
|
||||||
// Not implemented.
|
// Not implemented.
|
||||||
|
|
||||||
case wgpu::BindingType::UniformBuffer:
|
case wgpu::BindingType::UniformBuffer:
|
||||||
|
|
|
@ -51,6 +51,7 @@ namespace dawn_native { namespace d3d12 {
|
||||||
// See https://github.com/gpuweb/gpuweb/issues/332
|
// See https://github.com/gpuweb/gpuweb/issues/332
|
||||||
options.SetHLSLPointCoordCompat(true);
|
options.SetHLSLPointCoordCompat(true);
|
||||||
options.SetHLSLPointSizeCompat(true);
|
options.SetHLSLPointSizeCompat(true);
|
||||||
|
options.SetHLSLNonWritableUAVTextureAsSRV(true);
|
||||||
|
|
||||||
DAWN_TRY(CheckSpvcSuccess(
|
DAWN_TRY(CheckSpvcSuccess(
|
||||||
mSpvcContext.InitializeForHlsl(spirv.data(), spirv.size(), options),
|
mSpvcContext.InitializeForHlsl(spirv.data(), spirv.size(), options),
|
||||||
|
@ -90,6 +91,7 @@ namespace dawn_native { namespace d3d12 {
|
||||||
// See https://github.com/gpuweb/gpuweb/issues/332
|
// See https://github.com/gpuweb/gpuweb/issues/332
|
||||||
options_hlsl.point_coord_compat = true;
|
options_hlsl.point_coord_compat = true;
|
||||||
options_hlsl.point_size_compat = true;
|
options_hlsl.point_size_compat = true;
|
||||||
|
options_hlsl.nonwritable_uav_texture_as_srv = true;
|
||||||
|
|
||||||
compilerImpl = std::make_unique<spirv_cross::CompilerHLSL>(spirv);
|
compilerImpl = std::make_unique<spirv_cross::CompilerHLSL>(spirv);
|
||||||
compiler = compilerImpl.get();
|
compiler = compilerImpl.get();
|
||||||
|
|
|
@ -48,7 +48,7 @@ namespace dawn_native { namespace d3d12 {
|
||||||
if (usage & wgpu::TextureUsage::CopyDst) {
|
if (usage & wgpu::TextureUsage::CopyDst) {
|
||||||
resourceState |= D3D12_RESOURCE_STATE_COPY_DEST;
|
resourceState |= D3D12_RESOURCE_STATE_COPY_DEST;
|
||||||
}
|
}
|
||||||
if (usage & wgpu::TextureUsage::Sampled) {
|
if (usage & (wgpu::TextureUsage::Sampled | kReadonlyStorageTexture)) {
|
||||||
resourceState |= (D3D12_RESOURCE_STATE_PIXEL_SHADER_RESOURCE |
|
resourceState |= (D3D12_RESOURCE_STATE_PIXEL_SHADER_RESOURCE |
|
||||||
D3D12_RESOURCE_STATE_NON_PIXEL_SHADER_RESOURCE);
|
D3D12_RESOURCE_STATE_NON_PIXEL_SHADER_RESOURCE);
|
||||||
}
|
}
|
||||||
|
@ -830,4 +830,17 @@ namespace dawn_native { namespace d3d12 {
|
||||||
->GetDSVDescriptor(mipLevel, GetBaseArrayLayer(), GetLayerCount());
|
->GetDSVDescriptor(mipLevel, GetBaseArrayLayer(), GetLayerCount());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
D3D12_UNORDERED_ACCESS_VIEW_DESC TextureView::GetUAVDescriptor() const {
|
||||||
|
D3D12_UNORDERED_ACCESS_VIEW_DESC uavDesc;
|
||||||
|
uavDesc.Format = GetD3D12Format();
|
||||||
|
|
||||||
|
ASSERT(!GetTexture()->IsMultisampledTexture());
|
||||||
|
uavDesc.ViewDimension = D3D12_UAV_DIMENSION_TEXTURE2DARRAY;
|
||||||
|
uavDesc.Texture2DArray.FirstArraySlice = GetBaseArrayLayer();
|
||||||
|
uavDesc.Texture2DArray.ArraySize = GetLayerCount();
|
||||||
|
uavDesc.Texture2DArray.MipSlice = GetBaseMipLevel();
|
||||||
|
uavDesc.Texture2DArray.PlaneSlice = 0;
|
||||||
|
return uavDesc;
|
||||||
|
}
|
||||||
|
|
||||||
}} // namespace dawn_native::d3d12
|
}} // namespace dawn_native::d3d12
|
||||||
|
|
|
@ -116,6 +116,7 @@ namespace dawn_native { namespace d3d12 {
|
||||||
const D3D12_SHADER_RESOURCE_VIEW_DESC& GetSRVDescriptor() const;
|
const D3D12_SHADER_RESOURCE_VIEW_DESC& GetSRVDescriptor() const;
|
||||||
D3D12_RENDER_TARGET_VIEW_DESC GetRTVDescriptor() const;
|
D3D12_RENDER_TARGET_VIEW_DESC GetRTVDescriptor() const;
|
||||||
D3D12_DEPTH_STENCIL_VIEW_DESC GetDSVDescriptor() const;
|
D3D12_DEPTH_STENCIL_VIEW_DESC GetDSVDescriptor() const;
|
||||||
|
D3D12_UNORDERED_ACCESS_VIEW_DESC GetUAVDescriptor() const;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
D3D12_SHADER_RESOURCE_VIEW_DESC mSrvDesc;
|
D3D12_SHADER_RESOURCE_VIEW_DESC mSrvDesc;
|
||||||
|
|
|
@ -237,8 +237,14 @@ TEST_P(StorageTextureTests, BindGroupLayoutWithStorageTextureBindingType) {
|
||||||
|
|
||||||
// Test that read-only storage textures are supported in compute shader.
|
// Test that read-only storage textures are supported in compute shader.
|
||||||
TEST_P(StorageTextureTests, ReadonlyStorageTextureInComputeShader) {
|
TEST_P(StorageTextureTests, ReadonlyStorageTextureInComputeShader) {
|
||||||
// TODO(jiawei.shao@intel.com): support read-only storage texture on D3D12 and OpenGL.
|
// TODO(jiawei.shao@intel.com): support read-only storage texture on OpenGL.
|
||||||
DAWN_SKIP_TEST_IF(IsD3D12() || IsOpenGL());
|
DAWN_SKIP_TEST_IF(IsOpenGL());
|
||||||
|
|
||||||
|
// When we run dawn_end2end_tests with "--use-spvc-parser", extracting the binding type of a
|
||||||
|
// read-only image will always return shaderc_spvc_binding_type_writeonly_storage_texture.
|
||||||
|
// TODO(jiawei.shao@intel.com): enable this test when we specify "--use-spvc-parser" after the
|
||||||
|
// bug in spvc parser is fixed.
|
||||||
|
DAWN_SKIP_TEST_IF(IsD3D12() && IsSpvcParserBeingUsed());
|
||||||
|
|
||||||
// Prepare the read-only storage texture and fill it with the expected data.
|
// Prepare the read-only storage texture and fill it with the expected data.
|
||||||
// TODO(jiawei.shao@intel.com): test more texture formats.
|
// TODO(jiawei.shao@intel.com): test more texture formats.
|
||||||
|
@ -292,8 +298,8 @@ TEST_P(StorageTextureTests, ReadonlyStorageTextureInComputeShader) {
|
||||||
|
|
||||||
// Test that read-only storage textures are supported in vertex shader.
|
// Test that read-only storage textures are supported in vertex shader.
|
||||||
TEST_P(StorageTextureTests, ReadonlyStorageTextureInVertexShader) {
|
TEST_P(StorageTextureTests, ReadonlyStorageTextureInVertexShader) {
|
||||||
// TODO(jiawei.shao@intel.com): support read-only storage texture on D3D12 and OpenGL.
|
// TODO(jiawei.shao@intel.com): support read-only storage texture on OpenGL.
|
||||||
DAWN_SKIP_TEST_IF(IsD3D12() || IsOpenGL());
|
DAWN_SKIP_TEST_IF(IsOpenGL());
|
||||||
|
|
||||||
// When we run dawn_end2end_tests with "--use-spvc-parser", extracting the binding type of a
|
// When we run dawn_end2end_tests with "--use-spvc-parser", extracting the binding type of a
|
||||||
// read-only image will always return shaderc_spvc_binding_type_writeonly_storage_texture.
|
// read-only image will always return shaderc_spvc_binding_type_writeonly_storage_texture.
|
||||||
|
@ -336,8 +342,8 @@ TEST_P(StorageTextureTests, ReadonlyStorageTextureInVertexShader) {
|
||||||
|
|
||||||
// Test that read-only storage textures are supported in fragment shader.
|
// Test that read-only storage textures are supported in fragment shader.
|
||||||
TEST_P(StorageTextureTests, ReadonlyStorageTextureInFragmentShader) {
|
TEST_P(StorageTextureTests, ReadonlyStorageTextureInFragmentShader) {
|
||||||
// TODO(jiawei.shao@intel.com): support read-only storage texture on D3D12 and OpenGL.
|
// TODO(jiawei.shao@intel.com): support read-only storage texture on OpenGL.
|
||||||
DAWN_SKIP_TEST_IF(IsD3D12() || IsOpenGL());
|
DAWN_SKIP_TEST_IF(IsOpenGL());
|
||||||
|
|
||||||
// When we run dawn_end2end_tests with "--use-spvc-parser", extracting the binding type of a
|
// When we run dawn_end2end_tests with "--use-spvc-parser", extracting the binding type of a
|
||||||
// read-only image will always return shaderc_spvc_binding_type_writeonly_storage_texture.
|
// read-only image will always return shaderc_spvc_binding_type_writeonly_storage_texture.
|
||||||
|
@ -373,7 +379,13 @@ TEST_P(StorageTextureTests, ReadonlyStorageTextureInFragmentShader) {
|
||||||
// Test that write-only storage textures are supported in compute shader.
|
// Test that write-only storage textures are supported in compute shader.
|
||||||
TEST_P(StorageTextureTests, WriteonlyStorageTextureInComputeShader) {
|
TEST_P(StorageTextureTests, WriteonlyStorageTextureInComputeShader) {
|
||||||
// TODO(jiawei.shao@intel.com): support read-only storage texture on D3D12 and OpenGL.
|
// TODO(jiawei.shao@intel.com): support read-only storage texture on D3D12 and OpenGL.
|
||||||
DAWN_SKIP_TEST_IF(IsD3D12() || IsOpenGL());
|
DAWN_SKIP_TEST_IF(IsOpenGL());
|
||||||
|
|
||||||
|
// When we run dawn_end2end_tests with "--use-spvc-parser", extracting the binding type of a
|
||||||
|
// read-only image will always return shaderc_spvc_binding_type_writeonly_storage_texture.
|
||||||
|
// TODO(jiawei.shao@intel.com): enable this test when we specify "--use-spvc-parser" after the
|
||||||
|
// bug in spvc parser is fixed.
|
||||||
|
DAWN_SKIP_TEST_IF(IsD3D12() && IsSpvcParserBeingUsed());
|
||||||
|
|
||||||
// Prepare the write-only storage texture.
|
// Prepare the write-only storage texture.
|
||||||
// TODO(jiawei.shao@intel.com): test more texture formats.
|
// TODO(jiawei.shao@intel.com): test more texture formats.
|
||||||
|
@ -403,7 +415,13 @@ TEST_P(StorageTextureTests, WriteonlyStorageTextureInComputeShader) {
|
||||||
// Test that write-only storage textures are supported in fragment shader.
|
// Test that write-only storage textures are supported in fragment shader.
|
||||||
TEST_P(StorageTextureTests, WriteonlyStorageTextureInFragmentShader) {
|
TEST_P(StorageTextureTests, WriteonlyStorageTextureInFragmentShader) {
|
||||||
// TODO(jiawei.shao@intel.com): support read-only storage texture on D3D12 and OpenGL.
|
// TODO(jiawei.shao@intel.com): support read-only storage texture on D3D12 and OpenGL.
|
||||||
DAWN_SKIP_TEST_IF(IsD3D12() || IsOpenGL());
|
DAWN_SKIP_TEST_IF(IsOpenGL());
|
||||||
|
|
||||||
|
// When we run dawn_end2end_tests with "--use-spvc-parser", extracting the binding type of a
|
||||||
|
// read-only image will always return shaderc_spvc_binding_type_writeonly_storage_texture.
|
||||||
|
// TODO(jiawei.shao@intel.com): enable this test when we specify "--use-spvc-parser" after the
|
||||||
|
// bug in spvc parser is fixed.
|
||||||
|
DAWN_SKIP_TEST_IF(IsD3D12() && IsSpvcParserBeingUsed());
|
||||||
|
|
||||||
// Prepare the write-only storage texture.
|
// Prepare the write-only storage texture.
|
||||||
// TODO(jiawei.shao@intel.com): test more texture formats.
|
// TODO(jiawei.shao@intel.com): test more texture formats.
|
||||||
|
|
Loading…
Reference in New Issue