mirror of
				https://github.com/encounter/dawn-cmake.git
				synced 2025-10-25 19:20:30 +00:00 
			
		
		
		
	To support concurrent readers on multiple command queues/devices, Dawn must support importing via wait multiple fences and also export a signal fence. The previous implementation of using a single fence for waiting and signaling doesn't work for concurrent reads across queues. This CL adds support for specifying multiple wait fences for ExternalImageDXGI via a BeginAccess method that's meant to replace ProduceTexture. There's also an EndAccess method that returns a signal fence for the client. For performance reasons, we use the same fence as the signal fence that the Device uses internally, and record its value on the texture after ExecuteCommandLists. Therefore, the CL also makes the Device's internal fence a shared fence so that we can export it to the client. This CL also expands the ConcurrentExternalImageReadAccess test so that it tests fence synchronization across multiple devices. A number of test helpers also now take an optional device parameter so that we can use pixel value expectations with secondary devices. Bug: dawn:576 Change-Id: I6bc86808ede9b5aacf87667106cbd16731a12516 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/99746 Commit-Queue: Sunny Sachanandani <sunnyps@chromium.org> Reviewed-by: Austin Eng <enga@chromium.org> Kokoro: Kokoro <noreply+kokoro@google.com>
		
			
				
	
	
		
			139 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			139 lines
		
	
	
		
			5.3 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/dawn_wsi.h"
 | |
| #include "dawn/native/DawnNative.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);
 | |
| DAWN_NATIVE_EXPORT DawnSwapChainImplementation CreateNativeSwapChainImpl(WGPUDevice device,
 | |
|                                                                          HWND window);
 | |
| DAWN_NATIVE_EXPORT WGPUTextureFormat
 | |
| GetNativeSwapChainPreferredFormat(const DawnSwapChainImplementation* swapChain);
 | |
| 
 | |
| 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 AdapterDiscoveryOptionsBase {
 | |
|     AdapterDiscoveryOptions();
 | |
|     explicit AdapterDiscoveryOptions(Microsoft::WRL::ComPtr<IDXGIAdapter> adapter);
 | |
| 
 | |
|     Microsoft::WRL::ComPtr<IDXGIAdapter> dxgiAdapter;
 | |
| };
 | |
| 
 | |
| }  // namespace dawn::native::d3d12
 | |
| 
 | |
| #endif  // INCLUDE_DAWN_NATIVE_D3D12BACKEND_H_
 |