1 /*------------------------------------------------------------------------
2  * Vulkan Conformance Tests
3  * ------------------------
4  *
5  * Copyright (c) 2015 The Khronos Group Inc.
6  * Copyright (c) 2015 Intel Corporation
7  *
8  * Licensed under the Apache License, Version 2.0 (the "License");
9  * you may not use this file except in compliance with the License.
10  * You may obtain a copy of the License at
11  *
12  *      http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing, software
15  * distributed under the License is distributed on an "AS IS" BASIS,
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17  * See the License for the specific language governing permissions and
18  * limitations under the License.
19  *
20  *//*!
21  * \file
22  * \brief CreateInfo utilities
23  *//*--------------------------------------------------------------------*/
24 
25 #include "vktDrawCreateInfoUtil.hpp"
26 
27 #include "vkImageUtil.hpp"
28 
29 namespace vkt
30 {
31 namespace Draw
32 {
33 
ImageSubresourceRange(vk::VkImageAspectFlags _aspectMask,deUint32 _baseMipLevel,deUint32 _levelCount,deUint32 _baseArrayLayer,deUint32 _layerCount)34 ImageSubresourceRange::ImageSubresourceRange (vk::VkImageAspectFlags	_aspectMask,
35 											  deUint32					_baseMipLevel,
36 											  deUint32					_levelCount,
37 											  deUint32					_baseArrayLayer,
38 											  deUint32					_layerCount)
39 {
40 	aspectMask		= _aspectMask;
41 	baseMipLevel	= _baseMipLevel;
42 	levelCount		= _levelCount;
43 	baseArrayLayer	= _baseArrayLayer;
44 	layerCount		= _layerCount;
45 }
46 
ComponentMapping(vk::VkComponentSwizzle _r,vk::VkComponentSwizzle _g,vk::VkComponentSwizzle _b,vk::VkComponentSwizzle _a)47 ComponentMapping::ComponentMapping (vk::VkComponentSwizzle _r,
48 									vk::VkComponentSwizzle _g,
49 									vk::VkComponentSwizzle _b,
50 									vk::VkComponentSwizzle _a)
51 {
52 	r = _r;
53 	g = _g;
54 	b = _b;
55 	a = _a;
56 }
57 
ImageViewCreateInfo(vk::VkImage _image,vk::VkImageViewType _viewType,vk::VkFormat _format,const vk::VkImageSubresourceRange & _subresourceRange,const vk::VkComponentMapping & _components,vk::VkImageViewCreateFlags _flags)58 ImageViewCreateInfo::ImageViewCreateInfo (vk::VkImage							_image,
59 										  vk::VkImageViewType					_viewType,
60 										  vk::VkFormat							_format,
61 										  const vk::VkImageSubresourceRange&	_subresourceRange,
62 										  const vk::VkComponentMapping&			_components,
63 										  vk::VkImageViewCreateFlags			_flags)
64 {
65 	sType = vk::VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO;
66 	pNext = DE_NULL;
67 	flags				= 0u;
68 	image				= _image;
69 	viewType			= _viewType;
70 	format				= _format;
71 	components.r		= _components.r;
72 	components.g		= _components.g;
73 	components.b		= _components.b;
74 	components.a		= _components.a;
75 	subresourceRange	= _subresourceRange;
76 	flags				= _flags;
77 }
78 
ImageViewCreateInfo(vk::VkImage _image,vk::VkImageViewType _viewType,vk::VkFormat _format,const vk::VkComponentMapping & _components,vk::VkImageViewCreateFlags _flags)79 ImageViewCreateInfo::ImageViewCreateInfo (vk::VkImage					_image,
80 										  vk::VkImageViewType			_viewType,
81 										  vk::VkFormat					_format,
82 										  const vk::VkComponentMapping&	_components,
83 										  vk::VkImageViewCreateFlags	_flags)
84 {
85 	sType = vk::VK_STRUCTURE_TYPE_IMAGE_VIEW_CREATE_INFO;
86 	pNext = DE_NULL;
87 	flags			= 0u;
88 	image			= _image;
89 	viewType		= _viewType;
90 	format			= _format;
91 	components.r	= _components.r;
92 	components.g	= _components.g;
93 	components.b	= _components.b;
94 	components.a	= _components.a;
95 
96 	vk::VkImageAspectFlags aspectFlags;
97 	const tcu::TextureFormat tcuFormat = vk::mapVkFormat(_format);
98 
99 	switch (tcuFormat.order)
100 	{
101 		case tcu::TextureFormat::D:
102 			aspectFlags = vk::VK_IMAGE_ASPECT_DEPTH_BIT;
103 			break;
104 		case tcu::TextureFormat::S:
105 			aspectFlags = vk::VK_IMAGE_ASPECT_STENCIL_BIT;
106 			break;
107 		case tcu::TextureFormat::DS:
108 			aspectFlags = vk::VK_IMAGE_ASPECT_STENCIL_BIT | vk::VK_IMAGE_ASPECT_DEPTH_BIT;
109 			break;
110 		default:
111 			aspectFlags = vk::VK_IMAGE_ASPECT_COLOR_BIT;
112 			break;
113 	}
114 
115 	subresourceRange = ImageSubresourceRange(aspectFlags);;
116 	flags = _flags;
117 }
118 
BufferViewCreateInfo(vk::VkBuffer _buffer,vk::VkFormat _format,vk::VkDeviceSize _offset,vk::VkDeviceSize _range)119 BufferViewCreateInfo::BufferViewCreateInfo (vk::VkBuffer	_buffer,
120 											vk::VkFormat		_format,
121 											vk::VkDeviceSize _offset,
122 											vk::VkDeviceSize _range)
123 {
124 	sType = vk::VK_STRUCTURE_TYPE_BUFFER_VIEW_CREATE_INFO;
125 	pNext = DE_NULL;
126 
127 	flags	= 0;
128 	buffer	= _buffer;
129 	format	= _format;
130 	offset	= _offset;
131 	range	= _range;
132 }
133 
BufferCreateInfo(vk::VkDeviceSize _size,vk::VkBufferUsageFlags _usage,vk::VkSharingMode _sharingMode,deUint32 _queueFamilyIndexCount,const deUint32 * _pQueueFamilyIndices,vk::VkBufferCreateFlags _flags)134 BufferCreateInfo::BufferCreateInfo (vk::VkDeviceSize		_size,
135 									vk::VkBufferUsageFlags	_usage,
136 									vk::VkSharingMode		_sharingMode,
137 									deUint32				_queueFamilyIndexCount,
138 									const deUint32*			_pQueueFamilyIndices,
139 									vk::VkBufferCreateFlags _flags)
140 {
141 	sType = vk::VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO;
142 	pNext = DE_NULL;
143 	size					= _size;
144 	usage					= _usage;
145 	flags					= _flags;
146 	sharingMode				= _sharingMode;
147 	queueFamilyIndexCount	= _queueFamilyIndexCount;
148 
149 	if (_queueFamilyIndexCount)
150 	{
151 		m_queueFamilyIndices = std::vector<deUint32>(
152 			_pQueueFamilyIndices, _pQueueFamilyIndices + _queueFamilyIndexCount);
153 		pQueueFamilyIndices = &m_queueFamilyIndices[0];
154 	}
155 	else
156 	{
157 		pQueueFamilyIndices = _pQueueFamilyIndices;
158 	}
159 }
160 
BufferCreateInfo(const BufferCreateInfo & other)161 BufferCreateInfo::BufferCreateInfo (const BufferCreateInfo &other)
162 {
163 	sType					= other.sType;
164 	pNext					= other.pNext;
165 	size					= other.size;
166 	usage					= other.usage;
167 	flags					= other.flags;
168 	sharingMode				= other.sharingMode;
169 	queueFamilyIndexCount	= other.queueFamilyIndexCount;
170 
171 	m_queueFamilyIndices	= other.m_queueFamilyIndices;
172 	DE_ASSERT(m_queueFamilyIndices.size() == queueFamilyIndexCount);
173 
174 	if (m_queueFamilyIndices.size())
175 	{
176 		pQueueFamilyIndices = &m_queueFamilyIndices[0];
177 	}
178 	else
179 	{
180 		pQueueFamilyIndices = DE_NULL;
181 	}
182 }
183 
operator =(const BufferCreateInfo & other)184 BufferCreateInfo & BufferCreateInfo::operator= (const BufferCreateInfo &other)
185 {
186 	sType						= other.sType;
187 	pNext						= other.pNext;
188 	size						= other.size;
189 	usage						= other.usage;
190 	flags						= other.flags;
191 	sharingMode					= other.sharingMode;
192 	queueFamilyIndexCount		= other.queueFamilyIndexCount;
193 
194 	m_queueFamilyIndices		= other.m_queueFamilyIndices;
195 
196 	DE_ASSERT(m_queueFamilyIndices.size() == queueFamilyIndexCount);
197 
198 	if (m_queueFamilyIndices.size())
199 	{
200 		pQueueFamilyIndices = &m_queueFamilyIndices[0];
201 	}
202 	else
203 	{
204 		pQueueFamilyIndices = DE_NULL;
205 	}
206 
207 	return *this;
208 }
209 
ImageCreateInfo(vk::VkImageType _imageType,vk::VkFormat _format,vk::VkExtent3D _extent,deUint32 _mipLevels,deUint32 _arrayLayers,vk::VkSampleCountFlagBits _samples,vk::VkImageTiling _tiling,vk::VkImageUsageFlags _usage,vk::VkSharingMode _sharingMode,deUint32 _queueFamilyIndexCount,const deUint32 * _pQueueFamilyIndices,vk::VkImageCreateFlags _flags,vk::VkImageLayout _initialLayout)210 ImageCreateInfo::ImageCreateInfo (vk::VkImageType			_imageType,
211 								  vk::VkFormat				_format,
212 								  vk::VkExtent3D			_extent,
213 								  deUint32					_mipLevels,
214 								  deUint32					_arrayLayers,
215 								  vk::VkSampleCountFlagBits	_samples,
216 								  vk::VkImageTiling			_tiling,
217 								  vk::VkImageUsageFlags		_usage,
218 								  vk::VkSharingMode			_sharingMode,
219 								  deUint32					_queueFamilyIndexCount,
220 								  const deUint32*			_pQueueFamilyIndices,
221 								  vk::VkImageCreateFlags	_flags,
222 								  vk::VkImageLayout			_initialLayout)
223 {
224 	if (_queueFamilyIndexCount)
225 	{
226 		m_queueFamilyIndices = std::vector<deUint32>(_pQueueFamilyIndices, _pQueueFamilyIndices + _queueFamilyIndexCount);
227 	}
228 
229 	sType = vk::VK_STRUCTURE_TYPE_IMAGE_CREATE_INFO;
230 	pNext = DE_NULL;
231 	flags					= _flags;
232 	imageType				= _imageType;
233 	format					= _format;
234 	extent					= _extent;
235 	mipLevels				= _mipLevels;
236 	arrayLayers				= _arrayLayers;
237 	samples					= _samples;
238 	tiling					= _tiling;
239 	usage					= _usage;
240 	sharingMode				= _sharingMode;
241 	queueFamilyIndexCount	= _queueFamilyIndexCount;
242 
243 	if (m_queueFamilyIndices.size())
244 	{
245 		pQueueFamilyIndices = &m_queueFamilyIndices[0];
246 	}
247 	else
248 	{
249 		pQueueFamilyIndices = DE_NULL;
250 	}
251 	initialLayout	= _initialLayout;
252 }
253 
FramebufferCreateInfo(vk::VkRenderPass _renderPass,const std::vector<vk::VkImageView> & atachments,deUint32 _width,deUint32 _height,deUint32 _layers)254 FramebufferCreateInfo::FramebufferCreateInfo (vk::VkRenderPass						_renderPass,
255 											  const std::vector<vk::VkImageView>&	atachments,
256 											  deUint32								_width,
257 											  deUint32								_height,
258 											  deUint32								_layers)
259 {
260 	sType = vk::VK_STRUCTURE_TYPE_FRAMEBUFFER_CREATE_INFO;
261 	pNext = DE_NULL;
262 	flags = 0u;
263 
264 	renderPass		= _renderPass;
265 	attachmentCount	= static_cast<deUint32>(atachments.size());
266 
267 	if (attachmentCount)
268 	{
269 		pAttachments = const_cast<vk::VkImageView *>(&atachments[0]);
270 	}
271 
272 	width	= _width;
273 	height	= _height;
274 	layers	= _layers;
275 }
276 
RenderPassCreateInfo(const std::vector<vk::VkAttachmentDescription> & attachments,const std::vector<vk::VkSubpassDescription> & subpasses,const std::vector<vk::VkSubpassDependency> & dependiences)277 RenderPassCreateInfo::RenderPassCreateInfo (const std::vector<vk::VkAttachmentDescription>&	attachments,
278 											const std::vector<vk::VkSubpassDescription>&	subpasses,
279 											const std::vector<vk::VkSubpassDependency>&		dependiences)
280 
281 	: m_attachments			(attachments.begin(), attachments.end())
282 	, m_subpasses			(subpasses.begin(), subpasses.end())
283 	, m_dependiences		(dependiences.begin(), dependiences.end())
284 	, m_attachmentsStructs	(m_attachments.begin(), m_attachments.end())
285 	, m_subpassesStructs	(m_subpasses.begin(), m_subpasses.end())
286 	, m_dependiencesStructs	(m_dependiences.begin(), m_dependiences.end())
287 {
288 	sType = vk::VK_STRUCTURE_TYPE_RENDER_PASS_CREATE_INFO;
289 	pNext = DE_NULL;
290 	flags = 0;
291 
292 	attachmentCount = static_cast<deUint32>(m_attachments.size());
293 	pAttachments	= &m_attachmentsStructs[0];
294 	subpassCount	= static_cast<deUint32>(m_subpasses.size());
295 	pSubpasses		= &m_subpassesStructs[0];
296 	dependencyCount = static_cast<deUint32>(m_dependiences.size());
297 	pDependencies	= &m_dependiencesStructs[0];
298 }
299 
RenderPassCreateInfo(deUint32 _attachmentCount,const vk::VkAttachmentDescription * _pAttachments,deUint32 _subpassCount,const vk::VkSubpassDescription * _pSubpasses,deUint32 _dependencyCount,const vk::VkSubpassDependency * _pDependiences)300 RenderPassCreateInfo::RenderPassCreateInfo (deUint32							_attachmentCount,
301 											const vk::VkAttachmentDescription*	_pAttachments,
302 											deUint32							_subpassCount,
303 											const vk::VkSubpassDescription*		_pSubpasses,
304 											deUint32							_dependencyCount,
305 											const vk::VkSubpassDependency*		_pDependiences)
306 {
307 
308 	m_attachments	= std::vector<AttachmentDescription>(_pAttachments, _pAttachments + _attachmentCount);
309 	m_subpasses		= std::vector<SubpassDescription>(_pSubpasses, _pSubpasses + _subpassCount);
310 	m_dependiences	= std::vector<SubpassDependency>(_pDependiences, _pDependiences + _dependencyCount);
311 
312 	m_attachmentsStructs	= std::vector<vk::VkAttachmentDescription>	(m_attachments.begin(),		m_attachments.end());
313 	m_subpassesStructs		= std::vector<vk::VkSubpassDescription>		(m_subpasses.begin(),		m_subpasses.end());
314 	m_dependiencesStructs	= std::vector<vk::VkSubpassDependency>		(m_dependiences.begin(),	m_dependiences.end());
315 
316 	sType = vk::VK_STRUCTURE_TYPE_RENDER_PASS_CREATE_INFO;
317 	pNext = DE_NULL;
318 	flags = 0;
319 
320 	attachmentCount = static_cast<deUint32>(m_attachments.size());
321 
322 	if (attachmentCount) {
323 		pAttachments = &m_attachmentsStructs[0];
324 	}
325 	else
326 	{
327 		pAttachments = DE_NULL;
328 	}
329 
330 	subpassCount = static_cast<deUint32>(m_subpasses.size());
331 
332 	if (subpassCount) {
333 		pSubpasses = &m_subpassesStructs[0];
334 	}
335 	else
336 	{
337 		pSubpasses = DE_NULL;
338 	}
339 
340 	dependencyCount = static_cast<deUint32>(m_dependiences.size());
341 
342 	if (dependencyCount) {
343 		pDependencies = &m_dependiencesStructs[0];
344 	}
345 	else
346 	{
347 		pDependencies = DE_NULL;
348 	}
349 }
350 
351 void
addAttachment(vk::VkAttachmentDescription attachment)352 RenderPassCreateInfo::addAttachment (vk::VkAttachmentDescription attachment)
353 {
354 
355 	m_attachments.push_back(attachment);
356 	m_attachmentsStructs	= std::vector<vk::VkAttachmentDescription>(m_attachments.begin(), m_attachments.end());
357 	attachmentCount			= static_cast<deUint32>(m_attachments.size());
358 	pAttachments			= &m_attachmentsStructs[0];
359 }
360 
361 void
addSubpass(vk::VkSubpassDescription subpass)362 RenderPassCreateInfo::addSubpass (vk::VkSubpassDescription subpass)
363 {
364 
365 	m_subpasses.push_back(subpass);
366 	m_subpassesStructs	= std::vector<vk::VkSubpassDescription>(m_subpasses.begin(), m_subpasses.end());
367 	subpassCount		= static_cast<deUint32>(m_subpasses.size());
368 	pSubpasses			= &m_subpassesStructs[0];
369 }
370 
371 void
addDependency(vk::VkSubpassDependency dependency)372 RenderPassCreateInfo::addDependency (vk::VkSubpassDependency dependency)
373 {
374 
375 	m_dependiences.push_back(dependency);
376 	m_dependiencesStructs	= std::vector<vk::VkSubpassDependency>(m_dependiences.begin(), m_dependiences.end());
377 
378 	dependencyCount			= static_cast<deUint32>(m_dependiences.size());
379 	pDependencies			= &m_dependiencesStructs[0];
380 }
381 
RenderPassBeginInfo(vk::VkRenderPass _renderPass,vk::VkFramebuffer _framebuffer,vk::VkRect2D _renderArea,const std::vector<vk::VkClearValue> & _clearValues)382 RenderPassBeginInfo::RenderPassBeginInfo (vk::VkRenderPass						_renderPass,
383 										  vk::VkFramebuffer						_framebuffer,
384 										  vk::VkRect2D							_renderArea,
385 										  const std::vector<vk::VkClearValue>&	_clearValues)
386 {
387 
388 	m_clearValues	= _clearValues;
389 
390 	sType			= vk::VK_STRUCTURE_TYPE_RENDER_PASS_BEGIN_INFO;
391 	pNext			= DE_NULL;
392 	renderPass		= _renderPass;
393 	framebuffer		= _framebuffer;
394 	renderArea		= _renderArea;
395 	clearValueCount = static_cast<deUint32>(m_clearValues.size());
396 	pClearValues	= m_clearValues.size() ? &m_clearValues[0] : DE_NULL;
397 }
398 
CmdPoolCreateInfo(deUint32 _queueFamilyIndex,unsigned int _flags)399 CmdPoolCreateInfo::CmdPoolCreateInfo (deUint32 _queueFamilyIndex, unsigned int _flags)
400 {
401 	sType = vk::VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO;
402 	pNext = DE_NULL;
403 
404 	queueFamilyIndex = _queueFamilyIndex;
405 	flags				= _flags;
406 }
407 
AttachmentDescription(vk::VkFormat _format,vk::VkSampleCountFlagBits _samples,vk::VkAttachmentLoadOp _loadOp,vk::VkAttachmentStoreOp _storeOp,vk::VkAttachmentLoadOp _stencilLoadOp,vk::VkAttachmentStoreOp _stencilStoreOp,vk::VkImageLayout _initialLayout,vk::VkImageLayout _finalLayout)408 AttachmentDescription::AttachmentDescription (vk::VkFormat				_format,
409 											  vk::VkSampleCountFlagBits	_samples,
410 											  vk::VkAttachmentLoadOp	_loadOp,
411 											  vk::VkAttachmentStoreOp	_storeOp,
412 											  vk::VkAttachmentLoadOp	_stencilLoadOp,
413 											  vk::VkAttachmentStoreOp	_stencilStoreOp,
414 											  vk::VkImageLayout			_initialLayout,
415 											  vk::VkImageLayout			_finalLayout)
416 {
417 	flags = 0;
418 	format			= _format;
419 	samples			= _samples;
420 	loadOp			= _loadOp;
421 	storeOp			= _storeOp;
422 	stencilLoadOp	= _stencilLoadOp;
423 	stencilStoreOp	= _stencilStoreOp;
424 	initialLayout	= _initialLayout;
425 	finalLayout		= _finalLayout;
426 }
427 
AttachmentDescription(const vk::VkAttachmentDescription & rhs)428 AttachmentDescription::AttachmentDescription (const vk::VkAttachmentDescription& rhs)
429 {
430 	flags			= rhs.flags;
431 	format			= rhs.format;
432 	samples			= rhs.samples;
433 	loadOp			= rhs.loadOp;
434 	storeOp			= rhs.storeOp;
435 	stencilLoadOp	= rhs.stencilLoadOp;
436 	stencilStoreOp	= rhs.stencilStoreOp;
437 	initialLayout	= rhs.initialLayout;
438 	finalLayout		= rhs.finalLayout;
439 }
440 
AttachmentReference(deUint32 _attachment,vk::VkImageLayout _layout)441 AttachmentReference::AttachmentReference (deUint32 _attachment, vk::VkImageLayout _layout)
442 {
443 	attachment	= _attachment;
444 	layout		= _layout;
445 }
446 
AttachmentReference(void)447 AttachmentReference::AttachmentReference (void)
448 {
449 	attachment = VK_ATTACHMENT_UNUSED;
450 	layout = vk::VK_IMAGE_LAYOUT_UNDEFINED;
451 }
452 
SubpassDescription(vk::VkPipelineBindPoint _pipelineBindPoint,vk::VkSubpassDescriptionFlags _flags,deUint32 _inputAttachmentCount,const vk::VkAttachmentReference * _inputAttachments,deUint32 _colorAttachmentCount,const vk::VkAttachmentReference * _colorAttachments,const vk::VkAttachmentReference * _resolveAttachments,vk::VkAttachmentReference depthStencilAttachment,deUint32 _preserveAttachmentCount,const deUint32 * _preserveAttachments)453 SubpassDescription::SubpassDescription (vk::VkPipelineBindPoint				_pipelineBindPoint,
454 										vk::VkSubpassDescriptionFlags		_flags,
455 										deUint32							_inputAttachmentCount,
456 										const vk::VkAttachmentReference*	_inputAttachments,
457 										deUint32							_colorAttachmentCount,
458 										const vk::VkAttachmentReference*	_colorAttachments,
459 										const vk::VkAttachmentReference*	_resolveAttachments,
460 										vk::VkAttachmentReference			depthStencilAttachment,
461 										deUint32							_preserveAttachmentCount,
462 										const deUint32*						_preserveAttachments)
463 {
464 	m_inputAttachments = std::vector<vk::VkAttachmentReference>(_inputAttachments, _inputAttachments + _inputAttachmentCount);
465 	m_colorAttachments = std::vector<vk::VkAttachmentReference>(_colorAttachments, _colorAttachments + _colorAttachmentCount);
466 
467 	if (_resolveAttachments)
468 		m_resolveAttachments = std::vector<vk::VkAttachmentReference>(_resolveAttachments, _resolveAttachments + _colorAttachmentCount);
469 
470 	m_preserveAttachments = std::vector<deUint32>(_preserveAttachments, _preserveAttachments + _preserveAttachmentCount);
471 
472 	m_depthStencilAttachment = depthStencilAttachment;
473 
474 	flags					= _flags;
475 	pipelineBindPoint		= _pipelineBindPoint;
476 	inputAttachmentCount	= _inputAttachmentCount;
477 	pInputAttachments		= DE_NULL;
478 	colorAttachmentCount	= _colorAttachmentCount;
479 	pColorAttachments		= DE_NULL;
480 	pResolveAttachments		= DE_NULL;
481 	pDepthStencilAttachment	= &m_depthStencilAttachment;
482 	pPreserveAttachments	= DE_NULL;
483 	preserveAttachmentCount	= _preserveAttachmentCount;
484 
485 	if (!m_inputAttachments.empty())
486 		pInputAttachments = &m_inputAttachments[0];
487 
488 	if (!m_colorAttachments.empty())
489 		pColorAttachments = &m_colorAttachments[0];
490 
491 	if (!m_resolveAttachments.empty())
492 		pResolveAttachments = &m_resolveAttachments[0];
493 
494 	if (!m_preserveAttachments.empty())
495 		pPreserveAttachments = &m_preserveAttachments[0];
496 }
497 
SubpassDescription(const vk::VkSubpassDescription & rhs)498 SubpassDescription::SubpassDescription (const vk::VkSubpassDescription& rhs)
499 {
500 	*static_cast<vk::VkSubpassDescription*>(this) = rhs;
501 
502 	m_inputAttachments = std::vector<vk::VkAttachmentReference>(
503 		rhs.pInputAttachments, rhs.pInputAttachments + rhs.inputAttachmentCount);
504 
505 	m_colorAttachments = std::vector<vk::VkAttachmentReference>(
506 		rhs.pColorAttachments, rhs.pColorAttachments + rhs.colorAttachmentCount);
507 
508 	if (rhs.pResolveAttachments)
509 		m_resolveAttachments = std::vector<vk::VkAttachmentReference>(
510 			rhs.pResolveAttachments, rhs.pResolveAttachments + rhs.colorAttachmentCount);
511 
512 	m_preserveAttachments = std::vector<deUint32>(
513 		rhs.pPreserveAttachments, rhs.pPreserveAttachments + rhs.preserveAttachmentCount);
514 
515 	if (rhs.pDepthStencilAttachment)
516 		m_depthStencilAttachment = *rhs.pDepthStencilAttachment;
517 
518 	if (!m_inputAttachments.empty())
519 		pInputAttachments = &m_inputAttachments[0];
520 
521 	if (!m_colorAttachments.empty())
522 		pColorAttachments = &m_colorAttachments[0];
523 
524 	if (!m_resolveAttachments.empty())
525 		pResolveAttachments = &m_resolveAttachments[0];
526 
527 	pDepthStencilAttachment = &m_depthStencilAttachment;
528 
529 	if (!m_preserveAttachments.empty())
530 		pPreserveAttachments = &m_preserveAttachments[0];
531 }
532 
SubpassDescription(const SubpassDescription & rhs)533 SubpassDescription::SubpassDescription (const SubpassDescription& rhs) {
534 	*this = rhs;
535 }
536 
operator =(const SubpassDescription & rhs)537 SubpassDescription& SubpassDescription::operator= (const SubpassDescription& rhs)
538 {
539 	*static_cast<vk::VkSubpassDescription*>(this) = rhs;
540 
541 	m_inputAttachments		= rhs.m_inputAttachments;
542 	m_colorAttachments		= rhs.m_colorAttachments;
543 	m_resolveAttachments	= rhs.m_resolveAttachments;
544 	m_preserveAttachments	= rhs.m_preserveAttachments;
545 	m_depthStencilAttachment = rhs.m_depthStencilAttachment;
546 
547 	if (!m_inputAttachments.empty())
548 		pInputAttachments = &m_inputAttachments[0];
549 
550 	if (!m_colorAttachments.empty())
551 		pColorAttachments = &m_colorAttachments[0];
552 
553 	if (!m_resolveAttachments.empty())
554 		pResolveAttachments = &m_resolveAttachments[0];
555 
556 	pDepthStencilAttachment = &m_depthStencilAttachment;
557 
558 	if (!m_preserveAttachments.empty())
559 		pPreserveAttachments = &m_preserveAttachments[0];
560 
561 	return *this;
562 }
563 
SubpassDependency(deUint32 _srcSubpass,deUint32 _dstSubpass,vk::VkPipelineStageFlags _srcStageMask,vk::VkPipelineStageFlags _dstStageMask,vk::VkAccessFlags _srcAccessMask,vk::VkAccessFlags _dstAccessMask,vk::VkDependencyFlags _dependencyFlags)564 SubpassDependency::SubpassDependency (deUint32					_srcSubpass,
565 									  deUint32					_dstSubpass,
566 									  vk::VkPipelineStageFlags	_srcStageMask,
567 									  vk::VkPipelineStageFlags	_dstStageMask,
568 									  vk::VkAccessFlags			_srcAccessMask,
569 									  vk::VkAccessFlags			_dstAccessMask,
570 									  vk::VkDependencyFlags		_dependencyFlags)
571 {
572 	srcSubpass		= _srcSubpass;
573 	dstSubpass		= _dstSubpass;
574 	srcStageMask	= _srcStageMask;
575 	dstStageMask	= _dstStageMask;
576 	srcAccessMask	= _srcAccessMask;
577 	dstAccessMask	= _dstAccessMask;
578 	dependencyFlags	= _dependencyFlags;
579 }
580 
SubpassDependency(const vk::VkSubpassDependency & rhs)581 SubpassDependency::SubpassDependency (const vk::VkSubpassDependency& rhs)
582 {
583 	srcSubpass		= rhs.srcSubpass;
584 	dstSubpass		= rhs.dstSubpass;
585 	srcStageMask	= rhs.srcStageMask;
586 	dstStageMask	= rhs.dstStageMask;
587 	srcAccessMask	= rhs.srcAccessMask;
588 	dstAccessMask	= rhs.dstAccessMask;
589 	dependencyFlags	= rhs.dependencyFlags;
590 }
591 
CmdBufferBeginInfo(vk::VkCommandBufferUsageFlags _flags)592 CmdBufferBeginInfo::CmdBufferBeginInfo (vk::VkCommandBufferUsageFlags _flags)
593 {
594 	sType				= vk::VK_STRUCTURE_TYPE_COMMAND_BUFFER_BEGIN_INFO;
595 	pNext				= DE_NULL;
596 	flags				= _flags;
597 	pInheritanceInfo	= DE_NULL;
598 }
599 
DescriptorPoolCreateInfo(const std::vector<vk::VkDescriptorPoolSize> & poolSizeCounts,vk::VkDescriptorPoolCreateFlags _flags,deUint32 _maxSets)600 DescriptorPoolCreateInfo::DescriptorPoolCreateInfo (const std::vector<vk::VkDescriptorPoolSize>&	poolSizeCounts,
601 													vk::VkDescriptorPoolCreateFlags					_flags,
602 													deUint32										_maxSets)
603 	: m_poolSizeCounts(poolSizeCounts)
604 {
605 	sType = vk::VK_STRUCTURE_TYPE_DESCRIPTOR_POOL_CREATE_INFO;
606 	pNext = DE_NULL;
607 	flags			= _flags;
608 	maxSets			= _maxSets;
609 	poolSizeCount	= static_cast<deUint32>(m_poolSizeCounts.size());
610 	pPoolSizes		= &m_poolSizeCounts[0];
611 }
612 
addDescriptors(vk::VkDescriptorType type,deUint32 count)613 DescriptorPoolCreateInfo& DescriptorPoolCreateInfo::addDescriptors (vk::VkDescriptorType type, deUint32 count)
614 {
615 	vk::VkDescriptorPoolSize descriptorTypeCount = { type, count };
616 	m_poolSizeCounts.push_back(descriptorTypeCount);
617 
618 	poolSizeCount	= static_cast<deUint32>(m_poolSizeCounts.size());
619 	pPoolSizes		= &m_poolSizeCounts[0];
620 
621 	return *this;
622 }
623 
DescriptorSetLayoutCreateInfo(deUint32 _bindingCount,const vk::VkDescriptorSetLayoutBinding * _pBindings)624 DescriptorSetLayoutCreateInfo::DescriptorSetLayoutCreateInfo (deUint32 _bindingCount, const vk::VkDescriptorSetLayoutBinding* _pBindings)
625 {
626 	sType = vk::VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO;
627 	pNext = DE_NULL;
628 	flags = 0;
629 	bindingCount = _bindingCount;
630 	pBindings	 = _pBindings;
631 }
632 
PipelineLayoutCreateInfo(deUint32 _descriptorSetCount,const vk::VkDescriptorSetLayout * _pSetLayouts,deUint32 _pushConstantRangeCount,const vk::VkPushConstantRange * _pPushConstantRanges)633 PipelineLayoutCreateInfo::PipelineLayoutCreateInfo (deUint32							_descriptorSetCount,
634 													const vk::VkDescriptorSetLayout*	_pSetLayouts,
635 													deUint32							_pushConstantRangeCount,
636 													const vk::VkPushConstantRange*		_pPushConstantRanges)
637 	: m_pushConstantRanges(_pPushConstantRanges, _pPushConstantRanges + _pushConstantRangeCount)
638 {
639 	for (unsigned int i = 0; i < _descriptorSetCount; i++)
640 	{
641 		m_setLayouts.push_back(_pSetLayouts[i]);
642 	}
643 
644 	sType = vk::VK_STRUCTURE_TYPE_PIPELINE_LAYOUT_CREATE_INFO;
645 	pNext = DE_NULL;
646 	flags					= 0;
647 	setLayoutCount			= static_cast<deUint32>(m_setLayouts.size());
648 	pSetLayouts				= setLayoutCount > 0 ? &m_setLayouts[0] : DE_NULL;
649 	pushConstantRangeCount	= static_cast<deUint32>(m_pushConstantRanges.size());
650 
651 	if (m_pushConstantRanges.size()) {
652 		pPushConstantRanges = &m_pushConstantRanges[0];
653 	}
654 	else
655 	{
656 		pPushConstantRanges = DE_NULL;
657 	}
658 }
659 
PipelineLayoutCreateInfo(const std::vector<vk::VkDescriptorSetLayout> & setLayouts,deUint32 _pushConstantRangeCount,const vk::VkPushConstantRange * _pPushConstantRanges)660 PipelineLayoutCreateInfo::PipelineLayoutCreateInfo (const std::vector<vk::VkDescriptorSetLayout>&	setLayouts,
661 													deUint32										_pushConstantRangeCount,
662 													const vk::VkPushConstantRange*					_pPushConstantRanges)
663 	: m_setLayouts			(setLayouts)
664 	, m_pushConstantRanges	(_pPushConstantRanges, _pPushConstantRanges + _pushConstantRangeCount)
665 {
666 	sType = vk::VK_STRUCTURE_TYPE_PIPELINE_LAYOUT_CREATE_INFO;
667 	pNext = DE_NULL;
668 
669 	flags			= 0;
670 	setLayoutCount	= static_cast<deUint32>(m_setLayouts.size());
671 
672 	if (setLayoutCount)
673 	{
674 		pSetLayouts = &m_setLayouts[0];
675 	}
676 	else
677 	{
678 		pSetLayouts = DE_NULL;
679 	}
680 
681 	pushConstantRangeCount = static_cast<deUint32>(m_pushConstantRanges.size());
682 	if (pushConstantRangeCount) {
683 		pPushConstantRanges = &m_pushConstantRanges[0];
684 	}
685 	else
686 	{
687 		pPushConstantRanges = DE_NULL;
688 	}
689 }
690 
PipelineShaderStage(vk::VkShaderModule _module,const char * _pName,vk::VkShaderStageFlagBits _stage)691 PipelineCreateInfo::PipelineShaderStage::PipelineShaderStage (vk::VkShaderModule _module, const char* _pName, vk::VkShaderStageFlagBits _stage)
692 {
693 	sType = vk::VK_STRUCTURE_TYPE_PIPELINE_SHADER_STAGE_CREATE_INFO;
694 	pNext = DE_NULL;
695 	flags = 0u;
696 	stage				= _stage;
697 	module				= _module;
698 	pName				= _pName;
699 	pSpecializationInfo = DE_NULL;
700 }
701 
VertexInputState(deUint32 _vertexBindingDescriptionCount,const vk::VkVertexInputBindingDescription * _pVertexBindingDescriptions,deUint32 _vertexAttributeDescriptionCount,const vk::VkVertexInputAttributeDescription * _pVertexAttributeDescriptions)702 PipelineCreateInfo::VertexInputState::VertexInputState (deUint32										_vertexBindingDescriptionCount,
703 														const vk::VkVertexInputBindingDescription*		_pVertexBindingDescriptions,
704 														deUint32										_vertexAttributeDescriptionCount,
705 														const vk::VkVertexInputAttributeDescription*	_pVertexAttributeDescriptions)
706 {
707 	sType = vk::VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO;
708 	pNext = DE_NULL;
709 	flags							= 0u;
710 	vertexBindingDescriptionCount	= _vertexBindingDescriptionCount;
711 	pVertexBindingDescriptions		= _pVertexBindingDescriptions;
712 	vertexAttributeDescriptionCount	= _vertexAttributeDescriptionCount;
713 	pVertexAttributeDescriptions	= _pVertexAttributeDescriptions;
714 }
715 
addDivisors(deUint32 _vertexBindingDivisorCount,const vk::VkVertexInputBindingDivisorDescriptionEXT * _pVertexBindingDivisors)716 PipelineCreateInfo::VertexInputState& PipelineCreateInfo::VertexInputState::addDivisors (deUint32												_vertexBindingDivisorCount,
717 																						 const vk::VkVertexInputBindingDivisorDescriptionEXT*	_pVertexBindingDivisors)
718 {
719 	m_divisorState.sType = vk::VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_DIVISOR_STATE_CREATE_INFO_EXT;
720 	m_divisorState.vertexBindingDivisorCount = _vertexBindingDivisorCount;
721 	m_divisorState.pVertexBindingDivisors = _pVertexBindingDivisors;
722 
723 	// Link it into the chainadd
724 	m_divisorState.pNext = this->pNext;
725 	pNext = &m_divisorState;
726 
727 	return *this;
728 }
729 
InputAssemblerState(vk::VkPrimitiveTopology _topology,vk::VkBool32 _primitiveRestartEnable)730 PipelineCreateInfo::InputAssemblerState::InputAssemblerState (vk::VkPrimitiveTopology	_topology,
731 															  vk::VkBool32				_primitiveRestartEnable)
732 {
733 	sType = vk::VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO;
734 	pNext = DE_NULL;
735 	flags					= 0u;
736 	topology				= _topology;
737 	primitiveRestartEnable	= _primitiveRestartEnable;
738 }
739 
TessellationState(deUint32 _patchControlPoints)740 PipelineCreateInfo::TessellationState::TessellationState (deUint32 _patchControlPoints)
741 {
742 	sType = vk::VK_STRUCTURE_TYPE_PIPELINE_TESSELLATION_STATE_CREATE_INFO;
743 	pNext = DE_NULL;
744 	flags				= 0;
745 	patchControlPoints	= _patchControlPoints;
746 }
747 
ViewportState(deUint32 _viewportCount,std::vector<vk::VkViewport> _viewports,std::vector<vk::VkRect2D> _scissors)748 PipelineCreateInfo::ViewportState::ViewportState (deUint32						_viewportCount,
749 												  std::vector<vk::VkViewport>	_viewports,
750 												  std::vector<vk::VkRect2D>		_scissors)
751 {
752 	sType = vk::VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_STATE_CREATE_INFO;
753 	pNext = DE_NULL;
754 	flags			= 0u;
755 	viewportCount	= _viewportCount;
756 	scissorCount	= _viewportCount;
757 
758 	if (!_viewports.size())
759 	{
760 		m_viewports.resize(viewportCount);
761 		deMemset(&m_viewports[0], 0, sizeof(m_viewports[0]) * m_viewports.size());
762 	}
763 	else
764 	{
765 		m_viewports = _viewports;
766 	}
767 
768 	if (!_scissors.size())
769 	{
770 		m_scissors.resize(scissorCount);
771 		deMemset(&m_scissors[0], 0, sizeof(m_scissors[0]) * m_scissors.size());
772 	}
773 	else
774 	{
775 		m_scissors = _scissors;
776 	}
777 
778 	pViewports	= &m_viewports[0];
779 	pScissors	= &m_scissors[0];
780 }
781 
ViewportState(const ViewportState & other)782 PipelineCreateInfo::ViewportState::ViewportState (const ViewportState& other)
783 {
784 	sType			= other.sType;
785 	pNext			= other.pNext;
786 	flags			= other.flags;
787 	viewportCount	= other.viewportCount;
788 	scissorCount	= other.scissorCount;
789 
790 	m_viewports = std::vector<vk::VkViewport>(other.pViewports, other.pViewports + viewportCount);
791 	m_scissors	= std::vector<vk::VkRect2D>(other.pScissors, other.pScissors + scissorCount);
792 
793 	pViewports	= &m_viewports[0];
794 	pScissors	= &m_scissors[0];
795 }
796 
operator =(const ViewportState & other)797 PipelineCreateInfo::ViewportState& PipelineCreateInfo::ViewportState::operator= (const ViewportState& other)
798 {
799 	sType			= other.sType;
800 	pNext			= other.pNext;
801 	flags			= other.flags;
802 	viewportCount	= other.viewportCount;
803 	scissorCount	= other.scissorCount;
804 
805 	m_viewports		= std::vector<vk::VkViewport>(other.pViewports, other.pViewports + scissorCount);
806 	m_scissors		= std::vector<vk::VkRect2D>(other.pScissors, other.pScissors + scissorCount);
807 
808 	pViewports		= &m_viewports[0];
809 	pScissors		= &m_scissors[0];
810 	return *this;
811 }
812 
RasterizerState(vk::VkBool32 _depthClampEnable,vk::VkBool32 _rasterizerDiscardEnable,vk::VkPolygonMode _polygonMode,vk::VkCullModeFlags _cullMode,vk::VkFrontFace _frontFace,vk::VkBool32 _depthBiasEnable,float _depthBiasConstantFactor,float _depthBiasClamp,float _depthBiasSlopeFactor,float _lineWidth)813 PipelineCreateInfo::RasterizerState::RasterizerState (vk::VkBool32			_depthClampEnable,
814 													  vk::VkBool32			_rasterizerDiscardEnable,
815 													  vk::VkPolygonMode		_polygonMode,
816 													  vk::VkCullModeFlags	_cullMode,
817 													  vk::VkFrontFace		_frontFace,
818 													  vk::VkBool32			_depthBiasEnable,
819 													  float					_depthBiasConstantFactor,
820 													  float					_depthBiasClamp,
821 													  float					_depthBiasSlopeFactor,
822 													  float					_lineWidth)
823 {
824 	sType = vk::VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO;
825 	pNext = DE_NULL;
826 	flags					= 0u;
827 	depthClampEnable		= _depthClampEnable;
828 	rasterizerDiscardEnable = _rasterizerDiscardEnable;
829 	polygonMode				= _polygonMode;
830 	cullMode				= _cullMode;
831 	frontFace				= _frontFace;
832 
833 	depthBiasEnable			= _depthBiasEnable;
834 	depthBiasConstantFactor	= _depthBiasConstantFactor;
835 	depthBiasClamp			= _depthBiasClamp;
836 	depthBiasSlopeFactor	= _depthBiasSlopeFactor;
837 	lineWidth				= _lineWidth;
838 }
839 
MultiSampleState(vk::VkSampleCountFlagBits _rasterizationSamples,vk::VkBool32 _sampleShadingEnable,float _minSampleShading,const std::vector<vk::VkSampleMask> & _sampleMask,bool _alphaToCoverageEnable,bool _alphaToOneEnable)840 PipelineCreateInfo::MultiSampleState::MultiSampleState (vk::VkSampleCountFlagBits				_rasterizationSamples,
841 														vk::VkBool32							_sampleShadingEnable,
842 														float									_minSampleShading,
843 														const std::vector<vk::VkSampleMask>&	_sampleMask,
844 														bool									_alphaToCoverageEnable,
845 														bool									_alphaToOneEnable)
846 	: m_sampleMask(_sampleMask)
847 {
848 	sType = vk::VK_STRUCTURE_TYPE_PIPELINE_MULTISAMPLE_STATE_CREATE_INFO;
849 	pNext = DE_NULL;
850 	flags					= 0u;
851 	rasterizationSamples	= _rasterizationSamples;
852 	sampleShadingEnable		= _sampleShadingEnable;
853 	minSampleShading		= _minSampleShading;
854 	pSampleMask				= &m_sampleMask[0];
855 	alphaToCoverageEnable   = _alphaToCoverageEnable;
856 	alphaToOneEnable		= _alphaToOneEnable;
857 }
858 
MultiSampleState(const MultiSampleState & other)859 PipelineCreateInfo::MultiSampleState::MultiSampleState (const MultiSampleState& other)
860 {
861 	sType					= other.sType;
862 	pNext					= other.pNext;
863 	flags					= other.flags;
864 	rasterizationSamples	= other.rasterizationSamples;
865 	sampleShadingEnable		= other.sampleShadingEnable;
866 	minSampleShading		= other.minSampleShading;
867 
868 	const size_t sampleMaskArrayLen = (sizeof(vk::VkSampleMask) * 8 + other.rasterizationSamples) / (sizeof(vk::VkSampleMask) * 8);
869 
870 	m_sampleMask	= std::vector<vk::VkSampleMask>(other.pSampleMask, other.pSampleMask + sampleMaskArrayLen);
871 	pSampleMask		= &m_sampleMask[0];
872 }
873 
operator =(const MultiSampleState & other)874 PipelineCreateInfo::MultiSampleState& PipelineCreateInfo::MultiSampleState::operator= (const MultiSampleState& other)
875 {
876 	sType = other.sType;
877 	pNext = other.pNext;
878 	flags					= other.flags;
879 	rasterizationSamples	= other.rasterizationSamples;
880 	sampleShadingEnable		= other.sampleShadingEnable;
881 	minSampleShading		= other.minSampleShading;
882 
883 	const size_t sampleMaskArrayLen = (sizeof(vk::VkSampleMask) * 8 + other.rasterizationSamples) / (sizeof(vk::VkSampleMask) * 8);
884 
885 	m_sampleMask	= std::vector<vk::VkSampleMask>(other.pSampleMask, other.pSampleMask + sampleMaskArrayLen);
886 	pSampleMask		= &m_sampleMask[0];
887 
888 	return *this;
889 }
890 
ColorBlendState(const std::vector<vk::VkPipelineColorBlendAttachmentState> & _attachments,vk::VkBool32 _logicOpEnable,vk::VkLogicOp _logicOp)891 PipelineCreateInfo::ColorBlendState::ColorBlendState (const std::vector<vk::VkPipelineColorBlendAttachmentState>&	_attachments,
892 													  vk::VkBool32													_logicOpEnable,
893 													  vk::VkLogicOp													_logicOp)
894 	: m_attachments(_attachments)
895 {
896 	sType = vk::VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO;
897 	pNext = DE_NULL;
898 	flags					= 0u;
899 	logicOpEnable			= _logicOpEnable;
900 	logicOp					= _logicOp;
901 	attachmentCount			= static_cast<deUint32>(m_attachments.size());
902 	pAttachments			= &m_attachments[0];
903 }
904 
ColorBlendState(deUint32 _attachmentCount,const vk::VkPipelineColorBlendAttachmentState * _attachments,vk::VkBool32 _logicOpEnable,vk::VkLogicOp _logicOp)905 PipelineCreateInfo::ColorBlendState::ColorBlendState (deUint32											_attachmentCount,
906 													  const vk::VkPipelineColorBlendAttachmentState*	_attachments,
907 													  vk::VkBool32										_logicOpEnable,
908 													  vk::VkLogicOp										_logicOp)
909 	: m_attachments(_attachments, _attachments + _attachmentCount)
910 {
911 	sType = vk::VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO;
912 	pNext	= DE_NULL;
913 	flags					= 0;
914 	logicOpEnable			= _logicOpEnable;
915 	logicOp					= _logicOp;
916 	attachmentCount			= static_cast<deUint32>(m_attachments.size());
917 	pAttachments			= &m_attachments[0];
918 }
919 
ColorBlendState(const vk::VkPipelineColorBlendStateCreateInfo & createInfo)920 PipelineCreateInfo::ColorBlendState::ColorBlendState (const vk::VkPipelineColorBlendStateCreateInfo& createInfo)
921 	: m_attachments (createInfo.pAttachments, createInfo.pAttachments + createInfo.attachmentCount)
922 {
923 	sType = createInfo.sType;
924 	pNext = createInfo.pNext;
925 	flags					= createInfo.flags;
926 	logicOpEnable			= createInfo.logicOpEnable;
927 	logicOp					= createInfo.logicOp;
928 	attachmentCount			= static_cast<deUint32>(m_attachments.size());
929 	pAttachments			= &m_attachments[0];
930 }
931 
ColorBlendState(const ColorBlendState & createInfo,std::vector<float> _blendConstants)932 PipelineCreateInfo::ColorBlendState::ColorBlendState (const ColorBlendState& createInfo, std::vector<float> _blendConstants)
933 	: m_attachments (createInfo.pAttachments, createInfo.pAttachments + createInfo.attachmentCount)
934 {
935 	sType = createInfo.sType;
936 	pNext = createInfo.pNext;
937 	flags					= createInfo.flags;
938 	logicOpEnable			= createInfo.logicOpEnable;
939 	logicOp					= createInfo.logicOp;
940 	attachmentCount			= static_cast<deUint32>(m_attachments.size());
941 	pAttachments			= &m_attachments[0];
942 	deMemcpy(blendConstants, &_blendConstants[0], 4 * sizeof(float));
943 }
944 
Attachment(vk::VkBool32 _blendEnable,vk::VkBlendFactor _srcColorBlendFactor,vk::VkBlendFactor _dstColorBlendFactor,vk::VkBlendOp _colorBlendOp,vk::VkBlendFactor _srcAlphaBlendFactor,vk::VkBlendFactor _dstAlphaBlendFactor,vk::VkBlendOp _alphaBlendOp,vk::VkColorComponentFlags _colorWriteMask)945 PipelineCreateInfo::ColorBlendState::Attachment::Attachment (vk::VkBool32				_blendEnable,
946 															 vk::VkBlendFactor			_srcColorBlendFactor,
947 															 vk::VkBlendFactor			_dstColorBlendFactor,
948 															 vk::VkBlendOp				_colorBlendOp,
949 															 vk::VkBlendFactor			_srcAlphaBlendFactor,
950 															 vk::VkBlendFactor			_dstAlphaBlendFactor,
951 															 vk::VkBlendOp				_alphaBlendOp,
952 															 vk::VkColorComponentFlags	_colorWriteMask)
953 {
954 	blendEnable			= _blendEnable;
955 	srcColorBlendFactor	= _srcColorBlendFactor;
956 	dstColorBlendFactor	= _dstColorBlendFactor;
957 	colorBlendOp		= _colorBlendOp;
958 	srcAlphaBlendFactor	= _srcAlphaBlendFactor;
959 	dstAlphaBlendFactor	= _dstAlphaBlendFactor;
960 	alphaBlendOp		= _alphaBlendOp;
961 	colorWriteMask		= _colorWriteMask;
962 }
963 
StencilOpState(vk::VkStencilOp _failOp,vk::VkStencilOp _passOp,vk::VkStencilOp _depthFailOp,vk::VkCompareOp _compareOp,deUint32 _compareMask,deUint32 _writeMask,deUint32 _reference)964 PipelineCreateInfo::DepthStencilState::StencilOpState::StencilOpState (vk::VkStencilOp	_failOp,
965 																	   vk::VkStencilOp	_passOp,
966 																	   vk::VkStencilOp	_depthFailOp,
967 																	   vk::VkCompareOp	_compareOp,
968 																	   deUint32			_compareMask,
969 																	   deUint32			_writeMask,
970 																	   deUint32			_reference)
971 {
972 	failOp		= _failOp;
973 	passOp		= _passOp;
974 	depthFailOp	= _depthFailOp;
975 	compareOp	= _compareOp;
976 
977 	compareMask	= _compareMask;
978 	writeMask	= _writeMask;
979 	reference	= _reference;
980 }
981 
DepthStencilState(vk::VkBool32 _depthTestEnable,vk::VkBool32 _depthWriteEnable,vk::VkCompareOp _depthCompareOp,vk::VkBool32 _depthBoundsTestEnable,vk::VkBool32 _stencilTestEnable,StencilOpState _front,StencilOpState _back,float _minDepthBounds,float _maxDepthBounds)982 PipelineCreateInfo::DepthStencilState::DepthStencilState (vk::VkBool32		_depthTestEnable,
983 														  vk::VkBool32		_depthWriteEnable,
984 														  vk::VkCompareOp	_depthCompareOp,
985 														  vk::VkBool32		_depthBoundsTestEnable,
986 														  vk::VkBool32		_stencilTestEnable,
987 														  StencilOpState	_front,
988 														  StencilOpState	_back,
989 														  float				_minDepthBounds,
990 														  float				_maxDepthBounds)
991 {
992 	sType = vk::VK_STRUCTURE_TYPE_PIPELINE_DEPTH_STENCIL_STATE_CREATE_INFO;
993 	pNext = DE_NULL;
994 	flags					= 0u;
995 	depthTestEnable			= _depthTestEnable;
996 	depthWriteEnable		= _depthWriteEnable;
997 	depthCompareOp			= _depthCompareOp;
998 	depthBoundsTestEnable	= _depthBoundsTestEnable;
999 	stencilTestEnable		= _stencilTestEnable;
1000 	front	= _front;
1001 	back	= _back;
1002 
1003 	minDepthBounds = _minDepthBounds;
1004 	maxDepthBounds = _maxDepthBounds;
1005 }
1006 
DynamicState(const std::vector<vk::VkDynamicState> & _dynamicStates)1007 PipelineCreateInfo::DynamicState::DynamicState (const std::vector<vk::VkDynamicState>& _dynamicStates)
1008 {
1009 	sType	= vk::VK_STRUCTURE_TYPE_PIPELINE_DYNAMIC_STATE_CREATE_INFO;
1010 	pNext	= DE_NULL;
1011 	flags	= 0;
1012 
1013 	if (!_dynamicStates.size())
1014 	{
1015 		const vk::VkDynamicState dynamicState[] =
1016 		{
1017 			vk::VK_DYNAMIC_STATE_VIEWPORT,
1018 			vk::VK_DYNAMIC_STATE_SCISSOR,
1019 			vk::VK_DYNAMIC_STATE_LINE_WIDTH,
1020 			vk::VK_DYNAMIC_STATE_DEPTH_BIAS,
1021 			vk::VK_DYNAMIC_STATE_BLEND_CONSTANTS,
1022 			vk::VK_DYNAMIC_STATE_DEPTH_BOUNDS,
1023 			vk::VK_DYNAMIC_STATE_STENCIL_COMPARE_MASK,
1024 			vk::VK_DYNAMIC_STATE_STENCIL_WRITE_MASK,
1025 			vk::VK_DYNAMIC_STATE_STENCIL_REFERENCE,
1026 		};
1027 
1028 		for (size_t i = 0; i < DE_LENGTH_OF_ARRAY(dynamicState); ++i)
1029 		{
1030 			m_dynamicStates.push_back(dynamicState[i]);
1031 		}
1032 	}
1033 	else
1034 		m_dynamicStates = _dynamicStates;
1035 
1036 	dynamicStateCount = static_cast<deUint32>(m_dynamicStates.size());
1037 	pDynamicStates = &m_dynamicStates[0];
1038 }
1039 
DynamicState(const DynamicState & other)1040 PipelineCreateInfo::DynamicState::DynamicState (const DynamicState &other)
1041 {
1042 	sType = other.sType;
1043 	pNext = other.pNext;
1044 
1045 	flags				= other.flags;
1046 	dynamicStateCount	= other.dynamicStateCount;
1047 	m_dynamicStates		= std::vector<vk::VkDynamicState>(other.pDynamicStates, other.pDynamicStates + dynamicStateCount);
1048 	pDynamicStates		= &m_dynamicStates[0];
1049 }
1050 
operator =(const DynamicState & other)1051 PipelineCreateInfo::DynamicState& PipelineCreateInfo::DynamicState::operator= (const DynamicState& other)
1052 {
1053 	sType = other.sType;
1054 	pNext = other.pNext;
1055 
1056 	flags				= other.flags;
1057 	dynamicStateCount	= other.dynamicStateCount;
1058 	m_dynamicStates		= std::vector<vk::VkDynamicState>(other.pDynamicStates, other.pDynamicStates + dynamicStateCount);
1059 	pDynamicStates		= &m_dynamicStates[0];
1060 
1061 	return *this;
1062 }
1063 
PipelineCreateInfo(vk::VkPipelineLayout _layout,vk::VkRenderPass _renderPass,int _subpass,vk::VkPipelineCreateFlags _flags)1064 PipelineCreateInfo::PipelineCreateInfo (vk::VkPipelineLayout		_layout,
1065 										vk::VkRenderPass			_renderPass,
1066 										int							_subpass,
1067 										vk::VkPipelineCreateFlags	_flags)
1068 {
1069 	deMemset(static_cast<vk::VkGraphicsPipelineCreateInfo *>(this), 0,
1070 		sizeof(vk::VkGraphicsPipelineCreateInfo));
1071 
1072 	sType = vk::VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO;
1073 	pNext = DE_NULL;
1074 	flags				= _flags;
1075 	renderPass			= _renderPass;
1076 	subpass				= _subpass;
1077 	layout				= _layout;
1078 	basePipelineHandle	= DE_NULL;
1079 	basePipelineIndex	= 0;
1080 	pDynamicState		= DE_NULL;
1081 }
1082 
addShader(const vk::VkPipelineShaderStageCreateInfo & shader)1083 PipelineCreateInfo& PipelineCreateInfo::addShader (const vk::VkPipelineShaderStageCreateInfo& shader)
1084 {
1085 	m_shaders.push_back(shader);
1086 
1087 	stageCount	= static_cast<deUint32>(m_shaders.size());
1088 	pStages		= &m_shaders[0];
1089 
1090 	return *this;
1091 }
1092 
addState(const vk::VkPipelineVertexInputStateCreateInfo & state)1093 PipelineCreateInfo& PipelineCreateInfo::addState (const vk::VkPipelineVertexInputStateCreateInfo& state)
1094 {
1095 	m_vertexInputState	= state;
1096 	pVertexInputState	= &m_vertexInputState;
1097 
1098 	return *this;
1099 }
1100 
addState(const vk::VkPipelineInputAssemblyStateCreateInfo & state)1101 PipelineCreateInfo& PipelineCreateInfo::addState (const vk::VkPipelineInputAssemblyStateCreateInfo& state)
1102 {
1103 	m_inputAssemblyState = state;
1104 	pInputAssemblyState = &m_inputAssemblyState;
1105 
1106 	return *this;
1107 }
1108 
addState(const vk::VkPipelineColorBlendStateCreateInfo & state)1109 PipelineCreateInfo& PipelineCreateInfo::addState (const vk::VkPipelineColorBlendStateCreateInfo& state)
1110 {
1111 	m_colorBlendStateAttachments	= std::vector<vk::VkPipelineColorBlendAttachmentState>(state.pAttachments, state.pAttachments + state.attachmentCount);
1112 	m_colorBlendState				= state;
1113 	m_colorBlendState.pAttachments	= &m_colorBlendStateAttachments[0];
1114 	pColorBlendState				= &m_colorBlendState;
1115 
1116 	return *this;
1117 }
1118 
addState(const vk::VkPipelineViewportStateCreateInfo & state)1119 PipelineCreateInfo& PipelineCreateInfo::addState (const vk::VkPipelineViewportStateCreateInfo& state)
1120 {
1121 	m_viewports					= std::vector<vk::VkViewport>(state.pViewports, state.pViewports + state.viewportCount);
1122 	m_scissors					= std::vector<vk::VkRect2D>(state.pScissors, state.pScissors + state.scissorCount);
1123 	m_viewportState				= state;
1124 	m_viewportState.pViewports	= &m_viewports[0];
1125 	m_viewportState.pScissors	= &m_scissors[0];
1126 	pViewportState				= &m_viewportState;
1127 
1128 	return *this;
1129 }
1130 
addState(const vk::VkPipelineDepthStencilStateCreateInfo & state)1131 PipelineCreateInfo& PipelineCreateInfo::addState (const vk::VkPipelineDepthStencilStateCreateInfo& state)
1132 {
1133 	m_dynamicDepthStencilState	= state;
1134 	pDepthStencilState			= &m_dynamicDepthStencilState;
1135 	return *this;
1136 }
1137 
addState(const vk::VkPipelineTessellationStateCreateInfo & state)1138 PipelineCreateInfo& PipelineCreateInfo::addState (const vk::VkPipelineTessellationStateCreateInfo& state)
1139 {
1140 	m_tessState			= state;
1141 	pTessellationState	= &m_tessState;
1142 
1143 	return *this;
1144 }
1145 
addState(const vk::VkPipelineRasterizationStateCreateInfo & state)1146 PipelineCreateInfo& PipelineCreateInfo::addState (const vk::VkPipelineRasterizationStateCreateInfo& state)
1147 {
1148 	m_rasterState		= state;
1149 	pRasterizationState	= &m_rasterState;
1150 
1151 	return *this;
1152 }
1153 
addState(const vk::VkPipelineMultisampleStateCreateInfo & state)1154 PipelineCreateInfo& PipelineCreateInfo::addState (const vk::VkPipelineMultisampleStateCreateInfo& state)
1155 {
1156 
1157 	const size_t sampleMaskArrayLen = (sizeof(vk::VkSampleMask) * 8 + state.rasterizationSamples) / ( sizeof(vk::VkSampleMask) * 8 );
1158 	m_multisampleStateSampleMask	= std::vector<vk::VkSampleMask>(state.pSampleMask, state.pSampleMask + sampleMaskArrayLen);
1159 	m_multisampleState				= state;
1160 	m_multisampleState.pSampleMask	= &m_multisampleStateSampleMask[0];
1161 	pMultisampleState				= &m_multisampleState;
1162 
1163 	return *this;
1164 }
addState(const vk::VkPipelineDynamicStateCreateInfo & state)1165 PipelineCreateInfo& PipelineCreateInfo::addState (const vk::VkPipelineDynamicStateCreateInfo& state)
1166 {
1167 	m_dynamicStates					= std::vector<vk::VkDynamicState>(state.pDynamicStates, state.pDynamicStates + state.dynamicStateCount);
1168 	m_dynamicState					= state;
1169 	m_dynamicState.pDynamicStates	= &m_dynamicStates[0];
1170 	pDynamicState					= &m_dynamicState;
1171 
1172 	return *this;
1173 }
1174 
SamplerCreateInfo(vk::VkFilter _magFilter,vk::VkFilter _minFilter,vk::VkSamplerMipmapMode _mipmapMode,vk::VkSamplerAddressMode _addressModeU,vk::VkSamplerAddressMode _addressModeV,vk::VkSamplerAddressMode _addressModeW,float _mipLodBias,vk::VkBool32 _anisotropyEnable,float _maxAnisotropy,vk::VkBool32 _compareEnable,vk::VkCompareOp _compareOp,float _minLod,float _maxLod,vk::VkBorderColor _borderColor,vk::VkBool32 _unnormalizedCoordinates)1175 SamplerCreateInfo::SamplerCreateInfo (vk::VkFilter				_magFilter,
1176 									  vk::VkFilter				_minFilter,
1177 									  vk::VkSamplerMipmapMode	_mipmapMode,
1178 									  vk::VkSamplerAddressMode	_addressModeU,
1179 									  vk::VkSamplerAddressMode	_addressModeV,
1180 									  vk::VkSamplerAddressMode	_addressModeW,
1181 									  float						_mipLodBias,
1182 									  vk::VkBool32				_anisotropyEnable,
1183 									  float						_maxAnisotropy,
1184 									  vk::VkBool32				_compareEnable,
1185 									  vk::VkCompareOp			_compareOp,
1186 									  float						_minLod,
1187 									  float						_maxLod,
1188 									  vk::VkBorderColor			_borderColor,
1189 									  vk::VkBool32				_unnormalizedCoordinates)
1190 {
1191 	sType					= vk::VK_STRUCTURE_TYPE_SAMPLER_CREATE_INFO;
1192 	pNext					= DE_NULL;
1193 	flags					= 0u;
1194 	magFilter				= _magFilter;
1195 	minFilter				= _minFilter;
1196 	mipmapMode				= _mipmapMode;
1197 	addressModeU			= _addressModeU;
1198 	addressModeV			= _addressModeV;
1199 	addressModeW			= _addressModeW;
1200 	mipLodBias				= _mipLodBias;
1201 	anisotropyEnable		= _anisotropyEnable;
1202 	maxAnisotropy			= _maxAnisotropy;
1203 	compareEnable			= _compareEnable;
1204 	compareOp				= _compareOp;
1205 	minLod					= _minLod;
1206 	maxLod					= _maxLod;
1207 	borderColor				= _borderColor;
1208 	unnormalizedCoordinates = _unnormalizedCoordinates;
1209 }
1210 } // Draw
1211 } // vkt
1212