// Copyright 2017 The Dawn Authors // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #ifndef DAWNNATIVE_D3D12_DEVICED3D12_H_ #define DAWNNATIVE_D3D12_DEVICED3D12_H_ #include "dawn_native/dawn_platform.h" #include "common/Constants.h" #include "common/SerialQueue.h" #include "dawn_native/Device.h" #include "dawn_native/d3d12/CommandRecordingContext.h" #include "dawn_native/d3d12/D3D12Info.h" #include "dawn_native/d3d12/Forward.h" #include "dawn_native/d3d12/ResourceHeapAllocationD3D12.h" #include namespace dawn_native { namespace d3d12 { class CommandAllocatorManager; class DescriptorHeapAllocator; class MapRequestTracker; class PlatformFunctions; class ResidencyManager; class ResourceAllocatorManager; class SamplerHeapCache; class ShaderVisibleDescriptorAllocator; class StagingDescriptorAllocator; #define ASSERT_SUCCESS(hr) \ do { \ HRESULT succeeded = hr; \ ASSERT(SUCCEEDED(succeeded)); \ } while (0) // Definition of backend types class Device : public DeviceBase { public: static ResultOrError Create(Adapter* adapter, const DeviceDescriptor* descriptor); ~Device() override; MaybeError Initialize(); CommandBufferBase* CreateCommandBuffer(CommandEncoder* encoder, const CommandBufferDescriptor* descriptor) override; MaybeError TickImpl() override; ID3D12Device* GetD3D12Device() const; ComPtr GetCommandQueue() const; ID3D12SharingContract* GetSharingContract() const; ComPtr GetDispatchIndirectSignature() const; ComPtr GetDrawIndirectSignature() const; ComPtr GetDrawIndexedIndirectSignature() const; MapRequestTracker* GetMapRequestTracker() const; CommandAllocatorManager* GetCommandAllocatorManager() const; ResidencyManager* GetResidencyManager() const; const PlatformFunctions* GetFunctions() const; ComPtr GetFactory() const; ResultOrError GetPendingCommandContext(); const D3D12DeviceInfo& GetDeviceInfo() const; MaybeError NextSerial(); MaybeError WaitForSerial(Serial serial); void ReferenceUntilUnused(ComPtr object); MaybeError ExecutePendingCommandContext(); ResultOrError> CreateStagingBuffer(size_t size) override; MaybeError CopyFromStagingToBuffer(StagingBufferBase* source, uint64_t sourceOffset, BufferBase* destination, uint64_t destinationOffset, uint64_t size) override; ResultOrError AllocateMemory( D3D12_HEAP_TYPE heapType, const D3D12_RESOURCE_DESC& resourceDescriptor, D3D12_RESOURCE_STATES initialUsage); void DeallocateMemory(ResourceHeapAllocation& allocation); ShaderVisibleDescriptorAllocator* GetViewShaderVisibleDescriptorAllocator() const; ShaderVisibleDescriptorAllocator* GetSamplerShaderVisibleDescriptorAllocator() const; // Returns nullptr when descriptor count is zero. StagingDescriptorAllocator* GetViewStagingDescriptorAllocator( uint32_t descriptorCount) const; StagingDescriptorAllocator* GetSamplerStagingDescriptorAllocator( uint32_t descriptorCount) const; SamplerHeapCache* GetSamplerHeapCache(); StagingDescriptorAllocator* GetRenderTargetViewAllocator() const; StagingDescriptorAllocator* GetDepthStencilViewAllocator() const; Ref WrapSharedHandle(const ExternalImageDescriptor* descriptor, HANDLE sharedHandle, uint64_t acquireMutexKey, bool isSwapChainTexture); ResultOrError> CreateKeyedMutexForTexture( ID3D12Resource* d3d12Resource); void ReleaseKeyedMutexForTexture(ComPtr dxgiKeyedMutex); void InitTogglesFromDriver(); private: using DeviceBase::DeviceBase; ResultOrError CreateBindGroupImpl( const BindGroupDescriptor* descriptor) override; ResultOrError CreateBindGroupLayoutImpl( const BindGroupLayoutDescriptor* descriptor) override; ResultOrError CreateBufferImpl(const BufferDescriptor* descriptor) override; ResultOrError CreateComputePipelineImpl( const ComputePipelineDescriptor* descriptor) override; ResultOrError CreatePipelineLayoutImpl( const PipelineLayoutDescriptor* descriptor) override; ResultOrError CreateRenderPipelineImpl( const RenderPipelineDescriptor* descriptor) override; ResultOrError CreateSamplerImpl(const SamplerDescriptor* descriptor) override; ResultOrError CreateShaderModuleImpl( const ShaderModuleDescriptor* descriptor) override; ResultOrError CreateSwapChainImpl( const SwapChainDescriptor* descriptor) override; ResultOrError CreateSwapChainImpl( Surface* surface, NewSwapChainBase* previousSwapChain, const SwapChainDescriptor* descriptor) override; ResultOrError> CreateTextureImpl( const TextureDescriptor* descriptor) override; ResultOrError CreateTextureViewImpl( TextureBase* texture, const TextureViewDescriptor* descriptor) override; void ShutDownImpl() override; MaybeError WaitForIdleForDestruction() override; ComPtr mFence; HANDLE mFenceEvent = nullptr; Serial CheckAndUpdateCompletedSerials() override; ComPtr mD3d12Device; // Device is owned by adapter and will not be outlived. ComPtr mCommandQueue; ComPtr mD3d12SharingContract; // 11on12 device and device context corresponding to mCommandQueue ComPtr mD3d11On12Device; ComPtr mD3d11On12DeviceContext; ComPtr mDispatchIndirectSignature; ComPtr mDrawIndirectSignature; ComPtr mDrawIndexedIndirectSignature; CommandRecordingContext mPendingCommands; SerialQueue> mUsedComObjectRefs; std::unique_ptr mCommandAllocatorManager; std::unique_ptr mMapRequestTracker; std::unique_ptr mResourceAllocatorManager; std::unique_ptr mResidencyManager; // Index corresponds to the descriptor count in the range [0, kMaxBindingsPerGroup]. static constexpr uint32_t kNumOfStagingDescriptorAllocators = kMaxBindingsPerGroup + 1; std::array, kNumOfStagingDescriptorAllocators> mViewAllocators; std::array, kNumOfStagingDescriptorAllocators> mSamplerAllocators; std::unique_ptr mRenderTargetViewAllocator; std::unique_ptr mDepthStencilViewAllocator; std::unique_ptr mViewShaderVisibleDescriptorAllocator; std::unique_ptr mSamplerShaderVisibleDescriptorAllocator; // Sampler cache needs to be destroyed before the CPU sampler allocator to ensure the final // release is called. std::unique_ptr mSamplerHeapCache; }; }} // namespace dawn_native::d3d12 #endif // DAWNNATIVE_D3D12_DEVICED3D12_H_