[D3D12] Refactor compute pipeline creation

This commit is contained in:
Triang3l 2018-08-26 00:56:41 +03:00
parent 791c275fab
commit 79d43bb943
4 changed files with 52 additions and 54 deletions

View File

@ -156,64 +156,50 @@ bool RenderTargetCache::Initialize() {
return false; return false;
} }
// Create the load/store pipelines. // Create the pipelines.
D3D12_COMPUTE_PIPELINE_STATE_DESC pipeline_desc; // Load and store.
pipeline_desc.pRootSignature = edram_load_store_root_signature_;
pipeline_desc.NodeMask = 0;
pipeline_desc.CachedPSO.pCachedBlob = nullptr;
pipeline_desc.CachedPSO.CachedBlobSizeInBytes = 0;
pipeline_desc.Flags = D3D12_PIPELINE_STATE_FLAG_NONE;
for (uint32_t i = 0; i < uint32_t(EDRAMLoadStoreMode::kCount); ++i) { for (uint32_t i = 0; i < uint32_t(EDRAMLoadStoreMode::kCount); ++i) {
// Load.
const EDRAMLoadStoreModeInfo& mode_info = edram_load_store_mode_info_[i]; const EDRAMLoadStoreModeInfo& mode_info = edram_load_store_mode_info_[i];
pipeline_desc.CS.pShaderBytecode = mode_info.load_shader; edram_load_pipelines_[i] = ui::d3d12::util::CreateComputePipeline(
pipeline_desc.CS.BytecodeLength = mode_info.load_shader_size; device, mode_info.load_shader, mode_info.load_shader_size,
if (FAILED(device->CreateComputePipelineState( edram_load_store_root_signature_);
&pipeline_desc, IID_PPV_ARGS(&edram_load_pipelines_[i])))) { edram_store_pipelines_[i] = ui::d3d12::util::CreateComputePipeline(
XELOGE("Failed to create the EDRAM load pipeline for mode %u", i); device, mode_info.store_shader, mode_info.store_shader_size,
edram_load_store_root_signature_);
if (edram_load_pipelines_[i] == nullptr ||
edram_store_pipelines_[i] == nullptr) {
XELOGE("Failed to create the EDRAM load/store pipelines for mode %u", i);
Shutdown(); Shutdown();
return false; return false;
} }
edram_load_pipelines_[i]->SetName(mode_info.load_pipeline_name); edram_load_pipelines_[i]->SetName(mode_info.load_pipeline_name);
// Store.
pipeline_desc.CS.pShaderBytecode = mode_info.store_shader;
pipeline_desc.CS.BytecodeLength = mode_info.store_shader_size;
if (FAILED(device->CreateComputePipelineState(
&pipeline_desc, IID_PPV_ARGS(&edram_store_pipelines_[i])))) {
XELOGE("Failed to create the EDRAM store pipeline for mode %u", i);
Shutdown();
return false;
}
edram_store_pipelines_[i]->SetName(mode_info.store_pipeline_name); edram_store_pipelines_[i]->SetName(mode_info.store_pipeline_name);
} }
// Tile single sample into a texture - 32 bits per pixel. // Tile single sample into a texture - 32 bits per pixel.
pipeline_desc.CS.pShaderBytecode = edram_tile_sample_32bpp_cs; edram_tile_sample_32bpp_pipeline_ = ui::d3d12::util::CreateComputePipeline(
pipeline_desc.CS.BytecodeLength = sizeof(edram_tile_sample_32bpp_cs); device, edram_tile_sample_32bpp_cs, sizeof(edram_tile_sample_32bpp_cs),
if (FAILED(device->CreateComputePipelineState( edram_load_store_root_signature_);
&pipeline_desc, IID_PPV_ARGS(&edram_tile_sample_32bpp_pipeline_)))) { if (edram_tile_sample_32bpp_pipeline_ == nullptr) {
XELOGE("Failed to create the 32bpp EDRAM raw resolve pipeline"); XELOGE("Failed to create the 32bpp EDRAM raw resolve pipeline");
Shutdown(); Shutdown();
return false; return false;
} }
edram_tile_sample_32bpp_pipeline_->SetName(L"EDRAM Raw Resolve 32bpp"); edram_tile_sample_32bpp_pipeline_->SetName(L"EDRAM Raw Resolve 32bpp");
// Clear 32-bit color or unorm depth.
// Create the clear pipelines. edram_clear_32bpp_pipeline_ = ui::d3d12::util::CreateComputePipeline(
pipeline_desc.pRootSignature = edram_clear_root_signature_; device, edram_clear_32bpp_cs, sizeof(edram_clear_32bpp_cs),
// 32-bit color or unorm depth. edram_clear_root_signature_);
pipeline_desc.CS.pShaderBytecode = edram_clear_32bpp_cs; if (edram_clear_32bpp_pipeline_ == nullptr) {
pipeline_desc.CS.BytecodeLength = sizeof(edram_clear_32bpp_cs);
if (FAILED(device->CreateComputePipelineState(
&pipeline_desc, IID_PPV_ARGS(&edram_clear_32bpp_pipeline_)))) {
XELOGE("Failed to create the EDRAM 32bpp clear pipeline"); XELOGE("Failed to create the EDRAM 32bpp clear pipeline");
Shutdown(); Shutdown();
return false; return false;
} }
edram_clear_32bpp_pipeline_->SetName(L"EDRAM Clear 32bpp"); edram_clear_32bpp_pipeline_->SetName(L"EDRAM Clear 32bpp");
// Float depth. // Clear float depth.
pipeline_desc.CS.pShaderBytecode = edram_clear_depth_float_cs; edram_clear_depth_float_pipeline_ = ui::d3d12::util::CreateComputePipeline(
pipeline_desc.CS.BytecodeLength = sizeof(edram_clear_depth_float_cs); device, edram_clear_depth_float_cs, sizeof(edram_clear_depth_float_cs),
if (FAILED(device->CreateComputePipelineState( edram_clear_root_signature_);
&pipeline_desc, IID_PPV_ARGS(&edram_clear_depth_float_pipeline_)))) { if (edram_clear_depth_float_pipeline_ == nullptr) {
XELOGE("Failed to create the EDRAM float depth clear pipeline"); XELOGE("Failed to create the EDRAM float depth clear pipeline");
Shutdown(); Shutdown();
return false; return false;

View File

@ -254,30 +254,21 @@ bool TextureCache::Initialize() {
} }
// Create the loading and tiling pipelines. // Create the loading and tiling pipelines.
D3D12_COMPUTE_PIPELINE_STATE_DESC pipeline_desc;
pipeline_desc.pRootSignature = load_root_signature_;
pipeline_desc.NodeMask = 0;
pipeline_desc.CachedPSO.pCachedBlob = nullptr;
pipeline_desc.CachedPSO.CachedBlobSizeInBytes = 0;
pipeline_desc.Flags = D3D12_PIPELINE_STATE_FLAG_NONE;
for (uint32_t i = 0; i < uint32_t(LoadMode::kCount); ++i) { for (uint32_t i = 0; i < uint32_t(LoadMode::kCount); ++i) {
const LoadModeInfo& mode_info = load_mode_info_[i]; const LoadModeInfo& mode_info = load_mode_info_[i];
pipeline_desc.CS.pShaderBytecode = mode_info.shader; load_pipelines_[i] = ui::d3d12::util::CreateComputePipeline(
pipeline_desc.CS.BytecodeLength = mode_info.shader_size; device, mode_info.shader, mode_info.shader_size, load_root_signature_);
if (FAILED(device->CreateComputePipelineState( if (load_pipelines_[i] == nullptr) {
&pipeline_desc, IID_PPV_ARGS(&load_pipelines_[i])))) {
XELOGE("Failed to create the texture loading pipeline for mode %u", i); XELOGE("Failed to create the texture loading pipeline for mode %u", i);
Shutdown(); Shutdown();
return false; return false;
} }
} }
pipeline_desc.pRootSignature = tile_root_signature_;
for (uint32_t i = 0; i < uint32_t(TileMode::kCount); ++i) { for (uint32_t i = 0; i < uint32_t(TileMode::kCount); ++i) {
const TileModeInfo& mode_info = tile_mode_info_[i]; const TileModeInfo& mode_info = tile_mode_info_[i];
pipeline_desc.CS.pShaderBytecode = mode_info.shader; tile_pipelines_[i] = ui::d3d12::util::CreateComputePipeline(
pipeline_desc.CS.BytecodeLength = mode_info.shader_size; device, mode_info.shader, mode_info.shader_size, tile_root_signature_);
if (FAILED(device->CreateComputePipelineState( if (tile_pipelines_[i] == nullptr) {
&pipeline_desc, IID_PPV_ARGS(&tile_pipelines_[i])))) {
XELOGE("Failed to create the texture tiling pipeline for mode %u", i); XELOGE("Failed to create the texture tiling pipeline for mode %u", i);
Shutdown(); Shutdown();
return false; return false;

View File

@ -41,6 +41,22 @@ ID3D12RootSignature* CreateRootSignature(
return root_signature; return root_signature;
} }
ID3D12PipelineState* CreateComputePipeline(
ID3D12Device* device, const void* shader, size_t shader_size,
ID3D12RootSignature* root_signature) {
D3D12_COMPUTE_PIPELINE_STATE_DESC desc;
desc.pRootSignature = root_signature;
desc.CS.pShaderBytecode = shader;
desc.CS.BytecodeLength = shader_size;
desc.NodeMask = 0;
desc.CachedPSO.pCachedBlob = nullptr;
desc.CachedPSO.CachedBlobSizeInBytes = 0;
desc.Flags = D3D12_PIPELINE_STATE_FLAG_NONE;
ID3D12PipelineState* pipeline = nullptr;
device->CreateComputePipelineState(&desc, IID_PPV_ARGS(&pipeline));
return pipeline;
}
} // namespace util } // namespace util
} // namespace d3d12 } // namespace d3d12
} // namespace ui } // namespace ui

View File

@ -30,6 +30,11 @@ inline bool ReleaseAndNull(T& object) {
ID3D12RootSignature* CreateRootSignature(ID3D12Device* device, ID3D12RootSignature* CreateRootSignature(ID3D12Device* device,
const D3D12_ROOT_SIGNATURE_DESC& desc); const D3D12_ROOT_SIGNATURE_DESC& desc);
ID3D12PipelineState* CreateComputePipeline(ID3D12Device* device,
const void* shader,
size_t shader_size,
ID3D12RootSignature* root_signature);
} // namespace util } // namespace util
} // namespace d3d12 } // namespace d3d12
} // namespace ui } // namespace ui