E_INVALIDARG when calling CreateGraphicsPipelineState
E_INVALIDARG when calling CreateGraphicsPipelineState
我在调用CreateGraphicsPipelineState()
时遇到了一个奇怪的错误。即使描述已经全部设置好,函数也会返回E_INVALIDARG
。
之前的描述有效,我试图将indexbuffers
添加到我的管道中,我甚至没有接触任何PSO或Shaders的代码,现在PSO的创建完全一团糟。
问题是,在启用调试层时,我没有从驱动程序收到任何DX错误消息。我只得到这个
"Microsoft C++异常:内存位置处的_com_error
当我逐步完成函数时。
这感觉像是指针错误或类似的错误,但我不知道错误是什么。也许你们中的任何人都能看到我犯的明显错误?
这是我的代码:
CGraphicsPSO* pso = new CGraphicsPSO();
D3D12_GRAPHICS_PIPELINE_STATE_DESC psoDesc = {};
// Input Layout
std::vector<D3D12_INPUT_ELEMENT_DESC> elements;
if (aPSODesc.inputLayout != nullptr)
{
auto& ilData = aPSODesc.inputLayout->desc;
for (auto& element : ilData)
{
// All Data here is correct when breaking
D3D12_INPUT_ELEMENT_DESC elementDesc;
elementDesc.SemanticName = element.mySemanticName;
elementDesc.SemanticIndex = element.mySemanticIndex;
elementDesc.InputSlot = element.myInputSlot;
elementDesc.AlignedByteOffset = element.myAlignedByteOffset;
elementDesc.InputSlotClass = _ConvertInputClassificationDX12(element.myInputSlotClass);
elementDesc.Format = _ConvertFormatDX12(element.myFormat);
elementDesc.InstanceDataStepRate = element.myInstanceDataStepRate;
elements.push_back(elementDesc);
}
D3D12_INPUT_LAYOUT_DESC inputLayout = {};
inputLayout.NumElements = (UINT)elements.size();
inputLayout.pInputElementDescs = elements.data();
psoDesc.InputLayout = inputLayout;
}
// TOPOLOGY
switch (aPSODesc.topology)
{
default:
case EPrimitiveTopology::TriangleList:
psoDesc.PrimitiveTopologyType = D3D12_PRIMITIVE_TOPOLOGY_TYPE_TRIANGLE; // <--- Always this option
break;
case EPrimitiveTopology::PointList:
psoDesc.PrimitiveTopologyType = D3D12_PRIMITIVE_TOPOLOGY_TYPE_POINT;
break;
case EPrimitiveTopology::LineList:
psoDesc.PrimitiveTopologyType = D3D12_PRIMITIVE_TOPOLOGY_TYPE_LINE;
break;
//case EPrimitiveTopology::Patch:
// psoDesc.PrimitiveTopologyType = D3D12_PRIMITIVE_TOPOLOGY_TYPE_PATCH;
// break;
}
// Shaders
if (aPSODesc.vs != nullptr)
{
D3D12_SHADER_BYTECODE vertexShaderBytecode = {};
vertexShaderBytecode.BytecodeLength = aPSODesc.vs->myByteCodeSize;
vertexShaderBytecode.pShaderBytecode = aPSODesc.vs->myByteCode;
psoDesc.VS = vertexShaderBytecode;
}
if (aPSODesc.ps != nullptr)
{
D3D12_SHADER_BYTECODE pixelShaderBytecode = {};
pixelShaderBytecode.BytecodeLength = aPSODesc.ps->myByteCodeSize;
pixelShaderBytecode.pShaderBytecode = aPSODesc.ps->myByteCode;
psoDesc.PS = pixelShaderBytecode;
}
psoDesc.RTVFormats[0] = DXGI_FORMAT_R8G8B8A8_UNORM; // format of the render target
DXGI_SAMPLE_DESC sampleDesc = {};
sampleDesc.Count = 1;
sampleDesc.Quality = 0;
psoDesc.DepthStencilState.DepthEnable = FALSE;
psoDesc.DepthStencilState.StencilEnable = FALSE;
psoDesc.SampleDesc = sampleDesc; // must be the same sample description as the swapchain and depth/stencil buffer
psoDesc.SampleMask = UINT_MAX; // sample mask has to do with multi-sampling. 0xffffffff means point sampling is done
psoDesc.RasterizerState = CD3DX12_RASTERIZER_DESC(D3D12_DEFAULT); // a default rasterizer state.
psoDesc.BlendState = CD3DX12_BLEND_DESC(D3D12_DEFAULT); // a default blent state.
psoDesc.NumRenderTargets = 1; // we are only binding one render target
psoDesc.pRootSignature = myGraphicsRootSignature;
psoDesc.Flags = D3D12_PIPELINE_STATE_FLAG_NONE;
ID3D12PipelineState* pipelineState;
HRESULT hr = myDevice->CreateGraphicsPipelineState(&psoDesc, IID_PPV_ARGS(&pipelineState));
pso->myPipelineState = pipelineState;
if (FAILED(hr))
{
delete pso;
return nullptr;
}
return pso;
所以我刚刚发现了错误。我为输入布局解析语义的方式似乎给了我一个无效的指针。因此,地址处的存储器是无效的,并且给DX12设备提供了不正确的描述。
因此,我所做的是在我的CreatePSO函数中本地存储语义名称,直到创建了PSO,现在一切都正常了。
在我看来,您承诺的指向存储的指针似乎超出了范围。
..
D3D12_INPUT_LAYOUT_DESC inputLayout = {};
..
psoDesc.InputLayout = inputLayout;
}
相关文章:
- Java SWIG wrapper vs direct function calling
- 使用来自 Excel VBA 的 C++ dll 时"Bad DLL calling convention" - 如何解决?
- Calling StartXpsPrintJob1()
- E_INVALIDARG when calling CreateGraphicsPipelineState
- Calling C++ dll from python
- Calling Python Script from Visual Studio C++ Solution
- Mac 上的 node-gyp 构建错误"calling a protected constructor of class 'v8::HandleScope'"
- Calling cv::cuda::HOG from python
- Calling Haskell from c++
- calling from a *.lib c++
- Calling an xll UDF from VBA
- OpenGL 3.3: GL_INVALID_OPERATION when calling glBindBuffer
- ERROR_INVALID_HANDLE when calling ConnectNamedPipe
- Calling Java Swing from c++
- Calling JavaScript from C++
- Calling sync_client.cpp
- Calling C# from C++
- Calling C# COM DLL from C++
- calling C++ from R
- Calling ATL COM dll from MFC