mirror of
https://github.com/hajimehoshi/ebiten.git
synced 2025-01-26 10:42:42 +01:00
internal/graphicsdriver/directx: bug fix: leave mapped regions for constant buffers
Mapping for a constant buffer every frame might sometimes fails. We are not sure the reason, but in the official examples, leaving mapped regoins seems the way to go. Updates #2084 Closes #2157
This commit is contained in:
parent
506d534370
commit
712940cb02
@ -274,7 +274,8 @@ type pipelineStates struct {
|
||||
|
||||
samplerDescriptorHeap *_ID3D12DescriptorHeap
|
||||
|
||||
constantBuffers [frameCount][]*_ID3D12Resource
|
||||
constantBuffers [frameCount][]*_ID3D12Resource
|
||||
constantBufferMaps [frameCount][]uintptr
|
||||
}
|
||||
|
||||
const numConstantBufferAndSourceTextures = 1 + graphics.ShaderImageNum
|
||||
@ -366,8 +367,10 @@ func (p *pipelineStates) useGraphicsPipelineState(device *_ID3D12Device, command
|
||||
|
||||
if cap(p.constantBuffers[frameIndex]) > idx {
|
||||
p.constantBuffers[frameIndex] = p.constantBuffers[frameIndex][:idx+1]
|
||||
p.constantBufferMaps[frameIndex] = p.constantBufferMaps[frameIndex][:idx+1]
|
||||
} else {
|
||||
p.constantBuffers[frameIndex] = append(p.constantBuffers[frameIndex], nil)
|
||||
p.constantBufferMaps[frameIndex] = append(p.constantBufferMaps[frameIndex], 0)
|
||||
}
|
||||
|
||||
const bufferSizeAlignement = 256
|
||||
@ -377,10 +380,13 @@ func (p *pipelineStates) useGraphicsPipelineState(device *_ID3D12Device, command
|
||||
}
|
||||
|
||||
cb := p.constantBuffers[frameIndex][idx]
|
||||
m := p.constantBufferMaps[frameIndex][idx]
|
||||
if cb != nil {
|
||||
if uint32(cb.GetDesc().Width) < bufferSize {
|
||||
p.constantBuffers[frameIndex][idx].Unmap(0, nil)
|
||||
p.constantBuffers[frameIndex][idx].Release()
|
||||
p.constantBuffers[frameIndex][idx] = nil
|
||||
p.constantBufferMaps[frameIndex][idx] = 0
|
||||
cb = nil
|
||||
}
|
||||
}
|
||||
@ -401,6 +407,15 @@ func (p *pipelineStates) useGraphicsPipelineState(device *_ID3D12Device, command
|
||||
BufferLocation: cb.GetGPUVirtualAddress(),
|
||||
SizeInBytes: bufferSize,
|
||||
}, h)
|
||||
|
||||
m, err = cb.Map(0, &_D3D12_RANGE{0, 0})
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
p.constantBufferMaps[frameIndex][idx] = m
|
||||
}
|
||||
if m == 0 {
|
||||
return fmt.Errorf("directx: ID3D12Resource::Map failed")
|
||||
}
|
||||
|
||||
h, err := p.shaderDescriptorHeap.GetCPUDescriptorHandleForHeapStart()
|
||||
@ -424,14 +439,8 @@ func (p *pipelineStates) useGraphicsPipelineState(device *_ID3D12Device, command
|
||||
}
|
||||
|
||||
// Update the constant buffer.
|
||||
m, err := cb.Map(0, &_D3D12_RANGE{0, 0})
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
copyFloat32s(m, uniforms)
|
||||
|
||||
cb.Unmap(0, nil)
|
||||
|
||||
commandList.SetPipelineState(pipelineState)
|
||||
|
||||
rs, err := p.ensureRootSignature(device)
|
||||
|
Loading…
Reference in New Issue
Block a user