Skip to content

Commit

Permalink
nth attempt at fixing directx 12
Browse files Browse the repository at this point in the history
  • Loading branch information
Zyko0 committed Apr 14, 2024
1 parent 9881530 commit b28ab9b
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 14 deletions.
45 changes: 32 additions & 13 deletions internal/graphicsdriver/directx/graphics12_windows.go
Original file line number Diff line number Diff line change
Expand Up @@ -40,13 +40,14 @@ func (r *resourceWithSize) release() {
}

type graphics12 struct {
debug *_ID3D12Debug
device *_ID3D12Device
commandQueue *_ID3D12CommandQueue
rtvDescriptorHeap *_ID3D12DescriptorHeap
rtvDescriptorSize uint32
renderTargets [frameCount]*_ID3D12Resource
framePipelineToken _D3D12XBOX_FRAME_PIPELINE_TOKEN
debug *_ID3D12Debug
device *_ID3D12Device
commandQueue *_ID3D12CommandQueue
rtvDescriptorHeap *_ID3D12DescriptorHeap
rtvEmptyDescriptorHeap *_ID3D12DescriptorHeap
rtvDescriptorSize uint32
renderTargets [frameCount]*_ID3D12Resource
framePipelineToken _D3D12XBOX_FRAME_PIPELINE_TOKEN

fence *_ID3D12Fence
fenceValues [frameCount]uint64
Expand Down Expand Up @@ -418,6 +419,25 @@ func (g *graphics12) initializeMembers(frameIndex int) (ferr error) {
g.rtvDescriptorHeap = nil
}
}()

// Create a descriptor heap for empty RTV in case of MRT with empty locations.
h, err = g.device.CreateDescriptorHeap(&_D3D12_DESCRIPTOR_HEAP_DESC{
Type: _D3D12_DESCRIPTOR_HEAP_TYPE_RTV,
NumDescriptors: frameCount,
Flags: _D3D12_DESCRIPTOR_HEAP_FLAG_NONE,
NodeMask: 0,
})
if err != nil {
return err
}
g.rtvEmptyDescriptorHeap = h
defer func() {
if ferr != nil {
g.rtvEmptyDescriptorHeap.Release()
g.rtvEmptyDescriptorHeap = nil
}
}()

g.rtvDescriptorSize = g.device.GetDescriptorHandleIncrementSize(_D3D12_DESCRIPTOR_HEAP_TYPE_RTV)

if err := g.pipelineStates.initialize(g.device); err != nil {
Expand Down Expand Up @@ -1090,20 +1110,15 @@ func (g *graphics12) setAsRenderTargets(dsts []*image12, useStencil bool) error
// Ignore a nil image in case of MRT
if img == nil {
_ = i
rtvBase, err := g.rtvDescriptorHeap.GetCPUDescriptorHandleForHeapStart()
rtv, err := g.rtvEmptyDescriptorHeap.GetCPUDescriptorHandleForHeapStart()
if err != nil {
return err
}
rtv := rtvBase
rtv.Offset(int32(g.frameIndex), g.rtvDescriptorSize)
rtvs = append(rtvs, rtv)
continue
}

if err := img.ensureRenderTargetView(g.device); err != nil {
return err
}

if img.screen {
if useStencil {
return fmt.Errorf("directx: stencils are not available on the screen framebuffer")
Expand All @@ -1119,6 +1134,10 @@ func (g *graphics12) setAsRenderTargets(dsts []*image12, useStencil bool) error
continue
}

if err := img.ensureRenderTargetView(g.device); err != nil {
return err
}

rtvBase, err := img.rtvDescriptorHeap.GetCPUDescriptorHandleForHeapStart()
if err != nil {
return err
Expand Down
3 changes: 2 additions & 1 deletion internal/graphicsdriver/directx/pipeline12_windows.go
Original file line number Diff line number Diff line change
Expand Up @@ -510,7 +510,8 @@ func (p *pipelineStates) newPipelineState(device *_ID3D12Device, vsh, psh *_ID3D
AlphaToCoverageEnable: 0,
IndependentBlendEnable: 0,
RenderTarget: [8]_D3D12_RENDER_TARGET_BLEND_DESC{
rtBlendDesc, // TODO: need to fill them all?
rtBlendDesc, rtBlendDesc, rtBlendDesc, rtBlendDesc,
rtBlendDesc, rtBlendDesc, rtBlendDesc, rtBlendDesc, // TODO: need to fill them all?
},
},
SampleMask: math.MaxUint32,
Expand Down

0 comments on commit b28ab9b

Please sign in to comment.