[Vulkan] Implement ClearCaches and don't do it for pipelines
This commit is contained in:
parent
35cfb07967
commit
91c4e02e96
|
@ -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();
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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,
|
||||||
|
|
|
@ -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) {}
|
||||||
|
|
Loading…
Reference in New Issue