diff options
author | 2018-01-09 13:55:33 -0500 | |
---|---|---|
committer | 2018-01-09 19:22:27 +0000 | |
commit | 17b7c054339dfa592571ebd92d2419949baca6f0 (patch) | |
tree | 2ecef7a4c9ccfb2edaf72dd5eb56b229ed29a2ca /src/gpu/vk | |
parent | e48eb337e1ff16bc0190a0562b01ea4cc9a84ccb (diff) |
Update GrSemaphore to allow it to only be used once for signaling and once for waiting.
This is required for Vulkan which doesn't allow a semaphore to be waited on by
multiple things at once or signaled from multiple places.
Bug: skia:
Change-Id: Iac0cb782a6662167c2cab1fd6a2c80378834a480
Reviewed-on: https://skia-review.googlesource.com/92601
Commit-Queue: Greg Daniel <egdaniel@google.com>
Reviewed-by: Brian Osman <brianosman@google.com>
Diffstat (limited to 'src/gpu/vk')
-rw-r--r-- | src/gpu/vk/GrVkGpu.cpp | 17 | ||||
-rw-r--r-- | src/gpu/vk/GrVkGpu.h | 10 |
2 files changed, 15 insertions, 12 deletions
diff --git a/src/gpu/vk/GrVkGpu.cpp b/src/gpu/vk/GrVkGpu.cpp index baf022185f..e1be99e872 100644 --- a/src/gpu/vk/GrVkGpu.cpp +++ b/src/gpu/vk/GrVkGpu.cpp @@ -2162,25 +2162,28 @@ sk_sp<GrSemaphore> SK_WARN_UNUSED_RESULT GrVkGpu::makeSemaphore(bool isOwned) { return GrVkSemaphore::Make(this, isOwned); } -sk_sp<GrSemaphore> GrVkGpu::wrapBackendSemaphore(const GrBackendSemaphore& semaphore, - GrWrapOwnership ownership) { +sk_sp<GrSemaphore> GrVkGpu::onWrapBackendSemaphore(const GrBackendSemaphore& semaphore, + GrWrapOwnership ownership) { return GrVkSemaphore::MakeWrapped(this, semaphore.vkSemaphore(), ownership); } -void GrVkGpu::insertSemaphore(sk_sp<GrSemaphore> semaphore, bool flush) { +void GrVkGpu::onInsertSemaphore(sk_sp<GrSemaphore> semaphore, bool flush) { GrVkSemaphore* vkSem = static_cast<GrVkSemaphore*>(semaphore.get()); - const GrVkSemaphore::Resource* resource = vkSem->getResource(); - resource->ref(); - fSemaphoresToSignal.push_back(resource); + if (vkSem) { + const GrVkSemaphore::Resource* resource = vkSem->getResource(); + resource->ref(); + fSemaphoresToSignal.push_back(resource); + } if (flush) { this->submitCommandBuffer(kSkip_SyncQueue); } } -void GrVkGpu::waitSemaphore(sk_sp<GrSemaphore> semaphore) { +void GrVkGpu::onWaitSemaphore(sk_sp<GrSemaphore> semaphore) { GrVkSemaphore* vkSem = static_cast<GrVkSemaphore*>(semaphore.get()); + SkASSERT(vkSem); const GrVkSemaphore::Resource* resource = vkSem->getResource(); resource->ref(); diff --git a/src/gpu/vk/GrVkGpu.h b/src/gpu/vk/GrVkGpu.h index 95d96b1196..e3055945bc 100644 --- a/src/gpu/vk/GrVkGpu.h +++ b/src/gpu/vk/GrVkGpu.h @@ -135,11 +135,6 @@ public: void deleteFence(GrFence) const override; sk_sp<GrSemaphore> SK_WARN_UNUSED_RESULT makeSemaphore(bool isOwned) override; - sk_sp<GrSemaphore> wrapBackendSemaphore(const GrBackendSemaphore& semaphore, - GrWrapOwnership ownership) override; - void insertSemaphore(sk_sp<GrSemaphore> semaphore, bool flush) override; - void waitSemaphore(sk_sp<GrSemaphore> semaphore) override; - sk_sp<GrSemaphore> prepareTextureForCrossContextUsage(GrTexture*) override; void generateMipmap(GrVkTexture* tex, GrSurfaceOrigin texOrigin); @@ -209,6 +204,11 @@ private: void onFinishFlush(bool insertedSemaphores) override; + void onInsertSemaphore(sk_sp<GrSemaphore> semaphore, bool flush) override; + void onWaitSemaphore(sk_sp<GrSemaphore> semaphore) override; + sk_sp<GrSemaphore> onWrapBackendSemaphore(const GrBackendSemaphore& semaphore, + GrWrapOwnership ownership) override; + // Ends and submits the current command buffer to the queue and then creates a new command // buffer and begins it. If sync is set to kForce_SyncQueue, the function will wait for all // work in the queue to finish before returning. If this GrVkGpu object has any semaphores in |