Skip to content

Commit

Permalink
[Vulkan] Minor optimization for deferred token lookups. (apache#3960)
Browse files Browse the repository at this point in the history
Use a hash map keyed on the descriptor set to avoid bad asymptotic behaviour.
  • Loading branch information
ajtulloch authored and wweic committed Sep 30, 2019
1 parent 8ac4294 commit 72e5e7d
Showing 1 changed file with 11 additions and 5 deletions.
16 changes: 11 additions & 5 deletions src/runtime/vulkan/vulkan_stream.h
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
#include <functional>
#include <memory>
#include <vector>
#include <unordered_map>

#include "vulkan_common.h"

Expand Down Expand Up @@ -98,26 +99,29 @@ class VulkanStream {

// It is invalid to schedule this instance on the current stream if we already
// have a matching descriptor set and a non-matching buffer set.
if (std::any_of(deferred_tokens_.begin(), deferred_tokens_.end(),
if (std::any_of(deferred_tokens_[deferred_token.descriptor_set_].begin(),
deferred_tokens_[deferred_token.descriptor_set_].end(),
[&](const VulkanStreamToken& token) {
DCHECK(token.descriptor_set_ == deferred_token.descriptor_set_);
return token.descriptor_set_ == deferred_token.descriptor_set_ &&
token.buffers_ != deferred_token.buffers_;
})) {
Synchronize();
}

// It is unnecessary to invoke our initializer if we have a matching token.
if (!std::any_of(deferred_tokens_.begin(), deferred_tokens_.end(),
if (!std::any_of(deferred_tokens_[deferred_token.descriptor_set_].begin(),
deferred_tokens_[deferred_token.descriptor_set_].end(),
[&](const VulkanStreamToken& token) {
// If we have a matching descriptor set
DCHECK(token.descriptor_set_ == deferred_token.descriptor_set_);
return token.descriptor_set_ == deferred_token.descriptor_set_ &&
token.buffers_ == deferred_token.buffers_;
})) {
deferred_initializer();
}

deferred_kernels_.push_back(deferred_kernel);
deferred_tokens_.push_back(deferred_token);
deferred_tokens_[deferred_token.descriptor_set_].push_back(deferred_token);
}

// Synchronize the current stream `state_` with respect to the host.
Expand Down Expand Up @@ -172,7 +176,9 @@ class VulkanStream {
private:
const VulkanContext* vctx_;
std::unique_ptr<VulkanStreamState> state_;
std::vector<VulkanStreamToken> deferred_tokens_;
// An index of deferred tokens, allowing us to efficiently detect duplicated
// deferred_initializer blocks.
std::unordered_map<VkDescriptorSet, std::vector<VulkanStreamToken>> deferred_tokens_;
std::vector<std::function<void(VulkanStreamState*)>> deferred_kernels_;
VkCommandPool cmd_pool_;
};
Expand Down

0 comments on commit 72e5e7d

Please sign in to comment.