From 37bae461d145e96686454afd6eb097a45b40a087 Mon Sep 17 00:00:00 2001 From: Hajime Hoshi Date: Fri, 2 Sep 2022 12:47:58 +0900 Subject: [PATCH] internal/graphicsdriver/directx: bug fix: processtest failures The command allocators should be reset only when the frame index was updated. Closes #2249 --- .../directx/graphics_windows.go | 20 ++++++++++++------- 1 file changed, 13 insertions(+), 7 deletions(-) diff --git a/internal/graphicsdriver/directx/graphics_windows.go b/internal/graphicsdriver/directx/graphics_windows.go index 9cba3350e..c8010eab2 100644 --- a/internal/graphicsdriver/directx/graphics_windows.go +++ b/internal/graphicsdriver/directx/graphics_windows.go @@ -124,7 +124,8 @@ type Graphics struct { window windows.HWND - frameIndex int + frameIndex int + prevBeginFrameIndex int // frameStarted is true since Begin until End with present frameStarted bool @@ -684,6 +685,8 @@ func (g *Graphics) resizeSwapChainDesktop(width, height int) error { // TODO: Reset 0 on Xbox g.frameIndex = int(g.swapChain.GetCurrentBackBufferIndex()) + // TODO: Are these resetting necessary? + if err := g.drawCommandAllocators[g.frameIndex].Reset(); err != nil { return err } @@ -741,14 +744,17 @@ func (g *Graphics) Begin() error { } g.frameStarted = true - if err := g.drawCommandAllocators[g.frameIndex].Reset(); err != nil { - return err - } - if err := g.drawCommandList.Reset(g.drawCommandAllocators[g.frameIndex], nil); err != nil { - return err + if g.prevBeginFrameIndex != g.frameIndex { + if err := g.drawCommandAllocators[g.frameIndex].Reset(); err != nil { + return err + } + if err := g.copyCommandAllocators[g.frameIndex].Reset(); err != nil { + return err + } } + g.prevBeginFrameIndex = g.frameIndex - if err := g.copyCommandAllocators[g.frameIndex].Reset(); err != nil { + if err := g.drawCommandList.Reset(g.drawCommandAllocators[g.frameIndex], nil); err != nil { return err } if err := g.copyCommandList.Reset(g.copyCommandAllocators[g.frameIndex], nil); err != nil {