mirror of
				https://github.com/encounter/dawn-cmake.git
				synced 2025-10-26 11:40:29 +00:00 
			
		
		
		
	De-duplicate ExternalTexture Dummy Textures
Avoid recreating 1x1x1 dummy textures for single-plane external texture by just caching one and reusing it. Bug: dawn:1082 Change-Id: Ia1fc3520a1b503d4491a256353277400ba90f344 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/80462 Reviewed-by: Austin Eng <enga@chromium.org> Reviewed-by: Corentin Wallez <cwallez@chromium.org> Commit-Queue: Brandon1 Jones <brandon1.jones@intel.com>
This commit is contained in:
		
							parent
							
								
									7593ab8aa4
								
							
						
					
					
						commit
						c86f28cb84
					
				| @ -400,6 +400,7 @@ namespace dawn::native { | ||||
|         mPersistentCache = nullptr; | ||||
|         mEmptyBindGroupLayout = nullptr; | ||||
|         mInternalPipelineStore = nullptr; | ||||
|         mExternalTextureDummyView = nullptr; | ||||
| 
 | ||||
|         AssumeCommandsComplete(); | ||||
| 
 | ||||
| @ -787,6 +788,35 @@ namespace dawn::native { | ||||
|         ASSERT(removedCount == 1); | ||||
|     } | ||||
| 
 | ||||
|     ResultOrError<Ref<TextureViewBase>> | ||||
|     DeviceBase::GetOrCreateDummyTextureViewForExternalTexture() { | ||||
|         if (!mExternalTextureDummyView.Get()) { | ||||
|             Ref<TextureBase> externalTextureDummy; | ||||
|             TextureDescriptor textureDesc; | ||||
|             textureDesc.dimension = wgpu::TextureDimension::e2D; | ||||
|             textureDesc.format = wgpu::TextureFormat::RGBA8Unorm; | ||||
|             textureDesc.label = "Dawn_External_Texture_Dummy_Texture"; | ||||
|             textureDesc.size = {1, 1, 1}; | ||||
|             textureDesc.usage = wgpu::TextureUsage::TextureBinding; | ||||
| 
 | ||||
|             DAWN_TRY_ASSIGN(externalTextureDummy, CreateTexture(&textureDesc)); | ||||
| 
 | ||||
|             TextureViewDescriptor textureViewDesc; | ||||
|             textureViewDesc.arrayLayerCount = 1; | ||||
|             textureViewDesc.aspect = wgpu::TextureAspect::All; | ||||
|             textureViewDesc.baseArrayLayer = 0; | ||||
|             textureViewDesc.dimension = wgpu::TextureViewDimension::e2D; | ||||
|             textureViewDesc.format = wgpu::TextureFormat::RGBA8Unorm; | ||||
|             textureViewDesc.label = "Dawn_External_Texture_Dummy_Texture_View"; | ||||
|             textureViewDesc.mipLevelCount = 1; | ||||
| 
 | ||||
|             DAWN_TRY_ASSIGN(mExternalTextureDummyView, | ||||
|                             CreateTextureView(externalTextureDummy.Get(), &textureViewDesc)); | ||||
|         } | ||||
| 
 | ||||
|         return mExternalTextureDummyView; | ||||
|     } | ||||
| 
 | ||||
|     ResultOrError<Ref<PipelineLayoutBase>> DeviceBase::GetOrCreatePipelineLayout( | ||||
|         const PipelineLayoutDescriptor* descriptor) { | ||||
|         PipelineLayoutBase blueprint(this, descriptor, ApiObjectBase::kUntrackedByDevice); | ||||
|  | ||||
| @ -170,6 +170,8 @@ namespace dawn::native { | ||||
| 
 | ||||
|         void UncacheComputePipeline(ComputePipelineBase* obj); | ||||
| 
 | ||||
|         ResultOrError<Ref<TextureViewBase>> GetOrCreateDummyTextureViewForExternalTexture(); | ||||
| 
 | ||||
|         ResultOrError<Ref<PipelineLayoutBase>> GetOrCreatePipelineLayout( | ||||
|             const PipelineLayoutDescriptor* descriptor); | ||||
|         void UncachePipelineLayout(PipelineLayoutBase* obj); | ||||
| @ -507,6 +509,8 @@ namespace dawn::native { | ||||
| 
 | ||||
|         Ref<BindGroupLayoutBase> mEmptyBindGroupLayout; | ||||
| 
 | ||||
|         Ref<TextureViewBase> mExternalTextureDummyView; | ||||
| 
 | ||||
|         std::unique_ptr<DynamicUploader> mDynamicUploader; | ||||
|         std::unique_ptr<AsyncTaskManager> mAsyncTaskManager; | ||||
|         Ref<QueueBase> mQueue; | ||||
|  | ||||
| @ -129,26 +129,8 @@ namespace dawn::native { | ||||
|         if (descriptor->plane1) { | ||||
|             mTextureViews[1] = descriptor->plane1; | ||||
|         } else { | ||||
|             TextureDescriptor textureDesc; | ||||
|             textureDesc.dimension = wgpu::TextureDimension::e2D; | ||||
|             textureDesc.format = wgpu::TextureFormat::RGBA8Unorm; | ||||
|             textureDesc.label = "Dawn_External_Texture_Dummy_Texture"; | ||||
|             textureDesc.size = {1, 1, 1}; | ||||
|             textureDesc.usage = wgpu::TextureUsage::TextureBinding; | ||||
| 
 | ||||
|             DAWN_TRY_ASSIGN(mDummyTexture, device->CreateTexture(&textureDesc)); | ||||
| 
 | ||||
|             TextureViewDescriptor textureViewDesc; | ||||
|             textureViewDesc.arrayLayerCount = 1; | ||||
|             textureViewDesc.aspect = wgpu::TextureAspect::All; | ||||
|             textureViewDesc.baseArrayLayer = 0; | ||||
|             textureViewDesc.dimension = wgpu::TextureViewDimension::e2D; | ||||
|             textureViewDesc.format = wgpu::TextureFormat::RGBA8Unorm; | ||||
|             textureViewDesc.label = "Dawn_External_Texture_Dummy_Texture_View"; | ||||
|             textureViewDesc.mipLevelCount = 1; | ||||
| 
 | ||||
|             DAWN_TRY_ASSIGN(mTextureViews[1], | ||||
|                             device->CreateTextureView(mDummyTexture.Get(), &textureViewDesc)); | ||||
|                             device->GetOrCreateDummyTextureViewForExternalTexture()); | ||||
|         } | ||||
| 
 | ||||
|         // We must create a buffer to store parameters needed by a shader that operates on this
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user