mirror of
				https://github.com/encounter/dawn-cmake.git
				synced 2025-10-26 03:30:30 +00:00 
			
		
		
		
	These were helpers to avoid the need for users of implementation-based swapchains to implement them themselves. They are no longer used and can be removed. Also removes SwapChainuUtils.h that's no longer used. Bug: dawn:269 Change-Id: I3c563edaf107e9ce04f708e8bacae9d231b0f40d Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/126421 Kokoro: Kokoro <noreply+kokoro@google.com> Commit-Queue: Corentin Wallez <cwallez@chromium.org> Reviewed-by: Austin Eng <enga@chromium.org> Reviewed-by: Loko Kung <lokokung@google.com>
		
			
				
	
	
		
			132 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			132 lines
		
	
	
		
			4.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| // Copyright 2018 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 INCLUDE_DAWN_NATIVE_D3D12BACKEND_H_
 | |
| #define INCLUDE_DAWN_NATIVE_D3D12BACKEND_H_
 | |
| 
 | |
| #include <DXGI1_4.h>
 | |
| #include <d3d12.h>
 | |
| #include <windows.h>
 | |
| #include <wrl/client.h>
 | |
| 
 | |
| #include <memory>
 | |
| #include <vector>
 | |
| 
 | |
| #include "dawn/native/D3DBackend.h"
 | |
| 
 | |
| struct ID3D12Device;
 | |
| struct ID3D12Resource;
 | |
| 
 | |
| namespace dawn::native::d3d12 {
 | |
| 
 | |
| class D3D11on12ResourceCache;
 | |
| class Device;
 | |
| class ExternalImageDXGIImpl;
 | |
| 
 | |
| DAWN_NATIVE_EXPORT Microsoft::WRL::ComPtr<ID3D12Device> GetD3D12Device(WGPUDevice device);
 | |
| 
 | |
| enum MemorySegment {
 | |
|     Local,
 | |
|     NonLocal,
 | |
| };
 | |
| 
 | |
| DAWN_NATIVE_EXPORT uint64_t SetExternalMemoryReservation(WGPUDevice device,
 | |
|                                                          uint64_t requestedReservationSize,
 | |
|                                                          MemorySegment memorySegment);
 | |
| 
 | |
| struct DAWN_NATIVE_EXPORT ExternalImageDescriptorDXGISharedHandle : ExternalImageDescriptor {
 | |
|   public:
 | |
|     ExternalImageDescriptorDXGISharedHandle();
 | |
| 
 | |
|     // Note: SharedHandle must be a handle to a texture object.
 | |
|     HANDLE sharedHandle = nullptr;
 | |
| 
 | |
|     // Whether fence synchronization should be used instead of texture's keyed mutex.
 | |
|     bool useFenceSynchronization = false;
 | |
| };
 | |
| 
 | |
| // Keyed mutex acquire/release uses a fixed key of 0 to match Chromium behavior.
 | |
| constexpr UINT64 kDXGIKeyedMutexAcquireReleaseKey = 0;
 | |
| 
 | |
| struct DAWN_NATIVE_EXPORT ExternalImageDXGIFenceDescriptor {
 | |
|     // Shared handle for the fence. This never passes ownership to the callee (when used as an input
 | |
|     // parameter) or to the caller (when used as a return value or output parameter).
 | |
|     HANDLE fenceHandle = nullptr;
 | |
| 
 | |
|     // The value that was previously signaled on this fence and should be waited on.
 | |
|     uint64_t fenceValue = 0;
 | |
| };
 | |
| 
 | |
| struct DAWN_NATIVE_EXPORT ExternalImageDXGIBeginAccessDescriptor {
 | |
|     bool isInitialized = false;  // Whether the texture is initialized on import
 | |
|     WGPUTextureUsageFlags usage = WGPUTextureUsage_None;
 | |
| 
 | |
|     // A list of fences to wait on before accessing the texture.
 | |
|     std::vector<ExternalImageDXGIFenceDescriptor> waitFences;
 | |
| 
 | |
|     // Whether the texture is for a WebGPU swap chain.
 | |
|     bool isSwapChainTexture = false;
 | |
| };
 | |
| 
 | |
| // TODO(dawn:576): Remove after changing Chromium code to use the new struct name.
 | |
| struct DAWN_NATIVE_EXPORT ExternalImageAccessDescriptorDXGIKeyedMutex
 | |
|     : ExternalImageDXGIBeginAccessDescriptor {
 | |
|   public:
 | |
|     // TODO(chromium:1241533): Remove deprecated keyed mutex params after removing associated
 | |
|     // code from Chromium - we use a fixed key of 0 for acquire and release everywhere now.
 | |
|     uint64_t acquireMutexKey;
 | |
|     uint64_t releaseMutexKey;
 | |
| };
 | |
| 
 | |
| class DAWN_NATIVE_EXPORT ExternalImageDXGI {
 | |
|   public:
 | |
|     ~ExternalImageDXGI();
 | |
| 
 | |
|     static std::unique_ptr<ExternalImageDXGI> Create(
 | |
|         WGPUDevice device,
 | |
|         const ExternalImageDescriptorDXGISharedHandle* descriptor);
 | |
| 
 | |
|     // Returns true if the external image resources are still valid, otherwise ProduceTexture() is
 | |
|     // guaranteed to fail e.g. after device destruction.
 | |
|     bool IsValid() const;
 | |
| 
 | |
|     // TODO(sunnyps): |device| is ignored - remove after Chromium migrates to BeginAccess().
 | |
|     WGPUTexture ProduceTexture(WGPUDevice device,
 | |
|                                const ExternalImageDXGIBeginAccessDescriptor* descriptor);
 | |
| 
 | |
|     // Creates WGPUTexture wrapping the DXGI shared handle. The provided wait fences or the
 | |
|     // texture's keyed mutex will be synchronized before using the texture in any command lists.
 | |
|     // Empty fences (nullptr handle) are ignored for convenience (EndAccess can return such fences).
 | |
|     WGPUTexture BeginAccess(const ExternalImageDXGIBeginAccessDescriptor* descriptor);
 | |
| 
 | |
|     // Returns the signalFence that the client must wait on for correct synchronization. Can return
 | |
|     // an empty fence (nullptr handle) if the texture wasn't accessed by Dawn.
 | |
|     // Note that merely calling Destroy() on the WGPUTexture does not ensure synchronization.
 | |
|     void EndAccess(WGPUTexture texture, ExternalImageDXGIFenceDescriptor* signalFence);
 | |
| 
 | |
|   private:
 | |
|     explicit ExternalImageDXGI(std::unique_ptr<ExternalImageDXGIImpl> impl);
 | |
| 
 | |
|     std::unique_ptr<ExternalImageDXGIImpl> mImpl;
 | |
| };
 | |
| 
 | |
| struct DAWN_NATIVE_EXPORT AdapterDiscoveryOptions : public d3d::AdapterDiscoveryOptions {
 | |
|     AdapterDiscoveryOptions();
 | |
|     explicit AdapterDiscoveryOptions(Microsoft::WRL::ComPtr<IDXGIAdapter> adapter);
 | |
| };
 | |
| 
 | |
| }  // namespace dawn::native::d3d12
 | |
| 
 | |
| #endif  // INCLUDE_DAWN_NATIVE_D3D12BACKEND_H_
 |