mirror of
				https://github.com/encounter/dawn-cmake.git
				synced 2025-10-26 03:30:30 +00:00 
			
		
		
		
	node: Implement Compute/RenderPassTimestampWrites
Bug: dawn:1250 Change-Id: Iccd9123b3af7347d7586b998df5b11ab15608bb1 Reviewed-on: https://dawn-review.googlesource.com/c/dawn/+/112424 Kokoro: Kokoro <noreply+kokoro@google.com> Commit-Queue: Corentin Wallez <cwallez@chromium.org> Reviewed-by: Ben Clayton <bclayton@google.com> Reviewed-by: Austin Eng <enga@chromium.org>
This commit is contained in:
		
							parent
							
								
									42ada5f248
								
							
						
					
					
						commit
						89b2e10eac
					
				| @ -16,6 +16,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "src/dawn/node/binding/GPUBuffer.h" | #include "src/dawn/node/binding/GPUBuffer.h" | ||||||
| #include "src/dawn/node/binding/GPUPipelineLayout.h" | #include "src/dawn/node/binding/GPUPipelineLayout.h" | ||||||
|  | #include "src/dawn/node/binding/GPUQuerySet.h" | ||||||
| #include "src/dawn/node/binding/GPUSampler.h" | #include "src/dawn/node/binding/GPUSampler.h" | ||||||
| #include "src/dawn/node/binding/GPUShaderModule.h" | #include "src/dawn/node/binding/GPUShaderModule.h" | ||||||
| #include "src/dawn/node/binding/GPUTexture.h" | #include "src/dawn/node/binding/GPUTexture.h" | ||||||
| @ -1297,6 +1298,30 @@ bool Converter::Convert(wgpu::RenderPassDepthStencilAttachment& out, | |||||||
|            Convert(out.stencilReadOnly, in.stencilReadOnly); |            Convert(out.stencilReadOnly, in.stencilReadOnly); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | bool Converter::Convert(wgpu::RenderPassTimestampWrite& out, | ||||||
|  |                         const interop::GPURenderPassTimestampWrite& in) { | ||||||
|  |     out = {}; | ||||||
|  |     return Convert(out.querySet, in.querySet) &&      //
 | ||||||
|  |            Convert(out.queryIndex, in.queryIndex) &&  //
 | ||||||
|  |            Convert(out.location, in.location); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | bool Converter::Convert(wgpu::RenderPassTimestampLocation& out, | ||||||
|  |                         const interop::GPURenderPassTimestampLocation& in) { | ||||||
|  |     out = wgpu::RenderPassTimestampLocation::Beginning; | ||||||
|  |     switch (in) { | ||||||
|  |         case interop::GPURenderPassTimestampLocation::kBeginning: | ||||||
|  |             out = wgpu::RenderPassTimestampLocation::Beginning; | ||||||
|  |             return true; | ||||||
|  |         case interop::GPURenderPassTimestampLocation::kEnd: | ||||||
|  |             out = wgpu::RenderPassTimestampLocation::End; | ||||||
|  |             return true; | ||||||
|  |     } | ||||||
|  |     Napi::Error::New(env, "invalid value for GPURenderPassTimestampLocation") | ||||||
|  |         .ThrowAsJavaScriptException(); | ||||||
|  |     return false; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| bool Converter::Convert(wgpu::LoadOp& out, const interop::GPULoadOp& in) { | bool Converter::Convert(wgpu::LoadOp& out, const interop::GPULoadOp& in) { | ||||||
|     out = wgpu::LoadOp::Clear; |     out = wgpu::LoadOp::Clear; | ||||||
|     switch (in) { |     switch (in) { | ||||||
| @ -1325,6 +1350,30 @@ bool Converter::Convert(wgpu::StoreOp& out, const interop::GPUStoreOp& in) { | |||||||
|     return false; |     return false; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | bool Converter::Convert(wgpu::ComputePassTimestampWrite& out, | ||||||
|  |                         const interop::GPUComputePassTimestampWrite& in) { | ||||||
|  |     out = {}; | ||||||
|  |     return Convert(out.querySet, in.querySet) &&      //
 | ||||||
|  |            Convert(out.queryIndex, in.queryIndex) &&  //
 | ||||||
|  |            Convert(out.location, in.location); | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | bool Converter::Convert(wgpu::ComputePassTimestampLocation& out, | ||||||
|  |                         const interop::GPUComputePassTimestampLocation& in) { | ||||||
|  |     out = wgpu::ComputePassTimestampLocation::Beginning; | ||||||
|  |     switch (in) { | ||||||
|  |         case interop::GPUComputePassTimestampLocation::kBeginning: | ||||||
|  |             out = wgpu::ComputePassTimestampLocation::Beginning; | ||||||
|  |             return true; | ||||||
|  |         case interop::GPUComputePassTimestampLocation::kEnd: | ||||||
|  |             out = wgpu::ComputePassTimestampLocation::End; | ||||||
|  |             return true; | ||||||
|  |     } | ||||||
|  |     Napi::Error::New(env, "invalid value for GPUComputePassTimestampLocation") | ||||||
|  |         .ThrowAsJavaScriptException(); | ||||||
|  |     return false; | ||||||
|  | } | ||||||
|  | 
 | ||||||
| bool Converter::Convert(wgpu::BindGroupEntry& out, const interop::GPUBindGroupEntry& in) { | bool Converter::Convert(wgpu::BindGroupEntry& out, const interop::GPUBindGroupEntry& in) { | ||||||
|     out = {}; |     out = {}; | ||||||
|     if (!Convert(out.binding, in.binding)) { |     if (!Convert(out.binding, in.binding)) { | ||||||
|  | |||||||
| @ -196,10 +196,22 @@ class Converter { | |||||||
|     [[nodiscard]] bool Convert(wgpu::RenderPassDepthStencilAttachment& out, |     [[nodiscard]] bool Convert(wgpu::RenderPassDepthStencilAttachment& out, | ||||||
|                                const interop::GPURenderPassDepthStencilAttachment& in); |                                const interop::GPURenderPassDepthStencilAttachment& in); | ||||||
| 
 | 
 | ||||||
|  |     [[nodiscard]] bool Convert(wgpu::RenderPassTimestampWrite& out, | ||||||
|  |                                const interop::GPURenderPassTimestampWrite& in); | ||||||
|  | 
 | ||||||
|  |     [[nodiscard]] bool Convert(wgpu::RenderPassTimestampLocation& out, | ||||||
|  |                                const interop::GPURenderPassTimestampLocation& in); | ||||||
|  | 
 | ||||||
|     [[nodiscard]] bool Convert(wgpu::LoadOp& out, const interop::GPULoadOp& in); |     [[nodiscard]] bool Convert(wgpu::LoadOp& out, const interop::GPULoadOp& in); | ||||||
| 
 | 
 | ||||||
|     [[nodiscard]] bool Convert(wgpu::StoreOp& out, const interop::GPUStoreOp& in); |     [[nodiscard]] bool Convert(wgpu::StoreOp& out, const interop::GPUStoreOp& in); | ||||||
| 
 | 
 | ||||||
|  |     [[nodiscard]] bool Convert(wgpu::ComputePassTimestampWrite& out, | ||||||
|  |                                const interop::GPUComputePassTimestampWrite& in); | ||||||
|  | 
 | ||||||
|  |     [[nodiscard]] bool Convert(wgpu::ComputePassTimestampLocation& out, | ||||||
|  |                                const interop::GPUComputePassTimestampLocation& in); | ||||||
|  | 
 | ||||||
|     [[nodiscard]] bool Convert(wgpu::BindGroupEntry& out, const interop::GPUBindGroupEntry& in); |     [[nodiscard]] bool Convert(wgpu::BindGroupEntry& out, const interop::GPUBindGroupEntry& in); | ||||||
| 
 | 
 | ||||||
|     [[nodiscard]] bool Convert(wgpu::BindGroupLayoutEntry& out, |     [[nodiscard]] bool Convert(wgpu::BindGroupLayoutEntry& out, | ||||||
|  | |||||||
| @ -42,11 +42,11 @@ interop::Interface<interop::GPURenderPassEncoder> GPUCommandEncoder::beginRender | |||||||
|     wgpu::RenderPassDescriptorMaxDrawCount maxDrawCountDesc{}; |     wgpu::RenderPassDescriptorMaxDrawCount maxDrawCountDesc{}; | ||||||
|     desc.nextInChain = &maxDrawCountDesc; |     desc.nextInChain = &maxDrawCountDesc; | ||||||
| 
 | 
 | ||||||
|     // TODO(dawn:1250) handle timestampWrites
 |  | ||||||
|     if (!conv(desc.colorAttachments, desc.colorAttachmentCount, descriptor.colorAttachments) || |     if (!conv(desc.colorAttachments, desc.colorAttachmentCount, descriptor.colorAttachments) || | ||||||
|         !conv(desc.depthStencilAttachment, descriptor.depthStencilAttachment) || |         !conv(desc.depthStencilAttachment, descriptor.depthStencilAttachment) || | ||||||
|         !conv(desc.label, descriptor.label) || |         !conv(desc.label, descriptor.label) || | ||||||
|         !conv(desc.occlusionQuerySet, descriptor.occlusionQuerySet) || |         !conv(desc.occlusionQuerySet, descriptor.occlusionQuerySet) || | ||||||
|  |         !conv(desc.timestampWrites, desc.timestampWriteCount, descriptor.timestampWrites) || | ||||||
|         !conv(maxDrawCountDesc.maxDrawCount, descriptor.maxDrawCount)) { |         !conv(maxDrawCountDesc.maxDrawCount, descriptor.maxDrawCount)) { | ||||||
|         return {}; |         return {}; | ||||||
|     } |     } | ||||||
| @ -58,8 +58,13 @@ interop::Interface<interop::GPURenderPassEncoder> GPUCommandEncoder::beginRender | |||||||
| interop::Interface<interop::GPUComputePassEncoder> GPUCommandEncoder::beginComputePass( | interop::Interface<interop::GPUComputePassEncoder> GPUCommandEncoder::beginComputePass( | ||||||
|     Napi::Env env, |     Napi::Env env, | ||||||
|     interop::GPUComputePassDescriptor descriptor) { |     interop::GPUComputePassDescriptor descriptor) { | ||||||
|  |     Converter conv(env); | ||||||
|  | 
 | ||||||
|     wgpu::ComputePassDescriptor desc{}; |     wgpu::ComputePassDescriptor desc{}; | ||||||
|     // TODO(dawn:1250) handle timestampWrites
 |     if (!conv(desc.timestampWrites, desc.timestampWriteCount, descriptor.timestampWrites)) { | ||||||
|  |         return {}; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     return interop::GPUComputePassEncoder::Create<GPUComputePassEncoder>( |     return interop::GPUComputePassEncoder::Create<GPUComputePassEncoder>( | ||||||
|         env, enc_.BeginComputePass(&desc)); |         env, enc_.BeginComputePass(&desc)); | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user