[Vulkan] Change invalidated_textures_ to an unordered set

This commit is contained in:
DrChat 2018-02-24 14:23:22 -06:00
parent a753dbed15
commit 2a52156edf
2 changed files with 8 additions and 4 deletions

View File

@ -376,7 +376,7 @@ void TextureCache::WatchCallback(void* context_ptr, void* data_ptr,
// Add to pending list so Scavenge will clean it up. // Add to pending list so Scavenge will clean it up.
self->invalidated_textures_mutex_.lock(); self->invalidated_textures_mutex_.lock();
self->invalidated_textures_->push_back(touched_texture); self->invalidated_textures_->insert(touched_texture);
self->invalidated_textures_mutex_.unlock(); self->invalidated_textures_mutex_.unlock();
} }
@ -1467,13 +1467,16 @@ bool TextureCache::SetupTextureBinding(VkCommandBuffer command_buffer,
void TextureCache::RemoveInvalidatedTextures() { void TextureCache::RemoveInvalidatedTextures() {
// Clean up any invalidated textures. // Clean up any invalidated textures.
invalidated_textures_mutex_.lock(); invalidated_textures_mutex_.lock();
std::vector<Texture*>& invalidated_textures = *invalidated_textures_; std::unordered_set<Texture*>& invalidated_textures = *invalidated_textures_;
if (invalidated_textures_ == &invalidated_textures_sets_[0]) { if (invalidated_textures_ == &invalidated_textures_sets_[0]) {
invalidated_textures_ = &invalidated_textures_sets_[1]; invalidated_textures_ = &invalidated_textures_sets_[1];
} else { } else {
invalidated_textures_ = &invalidated_textures_sets_[0]; invalidated_textures_ = &invalidated_textures_sets_[0];
} }
invalidated_textures_mutex_.unlock(); invalidated_textures_mutex_.unlock();
// Append all invalidated textures to a deletion queue. They will be deleted
// when all command buffers using them have finished executing.
if (!invalidated_textures.empty()) { if (!invalidated_textures.empty()) {
for (auto it = invalidated_textures.begin(); for (auto it = invalidated_textures.begin();
it != invalidated_textures.end(); ++it) { it != invalidated_textures.end(); ++it) {

View File

@ -11,6 +11,7 @@
#define XENIA_GPU_VULKAN_TEXTURE_CACHE_H_ #define XENIA_GPU_VULKAN_TEXTURE_CACHE_H_
#include <unordered_map> #include <unordered_map>
#include <unordered_set>
#include "xenia/gpu/register_file.h" #include "xenia/gpu/register_file.h"
#include "xenia/gpu/sampler_info.h" #include "xenia/gpu/sampler_info.h"
@ -203,8 +204,8 @@ class TextureCache {
std::list<Texture*> pending_delete_textures_; std::list<Texture*> pending_delete_textures_;
std::mutex invalidated_textures_mutex_; std::mutex invalidated_textures_mutex_;
std::vector<Texture*>* invalidated_textures_; std::unordered_set<Texture*>* invalidated_textures_;
std::vector<Texture*> invalidated_textures_sets_[2]; std::unordered_set<Texture*> invalidated_textures_sets_[2];
struct UpdateSetInfo { struct UpdateSetInfo {
// Bitmap of all 32 fetch constants and whether they have been setup yet. // Bitmap of all 32 fetch constants and whether they have been setup yet.