[Vulkan] Implement ClearCaches and don't do it for pipelines

This commit is contained in:
Triang3l 2022-05-22 15:05:15 +03:00
parent 35cfb07967
commit 91c4e02e96
4 changed files with 23 additions and 34 deletions

View File

@ -70,6 +70,11 @@ VulkanCommandProcessor::VulkanCommandProcessor(
VulkanCommandProcessor::~VulkanCommandProcessor() = default; VulkanCommandProcessor::~VulkanCommandProcessor() = default;
void VulkanCommandProcessor::ClearCaches() {
CommandProcessor::ClearCaches();
cache_clear_requested_ = true;
}
void VulkanCommandProcessor::TracePlaybackWroteMemory(uint32_t base_ptr, void VulkanCommandProcessor::TracePlaybackWroteMemory(uint32_t base_ptr,
uint32_t length) { uint32_t length) {
shared_memory_->MemoryInvalidationCallback(base_ptr, length, true); shared_memory_->MemoryInvalidationCallback(base_ptr, length, true);
@ -2295,21 +2300,10 @@ bool VulkanCommandProcessor::EndSubmission(bool is_swap) {
texture_cache_->ClearCache(); texture_cache_->ClearCache();
pipeline_cache_->ClearCache();
render_target_cache_->ClearCache(); render_target_cache_->ClearCache();
for (const auto& pipeline_layout_pair : pipeline_layouts_) { // Not clearing the pipeline layouts and the descriptor set layouts as
dfn.vkDestroyPipelineLayout( // they're referenced by pipelines, which are not destroyed.
device, pipeline_layout_pair.second.GetPipelineLayout(), nullptr);
}
pipeline_layouts_.clear();
for (const auto& descriptor_set_layout_pair :
descriptor_set_layouts_textures_) {
dfn.vkDestroyDescriptorSetLayout(
device, descriptor_set_layout_pair.second, nullptr);
}
descriptor_set_layouts_textures_.clear();
primitive_processor_->ClearCache(); primitive_processor_->ClearCache();

View File

@ -62,6 +62,8 @@ class VulkanCommandProcessor : public CommandProcessor {
kernel::KernelState* kernel_state); kernel::KernelState* kernel_state);
~VulkanCommandProcessor(); ~VulkanCommandProcessor();
void ClearCaches() override;
void TracePlaybackWroteMemory(uint32_t base_ptr, uint32_t length) override; void TracePlaybackWroteMemory(uint32_t base_ptr, uint32_t length) override;
void RestoreEdramSnapshot(const void* snapshot) override; void RestoreEdramSnapshot(const void* snapshot) override;

View File

@ -64,24 +64,6 @@ void VulkanPipelineCache::Shutdown() {
const ui::vulkan::VulkanProvider::DeviceFunctions& dfn = provider.dfn(); const ui::vulkan::VulkanProvider::DeviceFunctions& dfn = provider.dfn();
VkDevice device = provider.device(); VkDevice device = provider.device();
ClearCache();
for (const auto& geometry_shader_pair : geometry_shaders_) {
if (geometry_shader_pair.second != VK_NULL_HANDLE) {
dfn.vkDestroyShaderModule(device, geometry_shader_pair.second, nullptr);
}
}
geometry_shaders_.clear();
shader_translator_.reset();
}
void VulkanPipelineCache::ClearCache() {
const ui::vulkan::VulkanProvider& provider =
command_processor_.GetVulkanProvider();
const ui::vulkan::VulkanProvider::DeviceFunctions& dfn = provider.dfn();
VkDevice device = provider.device();
// Destroy all pipelines. // Destroy all pipelines.
last_pipeline_ = nullptr; last_pipeline_ = nullptr;
for (const auto& pipeline_pair : pipelines_) { for (const auto& pipeline_pair : pipelines_) {
@ -91,13 +73,24 @@ void VulkanPipelineCache::ClearCache() {
} }
pipelines_.clear(); pipelines_.clear();
// Destroy all shaders. // Destroy all internal shaders.
for (const auto& geometry_shader_pair : geometry_shaders_) {
if (geometry_shader_pair.second != VK_NULL_HANDLE) {
dfn.vkDestroyShaderModule(device, geometry_shader_pair.second, nullptr);
}
}
geometry_shaders_.clear();
// Destroy all translated shaders.
for (auto it : shaders_) { for (auto it : shaders_) {
delete it.second; delete it.second;
} }
shaders_.clear(); shaders_.clear();
texture_binding_layout_map_.clear(); texture_binding_layout_map_.clear();
texture_binding_layouts_.clear(); texture_binding_layouts_.clear();
// Shut down shader translation.
shader_translator_.reset();
} }
VulkanShader* VulkanPipelineCache::LoadShader(xenos::ShaderType shader_type, VulkanShader* VulkanPipelineCache::LoadShader(xenos::ShaderType shader_type,

View File

@ -58,7 +58,6 @@ class VulkanPipelineCache {
bool Initialize(); bool Initialize();
void Shutdown(); void Shutdown();
void ClearCache();
VulkanShader* LoadShader(xenos::ShaderType shader_type, VulkanShader* LoadShader(xenos::ShaderType shader_type,
const uint32_t* host_address, uint32_t dword_count); const uint32_t* host_address, uint32_t dword_count);
@ -198,7 +197,8 @@ class VulkanPipelineCache {
struct Pipeline { struct Pipeline {
VkPipeline pipeline = VK_NULL_HANDLE; VkPipeline pipeline = VK_NULL_HANDLE;
// Owned by VulkanCommandProcessor, valid until ClearCache. // The layouts are owned by the VulkanCommandProcessor, and must not be
// destroyed by it while the pipeline cache is active.
const PipelineLayoutProvider* pipeline_layout; const PipelineLayoutProvider* pipeline_layout;
Pipeline(const PipelineLayoutProvider* pipeline_layout_provider) Pipeline(const PipelineLayoutProvider* pipeline_layout_provider)
: pipeline_layout(pipeline_layout_provider) {} : pipeline_layout(pipeline_layout_provider) {}