From 8af737d3bd422c69962748bf2221e6c5ffe94704 Mon Sep 17 00:00:00 2001 From: "Admiral H. Curtiss" Date: Mon, 3 Jan 2022 17:14:09 +0100 Subject: [PATCH] D3D12: Fix nullptr dereference when creating a shader with a name. --- Source/Core/VideoBackends/D3D12/DX12Shader.cpp | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/Source/Core/VideoBackends/D3D12/DX12Shader.cpp b/Source/Core/VideoBackends/D3D12/DX12Shader.cpp index 39589b6b24..eb0c3dd1f9 100644 --- a/Source/Core/VideoBackends/D3D12/DX12Shader.cpp +++ b/Source/Core/VideoBackends/D3D12/DX12Shader.cpp @@ -13,10 +13,6 @@ namespace DX12 DXShader::DXShader(ShaderStage stage, BinaryData bytecode, std::string_view name) : D3DCommon::Shader(stage, std::move(bytecode)), m_name(UTF8ToWString(name)) { - if (!m_name.empty()) - { - m_compute_pipeline->SetName(m_name.c_str()); - } } DXShader::~DXShader() = default; @@ -56,6 +52,10 @@ bool DXShader::CreateComputePipeline() HRESULT hr = g_dx_context->GetDevice()->CreateComputePipelineState( &desc, IID_PPV_ARGS(&m_compute_pipeline)); CHECK(SUCCEEDED(hr), "Creating compute pipeline failed"); + + if (m_compute_pipeline && !m_name.empty()) + m_compute_pipeline->SetName(m_name.c_str()); + return SUCCEEDED(hr); }