Flutter Engine
The Flutter Engine
Loading...
Searching...
No Matches
GrVkPipeline.cpp
Go to the documentation of this file.
1/*
2* Copyright 2016 Google Inc.
3*
4* Use of this source code is governed by a BSD-style license that can be
5* found in the LICENSE file.
6*/
7
9
19
20using namespace skia_private;
21
22#if defined(SK_ENABLE_SCOPED_LSAN_SUPPRESSIONS)
23#include <sanitizer/lsan_interface.h>
24#endif
25
27 switch (type) {
49 return VK_FORMAT_R8_SINT;
55 return VK_FORMAT_R8_UINT;
61 return VK_FORMAT_R8_UNORM;
73 return VK_FORMAT_R32_SINT;
75 return VK_FORMAT_R32_UINT;
80 }
81 SK_ABORT("Unknown vertex attrib type");
82}
83
85 const GrGeometryProcessor::AttributeSet& vertexAttribs,
86 const GrGeometryProcessor::AttributeSet& instanceAttribs,
89 VkVertexInputAttributeDescription* attributeDesc) {
90 int vaCount = vertexAttribs.count();
91 int iaCount = instanceAttribs.count();
92
93 uint32_t vertexBinding = 0, instanceBinding = 0;
94
95 int nextBinding = bindingDescs->size();
96 if (vaCount) {
97 vertexBinding = nextBinding++;
98 }
99
100 if (iaCount) {
101 instanceBinding = nextBinding;
102 }
103
104 // setup attribute descriptions
105 int attribIndex = 0;
106 for (auto attrib : vertexAttribs) {
107 VkVertexInputAttributeDescription& vkAttrib = attributeDesc[attribIndex];
108 vkAttrib.location = attribIndex++; // for now assume location = attribIndex
109 vkAttrib.binding = vertexBinding;
110 vkAttrib.format = attrib_type_to_vkformat(attrib.cpuType());
111 vkAttrib.offset = *attrib.offset();
112 }
113
114 for (auto attrib : instanceAttribs) {
115 VkVertexInputAttributeDescription& vkAttrib = attributeDesc[attribIndex];
116 vkAttrib.location = attribIndex++; // for now assume location = attribIndex
117 vkAttrib.binding = instanceBinding;
118 vkAttrib.format = attrib_type_to_vkformat(attrib.cpuType());
119 vkAttrib.offset = *attrib.offset();
120 }
121
122 if (vaCount) {
123 bindingDescs->push_back() = {
124 vertexBinding,
125 (uint32_t) vertexAttribs.stride(),
127 };
128 }
129 if (iaCount) {
130 bindingDescs->push_back() = {
131 instanceBinding,
132 (uint32_t) instanceAttribs.stride(),
134 };
135 }
136
137 memset(vertexInputInfo, 0, sizeof(VkPipelineVertexInputStateCreateInfo));
139 vertexInputInfo->pNext = nullptr;
140 vertexInputInfo->flags = 0;
141 vertexInputInfo->vertexBindingDescriptionCount = bindingDescs->size();
142 vertexInputInfo->pVertexBindingDescriptions = bindingDescs->begin();
143 vertexInputInfo->vertexAttributeDescriptionCount = vaCount + iaCount;
144 vertexInputInfo->pVertexAttributeDescriptions = attributeDesc;
145}
146
162
164 VkPipelineInputAssemblyStateCreateInfo* inputAssemblyInfo) {
165 memset(inputAssemblyInfo, 0, sizeof(VkPipelineInputAssemblyStateCreateInfo));
167 inputAssemblyInfo->pNext = nullptr;
168 inputAssemblyInfo->flags = 0;
169 inputAssemblyInfo->primitiveRestartEnable = false;
170 inputAssemblyInfo->topology = gr_primitive_type_to_vk_topology(primitiveType);
171}
172
174 static const VkStencilOp gTable[] = {
175 VK_STENCIL_OP_KEEP, // kKeep
176 VK_STENCIL_OP_ZERO, // kZero
177 VK_STENCIL_OP_REPLACE, // kReplace
178 VK_STENCIL_OP_INVERT, // kInvert
183 };
184 static_assert(std::size(gTable) == kGrStencilOpCount);
185 static_assert(0 == (int)GrStencilOp::kKeep);
186 static_assert(1 == (int)GrStencilOp::kZero);
187 static_assert(2 == (int)GrStencilOp::kReplace);
188 static_assert(3 == (int)GrStencilOp::kInvert);
189 static_assert(4 == (int)GrStencilOp::kIncWrap);
190 static_assert(5 == (int)GrStencilOp::kDecWrap);
191 static_assert(6 == (int)GrStencilOp::kIncClamp);
192 static_assert(7 == (int)GrStencilOp::kDecClamp);
194 return gTable[(int)op];
195}
196
198 static const VkCompareOp gTable[] = {
199 VK_COMPARE_OP_ALWAYS, // kAlways
200 VK_COMPARE_OP_NEVER, // kNever
201 VK_COMPARE_OP_GREATER, // kGreater
203 VK_COMPARE_OP_LESS, // kLess
205 VK_COMPARE_OP_EQUAL, // kEqual
206 VK_COMPARE_OP_NOT_EQUAL, // kNotEqual
207 };
208 static_assert(std::size(gTable) == kGrStencilTestCount);
209 static_assert(0 == (int)GrStencilTest::kAlways);
210 static_assert(1 == (int)GrStencilTest::kNever);
211 static_assert(2 == (int)GrStencilTest::kGreater);
212 static_assert(3 == (int)GrStencilTest::kGEqual);
213 static_assert(4 == (int)GrStencilTest::kLess);
214 static_assert(5 == (int)GrStencilTest::kLEqual);
215 static_assert(6 == (int)GrStencilTest::kEqual);
216 static_assert(7 == (int)GrStencilTest::kNotEqual);
218
219 return gTable[(int)test];
220}
221
223 VkStencilOpState* opState, const GrStencilSettings::Face& stencilFace) {
224 opState->failOp = stencil_op_to_vk_stencil_op(stencilFace.fFailOp);
225 opState->passOp = stencil_op_to_vk_stencil_op(stencilFace.fPassOp);
226 opState->depthFailOp = opState->failOp;
227 opState->compareOp = stencil_func_to_vk_compare_op(stencilFace.fTest);
228 opState->compareMask = stencilFace.fTestMask;
229 opState->writeMask = stencilFace.fWriteMask;
230 opState->reference = stencilFace.fRef;
231}
232
234 const GrStencilSettings& stencilSettings,
235 GrSurfaceOrigin origin,
237
238 memset(stencilInfo, 0, sizeof(VkPipelineDepthStencilStateCreateInfo));
240 stencilInfo->pNext = nullptr;
241 stencilInfo->flags = 0;
242 // set depth testing defaults
243 stencilInfo->depthTestEnable = VK_FALSE;
244 stencilInfo->depthWriteEnable = VK_FALSE;
246 stencilInfo->depthBoundsTestEnable = VK_FALSE;
247 stencilInfo->stencilTestEnable = !stencilSettings.isDisabled();
248 if (!stencilSettings.isDisabled()) {
249 if (!stencilSettings.isTwoSided()) {
250 setup_stencil_op_state(&stencilInfo->front, stencilSettings.singleSidedFace());
251 stencilInfo->back = stencilInfo->front;
252 } else {
253 setup_stencil_op_state(&stencilInfo->front, stencilSettings.postOriginCCWFace(origin));
254 setup_stencil_op_state(&stencilInfo->back, stencilSettings.postOriginCWFace(origin));
255 }
256 }
257 stencilInfo->minDepthBounds = 0.0f;
258 stencilInfo->maxDepthBounds = 1.0f;
259}
260
262 memset(viewportInfo, 0, sizeof(VkPipelineViewportStateCreateInfo));
264 viewportInfo->pNext = nullptr;
265 viewportInfo->flags = 0;
266
267 viewportInfo->viewportCount = 1;
268 viewportInfo->pViewports = nullptr; // This is set dynamically
269
270 viewportInfo->scissorCount = 1;
271 viewportInfo->pScissors = nullptr; // This is set dynamically
272
273 SkASSERT(viewportInfo->viewportCount == viewportInfo->scissorCount);
274}
275
276static void setup_multisample_state(int numSamples,
277 const GrCaps* caps,
278 VkPipelineMultisampleStateCreateInfo* multisampleInfo) {
279 memset(multisampleInfo, 0, sizeof(VkPipelineMultisampleStateCreateInfo));
281 multisampleInfo->pNext = nullptr;
282 multisampleInfo->flags = 0;
284 &multisampleInfo->rasterizationSamples));
285 multisampleInfo->sampleShadingEnable = VK_FALSE;
286 multisampleInfo->minSampleShading = 0.0f;
287 multisampleInfo->pSampleMask = nullptr;
288 multisampleInfo->alphaToCoverageEnable = VK_FALSE;
289 multisampleInfo->alphaToOneEnable = VK_FALSE;
290}
291
331
333 static const VkBlendOp gTable[] = {
334 // Basic blend ops
338
339 // Advanced blend ops
355
356 // Illegal.
358 };
359 static_assert(0 == (int)skgpu::BlendEquation::kAdd);
360 static_assert(1 == (int)skgpu::BlendEquation::kSubtract);
361 static_assert(2 == (int)skgpu::BlendEquation::kReverseSubtract);
362 static_assert(3 == (int)skgpu::BlendEquation::kScreen);
363 static_assert(4 == (int)skgpu::BlendEquation::kOverlay);
364 static_assert(5 == (int)skgpu::BlendEquation::kDarken);
365 static_assert(6 == (int)skgpu::BlendEquation::kLighten);
366 static_assert(7 == (int)skgpu::BlendEquation::kColorDodge);
367 static_assert(8 == (int)skgpu::BlendEquation::kColorBurn);
368 static_assert(9 == (int)skgpu::BlendEquation::kHardLight);
369 static_assert(10 == (int)skgpu::BlendEquation::kSoftLight);
370 static_assert(11 == (int)skgpu::BlendEquation::kDifference);
371 static_assert(12 == (int)skgpu::BlendEquation::kExclusion);
372 static_assert(13 == (int)skgpu::BlendEquation::kMultiply);
373 static_assert(14 == (int)skgpu::BlendEquation::kHSLHue);
374 static_assert(15 == (int)skgpu::BlendEquation::kHSLSaturation);
375 static_assert(16 == (int)skgpu::BlendEquation::kHSLColor);
376 static_assert(17 == (int)skgpu::BlendEquation::kHSLLuminosity);
377 static_assert(std::size(gTable) == skgpu::kBlendEquationCnt);
378
379 SkASSERT((unsigned)equation < skgpu::kBlendEquationCnt);
380 return gTable[(int)equation];
381}
382
383static void setup_color_blend_state(const skgpu::BlendInfo& blendInfo,
385 VkPipelineColorBlendAttachmentState* attachmentState) {
386 skgpu::BlendEquation equation = blendInfo.fEquation;
387 skgpu::BlendCoeff srcCoeff = blendInfo.fSrcBlend;
388 skgpu::BlendCoeff dstCoeff = blendInfo.fDstBlend;
389 bool blendOff = skgpu::BlendShouldDisable(equation, srcCoeff, dstCoeff);
390
391 memset(attachmentState, 0, sizeof(VkPipelineColorBlendAttachmentState));
392 attachmentState->blendEnable = !blendOff;
393 if (!blendOff) {
394 attachmentState->srcColorBlendFactor = blend_coeff_to_vk_blend(srcCoeff);
395 attachmentState->dstColorBlendFactor = blend_coeff_to_vk_blend(dstCoeff);
396 attachmentState->colorBlendOp = blend_equation_to_vk_blend_op(equation);
397 attachmentState->srcAlphaBlendFactor = blend_coeff_to_vk_blend(srcCoeff);
398 attachmentState->dstAlphaBlendFactor = blend_coeff_to_vk_blend(dstCoeff);
399 attachmentState->alphaBlendOp = blend_equation_to_vk_blend_op(equation);
400 }
401
402 if (!blendInfo.fWritesColor) {
403 attachmentState->colorWriteMask = 0;
404 } else {
407 }
408
409 memset(colorBlendInfo, 0, sizeof(VkPipelineColorBlendStateCreateInfo));
411 colorBlendInfo->pNext = nullptr;
412 colorBlendInfo->flags = 0;
413 colorBlendInfo->logicOpEnable = VK_FALSE;
414 colorBlendInfo->attachmentCount = 1;
415 colorBlendInfo->pAttachments = attachmentState;
416 // colorBlendInfo->blendConstants is set dynamically
417}
418
419static void setup_raster_state(bool isWireframe,
420 const GrCaps* caps,
422 memset(rasterInfo, 0, sizeof(VkPipelineRasterizationStateCreateInfo));
424 rasterInfo->pNext = nullptr;
425 rasterInfo->flags = 0;
426 rasterInfo->depthClampEnable = VK_FALSE;
427 rasterInfo->rasterizerDiscardEnable = VK_FALSE;
428 rasterInfo->polygonMode = (caps->wireframeMode() || isWireframe) ?
430 rasterInfo->cullMode = VK_CULL_MODE_NONE;
432 rasterInfo->depthBiasEnable = VK_FALSE;
433 rasterInfo->depthBiasConstantFactor = 0.0f;
434 rasterInfo->depthBiasClamp = 0.0f;
435 rasterInfo->depthBiasSlopeFactor = 0.0f;
436 rasterInfo->lineWidth = 1.0f;
437}
438
441 memset(conservativeRasterInfo, 0,
443 conservativeRasterInfo->sType =
445 conservativeRasterInfo->pNext = nullptr;
446 conservativeRasterInfo->flags = 0;
447 conservativeRasterInfo->conservativeRasterizationMode =
449 conservativeRasterInfo->extraPrimitiveOverestimationSize = 0;
450}
451
453 VkDynamicState* dynamicStates) {
454 memset(dynamicInfo, 0, sizeof(VkPipelineDynamicStateCreateInfo));
456 dynamicInfo->pNext = VK_NULL_HANDLE;
457 dynamicInfo->flags = 0;
458 dynamicStates[0] = VK_DYNAMIC_STATE_VIEWPORT;
459 dynamicStates[1] = VK_DYNAMIC_STATE_SCISSOR;
460 dynamicStates[2] = VK_DYNAMIC_STATE_BLEND_CONSTANTS;
461 dynamicInfo->dynamicStateCount = 3;
462 dynamicInfo->pDynamicStates = dynamicStates;
463}
464
466 const GrGeometryProcessor::AttributeSet& vertexAttribs,
467 const GrGeometryProcessor::AttributeSet& instanceAttribs,
468 GrPrimitiveType primitiveType,
469 GrSurfaceOrigin origin,
470 const GrStencilSettings& stencilSettings,
471 int numSamples,
472 bool isHWAntialiasState,
473 const skgpu::BlendInfo& blendInfo,
474 bool isWireframe,
475 bool useConservativeRaster,
476 uint32_t subpass,
477 VkPipelineShaderStageCreateInfo* shaderStageInfo,
478 int shaderStageCount,
479 VkRenderPass compatibleRenderPass,
480 VkPipelineLayout layout,
481 bool ownsLayout,
482 VkPipelineCache cache) {
486 int totalAttributeCnt = vertexAttribs.count() + instanceAttribs.count();
487 SkASSERT(totalAttributeCnt <= gpu->vkCaps().maxVertexAttributes());
488 VkVertexInputAttributeDescription* pAttribs = attributeDesc.push_back_n(totalAttributeCnt);
489 setup_vertex_input_state(vertexAttribs, instanceAttribs, &vertexInputInfo, &bindingDescs,
490 pAttribs);
491
493 setup_input_assembly_state(primitiveType, &inputAssemblyInfo);
494
496 setup_depth_stencil_state(stencilSettings, origin, &depthStencilInfo);
497
499 setup_viewport_scissor_state(&viewportInfo);
500
502 setup_multisample_state(numSamples, gpu->caps(), &multisampleInfo);
503
504 // We will only have one color attachment per pipeline.
505 VkPipelineColorBlendAttachmentState attachmentStates[1];
507 setup_color_blend_state(blendInfo, &colorBlendInfo, attachmentStates);
508
510 setup_raster_state(isWireframe, gpu->caps(), &rasterInfo);
511
513 if (useConservativeRaster) {
515 setup_conservative_raster_info(&conservativeRasterInfo);
516 conservativeRasterInfo.pNext = rasterInfo.pNext;
517 rasterInfo.pNext = &conservativeRasterInfo;
518 }
519
520 VkDynamicState dynamicStates[3];
522 setup_dynamic_state(&dynamicInfo, dynamicStates);
523
524 VkGraphicsPipelineCreateInfo pipelineCreateInfo;
525 memset(&pipelineCreateInfo, 0, sizeof(VkGraphicsPipelineCreateInfo));
527 pipelineCreateInfo.pNext = nullptr;
528 pipelineCreateInfo.flags = 0;
529 pipelineCreateInfo.stageCount = shaderStageCount;
530 pipelineCreateInfo.pStages = shaderStageInfo;
531 pipelineCreateInfo.pVertexInputState = &vertexInputInfo;
532 pipelineCreateInfo.pInputAssemblyState = &inputAssemblyInfo;
533 pipelineCreateInfo.pTessellationState = nullptr;
534 pipelineCreateInfo.pViewportState = &viewportInfo;
535 pipelineCreateInfo.pRasterizationState = &rasterInfo;
536 pipelineCreateInfo.pMultisampleState = &multisampleInfo;
537 pipelineCreateInfo.pDepthStencilState = &depthStencilInfo;
538 pipelineCreateInfo.pColorBlendState = &colorBlendInfo;
539 pipelineCreateInfo.pDynamicState = &dynamicInfo;
540 pipelineCreateInfo.layout = layout;
541 pipelineCreateInfo.renderPass = compatibleRenderPass;
542 pipelineCreateInfo.subpass = subpass;
543 pipelineCreateInfo.basePipelineHandle = VK_NULL_HANDLE;
544 pipelineCreateInfo.basePipelineIndex = -1;
545
546 VkPipeline vkPipeline;
547 VkResult err;
548 {
549 TRACE_EVENT0_ALWAYS("skia.shaders", "CreateGraphicsPipeline");
550#if defined(SK_ENABLE_SCOPED_LSAN_SUPPRESSIONS)
551 // skia:8712
552 __lsan::ScopedDisabler lsanDisabler;
553#endif
554 GR_VK_CALL_RESULT(gpu, err, CreateGraphicsPipelines(gpu->device(), cache, 1,
555 &pipelineCreateInfo, nullptr,
556 &vkPipeline));
557 }
558 if (err) {
559 SkDebugf("Failed to create pipeline. Error: %d\n", err);
560 return nullptr;
561 }
562
563 if (!ownsLayout) {
565 }
566 return sk_sp<GrVkPipeline>(new GrVkPipeline(gpu, vkPipeline, layout));
567}
568
570 const GrProgramInfo& programInfo,
571 VkPipelineShaderStageCreateInfo* shaderStageInfo,
572 int shaderStageCount,
573 VkRenderPass compatibleRenderPass,
574 VkPipelineLayout layout,
575 VkPipelineCache cache,
576 uint32_t subpass) {
577 const GrGeometryProcessor& geomProc = programInfo.geomProc();
578 const GrPipeline& pipeline = programInfo.pipeline();
579
580 return Make(gpu,
581 geomProc.vertexAttributes(),
582 geomProc.instanceAttributes(),
583 programInfo.primitiveType(),
584 programInfo.origin(),
585 programInfo.nonGLStencilSettings(),
586 programInfo.numSamples(),
587 programInfo.numSamples() > 1,
588 pipeline.getXferProcessor().getBlendInfo(),
589 pipeline.isWireframe(),
590 pipeline.usesConservativeRaster(),
591 subpass,
592 shaderStageInfo,
593 shaderStageCount,
594 compatibleRenderPass,
595 layout,
596 /*ownsLayout=*/true,
597 cache);
598}
599
601 GR_VK_CALL(fGpu->vkInterface(), DestroyPipeline(fGpu->device(), fPipeline, nullptr));
604 DestroyPipelineLayout(fGpu->device(), fPipelineLayout, nullptr));
605 }
606}
607
609 GrVkCommandBuffer* cmdBuffer,
610 SkISize colorAttachmentDimensions,
611 GrSurfaceOrigin rtOrigin,
612 const SkIRect& scissorRect) {
613 SkASSERT(scissorRect.isEmpty() ||
614 SkIRect::MakeSize(colorAttachmentDimensions).contains(scissorRect));
615
616 VkRect2D scissor;
617 scissor.offset.x = scissorRect.fLeft;
618 scissor.extent.width = scissorRect.width();
619 if (kTopLeft_GrSurfaceOrigin == rtOrigin) {
620 scissor.offset.y = scissorRect.fTop;
621 } else {
623 scissor.offset.y = colorAttachmentDimensions.height() - scissorRect.fBottom;
624 }
625 scissor.extent.height = scissorRect.height();
626
627 SkASSERT(scissor.offset.x >= 0);
628 SkASSERT(scissor.offset.y >= 0);
629 cmdBuffer->setScissor(gpu, 0, 1, &scissor);
630}
631
633 GrVkCommandBuffer* cmdBuffer,
634 SkISize colorAttachmentDimensions) {
635 // We always use one viewport the size of the RT
636 VkViewport viewport;
637 viewport.x = 0.0f;
638 viewport.y = 0.0f;
639 viewport.width = SkIntToScalar(colorAttachmentDimensions.width());
640 viewport.height = SkIntToScalar(colorAttachmentDimensions.height());
641 viewport.minDepth = 0.0f;
642 viewport.maxDepth = 1.0f;
643 cmdBuffer->setViewport(gpu, 0, 1, &viewport);
644}
645
647 GrVkCommandBuffer* cmdBuffer,
648 const skgpu::Swizzle& swizzle,
649 const GrXferProcessor& xferProcessor) {
650 const skgpu::BlendInfo& blendInfo = xferProcessor.getBlendInfo();
651 skgpu::BlendCoeff srcCoeff = blendInfo.fSrcBlend;
652 skgpu::BlendCoeff dstCoeff = blendInfo.fDstBlend;
653 float floatColors[4];
655 // Swizzle the blend to match what the shader will output.
656 SkPMColor4f blendConst = swizzle.applyTo(blendInfo.fBlendConstant);
657 floatColors[0] = blendConst.fR;
658 floatColors[1] = blendConst.fG;
659 floatColors[2] = blendConst.fB;
660 floatColors[3] = blendConst.fA;
661 cmdBuffer->setBlendConstants(gpu, floatColors);
662 }
663}
static constexpr int kGrStencilTestCount
GrStencilTest
GrStencilOp
static constexpr int kGrStencilOpCount
GrPrimitiveType
Definition GrTypesPriv.h:42
GrVertexAttribType
@ kUShort_norm_GrVertexAttribType
@ kFloat2_GrVertexAttribType
@ kUShort2_GrVertexAttribType
@ kUInt_GrVertexAttribType
@ kUByte4_norm_GrVertexAttribType
@ kUByte_GrVertexAttribType
@ kShort2_GrVertexAttribType
@ kUShort4_norm_GrVertexAttribType
@ kInt_GrVertexAttribType
@ kByte_GrVertexAttribType
@ kByte4_GrVertexAttribType
@ kFloat3_GrVertexAttribType
@ kFloat_GrVertexAttribType
@ kByte2_GrVertexAttribType
@ kFloat4_GrVertexAttribType
@ kShort4_GrVertexAttribType
@ kUShort2_norm_GrVertexAttribType
@ kInt3_GrVertexAttribType
@ kHalf2_GrVertexAttribType
@ kHalf4_GrVertexAttribType
@ kUByte4_GrVertexAttribType
@ kUByte2_GrVertexAttribType
@ kInt4_GrVertexAttribType
@ kUByte_norm_GrVertexAttribType
@ kInt2_GrVertexAttribType
@ kHalf_GrVertexAttribType
GrSurfaceOrigin
Definition GrTypes.h:147
@ kBottomLeft_GrSurfaceOrigin
Definition GrTypes.h:149
@ kTopLeft_GrSurfaceOrigin
Definition GrTypes.h:148
static VkBlendFactor blend_coeff_to_vk_blend(skgpu::BlendCoeff coeff)
static void setup_multisample_state(int numSamples, const GrCaps *caps, VkPipelineMultisampleStateCreateInfo *multisampleInfo)
static VkBlendOp blend_equation_to_vk_blend_op(skgpu::BlendEquation equation)
static VkStencilOp stencil_op_to_vk_stencil_op(GrStencilOp op)
static void setup_stencil_op_state(VkStencilOpState *opState, const GrStencilSettings::Face &stencilFace)
static void setup_vertex_input_state(const GrGeometryProcessor::AttributeSet &vertexAttribs, const GrGeometryProcessor::AttributeSet &instanceAttribs, VkPipelineVertexInputStateCreateInfo *vertexInputInfo, STArray< 2, VkVertexInputBindingDescription, true > *bindingDescs, VkVertexInputAttributeDescription *attributeDesc)
static void setup_conservative_raster_info(VkPipelineRasterizationConservativeStateCreateInfoEXT *conservativeRasterInfo)
static void setup_input_assembly_state(GrPrimitiveType primitiveType, VkPipelineInputAssemblyStateCreateInfo *inputAssemblyInfo)
static VkFormat attrib_type_to_vkformat(GrVertexAttribType type)
static void setup_viewport_scissor_state(VkPipelineViewportStateCreateInfo *viewportInfo)
static VkPrimitiveTopology gr_primitive_type_to_vk_topology(GrPrimitiveType primitiveType)
static void setup_raster_state(bool isWireframe, const GrCaps *caps, VkPipelineRasterizationStateCreateInfo *rasterInfo)
static void setup_color_blend_state(const skgpu::BlendInfo &blendInfo, VkPipelineColorBlendStateCreateInfo *colorBlendInfo, VkPipelineColorBlendAttachmentState *attachmentState)
static void setup_dynamic_state(VkPipelineDynamicStateCreateInfo *dynamicInfo, VkDynamicState *dynamicStates)
static VkCompareOp stencil_func_to_vk_compare_op(GrStencilTest test)
static void setup_depth_stencil_state(const GrStencilSettings &stencilSettings, GrSurfaceOrigin origin, VkPipelineDepthStencilStateCreateInfo *stencilInfo)
#define GR_VK_CALL(IFACE, X)
Definition GrVkUtil.h:24
#define GR_VK_CALL_RESULT(GPU, RESULT, X)
Definition GrVkUtil.h:35
#define SkAssertResult(cond)
Definition SkAssert.h:123
#define SkUNREACHABLE
Definition SkAssert.h:135
#define SK_ABORT(message,...)
Definition SkAssert.h:70
#define SkASSERT(cond)
Definition SkAssert.h:116
void SK_SPI SkDebugf(const char format[],...) SK_PRINTF_LIKE(1
#define SkIntToScalar(x)
Definition SkScalar.h:57
#define TRACE_EVENT0_ALWAYS(category_group, name)
Type::kYUV Type::kRGBA() int(0.7 *637)
bool conservativeRasterSupport() const
Definition GrCaps.h:95
bool wireframeMode() const
Definition GrCaps.h:399
const AttributeSet & vertexAttributes() const
const AttributeSet & instanceAttributes() const
const GrCaps * caps() const
Definition GrGpu.h:73
int numSamples() const
GrSurfaceOrigin origin() const
GrPrimitiveType primitiveType() const
const GrPipeline & pipeline() const
const GrGeometryProcessor & geomProc() const
GrStencilSettings nonGLStencilSettings() const
bool isTwoSided() const
const Face & postOriginCCWFace(GrSurfaceOrigin origin) const
bool isDisabled() const
const Face & singleSidedFace() const
const Face & postOriginCWFace(GrSurfaceOrigin origin) const
void setBlendConstants(const GrVkGpu *gpu, const float blendConstants[4])
void setViewport(const GrVkGpu *gpu, uint32_t firstViewport, uint32_t viewportCount, const VkViewport *viewports)
void setScissor(const GrVkGpu *gpu, uint32_t firstScissor, uint32_t scissorCount, const VkRect2D *scissors)
const skgpu::VulkanInterface * vkInterface() const
Definition GrVkGpu.h:60
VkDevice device() const
Definition GrVkGpu.h:71
static void SetDynamicScissorRectState(GrVkGpu *, GrVkCommandBuffer *, SkISize colorAttachmentDimensions, GrSurfaceOrigin, const SkIRect &scissorRect)
VkPipelineLayout layout() const
static void SetDynamicBlendConstantState(GrVkGpu *, GrVkCommandBuffer *, const skgpu::Swizzle &writeSwizzle, const GrXferProcessor &)
void freeGPUData() const override
VkPipeline fPipeline
static sk_sp< GrVkPipeline > Make(GrVkGpu *, const GrGeometryProcessor::AttributeSet &vertexAttribs, const GrGeometryProcessor::AttributeSet &instanceAttribs, GrPrimitiveType, GrSurfaceOrigin, const GrStencilSettings &, int numSamples, bool isHWAntialiasState, const skgpu::BlendInfo &, bool isWireframe, bool useConservativeRaster, uint32_t subpass, VkPipelineShaderStageCreateInfo *shaderStageInfo, int shaderStageCount, VkRenderPass compatibleRenderPass, VkPipelineLayout layout, bool ownsLayout, VkPipelineCache cache)
VkPipelineLayout fPipelineLayout
VkPipeline pipeline() const
static void SetDynamicViewportState(GrVkGpu *, GrVkCommandBuffer *, SkISize colorAttachmentDimensions)
skgpu::BlendInfo getBlendInfo() const
constexpr std::array< float, 4 > applyTo(std::array< float, 4 > color) const
Definition Swizzle.h:101
T * push_back_n(int n)
Definition SkTArray.h:262
int size() const
Definition SkTArray.h:416
static constexpr bool BlendCoeffRefsConstant(const BlendCoeff coeff)
Definition Blend.h:141
static constexpr bool BlendShouldDisable(BlendEquation equation, BlendCoeff srcCoeff, BlendCoeff dstCoeff)
Definition Blend.h:145
static const int kBlendEquationCnt
Definition Blend.h:55
BlendEquation
Definition Blend.h:26
BlendCoeff
Definition Blend.h:60
static constexpr bool SampleCountToVkSampleCount(uint32_t samples, VkSampleCountFlagBits *vkSamples)
int32_t fBottom
larger y-axis bounds
Definition SkRect.h:36
constexpr int32_t height() const
Definition SkRect.h:165
int32_t fTop
smaller y-axis bounds
Definition SkRect.h:34
static constexpr SkIRect MakeSize(const SkISize &size)
Definition SkRect.h:66
constexpr int32_t width() const
Definition SkRect.h:158
bool isEmpty() const
Definition SkRect.h:202
int32_t fLeft
smaller x-axis bounds
Definition SkRect.h:33
bool contains(int32_t x, int32_t y) const
Definition SkRect.h:463
constexpr int32_t width() const
Definition SkSize.h:36
constexpr int32_t height() const
Definition SkSize.h:37
float fB
blue component
Definition SkColor.h:265
float fR
red component
Definition SkColor.h:263
float fG
green component
Definition SkColor.h:264
float fA
alpha component
Definition SkColor.h:266
uint32_t width
uint32_t height
const VkPipelineTessellationStateCreateInfo * pTessellationState
const VkPipelineDepthStencilStateCreateInfo * pDepthStencilState
const VkPipelineDynamicStateCreateInfo * pDynamicState
const VkPipelineColorBlendStateCreateInfo * pColorBlendState
VkPipelineCreateFlags flags
const VkPipelineInputAssemblyStateCreateInfo * pInputAssemblyState
const VkPipelineMultisampleStateCreateInfo * pMultisampleState
const VkPipelineVertexInputStateCreateInfo * pVertexInputState
const VkPipelineShaderStageCreateInfo * pStages
const VkPipelineRasterizationStateCreateInfo * pRasterizationState
const VkPipelineViewportStateCreateInfo * pViewportState
VkColorComponentFlags colorWriteMask
VkPipelineColorBlendStateCreateFlags flags
const VkPipelineColorBlendAttachmentState * pAttachments
VkPipelineDepthStencilStateCreateFlags flags
VkPipelineDynamicStateCreateFlags flags
const VkDynamicState * pDynamicStates
VkPipelineInputAssemblyStateCreateFlags flags
VkPipelineMultisampleStateCreateFlags flags
VkSampleCountFlagBits rasterizationSamples
VkConservativeRasterizationModeEXT conservativeRasterizationMode
VkPipelineRasterizationConservativeStateCreateFlagsEXT flags
VkPipelineRasterizationStateCreateFlags flags
const VkVertexInputAttributeDescription * pVertexAttributeDescriptions
const VkVertexInputBindingDescription * pVertexBindingDescriptions
VkPipelineVertexInputStateCreateFlags flags
VkPipelineViewportStateCreateFlags flags
VkExtent2D extent
VkOffset2D offset
VkStencilOp failOp
VkStencilOp passOp
VkCompareOp compareOp
VkStencilOp depthFailOp
skgpu::BlendCoeff fDstBlend
Definition Blend.h:96
SkPMColor4f fBlendConstant
Definition Blend.h:97
bool fWritesColor
Definition Blend.h:98
skgpu::BlendCoeff fSrcBlend
Definition Blend.h:95
VkDynamicState
@ VK_DYNAMIC_STATE_BLEND_CONSTANTS
@ VK_DYNAMIC_STATE_VIEWPORT
@ VK_DYNAMIC_STATE_SCISSOR
VkStencilOp
@ VK_STENCIL_OP_INCREMENT_AND_CLAMP
@ VK_STENCIL_OP_DECREMENT_AND_CLAMP
@ VK_STENCIL_OP_INCREMENT_AND_WRAP
@ VK_STENCIL_OP_KEEP
@ VK_STENCIL_OP_REPLACE
@ VK_STENCIL_OP_ZERO
@ VK_STENCIL_OP_DECREMENT_AND_WRAP
@ VK_STENCIL_OP_INVERT
@ VK_CULL_MODE_NONE
@ VK_CONSERVATIVE_RASTERIZATION_MODE_OVERESTIMATE_EXT
VkCompareOp
@ VK_COMPARE_OP_LESS_OR_EQUAL
@ VK_COMPARE_OP_LESS
@ VK_COMPARE_OP_NOT_EQUAL
@ VK_COMPARE_OP_NEVER
@ VK_COMPARE_OP_ALWAYS
@ VK_COMPARE_OP_EQUAL
@ VK_COMPARE_OP_GREATER_OR_EQUAL
@ VK_COMPARE_OP_GREATER
VkBlendOp
@ VK_BLEND_OP_MULTIPLY_EXT
@ VK_BLEND_OP_ADD
@ VK_BLEND_OP_HARDLIGHT_EXT
@ VK_BLEND_OP_OVERLAY_EXT
@ VK_BLEND_OP_COLORDODGE_EXT
@ VK_BLEND_OP_SUBTRACT
@ VK_BLEND_OP_HSL_COLOR_EXT
@ VK_BLEND_OP_DARKEN_EXT
@ VK_BLEND_OP_SOFTLIGHT_EXT
@ VK_BLEND_OP_LIGHTEN_EXT
@ VK_BLEND_OP_HSL_HUE_EXT
@ VK_BLEND_OP_HSL_SATURATION_EXT
@ VK_BLEND_OP_SCREEN_EXT
@ VK_BLEND_OP_HSL_LUMINOSITY_EXT
@ VK_BLEND_OP_EXCLUSION_EXT
@ VK_BLEND_OP_COLORBURN_EXT
@ VK_BLEND_OP_DIFFERENCE_EXT
@ VK_BLEND_OP_REVERSE_SUBTRACT
#define VK_FALSE
VkPrimitiveTopology
@ VK_PRIMITIVE_TOPOLOGY_TRIANGLE_LIST
@ VK_PRIMITIVE_TOPOLOGY_TRIANGLE_STRIP
@ VK_PRIMITIVE_TOPOLOGY_POINT_LIST
@ VK_PRIMITIVE_TOPOLOGY_LINE_STRIP
@ VK_PRIMITIVE_TOPOLOGY_LINE_LIST
@ VK_FRONT_FACE_COUNTER_CLOCKWISE
VkResult
#define VK_NULL_HANDLE
Definition vulkan_core.h:46
@ VK_VERTEX_INPUT_RATE_VERTEX
@ VK_VERTEX_INPUT_RATE_INSTANCE
@ VK_COLOR_COMPONENT_R_BIT
@ VK_COLOR_COMPONENT_A_BIT
@ VK_COLOR_COMPONENT_B_BIT
@ VK_COLOR_COMPONENT_G_BIT
VkFormat
@ VK_FORMAT_R16G16B16A16_UNORM
@ VK_FORMAT_R16G16_SFLOAT
@ VK_FORMAT_R32G32_SFLOAT
@ VK_FORMAT_R16_SFLOAT
@ VK_FORMAT_R32_SINT
@ VK_FORMAT_R16G16_UINT
@ VK_FORMAT_R8_UNORM
@ VK_FORMAT_R32G32B32A32_SFLOAT
@ VK_FORMAT_R32_SFLOAT
@ VK_FORMAT_R16G16B16A16_SINT
@ VK_FORMAT_R8G8B8A8_UNORM
@ VK_FORMAT_R16G16_SINT
@ VK_FORMAT_R8G8_SINT
@ VK_FORMAT_R32G32B32_SINT
@ VK_FORMAT_R16_UNORM
@ VK_FORMAT_R8_SINT
@ VK_FORMAT_R8_UINT
@ VK_FORMAT_R16G16B16A16_SFLOAT
@ VK_FORMAT_R16G16_UNORM
@ VK_FORMAT_R8G8B8A8_SINT
@ VK_FORMAT_R32G32B32A32_SINT
@ VK_FORMAT_R32G32B32_SFLOAT
@ VK_FORMAT_R8G8B8A8_UINT
@ VK_FORMAT_R8G8_UINT
@ VK_FORMAT_R32G32_SINT
@ VK_FORMAT_R32_UINT
VkBlendFactor
@ VK_BLEND_FACTOR_ONE
@ VK_BLEND_FACTOR_SRC1_ALPHA
@ VK_BLEND_FACTOR_ONE_MINUS_DST_ALPHA
@ VK_BLEND_FACTOR_ONE_MINUS_SRC1_COLOR
@ VK_BLEND_FACTOR_ONE_MINUS_SRC_COLOR
@ VK_BLEND_FACTOR_ONE_MINUS_CONSTANT_COLOR
@ VK_BLEND_FACTOR_SRC_COLOR
@ VK_BLEND_FACTOR_CONSTANT_COLOR
@ VK_BLEND_FACTOR_SRC_ALPHA
@ VK_BLEND_FACTOR_DST_ALPHA
@ VK_BLEND_FACTOR_ONE_MINUS_SRC1_ALPHA
@ VK_BLEND_FACTOR_ZERO
@ VK_BLEND_FACTOR_ONE_MINUS_SRC_ALPHA
@ VK_BLEND_FACTOR_DST_COLOR
@ VK_BLEND_FACTOR_SRC1_COLOR
@ VK_BLEND_FACTOR_ONE_MINUS_DST_COLOR
@ VK_POLYGON_MODE_FILL
@ VK_POLYGON_MODE_LINE
@ VK_STRUCTURE_TYPE_PIPELINE_DYNAMIC_STATE_CREATE_INFO
@ VK_STRUCTURE_TYPE_PIPELINE_COLOR_BLEND_STATE_CREATE_INFO
@ VK_STRUCTURE_TYPE_PIPELINE_INPUT_ASSEMBLY_STATE_CREATE_INFO
@ VK_STRUCTURE_TYPE_PIPELINE_MULTISAMPLE_STATE_CREATE_INFO
@ VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_STATE_CREATE_INFO
@ VK_STRUCTURE_TYPE_PIPELINE_RASTERIZATION_CONSERVATIVE_STATE_CREATE_INFO_EXT
@ VK_STRUCTURE_TYPE_GRAPHICS_PIPELINE_CREATE_INFO
@ VK_STRUCTURE_TYPE_PIPELINE_VIEWPORT_STATE_CREATE_INFO
@ VK_STRUCTURE_TYPE_PIPELINE_VERTEX_INPUT_STATE_CREATE_INFO
@ VK_STRUCTURE_TYPE_PIPELINE_DEPTH_STENCIL_STATE_CREATE_INFO