blob: 23bc5b17821e6e3cd5a6b854d0ed420341ce7e23 [file] [log] [blame]
Ethan Nicholas8e265a72018-12-12 16:22:40 -05001/*
2 * Copyright 2018 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
Mike Kleinc0bd9f92019-04-23 12:05:21 -05008#include "src/gpu/vk/GrVkCommandPool.h"
Ethan Nicholas8e265a72018-12-12 16:22:40 -05009
Mike Kleinc0bd9f92019-04-23 12:05:21 -050010#include "src/gpu/GrContextPriv.h"
11#include "src/gpu/vk/GrVkCommandBuffer.h"
12#include "src/gpu/vk/GrVkGpu.h"
Ethan Nicholas8e265a72018-12-12 16:22:40 -050013
Greg Daniele643da62019-11-05 12:36:42 -050014GrVkCommandPool* GrVkCommandPool::Create(GrVkGpu* gpu) {
Greg Daniel8daf3b72019-07-30 09:57:26 -040015 VkCommandPoolCreateFlags cmdPoolCreateFlags =
16 VK_COMMAND_POOL_CREATE_TRANSIENT_BIT |
17 VK_COMMAND_POOL_CREATE_RESET_COMMAND_BUFFER_BIT;
18 if (gpu->protectedContext()) {
19 cmdPoolCreateFlags |= VK_COMMAND_POOL_CREATE_PROTECTED_BIT;
20 }
Emircan Uysaler23ca4e72019-06-24 10:53:09 -040021
Greg Daniel8daf3b72019-07-30 09:57:26 -040022 const VkCommandPoolCreateInfo cmdPoolInfo = {
23 VK_STRUCTURE_TYPE_COMMAND_POOL_CREATE_INFO, // sType
24 nullptr, // pNext
25 cmdPoolCreateFlags, // CmdPoolCreateFlags
26 gpu->queueIndex(), // queueFamilyIndex
27 };
Greg Daniel9b63dc82019-11-06 09:21:55 -050028 VkResult result;
Greg Daniel8daf3b72019-07-30 09:57:26 -040029 VkCommandPool pool;
Greg Daniel9b63dc82019-11-06 09:21:55 -050030 GR_VK_CALL_RESULT(gpu, result, CreateCommandPool(gpu->device(), &cmdPoolInfo, nullptr, &pool));
31 if (result != VK_SUCCESS) {
32 return nullptr;
33 }
Greg Daniel8daf3b72019-07-30 09:57:26 -040034 return new GrVkCommandPool(gpu, pool);
Ethan Nicholas8e265a72018-12-12 16:22:40 -050035}
36
37GrVkCommandPool::GrVkCommandPool(const GrVkGpu* gpu, VkCommandPool commandPool)
38 : fCommandPool(commandPool) {
Greg Daniel8daf3b72019-07-30 09:57:26 -040039 fPrimaryCommandBuffer.reset(GrVkPrimaryCommandBuffer::Create(gpu, this));
Ethan Nicholas8e265a72018-12-12 16:22:40 -050040}
41
Greg Daniel8daf3b72019-07-30 09:57:26 -040042std::unique_ptr<GrVkSecondaryCommandBuffer> GrVkCommandPool::findOrCreateSecondaryCommandBuffer(
43 GrVkGpu* gpu) {
44 std::unique_ptr<GrVkSecondaryCommandBuffer> result;
Ethan Nicholas8e265a72018-12-12 16:22:40 -050045 if (fAvailableSecondaryBuffers.count()) {
Greg Daniel8daf3b72019-07-30 09:57:26 -040046 result = std::move(fAvailableSecondaryBuffers.back());
Ethan Nicholas8e265a72018-12-12 16:22:40 -050047 fAvailableSecondaryBuffers.pop_back();
Greg Daniel8daf3b72019-07-30 09:57:26 -040048 } else{
49 result.reset(GrVkSecondaryCommandBuffer::Create(gpu, this));
Ethan Nicholas8e265a72018-12-12 16:22:40 -050050 }
Greg Daniel8daf3b72019-07-30 09:57:26 -040051 return result;
Ethan Nicholas8e265a72018-12-12 16:22:40 -050052}
53
54void GrVkCommandPool::recycleSecondaryCommandBuffer(GrVkSecondaryCommandBuffer* buffer) {
55 SkASSERT(buffer->commandPool() == this);
Greg Daniel8daf3b72019-07-30 09:57:26 -040056 std::unique_ptr<GrVkSecondaryCommandBuffer> scb(buffer);
57 fAvailableSecondaryBuffers.push_back(std::move(scb));
Ethan Nicholas8e265a72018-12-12 16:22:40 -050058}
59
60void GrVkCommandPool::close() {
61 fOpen = false;
62}
63
64void GrVkCommandPool::reset(GrVkGpu* gpu) {
65 SkASSERT(!fOpen);
66 fOpen = true;
Greg Daniel8daf3b72019-07-30 09:57:26 -040067 fPrimaryCommandBuffer->recycleSecondaryCommandBuffers(gpu);
Greg Daniel95f0b162019-11-11 13:42:30 -050068 // We can't use the normal result macro calls here because we may call reset on a different
69 // thread and we can't be modifying the lost state on the GrVkGpu. We just call
70 // vkResetCommandPool and assume the "next" vulkan call will catch the lost device.
71 SkDEBUGCODE(VkResult result = )GR_VK_CALL(gpu->vkInterface(),
72 ResetCommandPool(gpu->device(), fCommandPool, 0));
73 SkASSERT(result == VK_SUCCESS || result == VK_ERROR_DEVICE_LOST);
Ethan Nicholas8e265a72018-12-12 16:22:40 -050074}
75
76void GrVkCommandPool::releaseResources(GrVkGpu* gpu) {
Brian Salomone39526b2019-06-24 16:35:53 -040077 TRACE_EVENT0("skia.gpu", TRACE_FUNC);
Ethan Nicholas8e265a72018-12-12 16:22:40 -050078 SkASSERT(!fOpen);
79 fPrimaryCommandBuffer->releaseResources(gpu);
Ethan Nicholas8e265a72018-12-12 16:22:40 -050080}
81
82void GrVkCommandPool::abandonGPUData() const {
Greg Daniel8daf3b72019-07-30 09:57:26 -040083 fPrimaryCommandBuffer->abandonGPUData();
84 for (const auto& buffer : fAvailableSecondaryBuffers) {
85 buffer->abandonGPUData();
Ethan Nicholas8e265a72018-12-12 16:22:40 -050086 }
87}
88
89void GrVkCommandPool::freeGPUData(GrVkGpu* gpu) const {
Greg Daniel8daf3b72019-07-30 09:57:26 -040090 fPrimaryCommandBuffer->freeGPUData(gpu);
91 for (const auto& buffer : fAvailableSecondaryBuffers) {
92 buffer->freeGPUData(gpu);
Ethan Nicholas8e265a72018-12-12 16:22:40 -050093 }
94 if (fCommandPool != VK_NULL_HANDLE) {
95 GR_VK_CALL(gpu->vkInterface(),
96 DestroyCommandPool(gpu->device(), fCommandPool, nullptr));
97 }
98}