mirror of
				https://github.com/encounter/dawn-cmake.git
				synced 2025-10-25 19:20:30 +00:00 
			
		
		
		
	Remove RenderPassDescriptorBuilder
This patch removes RenderPassDescriptorBuilder completely from Dawn. With this patch, RenderPassDescriptor is a structure instead of a Dawn object, and all the checks in RenderPassDescriptorBuilder are moved into CommandEncoder.cpp. This patch also updates the helper functions and structures related to RenderPassDescriptor because RenderPassDescriptor is no longer an object but a structure with members in pointers. BUG=dawn:6 Change-Id: Ic6d015582031891f35ffef912f0e460a9c010f81 Reviewed-on: https://dawn-review.googlesource.com/c/4902 Commit-Queue: Corentin Wallez <cwallez@chromium.org> Reviewed-by: Corentin Wallez <cwallez@chromium.org> Reviewed-by: Kai Ninomiya <kainino@chromium.org>
This commit is contained in:
		
							parent
							
								
									738567f148
								
							
						
					
					
						commit
						b2c5023c9c
					
				
							
								
								
									
										2
									
								
								BUILD.gn
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								BUILD.gn
									
									
									
									
									
								
							| @ -483,8 +483,6 @@ source_set("libdawn_native_sources") { | |||||||
|     "src/dawn_native/Queue.h", |     "src/dawn_native/Queue.h", | ||||||
|     "src/dawn_native/RefCounted.cpp", |     "src/dawn_native/RefCounted.cpp", | ||||||
|     "src/dawn_native/RefCounted.h", |     "src/dawn_native/RefCounted.h", | ||||||
|     "src/dawn_native/RenderPassDescriptor.cpp", |  | ||||||
|     "src/dawn_native/RenderPassDescriptor.h", |  | ||||||
|     "src/dawn_native/RenderPassEncoder.cpp", |     "src/dawn_native/RenderPassEncoder.cpp", | ||||||
|     "src/dawn_native/RenderPassEncoder.h", |     "src/dawn_native/RenderPassEncoder.h", | ||||||
|     "src/dawn_native/RenderPipeline.cpp", |     "src/dawn_native/RenderPipeline.cpp", | ||||||
|  | |||||||
							
								
								
									
										36
									
								
								dawn.json
									
									
									
									
									
								
							
							
						
						
									
										36
									
								
								dawn.json
									
									
									
									
									
								
							| @ -285,7 +285,7 @@ | |||||||
|             { |             { | ||||||
|                 "name": "begin render pass", |                 "name": "begin render pass", | ||||||
|                 "args": [ |                 "args": [ | ||||||
|                     {"name": "info", "type": "render pass descriptor"} |                     {"name": "info", "type": "render pass descriptor", "annotation": "const*"} | ||||||
|                 ], |                 ], | ||||||
|                 "returns": "render pass encoder" |                 "returns": "render pass encoder" | ||||||
|             }, |             }, | ||||||
| @ -443,10 +443,6 @@ | |||||||
|                     {"name": "descriptor", "type": "fence descriptor", "annotation": "const*"} |                     {"name": "descriptor", "type": "fence descriptor", "annotation": "const*"} | ||||||
|                 ] |                 ] | ||||||
|             }, |             }, | ||||||
|             { |  | ||||||
|                 "name": "create render pass descriptor builder", |  | ||||||
|                 "returns": "render pass descriptor builder" |  | ||||||
|             }, |  | ||||||
|             { |             { | ||||||
|                 "name": "create input state builder", |                 "name": "create input state builder", | ||||||
|                 "returns": "input state builder" |                 "returns": "input state builder" | ||||||
| @ -746,31 +742,13 @@ | |||||||
|         ] |         ] | ||||||
|     }, |     }, | ||||||
| 
 | 
 | ||||||
|     "render pass descriptor builder": { |  | ||||||
|         "category": "object", |  | ||||||
|         "methods": [ |  | ||||||
|             { |  | ||||||
|                 "name": "get result", |  | ||||||
|                 "returns": "render pass descriptor" |  | ||||||
|             }, |  | ||||||
|             { |  | ||||||
|                 "name": "set color attachments", |  | ||||||
|                 "args": [ |  | ||||||
|                     {"name": "count", "type": "uint32_t"}, |  | ||||||
|                     {"name": "color attachments", "type": "render pass color attachment descriptor", "annotation": "const*", "length": "count"} |  | ||||||
|                 ] |  | ||||||
|             }, |  | ||||||
|             { |  | ||||||
|                 "name": "set depth stencil attachment", |  | ||||||
|                 "args": [ |  | ||||||
|                     {"name": "depth stencil attachment", "type": "render pass depth stencil attachment descriptor", "annotation": "const*"} |  | ||||||
|                 ] |  | ||||||
|             } |  | ||||||
|         ], |  | ||||||
|         "TODO": "Remove this builder and use render pass descriptor directly" |  | ||||||
|     }, |  | ||||||
|     "render pass descriptor": { |     "render pass descriptor": { | ||||||
|         "category": "object" |         "category": "structure", | ||||||
|  |         "members": [ | ||||||
|  |             {"name": "color attachment count", "type": "uint32_t"}, | ||||||
|  |             {"name": "color attachments", "type": "render pass color attachment descriptor", "annotation": "const*const*", "length": "color attachment count"}, | ||||||
|  |             {"name": "depth stencil attachment", "type": "render pass depth stencil attachment descriptor", "annotation": "const*", "optional": true} | ||||||
|  |         ] | ||||||
|     }, |     }, | ||||||
|     "render pass encoder": { |     "render pass encoder": { | ||||||
|         "category": "object", |         "category": "object", | ||||||
|  | |||||||
| @ -131,18 +131,18 @@ void init() { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void frame() { | void frame() { | ||||||
|     dawn::Texture backbuffer; |     dawn::Texture backbuffer = swapchain.GetNextTexture(); | ||||||
|     dawn::RenderPassDescriptor renderPass; |  | ||||||
|     GetNextRenderPassDescriptor(device, swapchain, depthStencilView, &backbuffer, &renderPass); |  | ||||||
| 
 | 
 | ||||||
|     static int f = 0; |     static int f = 0; | ||||||
|     f++; |     f++; | ||||||
| 
 | 
 | ||||||
|     size_t i = 0; |     size_t i = 0; | ||||||
| 
 | 
 | ||||||
|  |     utils::ComboRenderPassDescriptor renderPass({backbuffer.CreateDefaultTextureView()}, | ||||||
|  |                                                 depthStencilView); | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
| 
 | 
 | ||||||
|         for (int k = 0; k < 10000; k++) { |         for (int k = 0; k < 10000; k++) { | ||||||
|  | |||||||
| @ -118,23 +118,23 @@ void frame() { | |||||||
|         backbufferView = dawnTextureCreateDefaultTextureView(backbuffer); |         backbufferView = dawnTextureCreateDefaultTextureView(backbuffer); | ||||||
|     } |     } | ||||||
|     dawnRenderPassDescriptor renderpassInfo; |     dawnRenderPassDescriptor renderpassInfo; | ||||||
|  |     dawnRenderPassColorAttachmentDescriptor colorAttachment; | ||||||
|  |     dawnRenderPassColorAttachmentDescriptor* colorAttachments = {&colorAttachment}; | ||||||
|     { |     { | ||||||
|         dawnRenderPassDescriptorBuilder builder = dawnDeviceCreateRenderPassDescriptorBuilder(device); |  | ||||||
|         dawnRenderPassColorAttachmentDescriptor colorAttachment; |  | ||||||
|         colorAttachment.attachment = backbufferView; |         colorAttachment.attachment = backbufferView; | ||||||
|         colorAttachment.resolveTarget = nullptr; |         colorAttachment.resolveTarget = nullptr; | ||||||
|         colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |         colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; | ||||||
|         colorAttachment.loadOp = DAWN_LOAD_OP_CLEAR; |         colorAttachment.loadOp = DAWN_LOAD_OP_CLEAR; | ||||||
|         colorAttachment.storeOp = DAWN_STORE_OP_STORE; |         colorAttachment.storeOp = DAWN_STORE_OP_STORE; | ||||||
|         dawnRenderPassDescriptorBuilderSetColorAttachments(builder, 1, &colorAttachment); |         renderpassInfo.colorAttachmentCount = 1; | ||||||
|         renderpassInfo = dawnRenderPassDescriptorBuilderGetResult(builder); |         renderpassInfo.colorAttachments = &colorAttachments; | ||||||
|         dawnRenderPassDescriptorBuilderRelease(builder); |         renderpassInfo.depthStencilAttachment = nullptr; | ||||||
|     } |     } | ||||||
|     dawnCommandBuffer commands; |     dawnCommandBuffer commands; | ||||||
|     { |     { | ||||||
|         dawnCommandEncoder encoder = dawnDeviceCreateCommandEncoder(device); |         dawnCommandEncoder encoder = dawnDeviceCreateCommandEncoder(device); | ||||||
| 
 | 
 | ||||||
|         dawnRenderPassEncoder pass = dawnCommandEncoderBeginRenderPass(encoder, renderpassInfo); |         dawnRenderPassEncoder pass = dawnCommandEncoderBeginRenderPass(encoder, &renderpassInfo); | ||||||
|         dawnRenderPassEncoderSetPipeline(pass, pipeline); |         dawnRenderPassEncoderSetPipeline(pass, pipeline); | ||||||
|         dawnRenderPassEncoderDraw(pass, 3, 1, 0, 0); |         dawnRenderPassEncoderDraw(pass, 3, 1, 0, 0); | ||||||
|         dawnRenderPassEncoderEndPass(pass); |         dawnRenderPassEncoderEndPass(pass); | ||||||
| @ -147,7 +147,6 @@ void frame() { | |||||||
|     dawnQueueSubmit(queue, 1, &commands); |     dawnQueueSubmit(queue, 1, &commands); | ||||||
|     dawnCommandBufferRelease(commands); |     dawnCommandBufferRelease(commands); | ||||||
|     dawnSwapChainPresent(swapchain, backbuffer); |     dawnSwapChainPresent(swapchain, backbuffer); | ||||||
|     dawnRenderPassDescriptorRelease(renderpassInfo); |  | ||||||
|     dawnTextureViewRelease(backbufferView); |     dawnTextureViewRelease(backbufferView); | ||||||
| 
 | 
 | ||||||
|     DoFlush(); |     DoFlush(); | ||||||
|  | |||||||
| @ -277,7 +277,7 @@ void initSim() { | |||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| dawn::CommandBuffer createCommandBuffer(const dawn::RenderPassDescriptor& renderPass, size_t i) { | dawn::CommandBuffer createCommandBuffer(const dawn::Texture backbuffer, size_t i) { | ||||||
|     static const uint32_t zeroOffsets[1] = {0}; |     static const uint32_t zeroOffsets[1] = {0}; | ||||||
|     auto& bufferDst = particleBuffers[(i + 1) % 2]; |     auto& bufferDst = particleBuffers[(i + 1) % 2]; | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
| @ -291,7 +291,9 @@ dawn::CommandBuffer createCommandBuffer(const dawn::RenderPassDescriptor& render | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass); |         utils::ComboRenderPassDescriptor renderPass({backbuffer.CreateDefaultTextureView()}, | ||||||
|  |                                                     depthStencilView); | ||||||
|  |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.SetPipeline(renderPipeline); |         pass.SetPipeline(renderPipeline); | ||||||
|         pass.SetVertexBuffers(0, 1, &bufferDst, zeroOffsets); |         pass.SetVertexBuffers(0, 1, &bufferDst, zeroOffsets); | ||||||
|         pass.SetVertexBuffers(1, 1, &modelBuffer, zeroOffsets); |         pass.SetVertexBuffers(1, 1, &modelBuffer, zeroOffsets); | ||||||
| @ -316,11 +318,9 @@ void init() { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void frame() { | void frame() { | ||||||
|     dawn::Texture backbuffer; |     dawn::Texture backbuffer = swapchain.GetNextTexture(); | ||||||
|     dawn::RenderPassDescriptor renderPass; |  | ||||||
|     GetNextRenderPassDescriptor(device, swapchain, depthStencilView, &backbuffer, &renderPass); |  | ||||||
| 
 | 
 | ||||||
|     dawn::CommandBuffer commandBuffer = createCommandBuffer(renderPass, pingpong); |     dawn::CommandBuffer commandBuffer = createCommandBuffer(backbuffer, pingpong); | ||||||
|     queue.Submit(1, &commandBuffer); |     queue.Submit(1, &commandBuffer); | ||||||
|     swapchain.Present(backbuffer); |     swapchain.Present(backbuffer); | ||||||
|     DoFlush(); |     DoFlush(); | ||||||
|  | |||||||
| @ -160,14 +160,14 @@ void frame() { | |||||||
|     s.b += 0.02f; |     s.b += 0.02f; | ||||||
|     if (s.b >= 1.0f) {s.b = 0.0f;} |     if (s.b >= 1.0f) {s.b = 0.0f;} | ||||||
| 
 | 
 | ||||||
|     dawn::Texture backbuffer; |     dawn::Texture backbuffer = swapchain.GetNextTexture(); | ||||||
|     dawn::RenderPassDescriptor renderPass; |     utils::ComboRenderPassDescriptor renderPass({backbuffer.CreateDefaultTextureView()}, | ||||||
|     GetNextRenderPassDescriptor(device, swapchain, depthStencilView, &backbuffer, &renderPass); |                                                 depthStencilView); | ||||||
| 
 | 
 | ||||||
|     static const uint32_t vertexBufferOffsets[1] = {0}; |     static const uint32_t vertexBufferOffsets[1] = {0}; | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.SetBindGroup(0, bindGroup); |         pass.SetBindGroup(0, bindGroup); | ||||||
|         pass.SetVertexBuffers(0, 1, &vertexBuffer, vertexBufferOffsets); |         pass.SetVertexBuffers(0, 1, &vertexBuffer, vertexBufferOffsets); | ||||||
|  | |||||||
| @ -272,13 +272,13 @@ void frame() { | |||||||
| 
 | 
 | ||||||
|     cameraBuffer.SetSubData(0, sizeof(CameraData), reinterpret_cast<uint8_t*>(&cameraData)); |     cameraBuffer.SetSubData(0, sizeof(CameraData), reinterpret_cast<uint8_t*>(&cameraData)); | ||||||
| 
 | 
 | ||||||
|     dawn::Texture backbuffer; |     dawn::Texture backbuffer = swapchain.GetNextTexture(); | ||||||
|     dawn::RenderPassDescriptor renderPass; |     utils::ComboRenderPassDescriptor renderPass({backbuffer.CreateDefaultTextureView()}, | ||||||
|     GetNextRenderPassDescriptor(device, swapchain, depthStencilView, &backbuffer, &renderPass); |                                                 depthStencilView); | ||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.SetBindGroup(0, bindGroup[0]); |         pass.SetBindGroup(0, bindGroup[0]); | ||||||
|         pass.SetVertexBuffers(0, 1, &vertexBuffer, vertexBufferOffsets); |         pass.SetVertexBuffers(0, 1, &vertexBuffer, vertexBufferOffsets); | ||||||
|  | |||||||
| @ -170,35 +170,6 @@ dawn::TextureView CreateDefaultDepthStencilView(const dawn::Device& device) { | |||||||
|     return depthStencilTexture.CreateDefaultTextureView(); |     return depthStencilTexture.CreateDefaultTextureView(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| void GetNextRenderPassDescriptor(const dawn::Device& device, |  | ||||||
|     const dawn::SwapChain& swapchain, |  | ||||||
|     const dawn::TextureView& depthStencilView, |  | ||||||
|     dawn::Texture* backbuffer, |  | ||||||
|     dawn::RenderPassDescriptor* info) { |  | ||||||
|     *backbuffer = swapchain.GetNextTexture(); |  | ||||||
|     auto backbufferView = backbuffer->CreateDefaultTextureView(); |  | ||||||
|     dawn::RenderPassColorAttachmentDescriptor colorAttachment; |  | ||||||
|     colorAttachment.attachment = backbufferView; |  | ||||||
|     colorAttachment.resolveTarget = nullptr; |  | ||||||
|     colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|     colorAttachment.loadOp = dawn::LoadOp::Clear; |  | ||||||
|     colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
| 
 |  | ||||||
|     dawn::RenderPassDepthStencilAttachmentDescriptor depthStencilAttachment; |  | ||||||
|     depthStencilAttachment.attachment = depthStencilView; |  | ||||||
|     depthStencilAttachment.depthLoadOp = dawn::LoadOp::Clear; |  | ||||||
|     depthStencilAttachment.stencilLoadOp = dawn::LoadOp::Clear; |  | ||||||
|     depthStencilAttachment.clearDepth = 1.0f; |  | ||||||
|     depthStencilAttachment.clearStencil = 0; |  | ||||||
|     depthStencilAttachment.depthStoreOp = dawn::StoreOp::Store; |  | ||||||
|     depthStencilAttachment.stencilStoreOp = dawn::StoreOp::Store; |  | ||||||
| 
 |  | ||||||
|     *info = device.CreateRenderPassDescriptorBuilder() |  | ||||||
|         .SetColorAttachments(1, &colorAttachment) |  | ||||||
|         .SetDepthStencilAttachment(&depthStencilAttachment) |  | ||||||
|         .GetResult(); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| bool InitSample(int argc, const char** argv) { | bool InitSample(int argc, const char** argv) { | ||||||
|     for (int i = 1; i < argc; i++) { |     for (int i = 1; i < argc; i++) { | ||||||
|         if (std::string("-b") == argv[i] || std::string("--backend") == argv[i]) { |         if (std::string("-b") == argv[i] || std::string("--backend") == argv[i]) { | ||||||
|  | |||||||
| @ -27,8 +27,3 @@ uint64_t GetSwapChainImplementation(); | |||||||
| dawn::TextureFormat GetPreferredSwapChainTextureFormat(); | dawn::TextureFormat GetPreferredSwapChainTextureFormat(); | ||||||
| dawn::SwapChain GetSwapChain(const dawn::Device& device); | dawn::SwapChain GetSwapChain(const dawn::Device& device); | ||||||
| dawn::TextureView CreateDefaultDepthStencilView(const dawn::Device& device); | dawn::TextureView CreateDefaultDepthStencilView(const dawn::Device& device); | ||||||
| void GetNextRenderPassDescriptor(const dawn::Device& device, |  | ||||||
|     const dawn::SwapChain& swapchain, |  | ||||||
|     const dawn::TextureView& depthStencilView, |  | ||||||
|     dawn::Texture* backbuffer, |  | ||||||
|     dawn::RenderPassDescriptor* info); |  | ||||||
|  | |||||||
| @ -600,14 +600,14 @@ namespace { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     void frame() { |     void frame() { | ||||||
|         dawn::Texture backbuffer; |         dawn::Texture backbuffer = swapchain.GetNextTexture(); | ||||||
|         dawn::RenderPassDescriptor renderPass; |  | ||||||
|         GetNextRenderPassDescriptor(device, swapchain, depthStencilView, &backbuffer, &renderPass); |  | ||||||
| 
 | 
 | ||||||
|         const auto& defaultSceneNodes = scene.scenes.at(scene.defaultScene); |         const auto& defaultSceneNodes = scene.scenes.at(scene.defaultScene); | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         { |         { | ||||||
|             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass); |             utils::ComboRenderPassDescriptor renderPass({backbuffer.CreateDefaultTextureView()}, | ||||||
|  |                                                         depthStencilView); | ||||||
|  |             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|             for (const auto& n : defaultSceneNodes) { |             for (const auto& n : defaultSceneNodes) { | ||||||
|                 const auto& node = scene.nodes.at(n); |                 const auto& node = scene.nodes.at(n); | ||||||
|                 drawNode(pass, node); |                 drawNode(pass, node); | ||||||
|  | |||||||
| @ -23,7 +23,6 @@ | |||||||
| #include "dawn_native/ComputePassEncoder.h" | #include "dawn_native/ComputePassEncoder.h" | ||||||
| #include "dawn_native/Device.h" | #include "dawn_native/Device.h" | ||||||
| #include "dawn_native/ErrorData.h" | #include "dawn_native/ErrorData.h" | ||||||
| #include "dawn_native/RenderPassDescriptor.h" |  | ||||||
| #include "dawn_native/RenderPassEncoder.h" | #include "dawn_native/RenderPassEncoder.h" | ||||||
| #include "dawn_native/RenderPipeline.h" | #include "dawn_native/RenderPipeline.h" | ||||||
| 
 | 
 | ||||||
| @ -187,6 +186,117 @@ namespace dawn_native { | |||||||
|             return {}; |             return {}; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         MaybeError ValidateAttachmentArrayLayersAndLevelCount(const TextureViewBase* attachment) { | ||||||
|  |             // Currently we do not support layered rendering.
 | ||||||
|  |             if (attachment->GetLayerCount() > 1) { | ||||||
|  |                 return DAWN_VALIDATION_ERROR( | ||||||
|  |                     "The layer count of the texture view used as attachment cannot be greater than " | ||||||
|  |                     "1"); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (attachment->GetLevelCount() > 1) { | ||||||
|  |                 return DAWN_VALIDATION_ERROR( | ||||||
|  |                     "The mipmap level count of the texture view used as attachment cannot be " | ||||||
|  |                     "greater than 1"); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return {}; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         MaybeError ValidateOrSetAttachmentSize(const TextureViewBase* attachment, | ||||||
|  |                                                uint32_t* width, | ||||||
|  |                                                uint32_t* height) { | ||||||
|  |             const Extent3D& textureSize = attachment->GetTexture()->GetSize(); | ||||||
|  |             const uint32_t attachmentWidth = textureSize.width >> attachment->GetBaseMipLevel(); | ||||||
|  |             const uint32_t attachmentHeight = textureSize.height >> attachment->GetBaseMipLevel(); | ||||||
|  | 
 | ||||||
|  |             if (*width == 0) { | ||||||
|  |                 DAWN_ASSERT(*height == 0); | ||||||
|  |                 *width = attachmentWidth; | ||||||
|  |                 *height = attachmentHeight; | ||||||
|  |                 DAWN_ASSERT(*width != 0 && *height != 0); | ||||||
|  |             } else if (*width != attachmentWidth || *height != attachmentHeight) { | ||||||
|  |                 return DAWN_VALIDATION_ERROR("Attachment size mismatch"); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return {}; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         MaybeError ValidateRenderPassColorAttachment( | ||||||
|  |             const DeviceBase* device, | ||||||
|  |             const RenderPassColorAttachmentDescriptor* colorAttachment, | ||||||
|  |             uint32_t* width, | ||||||
|  |             uint32_t* height) { | ||||||
|  |             DAWN_ASSERT(colorAttachment != nullptr); | ||||||
|  | 
 | ||||||
|  |             DAWN_TRY(device->ValidateObject(colorAttachment->attachment)); | ||||||
|  | 
 | ||||||
|  |             // TODO(jiawei.shao@intel.com): support resolve target for multisample color attachment.
 | ||||||
|  |             if (colorAttachment->resolveTarget != nullptr) { | ||||||
|  |                 return DAWN_VALIDATION_ERROR("Resolve target is not supported now"); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             const TextureViewBase* attachment = colorAttachment->attachment; | ||||||
|  |             if (!IsColorRenderableTextureFormat(attachment->GetFormat())) { | ||||||
|  |                 return DAWN_VALIDATION_ERROR( | ||||||
|  |                     "The format of the texture view used as color attachment is not color " | ||||||
|  |                     "renderable"); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             DAWN_TRY(ValidateAttachmentArrayLayersAndLevelCount(attachment)); | ||||||
|  |             DAWN_TRY(ValidateOrSetAttachmentSize(attachment, width, height)); | ||||||
|  | 
 | ||||||
|  |             return {}; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         MaybeError ValidateRenderPassDepthStencilAttachment( | ||||||
|  |             const DeviceBase* device, | ||||||
|  |             const RenderPassDepthStencilAttachmentDescriptor* depthStencilAttachment, | ||||||
|  |             uint32_t* width, | ||||||
|  |             uint32_t* height) { | ||||||
|  |             DAWN_ASSERT(depthStencilAttachment != nullptr); | ||||||
|  | 
 | ||||||
|  |             DAWN_TRY(device->ValidateObject(depthStencilAttachment->attachment)); | ||||||
|  | 
 | ||||||
|  |             const TextureViewBase* attachment = depthStencilAttachment->attachment; | ||||||
|  |             if (!TextureFormatHasDepthOrStencil(attachment->GetFormat())) { | ||||||
|  |                 return DAWN_VALIDATION_ERROR( | ||||||
|  |                     "The format of the texture view used as depth stencil attachment is not a " | ||||||
|  |                     "depth stencil format"); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             DAWN_TRY(ValidateAttachmentArrayLayersAndLevelCount(attachment)); | ||||||
|  |             DAWN_TRY(ValidateOrSetAttachmentSize(attachment, width, height)); | ||||||
|  | 
 | ||||||
|  |             return {}; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         MaybeError ValidateRenderPassDescriptorAndSetSize(const DeviceBase* device, | ||||||
|  |                                                           const RenderPassDescriptor* renderPass, | ||||||
|  |                                                           uint32_t* width, | ||||||
|  |                                                           uint32_t* height) { | ||||||
|  |             if (renderPass->colorAttachmentCount > kMaxColorAttachments) { | ||||||
|  |                 return DAWN_VALIDATION_ERROR("Setting color attachments out of bounds"); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             for (uint32_t i = 0; i < renderPass->colorAttachmentCount; ++i) { | ||||||
|  |                 DAWN_TRY(ValidateRenderPassColorAttachment(device, renderPass->colorAttachments[i], | ||||||
|  |                                                            width, height)); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (renderPass->depthStencilAttachment != nullptr) { | ||||||
|  |                 DAWN_TRY(ValidateRenderPassDepthStencilAttachment( | ||||||
|  |                     device, renderPass->depthStencilAttachment, width, height)); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             if (renderPass->colorAttachmentCount == 0 && | ||||||
|  |                 renderPass->depthStencilAttachment == nullptr) { | ||||||
|  |                 return DAWN_VALIDATION_ERROR("Cannot use render pass with no attachments."); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             return {}; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         enum class PassType { |         enum class PassType { | ||||||
|             Render, |             Render, | ||||||
|             Compute, |             Compute, | ||||||
| @ -378,38 +488,53 @@ namespace dawn_native { | |||||||
|         return new ComputePassEncoderBase(GetDevice(), this, &mAllocator); |         return new ComputePassEncoderBase(GetDevice(), this, &mAllocator); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     RenderPassEncoderBase* CommandEncoderBase::BeginRenderPass(RenderPassDescriptorBase* info) { |     RenderPassEncoderBase* CommandEncoderBase::BeginRenderPass(const RenderPassDescriptor* info) { | ||||||
|  |         DeviceBase* device = GetDevice(); | ||||||
|  | 
 | ||||||
|         if (ConsumedError(ValidateCanRecordTopLevelCommands())) { |         if (ConsumedError(ValidateCanRecordTopLevelCommands())) { | ||||||
|             return nullptr; |             // Using nullptr as allocator will make ValidateCanRecordCommands() always return false,
 | ||||||
|  |             // thus any API call on the return value will result in a Dawn validation error.
 | ||||||
|  |             return new RenderPassEncoderBase(device, this, nullptr); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         if (info == nullptr) { |         uint32_t width = 0; | ||||||
|             HandleError("RenderPassDescriptor cannot be null"); |         uint32_t height = 0; | ||||||
|             return nullptr; |         if (ConsumedError(ValidateRenderPassDescriptorAndSetSize(device, info, &width, &height))) { | ||||||
|  |             return new RenderPassEncoderBase(device, this, nullptr); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  |         mEncodingState = EncodingState::RenderPass; | ||||||
|  | 
 | ||||||
|         BeginRenderPassCmd* cmd = mAllocator.Allocate<BeginRenderPassCmd>(Command::BeginRenderPass); |         BeginRenderPassCmd* cmd = mAllocator.Allocate<BeginRenderPassCmd>(Command::BeginRenderPass); | ||||||
|         new (cmd) BeginRenderPassCmd; |         new (cmd) BeginRenderPassCmd; | ||||||
| 
 | 
 | ||||||
|         for (uint32_t i : IterateBitSet(info->GetColorAttachmentMask())) { |         for (uint32_t i = 0; i < info->colorAttachmentCount; ++i) { | ||||||
|             const RenderPassColorAttachmentInfo& colorAttachment = info->GetColorAttachment(i); |             if (info->colorAttachments[i] != nullptr) { | ||||||
|             if (colorAttachment.view.Get() != nullptr) { |  | ||||||
|                 cmd->colorAttachmentsSet.set(i); |                 cmd->colorAttachmentsSet.set(i); | ||||||
|                 cmd->colorAttachments[i] = colorAttachment; |                 cmd->colorAttachments[i].view = info->colorAttachments[i]->attachment; | ||||||
|  |                 cmd->colorAttachments[i].resolveTarget = info->colorAttachments[i]->resolveTarget; | ||||||
|  |                 cmd->colorAttachments[i].loadOp = info->colorAttachments[i]->loadOp; | ||||||
|  |                 cmd->colorAttachments[i].storeOp = info->colorAttachments[i]->storeOp; | ||||||
|  |                 cmd->colorAttachments[i].clearColor = info->colorAttachments[i]->clearColor; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         cmd->hasDepthStencilAttachment = info->HasDepthStencilAttachment(); |         cmd->hasDepthStencilAttachment = info->depthStencilAttachment != nullptr; | ||||||
|         if (cmd->hasDepthStencilAttachment) { |         if (cmd->hasDepthStencilAttachment) { | ||||||
|             const RenderPassDepthStencilAttachmentInfo& depthStencilAttachment = |             cmd->hasDepthStencilAttachment = true; | ||||||
|                 info->GetDepthStencilAttachment(); |             cmd->depthStencilAttachment.view = info->depthStencilAttachment->attachment; | ||||||
|             cmd->depthStencilAttachment = depthStencilAttachment; |             cmd->depthStencilAttachment.clearDepth = info->depthStencilAttachment->clearDepth; | ||||||
|  |             cmd->depthStencilAttachment.clearStencil = info->depthStencilAttachment->clearStencil; | ||||||
|  |             cmd->depthStencilAttachment.depthLoadOp = info->depthStencilAttachment->depthLoadOp; | ||||||
|  |             cmd->depthStencilAttachment.depthStoreOp = info->depthStencilAttachment->depthStoreOp; | ||||||
|  |             cmd->depthStencilAttachment.stencilLoadOp = info->depthStencilAttachment->stencilLoadOp; | ||||||
|  |             cmd->depthStencilAttachment.stencilStoreOp = | ||||||
|  |                 info->depthStencilAttachment->stencilStoreOp; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         cmd->width = info->GetWidth(); |         cmd->width = width; | ||||||
|         cmd->height = info->GetHeight(); |         cmd->height = height; | ||||||
| 
 | 
 | ||||||
|         mEncodingState = EncodingState::RenderPass; |  | ||||||
|         return new RenderPassEncoderBase(GetDevice(), this, &mAllocator); |         return new RenderPassEncoderBase(GetDevice(), this, &mAllocator); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -42,7 +42,7 @@ namespace dawn_native { | |||||||
| 
 | 
 | ||||||
|         // Dawn API
 |         // Dawn API
 | ||||||
|         ComputePassEncoderBase* BeginComputePass(); |         ComputePassEncoderBase* BeginComputePass(); | ||||||
|         RenderPassEncoderBase* BeginRenderPass(RenderPassDescriptorBase* info); |         RenderPassEncoderBase* BeginRenderPass(const RenderPassDescriptor* info); | ||||||
|         void CopyBufferToBuffer(BufferBase* source, |         void CopyBufferToBuffer(BufferBase* source, | ||||||
|                                 uint32_t sourceOffset, |                                 uint32_t sourceOffset, | ||||||
|                                 BufferBase* destination, |                                 BufferBase* destination, | ||||||
|  | |||||||
| @ -62,7 +62,7 @@ namespace dawn_native { | |||||||
|         Ref<TextureViewBase> resolveTarget; |         Ref<TextureViewBase> resolveTarget; | ||||||
|         dawn::LoadOp loadOp; |         dawn::LoadOp loadOp; | ||||||
|         dawn::StoreOp storeOp; |         dawn::StoreOp storeOp; | ||||||
|         std::array<float, 4> clearColor = {{0.0f, 0.0f, 0.0f, 0.0f}}; |         dawn_native::Color clearColor; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     struct RenderPassDepthStencilAttachmentInfo { |     struct RenderPassDepthStencilAttachmentInfo { | ||||||
|  | |||||||
| @ -28,7 +28,6 @@ | |||||||
| #include "dawn_native/InputState.h" | #include "dawn_native/InputState.h" | ||||||
| #include "dawn_native/PipelineLayout.h" | #include "dawn_native/PipelineLayout.h" | ||||||
| #include "dawn_native/Queue.h" | #include "dawn_native/Queue.h" | ||||||
| #include "dawn_native/RenderPassDescriptor.h" |  | ||||||
| #include "dawn_native/RenderPipeline.h" | #include "dawn_native/RenderPipeline.h" | ||||||
| #include "dawn_native/Sampler.h" | #include "dawn_native/Sampler.h" | ||||||
| #include "dawn_native/ShaderModule.h" | #include "dawn_native/ShaderModule.h" | ||||||
| @ -194,9 +193,6 @@ namespace dawn_native { | |||||||
| 
 | 
 | ||||||
|         return result; |         return result; | ||||||
|     } |     } | ||||||
|     RenderPassDescriptorBuilder* DeviceBase::CreateRenderPassDescriptorBuilder() { |  | ||||||
|         return new RenderPassDescriptorBuilder(this); |  | ||||||
|     } |  | ||||||
|     SamplerBase* DeviceBase::CreateSampler(const SamplerDescriptor* descriptor) { |     SamplerBase* DeviceBase::CreateSampler(const SamplerDescriptor* descriptor) { | ||||||
|         SamplerBase* result = nullptr; |         SamplerBase* result = nullptr; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -61,8 +61,6 @@ namespace dawn_native { | |||||||
| 
 | 
 | ||||||
|         virtual CommandBufferBase* CreateCommandBuffer(CommandEncoderBase* encoder) = 0; |         virtual CommandBufferBase* CreateCommandBuffer(CommandEncoderBase* encoder) = 0; | ||||||
|         virtual InputStateBase* CreateInputState(InputStateBuilder* builder) = 0; |         virtual InputStateBase* CreateInputState(InputStateBuilder* builder) = 0; | ||||||
|         virtual RenderPassDescriptorBase* CreateRenderPassDescriptor( |  | ||||||
|             RenderPassDescriptorBuilder* builder) = 0; |  | ||||||
| 
 | 
 | ||||||
|         virtual Serial GetCompletedCommandSerial() const = 0; |         virtual Serial GetCompletedCommandSerial() const = 0; | ||||||
|         virtual Serial GetLastSubmittedCommandSerial() const = 0; |         virtual Serial GetLastSubmittedCommandSerial() const = 0; | ||||||
| @ -97,7 +95,6 @@ namespace dawn_native { | |||||||
|         InputStateBuilder* CreateInputStateBuilder(); |         InputStateBuilder* CreateInputStateBuilder(); | ||||||
|         PipelineLayoutBase* CreatePipelineLayout(const PipelineLayoutDescriptor* descriptor); |         PipelineLayoutBase* CreatePipelineLayout(const PipelineLayoutDescriptor* descriptor); | ||||||
|         QueueBase* CreateQueue(); |         QueueBase* CreateQueue(); | ||||||
|         RenderPassDescriptorBuilder* CreateRenderPassDescriptorBuilder(); |  | ||||||
|         RenderPipelineBase* CreateRenderPipeline(const RenderPipelineDescriptor* descriptor); |         RenderPipelineBase* CreateRenderPipeline(const RenderPipelineDescriptor* descriptor); | ||||||
|         SamplerBase* CreateSampler(const SamplerDescriptor* descriptor); |         SamplerBase* CreateSampler(const SamplerDescriptor* descriptor); | ||||||
|         ShaderModuleBase* CreateShaderModule(const ShaderModuleDescriptor* descriptor); |         ShaderModuleBase* CreateShaderModule(const ShaderModuleDescriptor* descriptor); | ||||||
|  | |||||||
| @ -34,8 +34,6 @@ namespace dawn_native { | |||||||
|     class PipelineBase; |     class PipelineBase; | ||||||
|     class PipelineLayoutBase; |     class PipelineLayoutBase; | ||||||
|     class QueueBase; |     class QueueBase; | ||||||
|     class RenderPassDescriptorBase; |  | ||||||
|     class RenderPassDescriptorBuilder; |  | ||||||
|     class RenderPassEncoderBase; |     class RenderPassEncoderBase; | ||||||
|     class RenderPipelineBase; |     class RenderPipelineBase; | ||||||
|     class SamplerBase; |     class SamplerBase; | ||||||
|  | |||||||
| @ -106,7 +106,7 @@ namespace dawn_native { | |||||||
| 
 | 
 | ||||||
|     MaybeError ProgrammablePassEncoder::ValidateCanRecordCommands() const { |     MaybeError ProgrammablePassEncoder::ValidateCanRecordCommands() const { | ||||||
|         if (mAllocator == nullptr) { |         if (mAllocator == nullptr) { | ||||||
|             return DAWN_VALIDATION_ERROR("Recording in an already ended pass encoder"); |             return DAWN_VALIDATION_ERROR("Recording in an error or already ended pass encoder"); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         return nullptr; |         return nullptr; | ||||||
|  | |||||||
| @ -1,226 +0,0 @@ | |||||||
| // 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.
 |  | ||||||
| 
 |  | ||||||
| #include "dawn_native/RenderPassDescriptor.h" |  | ||||||
| 
 |  | ||||||
| #include "common/Assert.h" |  | ||||||
| #include "common/BitSetIterator.h" |  | ||||||
| #include "dawn_native/Device.h" |  | ||||||
| #include "dawn_native/Texture.h" |  | ||||||
| 
 |  | ||||||
| namespace dawn_native { |  | ||||||
| 
 |  | ||||||
|     // RenderPassDescriptor
 |  | ||||||
| 
 |  | ||||||
|     RenderPassDescriptorBase::RenderPassDescriptorBase(RenderPassDescriptorBuilder* builder) |  | ||||||
|         : ObjectBase(builder->GetDevice()), |  | ||||||
|           mColorAttachmentsSet(builder->mColorAttachmentsSet), |  | ||||||
|           mColorAttachments(builder->mColorAttachments), |  | ||||||
|           mDepthStencilAttachmentSet(builder->mDepthStencilAttachmentSet), |  | ||||||
|           mDepthStencilAttachment(builder->mDepthStencilAttachment), |  | ||||||
|           mWidth(builder->mWidth), |  | ||||||
|           mHeight(builder->mHeight) { |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     std::bitset<kMaxColorAttachments> RenderPassDescriptorBase::GetColorAttachmentMask() const { |  | ||||||
|         return mColorAttachmentsSet; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     bool RenderPassDescriptorBase::HasDepthStencilAttachment() const { |  | ||||||
|         return mDepthStencilAttachmentSet; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     const RenderPassColorAttachmentInfo& RenderPassDescriptorBase::GetColorAttachment( |  | ||||||
|         uint32_t attachment) const { |  | ||||||
|         ASSERT(attachment < kMaxColorAttachments); |  | ||||||
|         ASSERT(mColorAttachmentsSet[attachment]); |  | ||||||
| 
 |  | ||||||
|         return mColorAttachments[attachment]; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     RenderPassColorAttachmentInfo& RenderPassDescriptorBase::GetColorAttachment( |  | ||||||
|         uint32_t attachment) { |  | ||||||
|         ASSERT(attachment < kMaxColorAttachments); |  | ||||||
|         ASSERT(mColorAttachmentsSet[attachment]); |  | ||||||
| 
 |  | ||||||
|         return mColorAttachments[attachment]; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     const RenderPassDepthStencilAttachmentInfo& |  | ||||||
|     RenderPassDescriptorBase::GetDepthStencilAttachment() const { |  | ||||||
|         ASSERT(mDepthStencilAttachmentSet); |  | ||||||
| 
 |  | ||||||
|         return mDepthStencilAttachment; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     RenderPassDepthStencilAttachmentInfo& RenderPassDescriptorBase::GetDepthStencilAttachment() { |  | ||||||
|         ASSERT(mDepthStencilAttachmentSet); |  | ||||||
| 
 |  | ||||||
|         return mDepthStencilAttachment; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     uint32_t RenderPassDescriptorBase::GetWidth() const { |  | ||||||
|         return mWidth; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     uint32_t RenderPassDescriptorBase::GetHeight() const { |  | ||||||
|         return mHeight; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     // RenderPassDescriptorBuilder
 |  | ||||||
| 
 |  | ||||||
|     RenderPassDescriptorBuilder::RenderPassDescriptorBuilder(DeviceBase* device) : Builder(device) { |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     bool RenderPassDescriptorBuilder::CheckArrayLayersAndLevelCountForAttachment( |  | ||||||
|         const TextureViewBase* textureView) { |  | ||||||
|         // Currently we do not support layered rendering.
 |  | ||||||
|         if (textureView->GetLayerCount() > 1) { |  | ||||||
|             HandleError( |  | ||||||
|                 "The layer count of the texture view used as attachment cannot be greater than 1"); |  | ||||||
|             return false; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         if (textureView->GetLevelCount() > 1) { |  | ||||||
|             HandleError( |  | ||||||
|                 "The mipmap level count of the texture view used as attachment cannot be greater " |  | ||||||
|                 "than 1"); |  | ||||||
|             return false; |  | ||||||
|         } |  | ||||||
|         return true; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     RenderPassDescriptorBase* RenderPassDescriptorBuilder::GetResultImpl() { |  | ||||||
|         auto CheckOrSetSize = [this](const TextureViewBase* attachment) -> bool { |  | ||||||
|             uint32_t mipLevel = attachment->GetBaseMipLevel(); |  | ||||||
|             if (this->mWidth == 0) { |  | ||||||
|                 ASSERT(this->mHeight == 0); |  | ||||||
| 
 |  | ||||||
|                 this->mWidth = attachment->GetTexture()->GetSize().width >> mipLevel; |  | ||||||
|                 this->mHeight = attachment->GetTexture()->GetSize().height >> mipLevel; |  | ||||||
|                 ASSERT(this->mWidth != 0 && this->mHeight != 0); |  | ||||||
| 
 |  | ||||||
|                 return true; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             ASSERT(this->mWidth != 0 && this->mHeight != 0); |  | ||||||
|             return this->mWidth == attachment->GetTexture()->GetSize().width >> mipLevel && |  | ||||||
|                    this->mHeight == attachment->GetTexture()->GetSize().height >> mipLevel; |  | ||||||
|         }; |  | ||||||
| 
 |  | ||||||
|         uint32_t attachmentCount = 0; |  | ||||||
|         for (uint32_t i : IterateBitSet(mColorAttachmentsSet)) { |  | ||||||
|             attachmentCount++; |  | ||||||
|             if (!CheckOrSetSize(mColorAttachments[i].view.Get())) { |  | ||||||
|                 HandleError("Attachment size mismatch"); |  | ||||||
|                 return nullptr; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         if (mDepthStencilAttachmentSet) { |  | ||||||
|             attachmentCount++; |  | ||||||
|             if (!CheckOrSetSize(mDepthStencilAttachment.view.Get())) { |  | ||||||
|                 HandleError("Attachment size mismatch"); |  | ||||||
|                 return nullptr; |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         if (attachmentCount == 0) { |  | ||||||
|             HandleError("Should have at least one attachment"); |  | ||||||
|             return nullptr; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         return GetDevice()->CreateRenderPassDescriptor(this); |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     void RenderPassDescriptorBuilder::SetColorAttachments( |  | ||||||
|         uint32_t count, |  | ||||||
|         const RenderPassColorAttachmentDescriptor* attachments) { |  | ||||||
|         if (count > kMaxColorAttachments) { |  | ||||||
|             HandleError("Setting color attachments out of bounds"); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         for (uint32_t i = 0; i < count; ++i) { |  | ||||||
|             // TODO(jiawei.shao@intel.com): support resolve target for multisample color attachment.
 |  | ||||||
|             if (attachments[i].resolveTarget != nullptr) { |  | ||||||
|                 HandleError("Resolve target is not supported now"); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             TextureViewBase* textureView = attachments[i].attachment; |  | ||||||
|             if (textureView == nullptr) { |  | ||||||
|                 continue; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             // TODO(cwallez@chromium.org): Once RenderPassDescriptor doesn't use a builder, check
 |  | ||||||
|             // that the textureView is a valid object.
 |  | ||||||
|             // See https://bugs.chromium.org/p/dawn/issues/detail?id=6
 |  | ||||||
| 
 |  | ||||||
|             if (!IsColorRenderableTextureFormat(textureView->GetFormat())) { |  | ||||||
|                 HandleError( |  | ||||||
|                     "The format of the texture view used as color attachment is not color " |  | ||||||
|                     "renderable"); |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             if (!CheckArrayLayersAndLevelCountForAttachment(textureView)) { |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
| 
 |  | ||||||
|             // TODO(jiawei.shao@intel.com): set and make use of storeOp
 |  | ||||||
|             mColorAttachmentsSet.set(i); |  | ||||||
|             mColorAttachments[i].loadOp = attachments[i].loadOp; |  | ||||||
|             mColorAttachments[i].view = textureView; |  | ||||||
| 
 |  | ||||||
|             mColorAttachments[i].clearColor[0] = attachments[i].clearColor.r; |  | ||||||
|             mColorAttachments[i].clearColor[1] = attachments[i].clearColor.g; |  | ||||||
|             mColorAttachments[i].clearColor[2] = attachments[i].clearColor.b; |  | ||||||
|             mColorAttachments[i].clearColor[3] = attachments[i].clearColor.a; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     void RenderPassDescriptorBuilder::SetDepthStencilAttachment( |  | ||||||
|         const RenderPassDepthStencilAttachmentDescriptor* attachment) { |  | ||||||
|         TextureViewBase* textureView = attachment->attachment; |  | ||||||
| 
 |  | ||||||
|         // TODO(cwallez@chromium.org): Once RenderPassDescriptor doesn't use a builder, check that
 |  | ||||||
|         // the textureView is a valid object.
 |  | ||||||
|         // See https://bugs.chromium.org/p/dawn/issues/detail?id=6
 |  | ||||||
|         if (textureView == nullptr) { |  | ||||||
|             HandleError("Texture view cannot be nullptr"); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         if (!TextureFormatHasDepthOrStencil(textureView->GetFormat())) { |  | ||||||
|             HandleError( |  | ||||||
|                 "The format of the texture view used as depth stencil attachment is not a depth " |  | ||||||
|                 "stencil format"); |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         if (!CheckArrayLayersAndLevelCountForAttachment(textureView)) { |  | ||||||
|             return; |  | ||||||
|         } |  | ||||||
| 
 |  | ||||||
|         // TODO(jiawei.shao@intel.com): set and make use of depthStoreOp and stencilStoreOp
 |  | ||||||
|         mDepthStencilAttachmentSet = true; |  | ||||||
|         mDepthStencilAttachment.depthLoadOp = attachment->depthLoadOp; |  | ||||||
|         mDepthStencilAttachment.stencilLoadOp = attachment->stencilLoadOp; |  | ||||||
|         mDepthStencilAttachment.view = textureView; |  | ||||||
|         mDepthStencilAttachment.clearDepth = attachment->clearDepth; |  | ||||||
|         mDepthStencilAttachment.clearStencil = attachment->clearStencil; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
| }  // namespace dawn_native
 |  | ||||||
| @ -1,92 +0,0 @@ | |||||||
| // 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_RENDERPASSDESCRIPTOR_H_ |  | ||||||
| #define DAWNNATIVE_RENDERPASSDESCRIPTOR_H_ |  | ||||||
| 
 |  | ||||||
| #include "common/Constants.h" |  | ||||||
| #include "dawn_native/Builder.h" |  | ||||||
| #include "dawn_native/Commands.h" |  | ||||||
| #include "dawn_native/Forward.h" |  | ||||||
| #include "dawn_native/ObjectBase.h" |  | ||||||
| 
 |  | ||||||
| #include "dawn_native/dawn_platform.h" |  | ||||||
| 
 |  | ||||||
| #include <array> |  | ||||||
| #include <bitset> |  | ||||||
| #include <vector> |  | ||||||
| 
 |  | ||||||
| namespace dawn_native { |  | ||||||
| 
 |  | ||||||
|     // RenderPassDescriptor contains the list of attachments for a renderpass along with data such
 |  | ||||||
|     // as the load operation and the clear values for the attachments.
 |  | ||||||
| 
 |  | ||||||
|     class RenderPassDescriptorBase : public ObjectBase { |  | ||||||
|       public: |  | ||||||
|         RenderPassDescriptorBase(RenderPassDescriptorBuilder* builder); |  | ||||||
| 
 |  | ||||||
|         std::bitset<kMaxColorAttachments> GetColorAttachmentMask() const; |  | ||||||
|         bool HasDepthStencilAttachment() const; |  | ||||||
| 
 |  | ||||||
|         const RenderPassColorAttachmentInfo& GetColorAttachment(uint32_t attachment) const; |  | ||||||
|         RenderPassColorAttachmentInfo& GetColorAttachment(uint32_t attachment); |  | ||||||
|         const RenderPassDepthStencilAttachmentInfo& GetDepthStencilAttachment() const; |  | ||||||
|         RenderPassDepthStencilAttachmentInfo& GetDepthStencilAttachment(); |  | ||||||
| 
 |  | ||||||
|         // All attachments of the render pass have the same size, these return that size.
 |  | ||||||
|         uint32_t GetWidth() const; |  | ||||||
|         uint32_t GetHeight() const; |  | ||||||
| 
 |  | ||||||
|       private: |  | ||||||
|         std::bitset<kMaxColorAttachments> mColorAttachmentsSet; |  | ||||||
|         std::array<RenderPassColorAttachmentInfo, kMaxColorAttachments> mColorAttachments; |  | ||||||
| 
 |  | ||||||
|         bool mDepthStencilAttachmentSet; |  | ||||||
|         RenderPassDepthStencilAttachmentInfo mDepthStencilAttachment; |  | ||||||
| 
 |  | ||||||
|         uint32_t mWidth; |  | ||||||
|         uint32_t mHeight; |  | ||||||
|     }; |  | ||||||
| 
 |  | ||||||
|     // TODO(jiawei.shao@intel.com): remove RenderPassDescriptorBuilder and set data into
 |  | ||||||
|     // RenderPassDescriptor directly.
 |  | ||||||
|     class RenderPassDescriptorBuilder : public Builder<RenderPassDescriptorBase> { |  | ||||||
|       public: |  | ||||||
|         RenderPassDescriptorBuilder(DeviceBase* device); |  | ||||||
| 
 |  | ||||||
|         // Dawn API
 |  | ||||||
|         RenderPassDescriptorBase* GetResultImpl() override; |  | ||||||
|         void SetColorAttachments(uint32_t count, |  | ||||||
|                                  const RenderPassColorAttachmentDescriptor* attachments); |  | ||||||
|         void SetDepthStencilAttachment( |  | ||||||
|             const RenderPassDepthStencilAttachmentDescriptor* attachment); |  | ||||||
| 
 |  | ||||||
|       private: |  | ||||||
|         friend class RenderPassDescriptorBase; |  | ||||||
| 
 |  | ||||||
|         bool CheckArrayLayersAndLevelCountForAttachment(const TextureViewBase* textureView); |  | ||||||
| 
 |  | ||||||
|         std::bitset<kMaxColorAttachments> mColorAttachmentsSet; |  | ||||||
|         std::array<RenderPassColorAttachmentInfo, kMaxColorAttachments> mColorAttachments; |  | ||||||
| 
 |  | ||||||
|         bool mDepthStencilAttachmentSet = false; |  | ||||||
|         RenderPassDepthStencilAttachmentInfo mDepthStencilAttachment; |  | ||||||
| 
 |  | ||||||
|         uint32_t mWidth = 0; |  | ||||||
|         uint32_t mHeight = 0; |  | ||||||
|     }; |  | ||||||
| 
 |  | ||||||
| }  // namespace dawn_native
 |  | ||||||
| 
 |  | ||||||
| #endif  // DAWNNATIVE_RENDERPASS_H_
 |  | ||||||
| @ -18,7 +18,6 @@ | |||||||
| #include "dawn_native/Commands.h" | #include "dawn_native/Commands.h" | ||||||
| #include "dawn_native/Device.h" | #include "dawn_native/Device.h" | ||||||
| #include "dawn_native/InputState.h" | #include "dawn_native/InputState.h" | ||||||
| #include "dawn_native/RenderPassDescriptor.h" |  | ||||||
| #include "dawn_native/Texture.h" | #include "dawn_native/Texture.h" | ||||||
| #include "dawn_native/ValidationUtils_autogen.h" | #include "dawn_native/ValidationUtils_autogen.h" | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -73,11 +73,6 @@ namespace dawn_native { | |||||||
|         using BackendType = typename BackendTraits::QueueType; |         using BackendType = typename BackendTraits::QueueType; | ||||||
|     }; |     }; | ||||||
| 
 | 
 | ||||||
|     template <typename BackendTraits> |  | ||||||
|     struct ToBackendTraits<RenderPassDescriptorBase, BackendTraits> { |  | ||||||
|         using BackendType = typename BackendTraits::RenderPassDescriptorType; |  | ||||||
|     }; |  | ||||||
| 
 |  | ||||||
|     template <typename BackendTraits> |     template <typename BackendTraits> | ||||||
|     struct ToBackendTraits<RenderPipelineBase, BackendTraits> { |     struct ToBackendTraits<RenderPipelineBase, BackendTraits> { | ||||||
|         using BackendType = typename BackendTraits::RenderPipelineType; |         using BackendType = typename BackendTraits::RenderPipelineType; | ||||||
|  | |||||||
| @ -609,7 +609,7 @@ namespace dawn_native { namespace d3d12 { | |||||||
|                 // Load op - color
 |                 // Load op - color
 | ||||||
|                 if (attachmentInfo.loadOp == dawn::LoadOp::Clear) { |                 if (attachmentInfo.loadOp == dawn::LoadOp::Clear) { | ||||||
|                     D3D12_CPU_DESCRIPTOR_HANDLE handle = args.RTVs[i]; |                     D3D12_CPU_DESCRIPTOR_HANDLE handle = args.RTVs[i]; | ||||||
|                     commandList->ClearRenderTargetView(handle, attachmentInfo.clearColor.data(), 0, |                     commandList->ClearRenderTargetView(handle, &attachmentInfo.clearColor.r, 0, | ||||||
|                                                        nullptr); |                                                        nullptr); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  | |||||||
| @ -17,7 +17,6 @@ | |||||||
| #include "common/Assert.h" | #include "common/Assert.h" | ||||||
| #include "dawn_native/BackendConnection.h" | #include "dawn_native/BackendConnection.h" | ||||||
| #include "dawn_native/DynamicUploader.h" | #include "dawn_native/DynamicUploader.h" | ||||||
| #include "dawn_native/RenderPassDescriptor.h" |  | ||||||
| #include "dawn_native/d3d12/AdapterD3D12.h" | #include "dawn_native/d3d12/AdapterD3D12.h" | ||||||
| #include "dawn_native/d3d12/BackendD3D12.h" | #include "dawn_native/d3d12/BackendD3D12.h" | ||||||
| #include "dawn_native/d3d12/BindGroupD3D12.h" | #include "dawn_native/d3d12/BindGroupD3D12.h" | ||||||
| @ -227,10 +226,6 @@ namespace dawn_native { namespace d3d12 { | |||||||
|     ResultOrError<QueueBase*> Device::CreateQueueImpl() { |     ResultOrError<QueueBase*> Device::CreateQueueImpl() { | ||||||
|         return new Queue(this); |         return new Queue(this); | ||||||
|     } |     } | ||||||
|     RenderPassDescriptorBase* Device::CreateRenderPassDescriptor( |  | ||||||
|         RenderPassDescriptorBuilder* builder) { |  | ||||||
|         return new RenderPassDescriptor(builder); |  | ||||||
|     } |  | ||||||
|     ResultOrError<RenderPipelineBase*> Device::CreateRenderPipelineImpl( |     ResultOrError<RenderPipelineBase*> Device::CreateRenderPipelineImpl( | ||||||
|         const RenderPipelineDescriptor* descriptor) { |         const RenderPipelineDescriptor* descriptor) { | ||||||
|         return new RenderPipeline(this, descriptor); |         return new RenderPipeline(this, descriptor); | ||||||
|  | |||||||
| @ -42,8 +42,6 @@ namespace dawn_native { namespace d3d12 { | |||||||
| 
 | 
 | ||||||
|         CommandBufferBase* CreateCommandBuffer(CommandEncoderBase* encoder) override; |         CommandBufferBase* CreateCommandBuffer(CommandEncoderBase* encoder) override; | ||||||
|         InputStateBase* CreateInputState(InputStateBuilder* builder) override; |         InputStateBase* CreateInputState(InputStateBuilder* builder) override; | ||||||
|         RenderPassDescriptorBase* CreateRenderPassDescriptor( |  | ||||||
|             RenderPassDescriptorBuilder* builder) override; |  | ||||||
| 
 | 
 | ||||||
|         Serial GetCompletedCommandSerial() const final override; |         Serial GetCompletedCommandSerial() const final override; | ||||||
|         Serial GetLastSubmittedCommandSerial() const final override; |         Serial GetLastSubmittedCommandSerial() const final override; | ||||||
|  | |||||||
| @ -29,7 +29,6 @@ namespace dawn_native { namespace d3d12 { | |||||||
|     class InputState; |     class InputState; | ||||||
|     class PipelineLayout; |     class PipelineLayout; | ||||||
|     class Queue; |     class Queue; | ||||||
|     using RenderPassDescriptor = RenderPassDescriptorBase; |  | ||||||
|     class RenderPipeline; |     class RenderPipeline; | ||||||
|     class Sampler; |     class Sampler; | ||||||
|     class ShaderModule; |     class ShaderModule; | ||||||
| @ -49,7 +48,6 @@ namespace dawn_native { namespace d3d12 { | |||||||
|         using InputStateType = InputState; |         using InputStateType = InputState; | ||||||
|         using PipelineLayoutType = PipelineLayout; |         using PipelineLayoutType = PipelineLayout; | ||||||
|         using QueueType = Queue; |         using QueueType = Queue; | ||||||
|         using RenderPassDescriptorType = RenderPassDescriptor; |  | ||||||
|         using RenderPipelineType = RenderPipeline; |         using RenderPipelineType = RenderPipeline; | ||||||
|         using SamplerType = Sampler; |         using SamplerType = Sampler; | ||||||
|         using ShaderModuleType = ShaderModule; |         using ShaderModuleType = ShaderModule; | ||||||
|  | |||||||
| @ -56,9 +56,9 @@ namespace dawn_native { namespace metal { | |||||||
| 
 | 
 | ||||||
|                 if (attachmentInfo.loadOp == dawn::LoadOp::Clear) { |                 if (attachmentInfo.loadOp == dawn::LoadOp::Clear) { | ||||||
|                     descriptor.colorAttachments[i].loadAction = MTLLoadActionClear; |                     descriptor.colorAttachments[i].loadAction = MTLLoadActionClear; | ||||||
|                     descriptor.colorAttachments[i].clearColor = MTLClearColorMake( |                     descriptor.colorAttachments[i].clearColor = | ||||||
|                         attachmentInfo.clearColor[0], attachmentInfo.clearColor[1], |                         MTLClearColorMake(attachmentInfo.clearColor.r, attachmentInfo.clearColor.g, | ||||||
|                         attachmentInfo.clearColor[2], attachmentInfo.clearColor[3]); |                                           attachmentInfo.clearColor.b, attachmentInfo.clearColor.a); | ||||||
|                 } else { |                 } else { | ||||||
|                     descriptor.colorAttachments[i].loadAction = MTLLoadActionLoad; |                     descriptor.colorAttachments[i].loadAction = MTLLoadActionLoad; | ||||||
|                 } |                 } | ||||||
|  | |||||||
| @ -38,8 +38,6 @@ namespace dawn_native { namespace metal { | |||||||
| 
 | 
 | ||||||
|         CommandBufferBase* CreateCommandBuffer(CommandEncoderBase* encoder) override; |         CommandBufferBase* CreateCommandBuffer(CommandEncoderBase* encoder) override; | ||||||
|         InputStateBase* CreateInputState(InputStateBuilder* builder) override; |         InputStateBase* CreateInputState(InputStateBuilder* builder) override; | ||||||
|         RenderPassDescriptorBase* CreateRenderPassDescriptor( |  | ||||||
|             RenderPassDescriptorBuilder* builder) override; |  | ||||||
| 
 | 
 | ||||||
|         Serial GetCompletedCommandSerial() const final override; |         Serial GetCompletedCommandSerial() const final override; | ||||||
|         Serial GetLastSubmittedCommandSerial() const final override; |         Serial GetLastSubmittedCommandSerial() const final override; | ||||||
|  | |||||||
| @ -18,7 +18,6 @@ | |||||||
| #include "dawn_native/BindGroup.h" | #include "dawn_native/BindGroup.h" | ||||||
| #include "dawn_native/BindGroupLayout.h" | #include "dawn_native/BindGroupLayout.h" | ||||||
| #include "dawn_native/DynamicUploader.h" | #include "dawn_native/DynamicUploader.h" | ||||||
| #include "dawn_native/RenderPassDescriptor.h" |  | ||||||
| #include "dawn_native/metal/BufferMTL.h" | #include "dawn_native/metal/BufferMTL.h" | ||||||
| #include "dawn_native/metal/CommandBufferMTL.h" | #include "dawn_native/metal/CommandBufferMTL.h" | ||||||
| #include "dawn_native/metal/ComputePipelineMTL.h" | #include "dawn_native/metal/ComputePipelineMTL.h" | ||||||
| @ -91,10 +90,6 @@ namespace dawn_native { namespace metal { | |||||||
|         const PipelineLayoutDescriptor* descriptor) { |         const PipelineLayoutDescriptor* descriptor) { | ||||||
|         return new PipelineLayout(this, descriptor); |         return new PipelineLayout(this, descriptor); | ||||||
|     } |     } | ||||||
|     RenderPassDescriptorBase* Device::CreateRenderPassDescriptor( |  | ||||||
|         RenderPassDescriptorBuilder* builder) { |  | ||||||
|         return new RenderPassDescriptor(builder); |  | ||||||
|     } |  | ||||||
|     ResultOrError<QueueBase*> Device::CreateQueueImpl() { |     ResultOrError<QueueBase*> Device::CreateQueueImpl() { | ||||||
|         return new Queue(this); |         return new Queue(this); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -20,7 +20,6 @@ | |||||||
| namespace { | namespace { | ||||||
|     class BindGroupBase; |     class BindGroupBase; | ||||||
|     class BindGroup; |     class BindGroup; | ||||||
|     class RenderPassDescriptor; |  | ||||||
| }  // namespace
 | }  // namespace
 | ||||||
| 
 | 
 | ||||||
| namespace dawn_native { namespace metal { | namespace dawn_native { namespace metal { | ||||||
| @ -36,7 +35,6 @@ namespace dawn_native { namespace metal { | |||||||
|     class InputState; |     class InputState; | ||||||
|     class PipelineLayout; |     class PipelineLayout; | ||||||
|     class Queue; |     class Queue; | ||||||
|     using RenderPassDescriptor = RenderPassDescriptorBase; |  | ||||||
|     class RenderPipeline; |     class RenderPipeline; | ||||||
|     class Sampler; |     class Sampler; | ||||||
|     class ShaderModule; |     class ShaderModule; | ||||||
| @ -56,7 +54,6 @@ namespace dawn_native { namespace metal { | |||||||
|         using InputStateType = InputState; |         using InputStateType = InputState; | ||||||
|         using PipelineLayoutType = PipelineLayout; |         using PipelineLayoutType = PipelineLayout; | ||||||
|         using QueueType = Queue; |         using QueueType = Queue; | ||||||
|         using RenderPassDescriptorType = RenderPassDescriptor; |  | ||||||
|         using RenderPipelineType = RenderPipeline; |         using RenderPipelineType = RenderPipeline; | ||||||
|         using SamplerType = Sampler; |         using SamplerType = Sampler; | ||||||
|         using ShaderModuleType = ShaderModule; |         using ShaderModuleType = ShaderModule; | ||||||
|  | |||||||
| @ -92,10 +92,6 @@ namespace dawn_native { namespace null { | |||||||
|     ResultOrError<QueueBase*> Device::CreateQueueImpl() { |     ResultOrError<QueueBase*> Device::CreateQueueImpl() { | ||||||
|         return new Queue(this); |         return new Queue(this); | ||||||
|     } |     } | ||||||
|     RenderPassDescriptorBase* Device::CreateRenderPassDescriptor( |  | ||||||
|         RenderPassDescriptorBuilder* builder) { |  | ||||||
|         return new RenderPassDescriptor(builder); |  | ||||||
|     } |  | ||||||
|     ResultOrError<RenderPipelineBase*> Device::CreateRenderPipelineImpl( |     ResultOrError<RenderPipelineBase*> Device::CreateRenderPipelineImpl( | ||||||
|         const RenderPipelineDescriptor* descriptor) { |         const RenderPipelineDescriptor* descriptor) { | ||||||
|         return new RenderPipeline(this, descriptor); |         return new RenderPipeline(this, descriptor); | ||||||
|  | |||||||
| @ -25,7 +25,6 @@ | |||||||
| #include "dawn_native/InputState.h" | #include "dawn_native/InputState.h" | ||||||
| #include "dawn_native/PipelineLayout.h" | #include "dawn_native/PipelineLayout.h" | ||||||
| #include "dawn_native/Queue.h" | #include "dawn_native/Queue.h" | ||||||
| #include "dawn_native/RenderPassDescriptor.h" |  | ||||||
| #include "dawn_native/RenderPipeline.h" | #include "dawn_native/RenderPipeline.h" | ||||||
| #include "dawn_native/RingBuffer.h" | #include "dawn_native/RingBuffer.h" | ||||||
| #include "dawn_native/Sampler.h" | #include "dawn_native/Sampler.h" | ||||||
| @ -48,7 +47,6 @@ namespace dawn_native { namespace null { | |||||||
|     using InputState = InputStateBase; |     using InputState = InputStateBase; | ||||||
|     using PipelineLayout = PipelineLayoutBase; |     using PipelineLayout = PipelineLayoutBase; | ||||||
|     class Queue; |     class Queue; | ||||||
|     using RenderPassDescriptor = RenderPassDescriptorBase; |  | ||||||
|     using RenderPipeline = RenderPipelineBase; |     using RenderPipeline = RenderPipelineBase; | ||||||
|     using Sampler = SamplerBase; |     using Sampler = SamplerBase; | ||||||
|     using ShaderModule = ShaderModuleBase; |     using ShaderModule = ShaderModuleBase; | ||||||
| @ -67,7 +65,6 @@ namespace dawn_native { namespace null { | |||||||
|         using InputStateType = InputState; |         using InputStateType = InputState; | ||||||
|         using PipelineLayoutType = PipelineLayout; |         using PipelineLayoutType = PipelineLayout; | ||||||
|         using QueueType = Queue; |         using QueueType = Queue; | ||||||
|         using RenderPassDescriptorType = RenderPassDescriptor; |  | ||||||
|         using RenderPipelineType = RenderPipeline; |         using RenderPipelineType = RenderPipeline; | ||||||
|         using SamplerType = Sampler; |         using SamplerType = Sampler; | ||||||
|         using ShaderModuleType = ShaderModule; |         using ShaderModuleType = ShaderModule; | ||||||
| @ -93,8 +90,6 @@ namespace dawn_native { namespace null { | |||||||
| 
 | 
 | ||||||
|         CommandBufferBase* CreateCommandBuffer(CommandEncoderBase* encoder) override; |         CommandBufferBase* CreateCommandBuffer(CommandEncoderBase* encoder) override; | ||||||
|         InputStateBase* CreateInputState(InputStateBuilder* builder) override; |         InputStateBase* CreateInputState(InputStateBuilder* builder) override; | ||||||
|         RenderPassDescriptorBase* CreateRenderPassDescriptor( |  | ||||||
|             RenderPassDescriptorBuilder* builder) override; |  | ||||||
| 
 | 
 | ||||||
|         Serial GetCompletedCommandSerial() const final override; |         Serial GetCompletedCommandSerial() const final override; | ||||||
|         Serial GetLastSubmittedCommandSerial() const final override; |         Serial GetLastSubmittedCommandSerial() const final override; | ||||||
|  | |||||||
| @ -546,7 +546,7 @@ namespace dawn_native { namespace opengl { | |||||||
| 
 | 
 | ||||||
|                 // Load op - color
 |                 // Load op - color
 | ||||||
|                 if (attachmentInfo.loadOp == dawn::LoadOp::Clear) { |                 if (attachmentInfo.loadOp == dawn::LoadOp::Clear) { | ||||||
|                     glClearBufferfv(GL_COLOR, i, attachmentInfo.clearColor.data()); |                     glClearBufferfv(GL_COLOR, i, &attachmentInfo.clearColor.r); | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -18,7 +18,6 @@ | |||||||
| #include "dawn_native/BindGroup.h" | #include "dawn_native/BindGroup.h" | ||||||
| #include "dawn_native/BindGroupLayout.h" | #include "dawn_native/BindGroupLayout.h" | ||||||
| #include "dawn_native/DynamicUploader.h" | #include "dawn_native/DynamicUploader.h" | ||||||
| #include "dawn_native/RenderPassDescriptor.h" |  | ||||||
| #include "dawn_native/opengl/BufferGL.h" | #include "dawn_native/opengl/BufferGL.h" | ||||||
| #include "dawn_native/opengl/CommandBufferGL.h" | #include "dawn_native/opengl/CommandBufferGL.h" | ||||||
| #include "dawn_native/opengl/ComputePipelineGL.h" | #include "dawn_native/opengl/ComputePipelineGL.h" | ||||||
| @ -78,10 +77,6 @@ namespace dawn_native { namespace opengl { | |||||||
|     ResultOrError<QueueBase*> Device::CreateQueueImpl() { |     ResultOrError<QueueBase*> Device::CreateQueueImpl() { | ||||||
|         return new Queue(this); |         return new Queue(this); | ||||||
|     } |     } | ||||||
|     RenderPassDescriptorBase* Device::CreateRenderPassDescriptor( |  | ||||||
|         RenderPassDescriptorBuilder* builder) { |  | ||||||
|         return new RenderPassDescriptor(builder); |  | ||||||
|     } |  | ||||||
|     ResultOrError<RenderPipelineBase*> Device::CreateRenderPipelineImpl( |     ResultOrError<RenderPipelineBase*> Device::CreateRenderPipelineImpl( | ||||||
|         const RenderPipelineDescriptor* descriptor) { |         const RenderPipelineDescriptor* descriptor) { | ||||||
|         return new RenderPipeline(this, descriptor); |         return new RenderPipeline(this, descriptor); | ||||||
|  | |||||||
| @ -42,8 +42,6 @@ namespace dawn_native { namespace opengl { | |||||||
|         // Dawn API
 |         // Dawn API
 | ||||||
|         CommandBufferBase* CreateCommandBuffer(CommandEncoderBase* encoder) override; |         CommandBufferBase* CreateCommandBuffer(CommandEncoderBase* encoder) override; | ||||||
|         InputStateBase* CreateInputState(InputStateBuilder* builder) override; |         InputStateBase* CreateInputState(InputStateBuilder* builder) override; | ||||||
|         RenderPassDescriptorBase* CreateRenderPassDescriptor( |  | ||||||
|             RenderPassDescriptorBuilder* builder) override; |  | ||||||
| 
 | 
 | ||||||
|         Serial GetCompletedCommandSerial() const final override; |         Serial GetCompletedCommandSerial() const final override; | ||||||
|         Serial GetLastSubmittedCommandSerial() const final override; |         Serial GetLastSubmittedCommandSerial() const final override; | ||||||
|  | |||||||
| @ -36,7 +36,6 @@ namespace dawn_native { namespace opengl { | |||||||
|     class PersistentPipelineState; |     class PersistentPipelineState; | ||||||
|     class PipelineLayout; |     class PipelineLayout; | ||||||
|     class Queue; |     class Queue; | ||||||
|     using RenderPassDescriptor = RenderPassDescriptorBase; |  | ||||||
|     class RenderPipeline; |     class RenderPipeline; | ||||||
|     class Sampler; |     class Sampler; | ||||||
|     class ShaderModule; |     class ShaderModule; | ||||||
| @ -55,7 +54,6 @@ namespace dawn_native { namespace opengl { | |||||||
|         using InputStateType = InputState; |         using InputStateType = InputState; | ||||||
|         using PipelineLayoutType = PipelineLayout; |         using PipelineLayoutType = PipelineLayout; | ||||||
|         using QueueType = Queue; |         using QueueType = Queue; | ||||||
|         using RenderPassDescriptorType = RenderPassDescriptor; |  | ||||||
|         using RenderPipelineType = RenderPipeline; |         using RenderPipelineType = RenderPipeline; | ||||||
|         using SamplerType = Sampler; |         using SamplerType = Sampler; | ||||||
|         using ShaderModuleType = ShaderModule; |         using ShaderModuleType = ShaderModule; | ||||||
|  | |||||||
| @ -148,10 +148,10 @@ namespace dawn_native { namespace vulkan { | |||||||
| 
 | 
 | ||||||
|                     attachments[attachmentCount] = view->GetHandle(); |                     attachments[attachmentCount] = view->GetHandle(); | ||||||
| 
 | 
 | ||||||
|                     clearValues[attachmentCount].color.float32[0] = attachmentInfo.clearColor[0]; |                     clearValues[attachmentCount].color.float32[0] = attachmentInfo.clearColor.r; | ||||||
|                     clearValues[attachmentCount].color.float32[1] = attachmentInfo.clearColor[1]; |                     clearValues[attachmentCount].color.float32[1] = attachmentInfo.clearColor.g; | ||||||
|                     clearValues[attachmentCount].color.float32[2] = attachmentInfo.clearColor[2]; |                     clearValues[attachmentCount].color.float32[2] = attachmentInfo.clearColor.b; | ||||||
|                     clearValues[attachmentCount].color.float32[3] = attachmentInfo.clearColor[3]; |                     clearValues[attachmentCount].color.float32[3] = attachmentInfo.clearColor.a; | ||||||
| 
 | 
 | ||||||
|                     attachmentCount++; |                     attachmentCount++; | ||||||
|                 } |                 } | ||||||
|  | |||||||
| @ -19,7 +19,6 @@ | |||||||
| #include "dawn_native/Commands.h" | #include "dawn_native/Commands.h" | ||||||
| #include "dawn_native/DynamicUploader.h" | #include "dawn_native/DynamicUploader.h" | ||||||
| #include "dawn_native/ErrorData.h" | #include "dawn_native/ErrorData.h" | ||||||
| #include "dawn_native/RenderPassDescriptor.h" |  | ||||||
| #include "dawn_native/vulkan/AdapterVk.h" | #include "dawn_native/vulkan/AdapterVk.h" | ||||||
| #include "dawn_native/vulkan/BackendVk.h" | #include "dawn_native/vulkan/BackendVk.h" | ||||||
| #include "dawn_native/vulkan/BindGroupLayoutVk.h" | #include "dawn_native/vulkan/BindGroupLayoutVk.h" | ||||||
| @ -163,10 +162,6 @@ namespace dawn_native { namespace vulkan { | |||||||
|     ResultOrError<QueueBase*> Device::CreateQueueImpl() { |     ResultOrError<QueueBase*> Device::CreateQueueImpl() { | ||||||
|         return new Queue(this); |         return new Queue(this); | ||||||
|     } |     } | ||||||
|     RenderPassDescriptorBase* Device::CreateRenderPassDescriptor( |  | ||||||
|         RenderPassDescriptorBuilder* builder) { |  | ||||||
|         return new RenderPassDescriptor(builder); |  | ||||||
|     } |  | ||||||
|     ResultOrError<RenderPipelineBase*> Device::CreateRenderPipelineImpl( |     ResultOrError<RenderPipelineBase*> Device::CreateRenderPipelineImpl( | ||||||
|         const RenderPipelineDescriptor* descriptor) { |         const RenderPipelineDescriptor* descriptor) { | ||||||
|         return new RenderPipeline(this, descriptor); |         return new RenderPipeline(this, descriptor); | ||||||
|  | |||||||
| @ -66,8 +66,6 @@ namespace dawn_native { namespace vulkan { | |||||||
|         // Dawn API
 |         // Dawn API
 | ||||||
|         CommandBufferBase* CreateCommandBuffer(CommandEncoderBase* encoder) override; |         CommandBufferBase* CreateCommandBuffer(CommandEncoderBase* encoder) override; | ||||||
|         InputStateBase* CreateInputState(InputStateBuilder* builder) override; |         InputStateBase* CreateInputState(InputStateBuilder* builder) override; | ||||||
|         RenderPassDescriptorBase* CreateRenderPassDescriptor( |  | ||||||
|             RenderPassDescriptorBuilder* builder) override; |  | ||||||
| 
 | 
 | ||||||
|         Serial GetCompletedCommandSerial() const final override; |         Serial GetCompletedCommandSerial() const final override; | ||||||
|         Serial GetLastSubmittedCommandSerial() const final override; |         Serial GetLastSubmittedCommandSerial() const final override; | ||||||
|  | |||||||
| @ -29,7 +29,6 @@ namespace dawn_native { namespace vulkan { | |||||||
|     class InputState; |     class InputState; | ||||||
|     class PipelineLayout; |     class PipelineLayout; | ||||||
|     class Queue; |     class Queue; | ||||||
|     using RenderPassDescriptor = RenderPassDescriptorBase; |  | ||||||
|     class RenderPipeline; |     class RenderPipeline; | ||||||
|     class Sampler; |     class Sampler; | ||||||
|     class ShaderModule; |     class ShaderModule; | ||||||
| @ -49,7 +48,6 @@ namespace dawn_native { namespace vulkan { | |||||||
|         using InputStateType = InputState; |         using InputStateType = InputState; | ||||||
|         using PipelineLayoutType = PipelineLayout; |         using PipelineLayoutType = PipelineLayout; | ||||||
|         using QueueType = Queue; |         using QueueType = Queue; | ||||||
|         using RenderPassDescriptorType = RenderPassDescriptor; |  | ||||||
|         using RenderPipelineType = RenderPipeline; |         using RenderPipelineType = RenderPipeline; | ||||||
|         using SamplerType = Sampler; |         using SamplerType = Sampler; | ||||||
|         using ShaderModuleType = ShaderModule; |         using ShaderModuleType = ShaderModule; | ||||||
|  | |||||||
| @ -153,7 +153,7 @@ TEST_P(BindGroupTests, ReusedUBO) { | |||||||
|     }); |     }); | ||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|     pass.SetPipeline(pipeline); |     pass.SetPipeline(pipeline); | ||||||
|     pass.SetBindGroup(0, bindGroup); |     pass.SetBindGroup(0, bindGroup); | ||||||
|     pass.Draw(3, 1, 0, 0); |     pass.Draw(3, 1, 0, 0); | ||||||
| @ -273,7 +273,7 @@ TEST_P(BindGroupTests, UBOSamplerAndTexture) { | |||||||
|     dawn::TextureCopyView textureCopyView = utils::CreateTextureCopyView(texture, 0, 0, {0, 0, 0}); |     dawn::TextureCopyView textureCopyView = utils::CreateTextureCopyView(texture, 0, 0, {0, 0, 0}); | ||||||
|     dawn::Extent3D copySize = {width, height, 1}; |     dawn::Extent3D copySize = {width, height, 1}; | ||||||
|     encoder.CopyBufferToTexture(&bufferCopyView, &textureCopyView, ©Size); |     encoder.CopyBufferToTexture(&bufferCopyView, &textureCopyView, ©Size); | ||||||
|     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|     pass.SetPipeline(pipeline); |     pass.SetPipeline(pipeline); | ||||||
|     pass.SetBindGroup(0, bindGroup); |     pass.SetBindGroup(0, bindGroup); | ||||||
|     pass.Draw(3, 1, 0, 0); |     pass.Draw(3, 1, 0, 0); | ||||||
| @ -368,7 +368,7 @@ TEST_P(BindGroupTests, MultipleBindLayouts) { | |||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|     pass.SetPipeline(pipeline); |     pass.SetPipeline(pipeline); | ||||||
|     pass.SetBindGroup(0, bindGroups[0]); |     pass.SetBindGroup(0, bindGroups[0]); | ||||||
|     pass.SetBindGroup(1, bindGroups[1]); |     pass.SetBindGroup(1, bindGroups[1]); | ||||||
| @ -435,7 +435,7 @@ TEST_P(BindGroupTests, DrawTwiceInSamePipelineWithFourBindGroupSets) | |||||||
| 
 | 
 | ||||||
|     dawn::RenderPipeline pipeline = device.CreateRenderPipeline(&pipelineDescriptor); |     dawn::RenderPipeline pipeline = device.CreateRenderPipeline(&pipelineDescriptor); | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
| 
 | 
 | ||||||
|     pass.SetPipeline(pipeline); |     pass.SetPipeline(pipeline); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -113,7 +113,7 @@ class ColorStateTest : public DawnTest { | |||||||
| 
 | 
 | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         { |         { | ||||||
|             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|             // First use the base pipeline to draw a triangle with no blending
 |             // First use the base pipeline to draw a triangle with no blending
 | ||||||
|             pass.SetPipeline(basePipeline); |             pass.SetPipeline(basePipeline); | ||||||
|             pass.SetBindGroup(0, MakeBindGroupForColors(std::array<RGBA8, 1>({{base}}))); |             pass.SetBindGroup(0, MakeBindGroupForColors(std::array<RGBA8, 1>({{base}}))); | ||||||
| @ -733,7 +733,7 @@ TEST_P(ColorStateTest, ColorWriteMaskBlendingDisabled) { | |||||||
| 
 | 
 | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         { |         { | ||||||
|             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|             pass.SetPipeline(testPipeline); |             pass.SetPipeline(testPipeline); | ||||||
|             pass.SetBindGroup(0, MakeBindGroupForColors(std::array<RGBA8, 1>({{base}}))); |             pass.SetBindGroup(0, MakeBindGroupForColors(std::array<RGBA8, 1>({{base}}))); | ||||||
|             pass.Draw(3, 1, 0, 0); |             pass.Draw(3, 1, 0, 0); | ||||||
| @ -769,18 +769,8 @@ TEST_P(ColorStateTest, IndependentColorState) { | |||||||
|         renderTargetViews[i] = renderTargets[i].CreateDefaultTextureView(); |         renderTargetViews[i] = renderTargets[i].CreateDefaultTextureView(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     dawn::RenderPassColorAttachmentDescriptor colorAttachments[4]; |     utils::ComboRenderPassDescriptor renderPass({renderTargetViews[0], renderTargetViews[1], | ||||||
|     for (uint32_t i = 0; i < 4; ++i) { |                                                 renderTargetViews[2], renderTargetViews[3]}); | ||||||
|         colorAttachments[i].attachment = renderTargetViews[i]; |  | ||||||
|         colorAttachments[i].resolveTarget = nullptr; |  | ||||||
|         colorAttachments[i].clearColor = {0.0f, 0.0f, 0.0f, 0.0f}; |  | ||||||
|         colorAttachments[i].loadOp = dawn::LoadOp::Clear; |  | ||||||
|         colorAttachments[i].storeOp = dawn::StoreOp::Store; |  | ||||||
|     } |  | ||||||
| 
 |  | ||||||
|     dawn::RenderPassDescriptor renderpass = device.CreateRenderPassDescriptorBuilder() |  | ||||||
|                                                 .SetColorAttachments(4, colorAttachments) |  | ||||||
|                                                 .GetResult(); |  | ||||||
| 
 | 
 | ||||||
|     dawn::ShaderModule fsModule = utils::CreateShaderModule(device, dawn::ShaderStage::Fragment, R"( |     dawn::ShaderModule fsModule = utils::CreateShaderModule(device, dawn::ShaderStage::Fragment, R"( | ||||||
|         #version 450 |         #version 450 | ||||||
| @ -859,7 +849,7 @@ TEST_P(ColorStateTest, IndependentColorState) { | |||||||
| 
 | 
 | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         { |         { | ||||||
|             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpass); |             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|             pass.SetPipeline(basePipeline); |             pass.SetPipeline(basePipeline); | ||||||
|             pass.SetBindGroup( |             pass.SetBindGroup( | ||||||
|                 0, MakeBindGroupForColors(std::array<RGBA8, 4>({{base, base, base, base}}))); |                 0, MakeBindGroupForColors(std::array<RGBA8, 4>({{base, base, base, base}}))); | ||||||
| @ -933,7 +923,7 @@ TEST_P(ColorStateTest, DefaultBlendColor) { | |||||||
|     { |     { | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         { |         { | ||||||
|             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|             pass.SetPipeline(basePipeline); |             pass.SetPipeline(basePipeline); | ||||||
|             pass.SetBindGroup(0, |             pass.SetBindGroup(0, | ||||||
|                               MakeBindGroupForColors(std::array<RGBA8, 1>({{RGBA8(0, 0, 0, 0)}}))); |                               MakeBindGroupForColors(std::array<RGBA8, 1>({{RGBA8(0, 0, 0, 0)}}))); | ||||||
| @ -955,7 +945,7 @@ TEST_P(ColorStateTest, DefaultBlendColor) { | |||||||
|     { |     { | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         { |         { | ||||||
|             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|             pass.SetPipeline(basePipeline); |             pass.SetPipeline(basePipeline); | ||||||
|             pass.SetBindGroup(0, |             pass.SetBindGroup(0, | ||||||
|                               MakeBindGroupForColors(std::array<RGBA8, 1>({{RGBA8(0, 0, 0, 0)}}))); |                               MakeBindGroupForColors(std::array<RGBA8, 1>({{RGBA8(0, 0, 0, 0)}}))); | ||||||
| @ -979,7 +969,7 @@ TEST_P(ColorStateTest, DefaultBlendColor) { | |||||||
|     { |     { | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         { |         { | ||||||
|             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|             pass.SetPipeline(basePipeline); |             pass.SetPipeline(basePipeline); | ||||||
|             pass.SetBindGroup(0, |             pass.SetBindGroup(0, | ||||||
|                               MakeBindGroupForColors(std::array<RGBA8, 1>({{RGBA8(0, 0, 0, 0)}}))); |                               MakeBindGroupForColors(std::array<RGBA8, 1>({{RGBA8(0, 0, 0, 0)}}))); | ||||||
| @ -992,7 +982,7 @@ TEST_P(ColorStateTest, DefaultBlendColor) { | |||||||
|             pass.EndPass(); |             pass.EndPass(); | ||||||
|         } |         } | ||||||
|         { |         { | ||||||
|             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|             pass.SetPipeline(basePipeline); |             pass.SetPipeline(basePipeline); | ||||||
|             pass.SetBindGroup(0, |             pass.SetBindGroup(0, | ||||||
|                               MakeBindGroupForColors(std::array<RGBA8, 1>({{RGBA8(0, 0, 0, 0)}}))); |                               MakeBindGroupForColors(std::array<RGBA8, 1>({{RGBA8(0, 0, 0, 0)}}))); | ||||||
|  | |||||||
| @ -24,7 +24,7 @@ TEST_P(DebugMarkerTests, NoFailureWithoutDebugToolAttached) { | |||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         pass.PushDebugGroup("Event Start"); |         pass.PushDebugGroup("Event Start"); | ||||||
|         pass.InsertDebugMarker("Marker"); |         pass.InsertDebugMarker("Marker"); | ||||||
|         pass.PopDebugGroup(); |         pass.PopDebugGroup(); | ||||||
|  | |||||||
| @ -53,26 +53,6 @@ class DepthStencilStateTest : public DawnTest { | |||||||
| 
 | 
 | ||||||
|             depthTextureView = depthTexture.CreateDefaultTextureView(); |             depthTextureView = depthTexture.CreateDefaultTextureView(); | ||||||
| 
 | 
 | ||||||
|             dawn::RenderPassColorAttachmentDescriptor colorAttachment; |  | ||||||
|             colorAttachment.attachment = renderTargetView; |  | ||||||
|             colorAttachment.resolveTarget = nullptr; |  | ||||||
|             colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|             colorAttachment.loadOp = dawn::LoadOp::Clear; |  | ||||||
|             colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
| 
 |  | ||||||
|             dawn::RenderPassDepthStencilAttachmentDescriptor depthStencilAttachment; |  | ||||||
|             depthStencilAttachment.attachment = depthTextureView; |  | ||||||
|             depthStencilAttachment.depthLoadOp = dawn::LoadOp::Clear; |  | ||||||
|             depthStencilAttachment.stencilLoadOp = dawn::LoadOp::Clear; |  | ||||||
|             depthStencilAttachment.clearDepth = 1.0f; |  | ||||||
|             depthStencilAttachment.clearStencil = 0; |  | ||||||
|             depthStencilAttachment.depthStoreOp = dawn::StoreOp::Store; |  | ||||||
|             depthStencilAttachment.stencilStoreOp = dawn::StoreOp::Store; |  | ||||||
|             renderpass = device.CreateRenderPassDescriptorBuilder() |  | ||||||
|                 .SetColorAttachments(1, &colorAttachment) |  | ||||||
|                 .SetDepthStencilAttachment(&depthStencilAttachment) |  | ||||||
|                 .GetResult(); |  | ||||||
| 
 |  | ||||||
|             vsModule = utils::CreateShaderModule(device, dawn::ShaderStage::Vertex, R"( |             vsModule = utils::CreateShaderModule(device, dawn::ShaderStage::Vertex, R"( | ||||||
|                 #version 450 |                 #version 450 | ||||||
|                 layout(set = 0, binding = 0) uniform myBlock { |                 layout(set = 0, binding = 0) uniform myBlock { | ||||||
| @ -273,7 +253,8 @@ class DepthStencilStateTest : public DawnTest { | |||||||
|                 float depth; |                 float depth; | ||||||
|             }; |             }; | ||||||
| 
 | 
 | ||||||
|             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpass); |             utils::ComboRenderPassDescriptor renderPass({renderTargetView}, depthTextureView); | ||||||
|  |             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
| 
 | 
 | ||||||
|             for (size_t i = 0; i < testParams.size(); ++i) { |             for (size_t i = 0; i < testParams.size(); ++i) { | ||||||
|                 const TestSpec& test = testParams[i]; |                 const TestSpec& test = testParams[i]; | ||||||
| @ -318,7 +299,6 @@ class DepthStencilStateTest : public DawnTest { | |||||||
|             DoTest(testParams, expected, expected); |             DoTest(testParams, expected, expected); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         dawn::RenderPassDescriptor renderpass; |  | ||||||
|         dawn::Texture renderTarget; |         dawn::Texture renderTarget; | ||||||
|         dawn::Texture depthTexture; |         dawn::Texture depthTexture; | ||||||
|         dawn::TextureView renderTargetView; |         dawn::TextureView renderTargetView; | ||||||
|  | |||||||
| @ -97,7 +97,8 @@ class DrawIndexedTest : public DawnTest { | |||||||
|             uint32_t zeroOffset = 0; |             uint32_t zeroOffset = 0; | ||||||
|             dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |             dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|             { |             { | ||||||
|                 dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |                 dawn::RenderPassEncoder pass = encoder.BeginRenderPass( | ||||||
|  |                     &renderPass.renderPassInfo); | ||||||
|                 pass.SetPipeline(pipeline); |                 pass.SetPipeline(pipeline); | ||||||
|                 pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); |                 pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); | ||||||
|                 pass.SetIndexBuffer(indexBuffer, 0); |                 pass.SetIndexBuffer(indexBuffer, 0); | ||||||
|  | |||||||
| @ -88,7 +88,7 @@ class DrawTest : public DawnTest { | |||||||
|         uint32_t zeroOffset = 0; |         uint32_t zeroOffset = 0; | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         { |         { | ||||||
|             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|             pass.SetPipeline(pipeline); |             pass.SetPipeline(pipeline); | ||||||
|             pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); |             pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); | ||||||
|             pass.Draw(vertexCount, instanceCount, firstIndex, firstInstance); |             pass.Draw(vertexCount, instanceCount, firstIndex, firstInstance); | ||||||
|  | |||||||
| @ -93,7 +93,7 @@ TEST_P(IndexFormatTest, Uint32) { | |||||||
|     uint32_t zeroOffset = 0; |     uint32_t zeroOffset = 0; | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); |         pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); | ||||||
|         pass.SetIndexBuffer(indexBuffer, 0); |         pass.SetIndexBuffer(indexBuffer, 0); | ||||||
| @ -124,7 +124,7 @@ TEST_P(IndexFormatTest, Uint16) { | |||||||
|     uint32_t zeroOffset = 0; |     uint32_t zeroOffset = 0; | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); |         pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); | ||||||
|         pass.SetIndexBuffer(indexBuffer, 0); |         pass.SetIndexBuffer(indexBuffer, 0); | ||||||
| @ -168,7 +168,7 @@ TEST_P(IndexFormatTest, Uint32PrimitiveRestart) { | |||||||
|     uint32_t zeroOffset = 0; |     uint32_t zeroOffset = 0; | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); |         pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); | ||||||
|         pass.SetIndexBuffer(indexBuffer, 0); |         pass.SetIndexBuffer(indexBuffer, 0); | ||||||
| @ -204,7 +204,7 @@ TEST_P(IndexFormatTest, Uint16PrimitiveRestart) { | |||||||
|     uint32_t zeroOffset = 0; |     uint32_t zeroOffset = 0; | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); |         pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); | ||||||
|         pass.SetIndexBuffer(indexBuffer, 0); |         pass.SetIndexBuffer(indexBuffer, 0); | ||||||
| @ -243,7 +243,7 @@ TEST_P(IndexFormatTest, ChangePipelineAfterSetIndexBuffer) { | |||||||
|     uint32_t zeroOffset = 0; |     uint32_t zeroOffset = 0; | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         pass.SetPipeline(pipeline16); |         pass.SetPipeline(pipeline16); | ||||||
|         pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); |         pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); | ||||||
|         pass.SetIndexBuffer(indexBuffer, 0); |         pass.SetIndexBuffer(indexBuffer, 0); | ||||||
| @ -278,7 +278,7 @@ TEST_P(IndexFormatTest, DISABLED_SetIndexBufferBeforeSetPipeline) { | |||||||
|     uint32_t zeroOffset = 0; |     uint32_t zeroOffset = 0; | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         pass.SetIndexBuffer(indexBuffer, 0); |         pass.SetIndexBuffer(indexBuffer, 0); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); |         pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); | ||||||
|  | |||||||
| @ -180,7 +180,7 @@ class InputStateTest : public DawnTest { | |||||||
| 
 | 
 | ||||||
|             dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |             dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
| 
 | 
 | ||||||
|             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|             pass.SetPipeline(pipeline); |             pass.SetPipeline(pipeline); | ||||||
| 
 | 
 | ||||||
|             uint32_t zeroOffset = 0; |             uint32_t zeroOffset = 0; | ||||||
| @ -454,7 +454,7 @@ TEST_P(InputStateTest, UnusedVertexSlot) { | |||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
| 
 | 
 | ||||||
|     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
| 
 | 
 | ||||||
|     uint32_t zeroOffset = 0; |     uint32_t zeroOffset = 0; | ||||||
|     pass.SetVertexBuffers(0, 1, &buffer, &zeroOffset); |     pass.SetVertexBuffers(0, 1, &buffer, &zeroOffset); | ||||||
| @ -499,7 +499,7 @@ TEST_P(InputStateTest, MultiplePipelinesMixedInputState) { | |||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
| 
 | 
 | ||||||
|     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
| 
 | 
 | ||||||
|     uint32_t zeroOffset = 0; |     uint32_t zeroOffset = 0; | ||||||
|     pass.SetVertexBuffers(0, 1, &buffer, &zeroOffset); |     pass.SetVertexBuffers(0, 1, &buffer, &zeroOffset); | ||||||
|  | |||||||
| @ -210,7 +210,8 @@ class PrimitiveTopologyTest : public DawnTest { | |||||||
|             static const uint32_t zeroOffset = 0; |             static const uint32_t zeroOffset = 0; | ||||||
|             dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |             dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|             { |             { | ||||||
|                 dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |                 dawn::RenderPassEncoder pass = encoder.BeginRenderPass( | ||||||
|  |                     &renderPass.renderPassInfo); | ||||||
|                 pass.SetPipeline(pipeline); |                 pass.SetPipeline(pipeline); | ||||||
|                 pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); |                 pass.SetVertexBuffers(0, 1, &vertexBuffer, &zeroOffset); | ||||||
|                 pass.Draw(6, 1, 0, 0); |                 pass.Draw(6, 1, 0, 0); | ||||||
|  | |||||||
| @ -251,7 +251,7 @@ TEST_P(PushConstantTest, RenderPassDefaultsToZero) { | |||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         // Test render push constants are set to zero by default.
 |         // Test render push constants are set to zero by default.
 | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.Draw(1, 1, 0, 0); |         pass.Draw(1, 1, 0, 0); | ||||||
| @ -378,7 +378,7 @@ TEST_P(PushConstantTest, SeparateVertexAndFragmentConstants) { | |||||||
|     uint32_t two = 2; |     uint32_t two = 2; | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         pass.SetPushConstants(dawn::ShaderStageBit::Vertex, 0, 1, &one); |         pass.SetPushConstants(dawn::ShaderStageBit::Vertex, 0, 1, &one); | ||||||
|         pass.SetPushConstants(dawn::ShaderStageBit::Fragment, 0, 1, &two); |         pass.SetPushConstants(dawn::ShaderStageBit::Fragment, 0, 1, &two); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
| @ -404,7 +404,7 @@ TEST_P(PushConstantTest, SimultaneousVertexAndFragmentConstants) { | |||||||
|     uint32_t two = 2; |     uint32_t two = 2; | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         pass.SetPushConstants(dawn::ShaderStageBit::Vertex | dawn::ShaderStageBit::Fragment, 0, 1, &two); |         pass.SetPushConstants(dawn::ShaderStageBit::Vertex | dawn::ShaderStageBit::Fragment, 0, 1, &two); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.Draw(1, 1, 0, 0); |         pass.Draw(1, 1, 0, 0); | ||||||
|  | |||||||
| @ -112,31 +112,17 @@ class RenderPassLoadOpTests : public DawnTest { | |||||||
| 
 | 
 | ||||||
| // Tests clearing, loading, and drawing into color attachments
 | // Tests clearing, loading, and drawing into color attachments
 | ||||||
| TEST_P(RenderPassLoadOpTests, ColorClearThenLoadAndDraw) { | TEST_P(RenderPassLoadOpTests, ColorClearThenLoadAndDraw) { | ||||||
|     dawn::RenderPassColorAttachmentDescriptor colorAttachment; |  | ||||||
|     colorAttachment.attachment = renderTargetView; |  | ||||||
|     colorAttachment.resolveTarget = nullptr; |  | ||||||
|     colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|     colorAttachment.loadOp = dawn::LoadOp::Clear; |  | ||||||
|     colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
| 
 |  | ||||||
|     // Part 1: clear once, check to make sure it's cleared
 |     // Part 1: clear once, check to make sure it's cleared
 | ||||||
|     auto renderPassClearZero = device.CreateRenderPassDescriptorBuilder() |     utils::ComboRenderPassDescriptor renderPassClearZero({renderTargetView}); | ||||||
|         .SetColorAttachments(1, &colorAttachment) |  | ||||||
|         .GetResult(); |  | ||||||
| 
 |  | ||||||
|     auto commandsClearZeroEncoder = device.CreateCommandEncoder(); |     auto commandsClearZeroEncoder = device.CreateCommandEncoder(); | ||||||
|     auto clearZeroPass = commandsClearZeroEncoder.BeginRenderPass(renderPassClearZero); |     auto clearZeroPass = commandsClearZeroEncoder.BeginRenderPass(&renderPassClearZero); | ||||||
|     clearZeroPass.EndPass(); |     clearZeroPass.EndPass(); | ||||||
|     auto commandsClearZero = commandsClearZeroEncoder.Finish(); |     auto commandsClearZero = commandsClearZeroEncoder.Finish(); | ||||||
| 
 | 
 | ||||||
|     dawn::RenderPassColorAttachmentDescriptor colorAttachmentGreen = colorAttachment; |     utils::ComboRenderPassDescriptor renderPassClearGreen({renderTargetView}); | ||||||
|     colorAttachmentGreen.clearColor = { 0.0f, 1.0f, 0.0f, 1.0f }; |     renderPassClearGreen.cColorAttachmentsInfoPtr[0]->clearColor = {0.0f, 1.0f, 0.0f, 1.0f}; | ||||||
|     auto renderPassClearGreen = device.CreateRenderPassDescriptorBuilder() |  | ||||||
|         .SetColorAttachments(1, &colorAttachmentGreen) |  | ||||||
|         .GetResult(); |  | ||||||
| 
 |  | ||||||
|     auto commandsClearGreenEncoder = device.CreateCommandEncoder(); |     auto commandsClearGreenEncoder = device.CreateCommandEncoder(); | ||||||
|     auto clearGreenPass = commandsClearGreenEncoder.BeginRenderPass(renderPassClearGreen); |     auto clearGreenPass = commandsClearGreenEncoder.BeginRenderPass(&renderPassClearGreen); | ||||||
|     clearGreenPass.EndPass(); |     clearGreenPass.EndPass(); | ||||||
|     auto commandsClearGreen = commandsClearGreenEncoder.Finish(); |     auto commandsClearGreen = commandsClearGreenEncoder.Finish(); | ||||||
| 
 | 
 | ||||||
| @ -147,16 +133,12 @@ TEST_P(RenderPassLoadOpTests, ColorClearThenLoadAndDraw) { | |||||||
|     EXPECT_TEXTURE_RGBA8_EQ(expectGreen.data(), renderTarget, 0, 0, kRTSize, kRTSize, 0, 0); |     EXPECT_TEXTURE_RGBA8_EQ(expectGreen.data(), renderTarget, 0, 0, kRTSize, kRTSize, 0, 0); | ||||||
| 
 | 
 | ||||||
|     // Part 2: draw a blue quad into the right half of the render target, and check result
 |     // Part 2: draw a blue quad into the right half of the render target, and check result
 | ||||||
|     dawn::RenderPassColorAttachmentDescriptor colorAttachmentLoad = colorAttachment; |     utils::ComboRenderPassDescriptor renderPassLoad({renderTargetView}); | ||||||
|     colorAttachmentLoad.loadOp = dawn::LoadOp::Load; |     renderPassLoad.cColorAttachmentsInfoPtr[0]->loadOp = dawn::LoadOp::Load; | ||||||
|     auto renderPassLoad = device.CreateRenderPassDescriptorBuilder() |  | ||||||
|         .SetColorAttachments(1, &colorAttachmentLoad) |  | ||||||
|         .GetResult(); |  | ||||||
| 
 |  | ||||||
|     dawn::CommandBuffer commandsLoad; |     dawn::CommandBuffer commandsLoad; | ||||||
|     { |     { | ||||||
|         auto encoder = device.CreateCommandEncoder(); |         auto encoder = device.CreateCommandEncoder(); | ||||||
|         auto pass = encoder.BeginRenderPass(renderPassLoad); |         auto pass = encoder.BeginRenderPass(&renderPassLoad); | ||||||
|         blueQuad.Draw(&pass); |         blueQuad.Draw(&pass); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|         commandsLoad = encoder.Finish(); |         commandsLoad = encoder.Finish(); | ||||||
|  | |||||||
| @ -82,22 +82,13 @@ TEST_P(RenderPassTest, TwoRenderPassesInOneCommandBuffer) { | |||||||
|     dawn::Texture renderTarget2 = CreateDefault2DTexture(); |     dawn::Texture renderTarget2 = CreateDefault2DTexture(); | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
| 
 | 
 | ||||||
|     dawn::RenderPassColorAttachmentDescriptor colorAttachment; |  | ||||||
|     colorAttachment.loadOp = dawn::LoadOp::Clear; |  | ||||||
|     colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
|     colorAttachment.resolveTarget = nullptr; |  | ||||||
| 
 |  | ||||||
|     { |     { | ||||||
|         // In the first render pass we clear renderTarget1 to red and draw a blue triangle in the
 |         // In the first render pass we clear renderTarget1 to red and draw a blue triangle in the
 | ||||||
|         // bottom left of renderTarget1.
 |         // bottom left of renderTarget1.
 | ||||||
|         colorAttachment.clearColor = { 1.0, 0.0, 0.0, 1.0 }; |         utils::ComboRenderPassDescriptor renderPass({renderTarget1.CreateDefaultTextureView()}); | ||||||
|  |         renderPass.cColorAttachmentsInfoPtr[0]->clearColor = {1.0f, 0.0f, 0.0f, 1.0f}; | ||||||
| 
 | 
 | ||||||
|         colorAttachment.attachment = renderTarget1.CreateDefaultTextureView(); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         dawn::RenderPassDescriptor renderPass = device.CreateRenderPassDescriptorBuilder() |  | ||||||
|             .SetColorAttachments(1, &colorAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
| 
 |  | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass); |  | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.Draw(3, 1, 0, 0); |         pass.Draw(3, 1, 0, 0); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
| @ -106,13 +97,10 @@ TEST_P(RenderPassTest, TwoRenderPassesInOneCommandBuffer) { | |||||||
|     { |     { | ||||||
|         // In the second render pass we clear renderTarget2 to green and draw a blue triangle in the
 |         // In the second render pass we clear renderTarget2 to green and draw a blue triangle in the
 | ||||||
|         // bottom left of renderTarget2.
 |         // bottom left of renderTarget2.
 | ||||||
|         colorAttachment.attachment = renderTarget2.CreateDefaultTextureView(); |         utils::ComboRenderPassDescriptor renderPass({renderTarget2.CreateDefaultTextureView()}); | ||||||
|         colorAttachment.clearColor = { 0.0, 1.0, 0.0, 1.0 }; |         renderPass.cColorAttachmentsInfoPtr[0]->clearColor = {0.0f, 1.0f, 0.0f, 1.0f}; | ||||||
|         dawn::RenderPassDescriptor renderPass = device.CreateRenderPassDescriptorBuilder() |  | ||||||
|             .SetColorAttachments(1, &colorAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
| 
 | 
 | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.Draw(3, 1, 0, 0); |         pass.Draw(3, 1, 0, 0); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|  | |||||||
| @ -140,7 +140,7 @@ protected: | |||||||
| 
 | 
 | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         { |         { | ||||||
|             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(mRenderPass.renderPassInfo); |             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&mRenderPass.renderPassInfo); | ||||||
|             pass.SetPipeline(mPipeline); |             pass.SetPipeline(mPipeline); | ||||||
|             pass.SetBindGroup(0, bindGroup); |             pass.SetBindGroup(0, bindGroup); | ||||||
|             pass.Draw(6, 1, 0, 0); |             pass.Draw(6, 1, 0, 0); | ||||||
|  | |||||||
| @ -53,7 +53,7 @@ TEST_P(ScissorTest, DefaultsToWholeRenderTarget) { | |||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.Draw(6, 1, 0, 0); |         pass.Draw(6, 1, 0, 0); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
| @ -75,7 +75,7 @@ TEST_P(ScissorTest, LargerThanAttachment) { | |||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.SetScissorRect(0, 0, 200, 200); |         pass.SetScissorRect(0, 0, 200, 200); | ||||||
|         pass.Draw(6, 1, 0, 0); |         pass.Draw(6, 1, 0, 0); | ||||||
| @ -101,7 +101,7 @@ TEST_P(ScissorTest, EmptyRect) { | |||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.SetScissorRect(0, 0, 0, 0); |         pass.SetScissorRect(0, 0, 0, 0); | ||||||
|         pass.Draw(6, 1, 0, 0); |         pass.Draw(6, 1, 0, 0); | ||||||
| @ -129,7 +129,7 @@ TEST_P(ScissorTest, PartialRect) { | |||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.SetScissorRect(kX, kY, kW, kH); |         pass.SetScissorRect(kX, kY, kW, kH); | ||||||
|         pass.Draw(6, 1, 0, 0); |         pass.Draw(6, 1, 0, 0); | ||||||
| @ -155,13 +155,13 @@ TEST_P(ScissorTest, NoInheritanceBetweenRenderPass) { | |||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     // RenderPass 1 set the scissor
 |     // RenderPass 1 set the scissor
 | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         pass.SetScissorRect(0, 0, 0, 0); |         pass.SetScissorRect(0, 0, 0, 0); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|     } |     } | ||||||
|     // RenderPass 2 draw a full quad, it shouldn't be scissored
 |     // RenderPass 2 draw a full quad, it shouldn't be scissored
 | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.Draw(6, 1, 0, 0); |         pass.Draw(6, 1, 0, 0); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|  | |||||||
| @ -178,7 +178,7 @@ protected: | |||||||
| 
 | 
 | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         { |         { | ||||||
|             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(mRenderPass.renderPassInfo); |             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&mRenderPass.renderPassInfo); | ||||||
|             pass.SetPipeline(pipeline); |             pass.SetPipeline(pipeline); | ||||||
|             pass.SetBindGroup(0, bindGroup); |             pass.SetBindGroup(0, bindGroup); | ||||||
|             pass.Draw(6, 1, 0, 0); |             pass.Draw(6, 1, 0, 0); | ||||||
| @ -492,15 +492,8 @@ class TextureViewRenderingTest : public DawnTest { | |||||||
|         dawn::ShaderModule vsModule = CreateDefaultVertexShaderModule(device); |         dawn::ShaderModule vsModule = CreateDefaultVertexShaderModule(device); | ||||||
| 
 | 
 | ||||||
|         // Clear textureView with Red(255, 0, 0, 255) and render Green(0, 255, 0, 255) into it
 |         // Clear textureView with Red(255, 0, 0, 255) and render Green(0, 255, 0, 255) into it
 | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachment; |         utils::ComboRenderPassDescriptor renderPassInfo({textureView}); | ||||||
|         colorAttachment.attachment = textureView; |         renderPassInfo.cColorAttachmentsInfoPtr[0]->clearColor = {1.0f, 0.0f, 0.0f, 1.0f}; | ||||||
|         colorAttachment.resolveTarget = nullptr; |  | ||||||
|         colorAttachment.clearColor = { 1.0, 0.0, 0.0, 1.0 }; |  | ||||||
|         colorAttachment.loadOp = dawn::LoadOp::Clear; |  | ||||||
|         colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
|         dawn::RenderPassDescriptor renderPassInfo = device.CreateRenderPassDescriptorBuilder() |  | ||||||
|             .SetColorAttachments(1, &colorAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
| 
 | 
 | ||||||
|         const char* oneColorFragmentShader = R"( |         const char* oneColorFragmentShader = R"( | ||||||
|             #version 450 |             #version 450 | ||||||
| @ -522,8 +515,7 @@ class TextureViewRenderingTest : public DawnTest { | |||||||
| 
 | 
 | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         { |         { | ||||||
|             dawn::RenderPassEncoder pass = |             dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPassInfo); | ||||||
|                 encoder.BeginRenderPass(renderPassInfo); |  | ||||||
|             pass.SetPipeline(oneColorPipeline); |             pass.SetPipeline(oneColorPipeline); | ||||||
|             pass.Draw(6, 1, 0, 0); |             pass.Draw(6, 1, 0, 0); | ||||||
|             pass.EndPass(); |             pass.EndPass(); | ||||||
|  | |||||||
| @ -46,7 +46,7 @@ TEST_P(ViewportOrientationTests, OriginAt0x0) { | |||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass.renderPassInfo); | ||||||
|         pass.SetPipeline(pipeline); |         pass.SetPipeline(pipeline); | ||||||
|         pass.Draw(1, 1, 0, 0); |         pass.Draw(1, 1, 0, 0); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|  | |||||||
| @ -26,12 +26,12 @@ TEST_F(CommandBufferValidationTest, Empty) { | |||||||
| 
 | 
 | ||||||
| // Test that a command buffer cannot be ended mid render pass
 | // Test that a command buffer cannot be ended mid render pass
 | ||||||
| TEST_F(CommandBufferValidationTest, EndedMidRenderPass) { | TEST_F(CommandBufferValidationTest, EndedMidRenderPass) { | ||||||
|     dawn::RenderPassDescriptor renderpass = CreateSimpleRenderPass(); |     DummyRenderPass dummyRenderPass(device); | ||||||
| 
 | 
 | ||||||
|     // Control case, command buffer ended after the pass is ended.
 |     // Control case, command buffer ended after the pass is ended.
 | ||||||
|     { |     { | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&dummyRenderPass); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|         encoder.Finish(); |         encoder.Finish(); | ||||||
|     } |     } | ||||||
| @ -39,7 +39,7 @@ TEST_F(CommandBufferValidationTest, EndedMidRenderPass) { | |||||||
|     // Error case, command buffer ended mid-pass.
 |     // Error case, command buffer ended mid-pass.
 | ||||||
|     { |     { | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&dummyRenderPass); | ||||||
|         ASSERT_DEVICE_ERROR(encoder.Finish()); |         ASSERT_DEVICE_ERROR(encoder.Finish()); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| @ -47,7 +47,7 @@ TEST_F(CommandBufferValidationTest, EndedMidRenderPass) { | |||||||
|     // should fail too.
 |     // should fail too.
 | ||||||
|     { |     { | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&dummyRenderPass); | ||||||
|         ASSERT_DEVICE_ERROR(encoder.Finish()); |         ASSERT_DEVICE_ERROR(encoder.Finish()); | ||||||
|         // TODO(cwallez@chromium.org) this should probably be a device error, but currently it
 |         // TODO(cwallez@chromium.org) this should probably be a device error, but currently it
 | ||||||
|         // produces a encoder error.
 |         // produces a encoder error.
 | ||||||
| @ -86,12 +86,12 @@ TEST_F(CommandBufferValidationTest, EndedMidComputePass) { | |||||||
| 
 | 
 | ||||||
| // Test that a render pass cannot be ended twice
 | // Test that a render pass cannot be ended twice
 | ||||||
| TEST_F(CommandBufferValidationTest, RenderPassEndedTwice) { | TEST_F(CommandBufferValidationTest, RenderPassEndedTwice) { | ||||||
|     dawn::RenderPassDescriptor renderpass = CreateSimpleRenderPass(); |     DummyRenderPass dummyRenderPass(device); | ||||||
| 
 | 
 | ||||||
|     // Control case, pass is ended once
 |     // Control case, pass is ended once
 | ||||||
|     { |     { | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&dummyRenderPass); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|         encoder.Finish(); |         encoder.Finish(); | ||||||
|     } |     } | ||||||
| @ -99,7 +99,7 @@ TEST_F(CommandBufferValidationTest, RenderPassEndedTwice) { | |||||||
|     // Error case, pass ended twice
 |     // Error case, pass ended twice
 | ||||||
|     { |     { | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&dummyRenderPass); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|         // TODO(cwallez@chromium.org) this should probably be a device error, but currently it
 |         // TODO(cwallez@chromium.org) this should probably be a device error, but currently it
 | ||||||
|         // produces a encoder error.
 |         // produces a encoder error.
 | ||||||
| @ -141,8 +141,8 @@ TEST_F(CommandBufferValidationTest, BufferWithMultipleReadUsage) { | |||||||
|     // Use the buffer as both index and vertex in the same pass
 |     // Use the buffer as both index and vertex in the same pass
 | ||||||
|     uint32_t zero = 0; |     uint32_t zero = 0; | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     auto renderpass = CreateSimpleRenderPass(); |     DummyRenderPass dummyRenderPass(device); | ||||||
|     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpass); |     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&dummyRenderPass); | ||||||
|     pass.SetIndexBuffer(buffer, 0); |     pass.SetIndexBuffer(buffer, 0); | ||||||
|     pass.SetVertexBuffers(0, 1, &buffer, &zero); |     pass.SetVertexBuffers(0, 1, &buffer, &zero); | ||||||
|     pass.EndPass(); |     pass.EndPass(); | ||||||
| @ -165,8 +165,8 @@ TEST_F(CommandBufferValidationTest, BufferWithReadAndWriteUsage) { | |||||||
| 
 | 
 | ||||||
|     // Use the buffer as both index and storage in the same pass
 |     // Use the buffer as both index and storage in the same pass
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     auto renderpass = CreateSimpleRenderPass(); |     DummyRenderPass dummyRenderPass(device); | ||||||
|     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpass); |     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&dummyRenderPass); | ||||||
|     pass.SetIndexBuffer(buffer, 0); |     pass.SetIndexBuffer(buffer, 0); | ||||||
|     pass.SetBindGroup(0, bg); |     pass.SetBindGroup(0, bg); | ||||||
|     pass.EndPass(); |     pass.EndPass(); | ||||||
| @ -194,19 +194,11 @@ TEST_F(CommandBufferValidationTest, TextureWithReadAndWriteUsage) { | |||||||
|     dawn::BindGroup bg = utils::MakeBindGroup(device, bgl, {{0, view}}); |     dawn::BindGroup bg = utils::MakeBindGroup(device, bgl, {{0, view}}); | ||||||
| 
 | 
 | ||||||
|     // Create the render pass that will use the texture as an output attachment
 |     // Create the render pass that will use the texture as an output attachment
 | ||||||
|     dawn::RenderPassColorAttachmentDescriptor colorAttachment; |     utils::ComboRenderPassDescriptor renderPass({view}); | ||||||
|     colorAttachment.attachment = view; |  | ||||||
|     colorAttachment.resolveTarget = nullptr; |  | ||||||
|     colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|     colorAttachment.loadOp = dawn::LoadOp::Load; |  | ||||||
|     colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
|     dawn::RenderPassDescriptor renderPass = device.CreateRenderPassDescriptorBuilder() |  | ||||||
|         .SetColorAttachments(1, &colorAttachment) |  | ||||||
|         .GetResult(); |  | ||||||
| 
 | 
 | ||||||
|     // Use the texture as both sampeld and output attachment in the same pass
 |     // Use the texture as both sampeld and output attachment in the same pass
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass); |     dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|     pass.SetBindGroup(0, bg); |     pass.SetBindGroup(0, bg); | ||||||
|     pass.EndPass(); |     pass.EndPass(); | ||||||
|     ASSERT_DEVICE_ERROR(encoder.Finish()); |     ASSERT_DEVICE_ERROR(encoder.Finish()); | ||||||
|  | |||||||
| @ -20,11 +20,11 @@ class DebugMarkerValidationTest : public ValidationTest {}; | |||||||
| 
 | 
 | ||||||
| // Correct usage of debug markers should succeed in render pass.
 | // Correct usage of debug markers should succeed in render pass.
 | ||||||
| TEST_F(DebugMarkerValidationTest, RenderSuccess) { | TEST_F(DebugMarkerValidationTest, RenderSuccess) { | ||||||
|     utils::BasicRenderPass renderPass = utils::CreateBasicRenderPass(device, 4, 4); |     DummyRenderPass renderPass(device); | ||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.PushDebugGroup("Event Start"); |         pass.PushDebugGroup("Event Start"); | ||||||
|         pass.PushDebugGroup("Event Start"); |         pass.PushDebugGroup("Event Start"); | ||||||
|         pass.InsertDebugMarker("Marker"); |         pass.InsertDebugMarker("Marker"); | ||||||
| @ -38,11 +38,11 @@ TEST_F(DebugMarkerValidationTest, RenderSuccess) { | |||||||
| 
 | 
 | ||||||
| // A PushDebugGroup call without a following PopDebugGroup produces an error in render pass.
 | // A PushDebugGroup call without a following PopDebugGroup produces an error in render pass.
 | ||||||
| TEST_F(DebugMarkerValidationTest, RenderUnbalancedPush) { | TEST_F(DebugMarkerValidationTest, RenderUnbalancedPush) { | ||||||
|     utils::BasicRenderPass renderPass = utils::CreateBasicRenderPass(device, 4, 4); |     DummyRenderPass renderPass(device); | ||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.PushDebugGroup("Event Start"); |         pass.PushDebugGroup("Event Start"); | ||||||
|         pass.PushDebugGroup("Event Start"); |         pass.PushDebugGroup("Event Start"); | ||||||
|         pass.InsertDebugMarker("Marker"); |         pass.InsertDebugMarker("Marker"); | ||||||
| @ -55,11 +55,11 @@ TEST_F(DebugMarkerValidationTest, RenderUnbalancedPush) { | |||||||
| 
 | 
 | ||||||
| // A PopDebugGroup call without a preceding PushDebugGroup produces an error in render pass.
 | // A PopDebugGroup call without a preceding PushDebugGroup produces an error in render pass.
 | ||||||
| TEST_F(DebugMarkerValidationTest, RenderUnbalancedPop) { | TEST_F(DebugMarkerValidationTest, RenderUnbalancedPop) { | ||||||
|     utils::BasicRenderPass renderPass = utils::CreateBasicRenderPass(device, 4, 4); |     DummyRenderPass renderPass(device); | ||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPassInfo); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.PushDebugGroup("Event Start"); |         pass.PushDebugGroup("Event Start"); | ||||||
|         pass.InsertDebugMarker("Marker"); |         pass.InsertDebugMarker("Marker"); | ||||||
|         pass.PopDebugGroup(); |         pass.PopDebugGroup(); | ||||||
|  | |||||||
| @ -19,11 +19,11 @@ class SetScissorRectTest : public ValidationTest { | |||||||
| 
 | 
 | ||||||
| // Test to check basic use of SetScissor
 | // Test to check basic use of SetScissor
 | ||||||
| TEST_F(SetScissorRectTest, Success) { | TEST_F(SetScissorRectTest, Success) { | ||||||
|     DummyRenderPass renderPass = CreateDummyRenderPass(); |     DummyRenderPass renderPass(device); | ||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.SetScissorRect(0, 0, 1, 1); |         pass.SetScissorRect(0, 0, 1, 1); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|     } |     } | ||||||
| @ -32,11 +32,11 @@ TEST_F(SetScissorRectTest, Success) { | |||||||
| 
 | 
 | ||||||
| // Test to check that an empty scissor is allowed
 | // Test to check that an empty scissor is allowed
 | ||||||
| TEST_F(SetScissorRectTest, EmptyScissor) { | TEST_F(SetScissorRectTest, EmptyScissor) { | ||||||
|     DummyRenderPass renderPass = CreateDummyRenderPass(); |     DummyRenderPass renderPass(device); | ||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.SetScissorRect(0, 0, 0, 0); |         pass.SetScissorRect(0, 0, 0, 0); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|     } |     } | ||||||
| @ -47,11 +47,11 @@ TEST_F(SetScissorRectTest, EmptyScissor) { | |||||||
| // TODO(cwallez@chromium.org): scissor values seem to be integers in all APIs do the same
 | // TODO(cwallez@chromium.org): scissor values seem to be integers in all APIs do the same
 | ||||||
| // and test negative values?
 | // and test negative values?
 | ||||||
| TEST_F(SetScissorRectTest, ScissorLargerThanFramebuffer) { | TEST_F(SetScissorRectTest, ScissorLargerThanFramebuffer) { | ||||||
|     DummyRenderPass renderPass = CreateDummyRenderPass(); |     DummyRenderPass renderPass(device); | ||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.SetScissorRect(0, 0, renderPass.width + 1, renderPass.height + 1); |         pass.SetScissorRect(0, 0, renderPass.width + 1, renderPass.height + 1); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|     } |     } | ||||||
| @ -63,11 +63,11 @@ class SetBlendColorTest : public ValidationTest { | |||||||
| 
 | 
 | ||||||
| // Test to check basic use of SetBlendColor
 | // Test to check basic use of SetBlendColor
 | ||||||
| TEST_F(SetBlendColorTest, Success) { | TEST_F(SetBlendColorTest, Success) { | ||||||
|     DummyRenderPass renderPass = CreateDummyRenderPass(); |     DummyRenderPass renderPass(device); | ||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         constexpr dawn::Color kTransparentBlack{0.0f, 0.0f, 0.0f, 0.0f}; |         constexpr dawn::Color kTransparentBlack{0.0f, 0.0f, 0.0f, 0.0f}; | ||||||
|         pass.SetBlendColor(&kTransparentBlack); |         pass.SetBlendColor(&kTransparentBlack); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
| @ -77,11 +77,11 @@ TEST_F(SetBlendColorTest, Success) { | |||||||
| 
 | 
 | ||||||
| // Test that SetBlendColor allows any value, large, small or negative
 | // Test that SetBlendColor allows any value, large, small or negative
 | ||||||
| TEST_F(SetBlendColorTest, AnyValueAllowed) { | TEST_F(SetBlendColorTest, AnyValueAllowed) { | ||||||
|     DummyRenderPass renderPass = CreateDummyRenderPass(); |     DummyRenderPass renderPass(device); | ||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         constexpr dawn::Color kAnyColorValue{-1.0f, 42.0f, -0.0f, 0.0f}; |         constexpr dawn::Color kAnyColorValue{-1.0f, 42.0f, -0.0f, 0.0f}; | ||||||
|         pass.SetBlendColor(&kAnyColorValue); |         pass.SetBlendColor(&kAnyColorValue); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
| @ -94,11 +94,11 @@ class SetStencilReferenceTest : public ValidationTest { | |||||||
| 
 | 
 | ||||||
| // Test to check basic use of SetStencilReferenceTest
 | // Test to check basic use of SetStencilReferenceTest
 | ||||||
| TEST_F(SetStencilReferenceTest, Success) { | TEST_F(SetStencilReferenceTest, Success) { | ||||||
|     DummyRenderPass renderPass = CreateDummyRenderPass(); |     DummyRenderPass renderPass(device); | ||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.SetStencilReference(0); |         pass.SetStencilReference(0); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|     } |     } | ||||||
| @ -107,11 +107,11 @@ TEST_F(SetStencilReferenceTest, Success) { | |||||||
| 
 | 
 | ||||||
| // Test that SetStencilReference allows any bit to be set
 | // Test that SetStencilReference allows any bit to be set
 | ||||||
| TEST_F(SetStencilReferenceTest, AllBitsAllowed) { | TEST_F(SetStencilReferenceTest, AllBitsAllowed) { | ||||||
|     DummyRenderPass renderPass = CreateDummyRenderPass(); |     DummyRenderPass renderPass(device); | ||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderPass.renderPass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.SetStencilReference(0xFFFFFFFF); |         pass.SetStencilReference(0xFFFFFFFF); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -44,7 +44,7 @@ class PushConstantTest : public ValidationTest { | |||||||
| 
 | 
 | ||||||
| // Test valid usage of the parameters to SetPushConstants
 | // Test valid usage of the parameters to SetPushConstants
 | ||||||
| TEST_F(PushConstantTest, Success) { | TEST_F(PushConstantTest, Success) { | ||||||
|     DummyRenderPass renderpassData = CreateDummyRenderPass(); |     DummyRenderPass renderpassData(device); | ||||||
| 
 | 
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     // PushConstants in a compute pass
 |     // PushConstants in a compute pass
 | ||||||
| @ -56,7 +56,7 @@ TEST_F(PushConstantTest, Success) { | |||||||
| 
 | 
 | ||||||
|     // PushConstants in a render pass
 |     // PushConstants in a render pass
 | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpassData.renderPass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderpassData); | ||||||
|         pass.SetPushConstants(dawn::ShaderStageBit::Vertex | dawn::ShaderStageBit::Fragment, 0, 1, constants); |         pass.SetPushConstants(dawn::ShaderStageBit::Vertex | dawn::ShaderStageBit::Fragment, 0, 1, constants); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|     } |     } | ||||||
| @ -142,12 +142,12 @@ TEST_F(PushConstantTest, StageForComputePass) { | |||||||
| 
 | 
 | ||||||
| // Test valid stages for render passes
 | // Test valid stages for render passes
 | ||||||
| TEST_F(PushConstantTest, StageForRenderPass) { | TEST_F(PushConstantTest, StageForRenderPass) { | ||||||
|     DummyRenderPass renderpassData = CreateDummyRenderPass(); |     DummyRenderPass renderpassData(device); | ||||||
| 
 | 
 | ||||||
|     // Control case: setting to vertex and fragment in render pass
 |     // Control case: setting to vertex and fragment in render pass
 | ||||||
|     { |     { | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpassData.renderPass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderpassData); | ||||||
|         pass.SetPushConstants(dawn::ShaderStageBit::Vertex | dawn::ShaderStageBit::Fragment, 0, 1, constants); |         pass.SetPushConstants(dawn::ShaderStageBit::Vertex | dawn::ShaderStageBit::Fragment, 0, 1, constants); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|         encoder.Finish(); |         encoder.Finish(); | ||||||
| @ -156,7 +156,7 @@ TEST_F(PushConstantTest, StageForRenderPass) { | |||||||
|     // Compute stage is disallowed
 |     // Compute stage is disallowed
 | ||||||
|     { |     { | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpassData.renderPass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderpassData); | ||||||
|         pass.SetPushConstants(dawn::ShaderStageBit::Compute, 0, 1, constants); |         pass.SetPushConstants(dawn::ShaderStageBit::Compute, 0, 1, constants); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|         ASSERT_DEVICE_ERROR(encoder.Finish()); |         ASSERT_DEVICE_ERROR(encoder.Finish()); | ||||||
| @ -165,7 +165,7 @@ TEST_F(PushConstantTest, StageForRenderPass) { | |||||||
|     // A None shader stage mask is valid.
 |     // A None shader stage mask is valid.
 | ||||||
|     { |     { | ||||||
|         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |         dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpassData.renderPass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderpassData); | ||||||
|         pass.SetPushConstants(dawn::ShaderStageBit::None, 0, 1, constants); |         pass.SetPushConstants(dawn::ShaderStageBit::None, 0, 1, constants); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|         encoder.Finish(); |         encoder.Finish(); | ||||||
|  | |||||||
| @ -16,9 +16,28 @@ | |||||||
| 
 | 
 | ||||||
| #include "common/Constants.h" | #include "common/Constants.h" | ||||||
| 
 | 
 | ||||||
|  | #include "utils/DawnHelpers.h" | ||||||
|  | 
 | ||||||
| namespace { | namespace { | ||||||
| 
 | 
 | ||||||
| class RenderPassDescriptorValidationTest : public ValidationTest { | class RenderPassDescriptorValidationTest : public ValidationTest { | ||||||
|  |   public: | ||||||
|  |     void AssertBeginRenderPassSuccess(const dawn::RenderPassDescriptor* descriptor) { | ||||||
|  |         dawn::CommandEncoder commandEncoder = TestBeginRenderPass(descriptor); | ||||||
|  |         commandEncoder.Finish(); | ||||||
|  |     } | ||||||
|  |     void AssertBeginRenderPassError(const dawn::RenderPassDescriptor* descriptor) { | ||||||
|  |         dawn::CommandEncoder commandEncoder = TestBeginRenderPass(descriptor); | ||||||
|  |         ASSERT_DEVICE_ERROR(commandEncoder.Finish()); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |   private: | ||||||
|  |     dawn::CommandEncoder TestBeginRenderPass(const dawn::RenderPassDescriptor* descriptor) { | ||||||
|  |         dawn::CommandEncoder commandEncoder = device.CreateCommandEncoder(); | ||||||
|  |         dawn::RenderPassEncoder renderPassEncoder = commandEncoder.BeginRenderPass(descriptor); | ||||||
|  |         renderPassEncoder.EndPass(); | ||||||
|  |         return commandEncoder; | ||||||
|  |     } | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| dawn::Texture CreateTexture(dawn::Device& device, | dawn::Texture CreateTexture(dawn::Device& device, | ||||||
| @ -51,10 +70,10 @@ dawn::TextureView Create2DAttachment(dawn::Device& device, | |||||||
|     return texture.CreateDefaultTextureView(); |     return texture.CreateDefaultTextureView(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // A render pass with no attachments isn't valid
 | // Using BeginRenderPass with no attachments isn't valid
 | ||||||
| TEST_F(RenderPassDescriptorValidationTest, Empty) { | TEST_F(RenderPassDescriptorValidationTest, Empty) {   | ||||||
|     AssertWillBeError(device.CreateRenderPassDescriptorBuilder()) |     utils::ComboRenderPassDescriptor renderPass({}, nullptr); | ||||||
|         .GetResult(); |     AssertBeginRenderPassError(&renderPass); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // A render pass with only one color or one depth attachment is ok
 | // A render pass with only one color or one depth attachment is ok
 | ||||||
| @ -62,60 +81,67 @@ TEST_F(RenderPassDescriptorValidationTest, OneAttachment) { | |||||||
|     // One color attachment
 |     // One color attachment
 | ||||||
|     { |     { | ||||||
|         dawn::TextureView color = Create2DAttachment(device, 1, 1, dawn::TextureFormat::R8G8B8A8Unorm); |         dawn::TextureView color = Create2DAttachment(device, 1, 1, dawn::TextureFormat::R8G8B8A8Unorm); | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachment; |         utils::ComboRenderPassDescriptor renderPass({color}); | ||||||
|         colorAttachment.attachment = color; | 
 | ||||||
|         colorAttachment.resolveTarget = nullptr; |         AssertBeginRenderPassSuccess(&renderPass); | ||||||
|         colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|         colorAttachment.loadOp = dawn::LoadOp::Clear; |  | ||||||
|         colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
|         AssertWillBeSuccess(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetColorAttachments(1, &colorAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
|     // One depth-stencil attachment
 |     // One depth-stencil attachment
 | ||||||
|     { |     { | ||||||
|         dawn::TextureView depthStencil = Create2DAttachment(device, 1, 1, dawn::TextureFormat::D32FloatS8Uint); |         dawn::TextureView depthStencil = Create2DAttachment(device, 1, 1, dawn::TextureFormat::D32FloatS8Uint); | ||||||
|         dawn::RenderPassDepthStencilAttachmentDescriptor depthStencilAttachment; |         utils::ComboRenderPassDescriptor renderPass({}, depthStencil); | ||||||
|         depthStencilAttachment.attachment = depthStencil; | 
 | ||||||
|         depthStencilAttachment.depthLoadOp = dawn::LoadOp::Clear; |         AssertBeginRenderPassSuccess(&renderPass); | ||||||
|         depthStencilAttachment.stencilLoadOp = dawn::LoadOp::Clear; |  | ||||||
|         depthStencilAttachment.clearDepth = 1.0f; |  | ||||||
|         depthStencilAttachment.clearStencil = 0; |  | ||||||
|         depthStencilAttachment.depthStoreOp = dawn::StoreOp::Store; |  | ||||||
|         depthStencilAttachment.stencilStoreOp = dawn::StoreOp::Store; |  | ||||||
|         AssertWillBeSuccess(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetDepthStencilAttachment(&depthStencilAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // Test OOB color attachment indices are handled
 | // Test OOB color attachment indices are handled
 | ||||||
| TEST_F(RenderPassDescriptorValidationTest, ColorAttachmentOutOfBounds) { | TEST_F(RenderPassDescriptorValidationTest, ColorAttachmentOutOfBounds) { | ||||||
|  |     dawn::TextureView color1 = Create2DAttachment(device, 1, 1, | ||||||
|  |                                                   dawn::TextureFormat::R8G8B8A8Unorm); | ||||||
|  |     dawn::TextureView color2 = Create2DAttachment(device, 1, 1, | ||||||
|  |                                                   dawn::TextureFormat::R8G8B8A8Unorm); | ||||||
|  |     dawn::TextureView color3 = Create2DAttachment(device, 1, 1, | ||||||
|  |                                                   dawn::TextureFormat::R8G8B8A8Unorm); | ||||||
|  |     dawn::TextureView color4 = Create2DAttachment(device, 1, 1, | ||||||
|  |                                                   dawn::TextureFormat::R8G8B8A8Unorm); | ||||||
|     // For setting the color attachment, control case
 |     // For setting the color attachment, control case
 | ||||||
|     { |     { | ||||||
|         dawn::TextureView color = Create2DAttachment(device, 1, 1, dawn::TextureFormat::R8G8B8A8Unorm); |         utils::ComboRenderPassDescriptor renderPass({color1, color2, color3, color4}); | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachments[kMaxColorAttachments]; |         AssertBeginRenderPassSuccess(&renderPass); | ||||||
|         colorAttachments[kMaxColorAttachments - 1].attachment = color; |  | ||||||
|         colorAttachments[kMaxColorAttachments - 1].resolveTarget = nullptr; |  | ||||||
|         colorAttachments[kMaxColorAttachments - 1].clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|         colorAttachments[kMaxColorAttachments - 1].loadOp = dawn::LoadOp::Clear; |  | ||||||
|         colorAttachments[kMaxColorAttachments - 1].storeOp = dawn::StoreOp::Store; |  | ||||||
|         AssertWillBeSuccess(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetColorAttachments(kMaxColorAttachments, colorAttachments) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
|     // For setting the color attachment, OOB
 |     // For setting the color attachment, OOB
 | ||||||
|     { |     { | ||||||
|         dawn::TextureView color = Create2DAttachment(device, 1, 1, dawn::TextureFormat::R8G8B8A8Unorm); |         // We cannot use utils::ComboRenderPassDescriptor here because it only supports at most
 | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachments[kMaxColorAttachments + 1]; |         // kMaxColorAttachments(4) color attachments.
 | ||||||
|         colorAttachments[kMaxColorAttachments].attachment = color; |         dawn::RenderPassColorAttachmentDescriptor colorAttachment1; | ||||||
|         colorAttachments[kMaxColorAttachments].resolveTarget = nullptr; |         colorAttachment1.attachment = color1; | ||||||
|         colorAttachments[kMaxColorAttachments].clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |         colorAttachment1.resolveTarget = nullptr; | ||||||
|         colorAttachments[kMaxColorAttachments].loadOp = dawn::LoadOp::Clear; |         colorAttachment1.clearColor = {0.0f, 0.0f, 0.0f, 0.0f}; | ||||||
|         colorAttachments[kMaxColorAttachments].storeOp = dawn::StoreOp::Store; |         colorAttachment1.loadOp = dawn::LoadOp::Clear; | ||||||
|         AssertWillBeError(device.CreateRenderPassDescriptorBuilder()) |         colorAttachment1.storeOp = dawn::StoreOp::Store; | ||||||
|             .SetColorAttachments(kMaxColorAttachments + 1, colorAttachments) | 
 | ||||||
|             .GetResult(); |         dawn::RenderPassColorAttachmentDescriptor colorAttachment2 = colorAttachment1; | ||||||
|  |         dawn::RenderPassColorAttachmentDescriptor colorAttachment3 = colorAttachment1; | ||||||
|  |         dawn::RenderPassColorAttachmentDescriptor colorAttachment4 = colorAttachment1; | ||||||
|  |         colorAttachment2.attachment = color2; | ||||||
|  |         colorAttachment3.attachment = color3; | ||||||
|  |         colorAttachment4.attachment = color4; | ||||||
|  | 
 | ||||||
|  |         dawn::TextureView color5 = Create2DAttachment(device, 1, 1, | ||||||
|  |                                                       dawn::TextureFormat::R8G8B8A8Unorm); | ||||||
|  |         dawn::RenderPassColorAttachmentDescriptor colorAttachment5 = colorAttachment1; | ||||||
|  |         colorAttachment5.attachment = color5; | ||||||
|  | 
 | ||||||
|  |         dawn::RenderPassColorAttachmentDescriptor* colorAttachments[] = {&colorAttachment1, | ||||||
|  |                                                                          &colorAttachment2, | ||||||
|  |                                                                          &colorAttachment3, | ||||||
|  |                                                                          &colorAttachment4, | ||||||
|  |                                                                          &colorAttachment5}; | ||||||
|  |         dawn::RenderPassDescriptor renderPass; | ||||||
|  |         renderPass.colorAttachmentCount = kMaxColorAttachments + 1; | ||||||
|  |         renderPass.colorAttachments = colorAttachments; | ||||||
|  |         renderPass.depthStencilAttachment = nullptr; | ||||||
|  |         AssertBeginRenderPassError(&renderPass); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -125,82 +151,25 @@ TEST_F(RenderPassDescriptorValidationTest, SizeMustMatch) { | |||||||
|     dawn::TextureView color1x1B = Create2DAttachment(device, 1, 1, dawn::TextureFormat::R8G8B8A8Unorm); |     dawn::TextureView color1x1B = Create2DAttachment(device, 1, 1, dawn::TextureFormat::R8G8B8A8Unorm); | ||||||
|     dawn::TextureView color2x2 = Create2DAttachment(device, 2, 2, dawn::TextureFormat::R8G8B8A8Unorm); |     dawn::TextureView color2x2 = Create2DAttachment(device, 2, 2, dawn::TextureFormat::R8G8B8A8Unorm); | ||||||
| 
 | 
 | ||||||
|     dawn::RenderPassColorAttachmentDescriptor colorAttachment1x1A; |  | ||||||
|     colorAttachment1x1A.attachment = color1x1A; |  | ||||||
|     colorAttachment1x1A.resolveTarget = nullptr; |  | ||||||
|     colorAttachment1x1A.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|     colorAttachment1x1A.loadOp = dawn::LoadOp::Clear; |  | ||||||
|     colorAttachment1x1A.storeOp = dawn::StoreOp::Store; |  | ||||||
| 
 |  | ||||||
|     dawn::RenderPassColorAttachmentDescriptor colorAttachment1x1B; |  | ||||||
|     colorAttachment1x1B.attachment = color1x1B; |  | ||||||
|     colorAttachment1x1B.resolveTarget = nullptr; |  | ||||||
|     colorAttachment1x1B.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|     colorAttachment1x1B.loadOp = dawn::LoadOp::Clear; |  | ||||||
|     colorAttachment1x1B.storeOp = dawn::StoreOp::Store; |  | ||||||
| 
 |  | ||||||
|     dawn::RenderPassColorAttachmentDescriptor colorAttachment2x2; |  | ||||||
|     colorAttachment2x2.attachment = color2x2; |  | ||||||
|     colorAttachment2x2.resolveTarget = nullptr; |  | ||||||
|     colorAttachment2x2.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|     colorAttachment2x2.loadOp = dawn::LoadOp::Clear; |  | ||||||
|     colorAttachment2x2.storeOp = dawn::StoreOp::Store; |  | ||||||
| 
 |  | ||||||
|     dawn::TextureView depthStencil1x1 = Create2DAttachment(device, 1, 1, dawn::TextureFormat::D32FloatS8Uint); |     dawn::TextureView depthStencil1x1 = Create2DAttachment(device, 1, 1, dawn::TextureFormat::D32FloatS8Uint); | ||||||
|     dawn::TextureView depthStencil2x2 = Create2DAttachment(device, 2, 2, dawn::TextureFormat::D32FloatS8Uint); |     dawn::TextureView depthStencil2x2 = Create2DAttachment(device, 2, 2, dawn::TextureFormat::D32FloatS8Uint); | ||||||
| 
 | 
 | ||||||
|     dawn::RenderPassDepthStencilAttachmentDescriptor depthStencilAttachment1x1; |  | ||||||
|     depthStencilAttachment1x1.attachment = depthStencil1x1; |  | ||||||
|     depthStencilAttachment1x1.depthLoadOp = dawn::LoadOp::Clear; |  | ||||||
|     depthStencilAttachment1x1.stencilLoadOp = dawn::LoadOp::Clear; |  | ||||||
|     depthStencilAttachment1x1.clearDepth = 1.0f; |  | ||||||
|     depthStencilAttachment1x1.clearStencil = 0; |  | ||||||
|     depthStencilAttachment1x1.depthStoreOp = dawn::StoreOp::Store; |  | ||||||
|     depthStencilAttachment1x1.stencilStoreOp = dawn::StoreOp::Store; |  | ||||||
| 
 |  | ||||||
|     dawn::RenderPassDepthStencilAttachmentDescriptor depthStencilAttachment2x2; |  | ||||||
|     depthStencilAttachment2x2.attachment = depthStencil2x2; |  | ||||||
|     depthStencilAttachment2x2.depthLoadOp = dawn::LoadOp::Clear; |  | ||||||
|     depthStencilAttachment2x2.stencilLoadOp = dawn::LoadOp::Clear; |  | ||||||
|     depthStencilAttachment2x2.clearDepth = 1.0f; |  | ||||||
|     depthStencilAttachment2x2.clearStencil = 0; |  | ||||||
|     depthStencilAttachment2x2.depthStoreOp = dawn::StoreOp::Store; |  | ||||||
|     depthStencilAttachment2x2.stencilStoreOp = dawn::StoreOp::Store; |  | ||||||
| 
 |  | ||||||
|     // Control case: all the same size (1x1)
 |     // Control case: all the same size (1x1)
 | ||||||
|     { |     { | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachments[2]; |         utils::ComboRenderPassDescriptor renderPass({color1x1A, color1x1B}, depthStencil1x1); | ||||||
|         colorAttachments[0] = colorAttachment1x1A; |         AssertBeginRenderPassSuccess(&renderPass); | ||||||
|         colorAttachments[1] = colorAttachment1x1B; |  | ||||||
| 
 |  | ||||||
|         AssertWillBeSuccess(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetColorAttachments(2, colorAttachments) |  | ||||||
|             .SetDepthStencilAttachment(&depthStencilAttachment1x1) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // One of the color attachments has a different size
 |     // One of the color attachments has a different size
 | ||||||
|     { |     { | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachments[2]; |         utils::ComboRenderPassDescriptor renderPass({color1x1A, color2x2}); | ||||||
|         colorAttachments[0] = colorAttachment1x1A; |         AssertBeginRenderPassError(&renderPass); | ||||||
|         colorAttachments[1] = colorAttachment2x2; |  | ||||||
| 
 |  | ||||||
|         AssertWillBeError(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetColorAttachments(2, colorAttachments) |  | ||||||
|             .SetDepthStencilAttachment(&depthStencilAttachment1x1) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // The depth stencil attachment has a different size
 |     // The depth stencil attachment has a different size
 | ||||||
|     { |     { | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachments[2]; |         utils::ComboRenderPassDescriptor renderPass({color1x1A, color1x1B}, depthStencil2x2); | ||||||
|         colorAttachments[0] = colorAttachment1x1A; |         AssertBeginRenderPassError(&renderPass); | ||||||
|         colorAttachments[1] = colorAttachment1x1B; |  | ||||||
| 
 |  | ||||||
|         AssertWillBeError(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetColorAttachments(2, colorAttachments) |  | ||||||
|             .SetDepthStencilAttachment(&depthStencilAttachment2x2) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -211,31 +180,14 @@ TEST_F(RenderPassDescriptorValidationTest, FormatMismatch) { | |||||||
| 
 | 
 | ||||||
|     // Using depth-stencil for color
 |     // Using depth-stencil for color
 | ||||||
|     { |     { | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachment; |         utils::ComboRenderPassDescriptor renderPass({depthStencil}); | ||||||
|         colorAttachment.attachment = depthStencil; |         AssertBeginRenderPassError(&renderPass); | ||||||
|         colorAttachment.resolveTarget = nullptr; |  | ||||||
|         colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|         colorAttachment.loadOp = dawn::LoadOp::Clear; |  | ||||||
|         colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
| 
 |  | ||||||
|         AssertWillBeError(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetColorAttachments(1, &colorAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Using color for depth-stencil
 |     // Using color for depth-stencil
 | ||||||
|     { |     { | ||||||
|         dawn::RenderPassDepthStencilAttachmentDescriptor depthStencilAttachment; |         utils::ComboRenderPassDescriptor renderPass({}, color); | ||||||
|         depthStencilAttachment.attachment = color; |         AssertBeginRenderPassError(&renderPass); | ||||||
|         depthStencilAttachment.depthLoadOp = dawn::LoadOp::Clear; |  | ||||||
|         depthStencilAttachment.stencilLoadOp = dawn::LoadOp::Clear; |  | ||||||
|         depthStencilAttachment.clearDepth = 1.0f; |  | ||||||
|         depthStencilAttachment.clearStencil = 0; |  | ||||||
|         depthStencilAttachment.depthStoreOp = dawn::StoreOp::Store; |  | ||||||
|         depthStencilAttachment.stencilStoreOp = dawn::StoreOp::Store; |  | ||||||
|         AssertWillBeError(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetDepthStencilAttachment(&depthStencilAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -269,16 +221,8 @@ TEST_F(RenderPassDescriptorValidationTest, TextureViewLayerCountForColorAndDepth | |||||||
|         descriptor.arrayLayerCount = 5; |         descriptor.arrayLayerCount = 5; | ||||||
| 
 | 
 | ||||||
|         dawn::TextureView colorTextureView = colorTexture.CreateTextureView(&descriptor); |         dawn::TextureView colorTextureView = colorTexture.CreateTextureView(&descriptor); | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachment; |         utils::ComboRenderPassDescriptor renderPass({colorTextureView}); | ||||||
|         colorAttachment.attachment = colorTextureView; |         AssertBeginRenderPassError(&renderPass); | ||||||
|         colorAttachment.resolveTarget = nullptr; |  | ||||||
|         colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|         colorAttachment.loadOp = dawn::LoadOp::Clear; |  | ||||||
|         colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
| 
 |  | ||||||
|         AssertWillBeError(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetColorAttachments(1, &colorAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Using 2D array texture view with arrayLayerCount > 1 is not allowed for depth stencil
 |     // Using 2D array texture view with arrayLayerCount > 1 is not allowed for depth stencil
 | ||||||
| @ -288,17 +232,8 @@ TEST_F(RenderPassDescriptorValidationTest, TextureViewLayerCountForColorAndDepth | |||||||
|         descriptor.arrayLayerCount = 5; |         descriptor.arrayLayerCount = 5; | ||||||
| 
 | 
 | ||||||
|         dawn::TextureView depthStencilView = depthStencilTexture.CreateTextureView(&descriptor); |         dawn::TextureView depthStencilView = depthStencilTexture.CreateTextureView(&descriptor); | ||||||
|         dawn::RenderPassDepthStencilAttachmentDescriptor depthStencilAttachment; |         utils::ComboRenderPassDescriptor renderPass({}, depthStencilView); | ||||||
|         depthStencilAttachment.attachment = depthStencilView; |         AssertBeginRenderPassError(&renderPass); | ||||||
|         depthStencilAttachment.depthLoadOp = dawn::LoadOp::Clear; |  | ||||||
|         depthStencilAttachment.stencilLoadOp = dawn::LoadOp::Clear; |  | ||||||
|         depthStencilAttachment.clearDepth = 1.0f; |  | ||||||
|         depthStencilAttachment.clearStencil = 0; |  | ||||||
|         depthStencilAttachment.depthStoreOp = dawn::StoreOp::Store; |  | ||||||
|         depthStencilAttachment.stencilStoreOp = dawn::StoreOp::Store; |  | ||||||
|         AssertWillBeError(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetDepthStencilAttachment(&depthStencilAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Using 2D array texture view that covers the first layer of the texture is OK for color
 |     // Using 2D array texture view that covers the first layer of the texture is OK for color
 | ||||||
| @ -309,15 +244,8 @@ TEST_F(RenderPassDescriptorValidationTest, TextureViewLayerCountForColorAndDepth | |||||||
|         descriptor.arrayLayerCount = 1; |         descriptor.arrayLayerCount = 1; | ||||||
| 
 | 
 | ||||||
|         dawn::TextureView colorTextureView = colorTexture.CreateTextureView(&descriptor); |         dawn::TextureView colorTextureView = colorTexture.CreateTextureView(&descriptor); | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachment; |         utils::ComboRenderPassDescriptor renderPass({colorTextureView}); | ||||||
|         colorAttachment.attachment = colorTextureView; |         AssertBeginRenderPassSuccess(&renderPass); | ||||||
|         colorAttachment.resolveTarget = nullptr; |  | ||||||
|         colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|         colorAttachment.loadOp = dawn::LoadOp::Clear; |  | ||||||
|         colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
|         AssertWillBeSuccess(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetColorAttachments(1, &colorAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Using 2D array texture view that covers the first layer is OK for depth stencil
 |     // Using 2D array texture view that covers the first layer is OK for depth stencil
 | ||||||
| @ -327,19 +255,9 @@ TEST_F(RenderPassDescriptorValidationTest, TextureViewLayerCountForColorAndDepth | |||||||
|         descriptor.baseArrayLayer = 0; |         descriptor.baseArrayLayer = 0; | ||||||
|         descriptor.arrayLayerCount = 1; |         descriptor.arrayLayerCount = 1; | ||||||
| 
 | 
 | ||||||
|         dawn::TextureView depthStencilTextureView = |         dawn::TextureView depthStencilView = depthStencilTexture.CreateTextureView(&descriptor); | ||||||
|             depthStencilTexture.CreateTextureView(&descriptor); |         utils::ComboRenderPassDescriptor renderPass({}, depthStencilView); | ||||||
|         dawn::RenderPassDepthStencilAttachmentDescriptor depthStencilAttachment; |         AssertBeginRenderPassSuccess(&renderPass); | ||||||
|         depthStencilAttachment.attachment = depthStencilTextureView; |  | ||||||
|         depthStencilAttachment.depthLoadOp = dawn::LoadOp::Clear; |  | ||||||
|         depthStencilAttachment.stencilLoadOp = dawn::LoadOp::Clear; |  | ||||||
|         depthStencilAttachment.clearDepth = 1.0f; |  | ||||||
|         depthStencilAttachment.clearStencil = 0; |  | ||||||
|         depthStencilAttachment.depthStoreOp = dawn::StoreOp::Store; |  | ||||||
|         depthStencilAttachment.stencilStoreOp = dawn::StoreOp::Store; |  | ||||||
|         AssertWillBeSuccess(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetDepthStencilAttachment(&depthStencilAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Using 2D array texture view that covers the last layer is OK for color
 |     // Using 2D array texture view that covers the last layer is OK for color
 | ||||||
| @ -350,15 +268,8 @@ TEST_F(RenderPassDescriptorValidationTest, TextureViewLayerCountForColorAndDepth | |||||||
|         descriptor.arrayLayerCount = 1; |         descriptor.arrayLayerCount = 1; | ||||||
| 
 | 
 | ||||||
|         dawn::TextureView colorTextureView = colorTexture.CreateTextureView(&descriptor); |         dawn::TextureView colorTextureView = colorTexture.CreateTextureView(&descriptor); | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachment; |         utils::ComboRenderPassDescriptor renderPass({colorTextureView}); | ||||||
|         colorAttachment.attachment = colorTextureView; |         AssertBeginRenderPassSuccess(&renderPass); | ||||||
|         colorAttachment.resolveTarget = nullptr; |  | ||||||
|         colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|         colorAttachment.loadOp = dawn::LoadOp::Clear; |  | ||||||
|         colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
|         AssertWillBeSuccess(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetColorAttachments(1, &colorAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Using 2D array texture view that covers the last layer is OK for depth stencil
 |     // Using 2D array texture view that covers the last layer is OK for depth stencil
 | ||||||
| @ -368,19 +279,9 @@ TEST_F(RenderPassDescriptorValidationTest, TextureViewLayerCountForColorAndDepth | |||||||
|         descriptor.baseArrayLayer = kArrayLayers - 1; |         descriptor.baseArrayLayer = kArrayLayers - 1; | ||||||
|         descriptor.arrayLayerCount = 1; |         descriptor.arrayLayerCount = 1; | ||||||
| 
 | 
 | ||||||
|         dawn::TextureView depthStencilTextureView = |         dawn::TextureView depthStencilView = depthStencilTexture.CreateTextureView(&descriptor); | ||||||
|             depthStencilTexture.CreateTextureView(&descriptor); |         utils::ComboRenderPassDescriptor renderPass({}, depthStencilView); | ||||||
|         dawn::RenderPassDepthStencilAttachmentDescriptor depthStencilAttachment; |         AssertBeginRenderPassSuccess(&renderPass); | ||||||
|         depthStencilAttachment.attachment = depthStencilTextureView; |  | ||||||
|         depthStencilAttachment.depthLoadOp = dawn::LoadOp::Clear; |  | ||||||
|         depthStencilAttachment.stencilLoadOp = dawn::LoadOp::Clear; |  | ||||||
|         depthStencilAttachment.clearDepth = 1.0f; |  | ||||||
|         depthStencilAttachment.clearStencil = 0; |  | ||||||
|         depthStencilAttachment.depthStoreOp = dawn::StoreOp::Store; |  | ||||||
|         depthStencilAttachment.stencilStoreOp = dawn::StoreOp::Store; |  | ||||||
|         AssertWillBeSuccess(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetDepthStencilAttachment(&depthStencilAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -413,15 +314,8 @@ TEST_F(RenderPassDescriptorValidationTest, TextureViewLevelCountForColorAndDepth | |||||||
|         descriptor.mipLevelCount = 2; |         descriptor.mipLevelCount = 2; | ||||||
| 
 | 
 | ||||||
|         dawn::TextureView colorTextureView = colorTexture.CreateTextureView(&descriptor); |         dawn::TextureView colorTextureView = colorTexture.CreateTextureView(&descriptor); | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachment; |         utils::ComboRenderPassDescriptor renderPass({colorTextureView}); | ||||||
|         colorAttachment.attachment = colorTextureView; |         AssertBeginRenderPassError(&renderPass); | ||||||
|         colorAttachment.resolveTarget = nullptr; |  | ||||||
|         colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|         colorAttachment.loadOp = dawn::LoadOp::Clear; |  | ||||||
|         colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
|         AssertWillBeError(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetColorAttachments(1, &colorAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Using 2D texture view with mipLevelCount > 1 is not allowed for depth stencil
 |     // Using 2D texture view with mipLevelCount > 1 is not allowed for depth stencil
 | ||||||
| @ -431,17 +325,8 @@ TEST_F(RenderPassDescriptorValidationTest, TextureViewLevelCountForColorAndDepth | |||||||
|         descriptor.mipLevelCount = 2; |         descriptor.mipLevelCount = 2; | ||||||
| 
 | 
 | ||||||
|         dawn::TextureView depthStencilView = depthStencilTexture.CreateTextureView(&descriptor); |         dawn::TextureView depthStencilView = depthStencilTexture.CreateTextureView(&descriptor); | ||||||
|         dawn::RenderPassDepthStencilAttachmentDescriptor depthStencilAttachment; |         utils::ComboRenderPassDescriptor renderPass({}, depthStencilView); | ||||||
|         depthStencilAttachment.attachment = depthStencilView; |         AssertBeginRenderPassError(&renderPass); | ||||||
|         depthStencilAttachment.depthLoadOp = dawn::LoadOp::Clear; |  | ||||||
|         depthStencilAttachment.stencilLoadOp = dawn::LoadOp::Clear; |  | ||||||
|         depthStencilAttachment.clearDepth = 1.0f; |  | ||||||
|         depthStencilAttachment.clearStencil = 0; |  | ||||||
|         depthStencilAttachment.depthStoreOp = dawn::StoreOp::Store; |  | ||||||
|         depthStencilAttachment.stencilStoreOp = dawn::StoreOp::Store; |  | ||||||
|         AssertWillBeError(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetDepthStencilAttachment(&depthStencilAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Using 2D texture view that covers the first level of the texture is OK for color
 |     // Using 2D texture view that covers the first level of the texture is OK for color
 | ||||||
| @ -452,15 +337,8 @@ TEST_F(RenderPassDescriptorValidationTest, TextureViewLevelCountForColorAndDepth | |||||||
|         descriptor.mipLevelCount = 1; |         descriptor.mipLevelCount = 1; | ||||||
| 
 | 
 | ||||||
|         dawn::TextureView colorTextureView = colorTexture.CreateTextureView(&descriptor); |         dawn::TextureView colorTextureView = colorTexture.CreateTextureView(&descriptor); | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachment; |         utils::ComboRenderPassDescriptor renderPass({colorTextureView}); | ||||||
|         colorAttachment.attachment = colorTextureView; |         AssertBeginRenderPassSuccess(&renderPass); | ||||||
|         colorAttachment.resolveTarget = nullptr; |  | ||||||
|         colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|         colorAttachment.loadOp = dawn::LoadOp::Clear; |  | ||||||
|         colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
|         AssertWillBeSuccess(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetColorAttachments(1, &colorAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Using 2D texture view that covers the first level is OK for depth stencil
 |     // Using 2D texture view that covers the first level is OK for depth stencil
 | ||||||
| @ -470,19 +348,9 @@ TEST_F(RenderPassDescriptorValidationTest, TextureViewLevelCountForColorAndDepth | |||||||
|         descriptor.baseMipLevel = 0; |         descriptor.baseMipLevel = 0; | ||||||
|         descriptor.mipLevelCount = 1; |         descriptor.mipLevelCount = 1; | ||||||
| 
 | 
 | ||||||
|         dawn::TextureView depthStencilTextureView = |         dawn::TextureView depthStencilView = depthStencilTexture.CreateTextureView(&descriptor); | ||||||
|             depthStencilTexture.CreateTextureView(&descriptor); |         utils::ComboRenderPassDescriptor renderPass({}, depthStencilView); | ||||||
|         dawn::RenderPassDepthStencilAttachmentDescriptor depthStencilAttachment; |         AssertBeginRenderPassSuccess(&renderPass); | ||||||
|         depthStencilAttachment.attachment = depthStencilTextureView; |  | ||||||
|         depthStencilAttachment.depthLoadOp = dawn::LoadOp::Clear; |  | ||||||
|         depthStencilAttachment.stencilLoadOp = dawn::LoadOp::Clear; |  | ||||||
|         depthStencilAttachment.clearDepth = 1.0f; |  | ||||||
|         depthStencilAttachment.clearStencil = 0; |  | ||||||
|         depthStencilAttachment.depthStoreOp = dawn::StoreOp::Store; |  | ||||||
|         depthStencilAttachment.stencilStoreOp = dawn::StoreOp::Store; |  | ||||||
|         AssertWillBeSuccess(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetDepthStencilAttachment(&depthStencilAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Using 2D texture view that covers the last level is OK for color
 |     // Using 2D texture view that covers the last level is OK for color
 | ||||||
| @ -493,15 +361,8 @@ TEST_F(RenderPassDescriptorValidationTest, TextureViewLevelCountForColorAndDepth | |||||||
|         descriptor.mipLevelCount = 1; |         descriptor.mipLevelCount = 1; | ||||||
| 
 | 
 | ||||||
|         dawn::TextureView colorTextureView = colorTexture.CreateTextureView(&descriptor); |         dawn::TextureView colorTextureView = colorTexture.CreateTextureView(&descriptor); | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachment; |         utils::ComboRenderPassDescriptor renderPass({colorTextureView}); | ||||||
|         colorAttachment.attachment = colorTextureView; |         AssertBeginRenderPassSuccess(&renderPass); | ||||||
|         colorAttachment.resolveTarget = nullptr; |  | ||||||
|         colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|         colorAttachment.loadOp = dawn::LoadOp::Clear; |  | ||||||
|         colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
|         AssertWillBeSuccess(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetColorAttachments(1, &colorAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     // Using 2D texture view that covers the last level is OK for depth stencil
 |     // Using 2D texture view that covers the last level is OK for depth stencil
 | ||||||
| @ -511,19 +372,9 @@ TEST_F(RenderPassDescriptorValidationTest, TextureViewLevelCountForColorAndDepth | |||||||
|         descriptor.baseMipLevel = kLevelCount - 1; |         descriptor.baseMipLevel = kLevelCount - 1; | ||||||
|         descriptor.mipLevelCount = 1; |         descriptor.mipLevelCount = 1; | ||||||
| 
 | 
 | ||||||
|         dawn::TextureView depthStencilTextureView = |         dawn::TextureView depthStencilView = depthStencilTexture.CreateTextureView(&descriptor); | ||||||
|             depthStencilTexture.CreateTextureView(&descriptor); |         utils::ComboRenderPassDescriptor renderPass({}, depthStencilView); | ||||||
|         dawn::RenderPassDepthStencilAttachmentDescriptor depthStencilAttachment; |         AssertBeginRenderPassSuccess(&renderPass); | ||||||
|         depthStencilAttachment.attachment = depthStencilTextureView; |  | ||||||
|         depthStencilAttachment.depthLoadOp = dawn::LoadOp::Clear; |  | ||||||
|         depthStencilAttachment.stencilLoadOp = dawn::LoadOp::Clear; |  | ||||||
|         depthStencilAttachment.clearDepth = 1.0f; |  | ||||||
|         depthStencilAttachment.clearStencil = 0; |  | ||||||
|         depthStencilAttachment.depthStoreOp = dawn::StoreOp::Store; |  | ||||||
|         depthStencilAttachment.stencilStoreOp = dawn::StoreOp::Store; |  | ||||||
|         AssertWillBeSuccess(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetDepthStencilAttachment(&depthStencilAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| @ -547,15 +398,9 @@ TEST_F(RenderPassDescriptorValidationTest, ResolveTarget) { | |||||||
|         dawn::TextureView colorTextureView = colorTexture.CreateDefaultTextureView(); |         dawn::TextureView colorTextureView = colorTexture.CreateDefaultTextureView(); | ||||||
|         dawn::TextureView resolveTargetTextureView = resolveTexture.CreateDefaultTextureView(); |         dawn::TextureView resolveTargetTextureView = resolveTexture.CreateDefaultTextureView(); | ||||||
| 
 | 
 | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachment; |         utils::ComboRenderPassDescriptor renderPass({colorTextureView}); | ||||||
|         colorAttachment.attachment = colorTextureView; |         renderPass.cColorAttachmentsInfoPtr[0]->resolveTarget = resolveTargetTextureView; | ||||||
|         colorAttachment.resolveTarget = resolveTargetTextureView; |         AssertBeginRenderPassError(&renderPass); | ||||||
|         colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|         colorAttachment.loadOp = dawn::LoadOp::Clear; |  | ||||||
|         colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
|         AssertWillBeError(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|             .SetColorAttachments(1, &colorAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -84,31 +84,6 @@ std::string ValidationTest::GetLastDeviceErrorMessage() const { | |||||||
|     return mDeviceErrorMessage; |     return mDeviceErrorMessage; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| dawn::RenderPassDescriptor ValidationTest::CreateSimpleRenderPass() { |  | ||||||
|         dawn::TextureDescriptor descriptor; |  | ||||||
|         descriptor.dimension = dawn::TextureDimension::e2D; |  | ||||||
|         descriptor.size.width = 640; |  | ||||||
|         descriptor.size.height = 480; |  | ||||||
|         descriptor.size.depth = 1; |  | ||||||
|         descriptor.arrayLayerCount = 1; |  | ||||||
|         descriptor.sampleCount = 1; |  | ||||||
|         descriptor.format = dawn::TextureFormat::R8G8B8A8Unorm; |  | ||||||
|         descriptor.mipLevelCount = 1; |  | ||||||
|         descriptor.usage = dawn::TextureUsageBit::OutputAttachment; |  | ||||||
| 
 |  | ||||||
|         auto colorBuffer = device.CreateTexture(&descriptor); |  | ||||||
|         auto colorView = colorBuffer.CreateDefaultTextureView(); |  | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachment; |  | ||||||
|         colorAttachment.attachment = colorView; |  | ||||||
|         colorAttachment.resolveTarget = nullptr; |  | ||||||
|         colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |  | ||||||
|         colorAttachment.loadOp = dawn::LoadOp::Clear; |  | ||||||
|         colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
|         return device.CreateRenderPassDescriptorBuilder() |  | ||||||
|             .SetColorAttachments(1, &colorAttachment) |  | ||||||
|             .GetResult(); |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| void ValidationTest::OnDeviceError(const char* message, dawnCallbackUserdata userdata) { | void ValidationTest::OnDeviceError(const char* message, dawnCallbackUserdata userdata) { | ||||||
|     auto self = reinterpret_cast<ValidationTest*>(static_cast<uintptr_t>(userdata)); |     auto self = reinterpret_cast<ValidationTest*>(static_cast<uintptr_t>(userdata)); | ||||||
|     self->mDeviceErrorMessage = message; |     self->mDeviceErrorMessage = message; | ||||||
| @ -138,34 +113,30 @@ void ValidationTest::OnBuilderErrorStatus(dawnBuilderErrorStatus status, const c | |||||||
|     expectation.statusMessage = message; |     expectation.statusMessage = message; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| ValidationTest::DummyRenderPass ValidationTest::CreateDummyRenderPass() { | ValidationTest::DummyRenderPass::DummyRenderPass(const dawn::Device& device) | ||||||
|     DummyRenderPass dummy; |     : attachmentFormat(dawn::TextureFormat::R8G8B8A8Unorm), width(400), height(400) { | ||||||
|     dummy.width = 400; |  | ||||||
|     dummy.height = 400; |  | ||||||
|     dummy.attachmentFormat = dawn::TextureFormat::R8G8B8A8Unorm; |  | ||||||
| 
 | 
 | ||||||
|     dawn::TextureDescriptor descriptor; |     dawn::TextureDescriptor descriptor; | ||||||
|     descriptor.dimension = dawn::TextureDimension::e2D; |     descriptor.dimension = dawn::TextureDimension::e2D; | ||||||
|     descriptor.size.width = dummy.width; |     descriptor.size.width = width; | ||||||
|     descriptor.size.height = dummy.height; |     descriptor.size.height = height; | ||||||
|     descriptor.size.depth = 1; |     descriptor.size.depth = 1; | ||||||
|     descriptor.arrayLayerCount = 1; |     descriptor.arrayLayerCount = 1; | ||||||
|     descriptor.sampleCount = 1; |     descriptor.sampleCount = 1; | ||||||
|     descriptor.format = dummy.attachmentFormat; |     descriptor.format = attachmentFormat; | ||||||
|     descriptor.mipLevelCount = 1; |     descriptor.mipLevelCount = 1; | ||||||
|     descriptor.usage = dawn::TextureUsageBit::OutputAttachment; |     descriptor.usage = dawn::TextureUsageBit::OutputAttachment; | ||||||
|     dummy.attachment = device.CreateTexture(&descriptor); |     attachment = device.CreateTexture(&descriptor); | ||||||
| 
 | 
 | ||||||
|     dawn::TextureView view = dummy.attachment.CreateDefaultTextureView(); |     dawn::TextureView view = attachment.CreateDefaultTextureView(); | ||||||
|     dawn::RenderPassColorAttachmentDescriptor colorAttachment; |     mColorAttachment.attachment = view; | ||||||
|     colorAttachment.attachment = view; |     mColorAttachment.resolveTarget = nullptr; | ||||||
|     colorAttachment.resolveTarget = nullptr; |     mColorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; | ||||||
|     colorAttachment.clearColor = { 0.0f, 0.0f, 0.0f, 0.0f }; |     mColorAttachment.loadOp = dawn::LoadOp::Clear; | ||||||
|     colorAttachment.loadOp = dawn::LoadOp::Clear; |     mColorAttachment.storeOp = dawn::StoreOp::Store; | ||||||
|     colorAttachment.storeOp = dawn::StoreOp::Store; |     mColorAttachments[0] = &mColorAttachment; | ||||||
|     dummy.renderPass = AssertWillBeSuccess(device.CreateRenderPassDescriptorBuilder()) |  | ||||||
|         .SetColorAttachments(1, &colorAttachment) |  | ||||||
|         .GetResult(); |  | ||||||
| 
 | 
 | ||||||
|     return dummy; |     colorAttachmentCount = 1; | ||||||
|  |     colorAttachments = mColorAttachments; | ||||||
|  |     depthStencilAttachment = nullptr; | ||||||
| } | } | ||||||
|  | |||||||
| @ -53,18 +53,20 @@ class ValidationTest : public testing::Test { | |||||||
|         bool EndExpectDeviceError(); |         bool EndExpectDeviceError(); | ||||||
|         std::string GetLastDeviceErrorMessage() const; |         std::string GetLastDeviceErrorMessage() const; | ||||||
| 
 | 
 | ||||||
|         dawn::RenderPassDescriptor CreateSimpleRenderPass(); |  | ||||||
| 
 |  | ||||||
|         // Helper functions to create objects to test validation.
 |         // Helper functions to create objects to test validation.
 | ||||||
| 
 | 
 | ||||||
|         struct DummyRenderPass { |         struct DummyRenderPass : public dawn::RenderPassDescriptor{ | ||||||
|             dawn::RenderPassDescriptor renderPass; |           public: | ||||||
|  |             DummyRenderPass(const dawn::Device& device); | ||||||
|             dawn::Texture attachment; |             dawn::Texture attachment; | ||||||
|             dawn::TextureFormat attachmentFormat; |             dawn::TextureFormat attachmentFormat; | ||||||
|             uint32_t width; |             uint32_t width; | ||||||
|             uint32_t height; |             uint32_t height; | ||||||
|  | 
 | ||||||
|  |           private: | ||||||
|  |             dawn::RenderPassColorAttachmentDescriptor mColorAttachment; | ||||||
|  |             dawn::RenderPassColorAttachmentDescriptor* mColorAttachments[1]; | ||||||
|         }; |         }; | ||||||
|         DummyRenderPass CreateDummyRenderPass(); |  | ||||||
| 
 | 
 | ||||||
|     protected: |     protected: | ||||||
|         dawn::Device device; |         dawn::Device device; | ||||||
|  | |||||||
| @ -24,8 +24,6 @@ class VertexBufferValidationTest : public ValidationTest { | |||||||
|         void SetUp() override { |         void SetUp() override { | ||||||
|             ValidationTest::SetUp(); |             ValidationTest::SetUp(); | ||||||
| 
 | 
 | ||||||
|             renderpass = CreateSimpleRenderPass(); |  | ||||||
| 
 |  | ||||||
|             fsModule = utils::CreateShaderModule(device, dawn::ShaderStage::Fragment, R"( |             fsModule = utils::CreateShaderModule(device, dawn::ShaderStage::Fragment, R"( | ||||||
|                 #version 450 |                 #version 450 | ||||||
|                 layout(location = 0) out vec4 fragColor; |                 layout(location = 0) out vec4 fragColor; | ||||||
| @ -99,11 +97,11 @@ class VertexBufferValidationTest : public ValidationTest { | |||||||
|             return device.CreateRenderPipeline(&descriptor); |             return device.CreateRenderPipeline(&descriptor); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         dawn::RenderPassDescriptor renderpass; |  | ||||||
|         dawn::ShaderModule fsModule; |         dawn::ShaderModule fsModule; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
| TEST_F(VertexBufferValidationTest, VertexInputsInheritedBetweenPipelines) { | TEST_F(VertexBufferValidationTest, VertexInputsInheritedBetweenPipelines) { | ||||||
|  |     DummyRenderPass renderPass(device); | ||||||
|     auto vsModule2 = MakeVertexShader(2); |     auto vsModule2 = MakeVertexShader(2); | ||||||
|     auto vsModule1 = MakeVertexShader(1); |     auto vsModule1 = MakeVertexShader(1); | ||||||
| 
 | 
 | ||||||
| @ -119,7 +117,7 @@ TEST_F(VertexBufferValidationTest, VertexInputsInheritedBetweenPipelines) { | |||||||
|     // Check failure when vertex buffer is not set
 |     // Check failure when vertex buffer is not set
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.SetPipeline(pipeline1); |         pass.SetPipeline(pipeline1); | ||||||
|         pass.Draw(3, 1, 0, 0); |         pass.Draw(3, 1, 0, 0); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
| @ -129,7 +127,7 @@ TEST_F(VertexBufferValidationTest, VertexInputsInheritedBetweenPipelines) { | |||||||
|     // Check success when vertex buffer is inherited from previous pipeline
 |     // Check success when vertex buffer is inherited from previous pipeline
 | ||||||
|     encoder = device.CreateCommandEncoder(); |     encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.SetPipeline(pipeline2); |         pass.SetPipeline(pipeline2); | ||||||
|         pass.SetVertexBuffers(0, 2, vertexBuffers.data(), offsets); |         pass.SetVertexBuffers(0, 2, vertexBuffers.data(), offsets); | ||||||
|         pass.Draw(3, 1, 0, 0); |         pass.Draw(3, 1, 0, 0); | ||||||
| @ -141,6 +139,7 @@ TEST_F(VertexBufferValidationTest, VertexInputsInheritedBetweenPipelines) { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| TEST_F(VertexBufferValidationTest, VertexInputsNotInheritedBetweenRendePasses) { | TEST_F(VertexBufferValidationTest, VertexInputsNotInheritedBetweenRendePasses) { | ||||||
|  |     DummyRenderPass renderPass(device); | ||||||
|     auto vsModule2 = MakeVertexShader(2); |     auto vsModule2 = MakeVertexShader(2); | ||||||
|     auto vsModule1 = MakeVertexShader(1); |     auto vsModule1 = MakeVertexShader(1); | ||||||
| 
 | 
 | ||||||
| @ -156,14 +155,14 @@ TEST_F(VertexBufferValidationTest, VertexInputsNotInheritedBetweenRendePasses) { | |||||||
|     // Check success when vertex buffer is set for each render pass
 |     // Check success when vertex buffer is set for each render pass
 | ||||||
|     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); |     dawn::CommandEncoder encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.SetPipeline(pipeline2); |         pass.SetPipeline(pipeline2); | ||||||
|         pass.SetVertexBuffers(0, 2, vertexBuffers.data(), offsets); |         pass.SetVertexBuffers(0, 2, vertexBuffers.data(), offsets); | ||||||
|         pass.Draw(3, 1, 0, 0); |         pass.Draw(3, 1, 0, 0); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|     } |     } | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.SetPipeline(pipeline1); |         pass.SetPipeline(pipeline1); | ||||||
|         pass.SetVertexBuffers(0, 1, vertexBuffers.data(), offsets); |         pass.SetVertexBuffers(0, 1, vertexBuffers.data(), offsets); | ||||||
|         pass.Draw(3, 1, 0, 0); |         pass.Draw(3, 1, 0, 0); | ||||||
| @ -174,14 +173,14 @@ TEST_F(VertexBufferValidationTest, VertexInputsNotInheritedBetweenRendePasses) { | |||||||
|     // Check failure because vertex buffer is not inherited in second subpass
 |     // Check failure because vertex buffer is not inherited in second subpass
 | ||||||
|     encoder = device.CreateCommandEncoder(); |     encoder = device.CreateCommandEncoder(); | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.SetPipeline(pipeline2); |         pass.SetPipeline(pipeline2); | ||||||
|         pass.SetVertexBuffers(0, 2, vertexBuffers.data(), offsets); |         pass.SetVertexBuffers(0, 2, vertexBuffers.data(), offsets); | ||||||
|         pass.Draw(3, 1, 0, 0); |         pass.Draw(3, 1, 0, 0); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|     } |     } | ||||||
|     { |     { | ||||||
|         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(renderpass); |         dawn::RenderPassEncoder pass = encoder.BeginRenderPass(&renderPass); | ||||||
|         pass.SetPipeline(pipeline1); |         pass.SetPipeline(pipeline1); | ||||||
|         pass.Draw(3, 1, 0, 0); |         pass.Draw(3, 1, 0, 0); | ||||||
|         pass.EndPass(); |         pass.EndPass(); | ||||||
|  | |||||||
| @ -179,34 +179,31 @@ TEST_F(WireArgumentTests, CStringArgument) { | |||||||
|     FlushClient(); |     FlushClient(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| // Test that the wire is able to send objects as value arguments
 | // Test that the wire is able to send objects as value arguments
 | ||||||
| TEST_F(WireArgumentTests, ObjectAsValueArgument) { | TEST_F(WireArgumentTests, ObjectAsValueArgument) { | ||||||
|     // Create a RenderPassDescriptor
 |  | ||||||
|     dawnRenderPassDescriptorBuilder renderPassBuilder = |  | ||||||
|         dawnDeviceCreateRenderPassDescriptorBuilder(device); |  | ||||||
|     dawnRenderPassDescriptor renderPass = |  | ||||||
|         dawnRenderPassDescriptorBuilderGetResult(renderPassBuilder); |  | ||||||
| 
 |  | ||||||
|     dawnRenderPassDescriptorBuilder apiRenderPassBuilder = api.GetNewRenderPassDescriptorBuilder(); |  | ||||||
|     EXPECT_CALL(api, DeviceCreateRenderPassDescriptorBuilder(apiDevice)) |  | ||||||
|         .WillOnce(Return(apiRenderPassBuilder)); |  | ||||||
|     dawnRenderPassDescriptor apiRenderPass = api.GetNewRenderPassDescriptor(); |  | ||||||
|     EXPECT_CALL(api, RenderPassDescriptorBuilderGetResult(apiRenderPassBuilder)) |  | ||||||
|         .WillOnce(Return(apiRenderPass)); |  | ||||||
| 
 |  | ||||||
|     // Create command buffer encoder, setting render pass descriptor
 |  | ||||||
|     dawnCommandEncoder cmdBufEncoder = dawnDeviceCreateCommandEncoder(device); |     dawnCommandEncoder cmdBufEncoder = dawnDeviceCreateCommandEncoder(device); | ||||||
|     dawnCommandEncoderBeginRenderPass(cmdBufEncoder, renderPass); |     dawnCommandEncoder apiEncoder = api.GetNewCommandEncoder(); | ||||||
|  |     EXPECT_CALL(api, DeviceCreateCommandEncoder(apiDevice)).WillOnce(Return(apiEncoder)); | ||||||
| 
 | 
 | ||||||
|     dawnCommandEncoder apiCmdBufEncoder = api.GetNewCommandEncoder(); |     dawnBufferDescriptor descriptor; | ||||||
|     EXPECT_CALL(api, DeviceCreateCommandEncoder(apiDevice)) |     descriptor.nextInChain = nullptr; | ||||||
|         .WillOnce(Return(apiCmdBufEncoder)); |     descriptor.size = 8; | ||||||
|  |     descriptor.usage = static_cast<dawnBufferUsageBit>(DAWN_BUFFER_USAGE_BIT_TRANSFER_SRC | | ||||||
|  |                                                        DAWN_BUFFER_USAGE_BIT_TRANSFER_DST); | ||||||
| 
 | 
 | ||||||
|     EXPECT_CALL(api, CommandEncoderBeginRenderPass(apiCmdBufEncoder, apiRenderPass)).Times(1); |     dawnBuffer buffer = dawnDeviceCreateBuffer(device, &descriptor); | ||||||
|  |     dawnBuffer apiBuffer = api.GetNewBuffer(); | ||||||
|  |     EXPECT_CALL(api, DeviceCreateBuffer(apiDevice, _)) | ||||||
|  |         .WillOnce(Return(apiBuffer)) | ||||||
|  |         .RetiresOnSaturation(); | ||||||
|  | 
 | ||||||
|  |     dawnCommandEncoderCopyBufferToBuffer(cmdBufEncoder, buffer, 0, buffer, 4, 4); | ||||||
|  |     EXPECT_CALL(api, CommandEncoderCopyBufferToBuffer(apiEncoder, apiBuffer, 0, apiBuffer, 4, 4)); | ||||||
|  | 
 | ||||||
|  |     EXPECT_CALL(api, CommandEncoderRelease(apiEncoder)); | ||||||
|  |     EXPECT_CALL(api, BufferRelease(apiBuffer)); | ||||||
| 
 | 
 | ||||||
|     EXPECT_CALL(api, CommandEncoderRelease(apiCmdBufEncoder)); |  | ||||||
|     EXPECT_CALL(api, RenderPassDescriptorBuilderRelease(apiRenderPassBuilder)); |  | ||||||
|     EXPECT_CALL(api, RenderPassDescriptorRelease(apiRenderPass)); |  | ||||||
|     FlushClient(); |     FlushClient(); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -126,14 +126,97 @@ namespace utils { | |||||||
|         return buffer; |         return buffer; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     ComboRenderPassDescriptor::ComboRenderPassDescriptor( | ||||||
|  |         std::initializer_list<dawn::TextureView> colorAttachmentInfo, | ||||||
|  |         dawn::TextureView depthStencil) | ||||||
|  |         : cColorAttachmentsInfoPtr() { | ||||||
|  |         for (uint32_t i = 0; i < kMaxColorAttachments; ++i) { | ||||||
|  |             mColorAttachmentsInfo[i].loadOp = dawn::LoadOp::Clear; | ||||||
|  |             mColorAttachmentsInfo[i].storeOp = dawn::StoreOp::Store; | ||||||
|  |             mColorAttachmentsInfo[i].clearColor = {0.0f, 0.0f, 0.0f, 0.0f}; | ||||||
|  |             cColorAttachmentsInfoPtr[i] = nullptr; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         cDepthStencilAttachmentInfo.clearDepth = 1.0f; | ||||||
|  |         cDepthStencilAttachmentInfo.clearStencil = 0; | ||||||
|  |         cDepthStencilAttachmentInfo.depthLoadOp = dawn::LoadOp::Clear; | ||||||
|  |         cDepthStencilAttachmentInfo.depthStoreOp = dawn::StoreOp::Store; | ||||||
|  |         cDepthStencilAttachmentInfo.stencilLoadOp = dawn::LoadOp::Clear; | ||||||
|  |         cDepthStencilAttachmentInfo.stencilStoreOp = dawn::StoreOp::Store; | ||||||
|  | 
 | ||||||
|  |         colorAttachmentCount = static_cast<uint32_t>(colorAttachmentInfo.size()); | ||||||
|  |         uint32_t colorAttachmentIndex = 0; | ||||||
|  |         for (const dawn::TextureView& colorAttachment : colorAttachmentInfo) { | ||||||
|  |             if (colorAttachment.Get() != nullptr) { | ||||||
|  |                 mColorAttachmentsInfo[colorAttachmentIndex].attachment = colorAttachment; | ||||||
|  |                 cColorAttachmentsInfoPtr[colorAttachmentIndex] = | ||||||
|  |                     &mColorAttachmentsInfo[colorAttachmentIndex]; | ||||||
|  |             } | ||||||
|  |             ++colorAttachmentIndex; | ||||||
|  |         } | ||||||
|  |         colorAttachments = cColorAttachmentsInfoPtr; | ||||||
|  | 
 | ||||||
|  |         if (depthStencil.Get() != nullptr) { | ||||||
|  |             cDepthStencilAttachmentInfo.attachment = depthStencil; | ||||||
|  |             depthStencilAttachment = &cDepthStencilAttachmentInfo; | ||||||
|  |         } else { | ||||||
|  |             depthStencilAttachment = nullptr; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     const ComboRenderPassDescriptor& ComboRenderPassDescriptor::operator=( | ||||||
|  |         const ComboRenderPassDescriptor& otherRenderPass) { | ||||||
|  |         cDepthStencilAttachmentInfo = otherRenderPass.cDepthStencilAttachmentInfo; | ||||||
|  |         mColorAttachmentsInfo = otherRenderPass.mColorAttachmentsInfo; | ||||||
|  | 
 | ||||||
|  |         colorAttachmentCount = otherRenderPass.colorAttachmentCount; | ||||||
|  | 
 | ||||||
|  |         // Assign the pointers in colorAttachmentsInfoPtr to items in this->mColorAttachmentsInfo
 | ||||||
|  |         for (uint32_t i = 0; i < colorAttachmentCount; ++i) { | ||||||
|  |             if (otherRenderPass.cColorAttachmentsInfoPtr[i] != nullptr) { | ||||||
|  |                 cColorAttachmentsInfoPtr[i] = &mColorAttachmentsInfo[i]; | ||||||
|  |             } else { | ||||||
|  |                 cColorAttachmentsInfoPtr[i] = nullptr; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |         colorAttachments = cColorAttachmentsInfoPtr; | ||||||
|  | 
 | ||||||
|  |         if (otherRenderPass.depthStencilAttachment != nullptr) { | ||||||
|  |             // Assign desc.depthStencilAttachment to this->depthStencilAttachmentInfo;
 | ||||||
|  |             depthStencilAttachment = &cDepthStencilAttachmentInfo; | ||||||
|  |         } else { | ||||||
|  |             depthStencilAttachment = nullptr; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         return *this; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     BasicRenderPass::BasicRenderPass() | ||||||
|  |         : width(0), | ||||||
|  |           height(0), | ||||||
|  |           color(nullptr), | ||||||
|  |           colorFormat(dawn::TextureFormat::R8G8B8A8Unorm), | ||||||
|  |           renderPassInfo({}) { | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     BasicRenderPass::BasicRenderPass(uint32_t texWidth, | ||||||
|  |                                      uint32_t texHeight, | ||||||
|  |                                      dawn::Texture colorAttachment, | ||||||
|  |                                      dawn::TextureFormat textureFormat) | ||||||
|  |         : width(texWidth), | ||||||
|  |           height(texHeight), | ||||||
|  |           color(colorAttachment), | ||||||
|  |           colorFormat(textureFormat), | ||||||
|  |           renderPassInfo({colorAttachment.CreateDefaultTextureView()}) { | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     BasicRenderPass CreateBasicRenderPass(const dawn::Device& device, |     BasicRenderPass CreateBasicRenderPass(const dawn::Device& device, | ||||||
|                                           uint32_t width, |                                           uint32_t width, | ||||||
|                                           uint32_t height) { |                                           uint32_t height) { | ||||||
|         BasicRenderPass result; |         DAWN_ASSERT(width > 0 && height > 0); | ||||||
|         result.width = width; | 
 | ||||||
|         result.height = height; |         dawn::TextureFormat kColorFormat = dawn::TextureFormat::R8G8B8A8Unorm; | ||||||
| 
 | 
 | ||||||
|         result.colorFormat = dawn::TextureFormat::R8G8B8A8Unorm; |  | ||||||
|         dawn::TextureDescriptor descriptor; |         dawn::TextureDescriptor descriptor; | ||||||
|         descriptor.dimension = dawn::TextureDimension::e2D; |         descriptor.dimension = dawn::TextureDimension::e2D; | ||||||
|         descriptor.size.width = width; |         descriptor.size.width = width; | ||||||
| @ -141,24 +224,13 @@ namespace utils { | |||||||
|         descriptor.size.depth = 1; |         descriptor.size.depth = 1; | ||||||
|         descriptor.arrayLayerCount = 1; |         descriptor.arrayLayerCount = 1; | ||||||
|         descriptor.sampleCount = 1; |         descriptor.sampleCount = 1; | ||||||
|         descriptor.format = result.colorFormat; |         descriptor.format = kColorFormat; | ||||||
|         descriptor.mipLevelCount = 1; |         descriptor.mipLevelCount = 1; | ||||||
|         descriptor.usage = |         descriptor.usage = | ||||||
|             dawn::TextureUsageBit::OutputAttachment | dawn::TextureUsageBit::TransferSrc; |             dawn::TextureUsageBit::OutputAttachment | dawn::TextureUsageBit::TransferSrc; | ||||||
|         result.color = device.CreateTexture(&descriptor); |         dawn::Texture color = device.CreateTexture(&descriptor); | ||||||
| 
 | 
 | ||||||
|         dawn::TextureView colorView = result.color.CreateDefaultTextureView(); |         return BasicRenderPass(width, height, color, kColorFormat); | ||||||
|         dawn::RenderPassColorAttachmentDescriptor colorAttachment; |  | ||||||
|         colorAttachment.attachment = colorView; |  | ||||||
|         colorAttachment.resolveTarget = nullptr; |  | ||||||
|         colorAttachment.clearColor = {0.0f, 0.0f, 0.0f, 0.0f}; |  | ||||||
|         colorAttachment.loadOp = dawn::LoadOp::Clear; |  | ||||||
|         colorAttachment.storeOp = dawn::StoreOp::Store; |  | ||||||
|         result.renderPassInfo = device.CreateRenderPassDescriptorBuilder() |  | ||||||
|                                     .SetColorAttachments(1, &colorAttachment) |  | ||||||
|                                     .GetResult(); |  | ||||||
| 
 |  | ||||||
|         return result; |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     dawn::BufferCopyView CreateBufferCopyView(dawn::Buffer buffer, |     dawn::BufferCopyView CreateBufferCopyView(dawn::Buffer buffer, | ||||||
|  | |||||||
| @ -17,8 +17,11 @@ | |||||||
| 
 | 
 | ||||||
| #include <dawn/dawncpp.h> | #include <dawn/dawncpp.h> | ||||||
| 
 | 
 | ||||||
|  | #include <array> | ||||||
| #include <initializer_list> | #include <initializer_list> | ||||||
| 
 | 
 | ||||||
|  | #include "common/Constants.h" | ||||||
|  | 
 | ||||||
| namespace utils { | namespace utils { | ||||||
| 
 | 
 | ||||||
|     enum Expectation { Success, Failure }; |     enum Expectation { Success, Failure }; | ||||||
| @ -49,12 +52,34 @@ namespace utils { | |||||||
|                                                 uint32_t slice, |                                                 uint32_t slice, | ||||||
|                                                 dawn::Origin3D origin); |                                                 dawn::Origin3D origin); | ||||||
| 
 | 
 | ||||||
|  |     struct ComboRenderPassDescriptor : public dawn::RenderPassDescriptor { | ||||||
|  |       public: | ||||||
|  |         ComboRenderPassDescriptor(std::initializer_list<dawn::TextureView> colorAttachmentInfo, | ||||||
|  |                                   dawn::TextureView depthStencil = dawn::TextureView()); | ||||||
|  |         const ComboRenderPassDescriptor& operator=( | ||||||
|  |             const ComboRenderPassDescriptor& otherRenderPass); | ||||||
|  | 
 | ||||||
|  |         dawn::RenderPassColorAttachmentDescriptor* cColorAttachmentsInfoPtr[kMaxColorAttachments]; | ||||||
|  |         dawn::RenderPassDepthStencilAttachmentDescriptor cDepthStencilAttachmentInfo; | ||||||
|  | 
 | ||||||
|  |       private: | ||||||
|  |         std::array<dawn::RenderPassColorAttachmentDescriptor, kMaxColorAttachments> | ||||||
|  |             mColorAttachmentsInfo; | ||||||
|  |     }; | ||||||
|  | 
 | ||||||
|     struct BasicRenderPass { |     struct BasicRenderPass { | ||||||
|  |       public: | ||||||
|  |         BasicRenderPass(); | ||||||
|  |         BasicRenderPass(uint32_t width, | ||||||
|  |                         uint32_t height, | ||||||
|  |                         dawn::Texture color, | ||||||
|  |                         dawn::TextureFormat texture); | ||||||
|  | 
 | ||||||
|         uint32_t width; |         uint32_t width; | ||||||
|         uint32_t height; |         uint32_t height; | ||||||
|         dawn::Texture color; |         dawn::Texture color; | ||||||
|         dawn::TextureFormat colorFormat; |         dawn::TextureFormat colorFormat; | ||||||
|         dawn::RenderPassDescriptor renderPassInfo; |         utils::ComboRenderPassDescriptor renderPassInfo; | ||||||
|     }; |     }; | ||||||
|     BasicRenderPass CreateBasicRenderPass(const dawn::Device& device, |     BasicRenderPass CreateBasicRenderPass(const dawn::Device& device, | ||||||
|                                           uint32_t width, |                                           uint32_t width, | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user