Allow null fragment shader for depth only programs.

This commit is contained in:
Branimir Karadžić 2018-03-05 18:15:35 -08:00
parent c5f7ad598b
commit 67ad9fbbef
4 changed files with 104 additions and 73 deletions

View File

@ -6420,8 +6420,8 @@ BX_PRAGMA_DIAGNOSTIC_POP();
deviceCtx->VSSetConstantBuffers(0, 1, &vsh->m_buffer);
const ShaderD3D11* fsh = program.m_fsh;
if (NULL != m_currentColor
|| fsh->m_hasDepthOp)
if (NULL != fsh
&& (NULL != m_currentColor || fsh->m_hasDepthOp) )
{
deviceCtx->PSSetShader(fsh->m_pixelShader, NULL, 0);
deviceCtx->PSSetConstantBuffers(0, 1, &fsh->m_buffer);
@ -6448,12 +6448,15 @@ BX_PRAGMA_DIAGNOSTIC_POP();
commit(*vcb);
}
if (NULL != program.m_fsh)
{
UniformBuffer* fcb = program.m_fsh->m_constantBuffer;
if (NULL != fcb)
{
commit(*fcb);
}
}
}
viewState.setPredefined<4>(this, view, eye, program, _render, draw);

View File

@ -2826,7 +2826,11 @@ data.NumQualityLevels = 0;
murmur.add(_stencil);
murmur.add(program.m_vsh->m_hash);
murmur.add(program.m_vsh->m_attrMask, sizeof(program.m_vsh->m_attrMask) );
if (NULL != program.m_fsh)
{
murmur.add(program.m_fsh->m_hash);
}
for (uint32_t ii = 0; ii < _numStreams; ++ii)
{
murmur.add(_vertexDecls[ii]->m_hash);
@ -2851,7 +2855,11 @@ data.NumQualityLevels = 0;
desc.VS.pShaderBytecode = program.m_vsh->m_code->data;
desc.VS.BytecodeLength = program.m_vsh->m_code->size;
const Memory* temp = alloc(program.m_fsh->m_code->size);
const Memory* temp = NULL;
if (NULL != program.m_fsh)
{
temp = alloc(program.m_fsh->m_code->size);
bx::memSet(temp->data, 0, temp->size);
bx::MemoryReader rd(program.m_fsh->m_code->data, program.m_fsh->m_code->size);
bx::StaticMemoryBlockWriter wr(temp->data, temp->size);
@ -2912,6 +2920,12 @@ data.NumQualityLevels = 0;
desc.PS.pShaderBytecode = program.m_fsh->m_code->data;
desc.PS.BytecodeLength = program.m_fsh->m_code->size;
}
}
else
{
desc.PS.pShaderBytecode = NULL;
desc.PS.BytecodeLength = 0;
}
desc.DS.pShaderBytecode = NULL;
desc.DS.BytecodeLength = 0;
@ -3018,7 +3032,10 @@ data.NumQualityLevels = 0;
m_pipelineStateCache.add(hash, pso);
if (NULL != temp)
{
release(temp);
}
ID3DBlob* blob;
HRESULT hr = pso->GetCachedBlob(&blob);
@ -6285,11 +6302,14 @@ data.NumQualityLevels = 0;
commit(*vcb);
}
if (NULL != program.m_fsh)
{
UniformBuffer* fcb = program.m_fsh->m_constantBuffer;
if (NULL != fcb)
{
commit(*fcb);
}
}
hasPredefined = 0 < program.m_numPredefined;
constantsChanged = true;

View File

@ -1027,7 +1027,7 @@ namespace bgfx { namespace d3d9
void createProgram(ProgramHandle _handle, ShaderHandle _vsh, ShaderHandle _fsh) override
{
m_program[_handle.idx].create(m_shaders[_vsh.idx], m_shaders[_fsh.idx]);
m_program[_handle.idx].create(&m_shaders[_vsh.idx], isValid(_fsh) ? &m_shaders[_fsh.idx] : NULL);
}
void destroyProgram(ProgramHandle _handle) override
@ -4105,7 +4105,10 @@ namespace bgfx { namespace d3d9
{
ProgramD3D9& program = m_program[programIdx];
device->SetVertexShader(program.m_vsh->m_vertexShader);
device->SetPixelShader(program.m_fsh->m_pixelShader);
device->SetPixelShader(NULL == program.m_fsh
? NULL
: program.m_fsh->m_pixelShader
);
}
programChanged =
@ -4124,12 +4127,15 @@ namespace bgfx { namespace d3d9
commit(*vcb);
}
if (NULL != program.m_fsh)
{
UniformBuffer* fcb = program.m_fsh->m_constantBuffer;
if (NULL != fcb)
{
commit(*fcb);
}
}
}
viewState.setPredefined<4>(this, view, 0, program, _render, draw);
}
@ -4406,11 +4412,11 @@ namespace bgfx { namespace d3d9
);
const D3DADAPTER_IDENTIFIER9& identifier = m_identifier;
tvm.printf(0, pos++, 0x8b, " Device: %s (%s)", identifier.Description, identifier.Driver);
tvm.printf(0, pos++, 0x8f, " Device: %s (%s)", identifier.Description, identifier.Driver);
char processMemoryUsed[16];
bx::prettify(processMemoryUsed, BX_COUNTOF(processMemoryUsed), bx::getProcessMemoryUsed() );
tvm.printf(0, pos++, 0x8b, " Memory: %s (process) ", processMemoryUsed);
tvm.printf(0, pos++, 0x8f, " Memory: %s (process) ", processMemoryUsed);
pos = 10;
tvm.printf(10, pos++, 0x8b, " Frame: %7.3f, % 7.3f \x1f, % 7.3f \x1e [ms] / % 6.2f FPS "

View File

@ -259,17 +259,19 @@ namespace bgfx { namespace d3d9
struct ProgramD3D9
{
void create(const ShaderD3D9& _vsh, const ShaderD3D9& _fsh)
void create(const ShaderD3D9* _vsh, const ShaderD3D9* _fsh)
{
BX_CHECK(NULL != _vsh.m_vertexShader, "Vertex shader doesn't exist.");
m_vsh = &_vsh;
m_vsh = _vsh;
m_fsh = _fsh;
BX_CHECK(NULL != _fsh.m_pixelShader, "Fragment shader doesn't exist.");
m_fsh = &_fsh;
bx::memCopy(&m_predefined[0], _vsh->m_predefined, _vsh->m_numPredefined*sizeof(PredefinedUniform) );
m_numPredefined = _vsh->m_numPredefined;
bx::memCopy(&m_predefined[0], _vsh.m_predefined, _vsh.m_numPredefined*sizeof(PredefinedUniform) );
bx::memCopy(&m_predefined[_vsh.m_numPredefined], _fsh.m_predefined, _fsh.m_numPredefined*sizeof(PredefinedUniform) );
m_numPredefined = _vsh.m_numPredefined + _fsh.m_numPredefined;
if (NULL != _fsh)
{
bx::memCopy(&m_predefined[_vsh->m_numPredefined], _fsh->m_predefined, _fsh->m_numPredefined*sizeof(PredefinedUniform) );
m_numPredefined += _fsh->m_numPredefined;
}
}
void destroy()