Fix D3D12 Device Initialize calls NextSerial

Device shouldn't be used until after DeviceBase::Initialize so we need
to move the NextSerial call to after Device Initialization is completed.

Bug: chromium:1094477
Change-Id: I2ab317c1d75f853c022faac3fc0bbd66fbd7c14e
Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/23261
Reviewed-by: Austin Eng <enga@chromium.org>
Commit-Queue: Natasha Lee <natlee@microsoft.com>
This commit is contained in:
Natasha Lee 2020-06-16 23:55:08 +00:00 committed by Commit Bot service account
parent 67cd013b62
commit 3f4f356611
1 changed files with 5 additions and 3 deletions

View File

@ -121,8 +121,6 @@ namespace dawn_native { namespace d3d12 {
mViewShaderVisibleDescriptorAllocator, mViewShaderVisibleDescriptorAllocator,
ShaderVisibleDescriptorAllocator::Create(this, D3D12_DESCRIPTOR_HEAP_TYPE_CBV_SRV_UAV)); ShaderVisibleDescriptorAllocator::Create(this, D3D12_DESCRIPTOR_HEAP_TYPE_CBV_SRV_UAV));
DAWN_TRY(NextSerial());
// Initialize indirect commands // Initialize indirect commands
D3D12_INDIRECT_ARGUMENT_DESC argumentDesc = {}; D3D12_INDIRECT_ARGUMENT_DESC argumentDesc = {};
argumentDesc.Type = D3D12_INDIRECT_ARGUMENT_TYPE_DISPATCH; argumentDesc.Type = D3D12_INDIRECT_ARGUMENT_TYPE_DISPATCH;
@ -147,7 +145,11 @@ namespace dawn_native { namespace d3d12 {
GetD3D12Device()->CreateCommandSignature(&programDesc, NULL, GetD3D12Device()->CreateCommandSignature(&programDesc, NULL,
IID_PPV_ARGS(&mDrawIndexedIndirectSignature)); IID_PPV_ARGS(&mDrawIndexedIndirectSignature));
return DeviceBase::Initialize(new Queue(this)); DAWN_TRY(DeviceBase::Initialize(new Queue(this)));
// Device shouldn't be used until after DeviceBase::Initialize so we must wait until after
// device initialization to call NextSerial
DAWN_TRY(NextSerial());
return {};
} }
Device::~Device() { Device::~Device() {