diff options
| author | 2021-04-19 01:03:38 +0200 | |
|---|---|---|
| committer | 2021-07-22 21:51:29 -0400 | |
| commit | b541f5e5e333a8ec8c3569e02d67e59ad14217c2 (patch) | |
| tree | 5b19bdd92d74ce8e32be75cfa2c27a4612a663de /src/video_core/renderer_vulkan | |
| parent | shader: Implement delegation of Exit to dispatcher on CFG (diff) | |
| download | yuzu-b541f5e5e333a8ec8c3569e02d67e59ad14217c2.tar.gz yuzu-b541f5e5e333a8ec8c3569e02d67e59ad14217c2.tar.xz yuzu-b541f5e5e333a8ec8c3569e02d67e59ad14217c2.zip | |
shader: Implement VertexA stage
Diffstat (limited to 'src/video_core/renderer_vulkan')
| -rw-r--r-- | src/video_core/renderer_vulkan/vk_pipeline_cache.cpp | 17 |
1 files changed, 14 insertions, 3 deletions
diff --git a/src/video_core/renderer_vulkan/vk_pipeline_cache.cpp b/src/video_core/renderer_vulkan/vk_pipeline_cache.cpp index 0822862fe..638475251 100644 --- a/src/video_core/renderer_vulkan/vk_pipeline_cache.cpp +++ b/src/video_core/renderer_vulkan/vk_pipeline_cache.cpp | |||
| @@ -47,6 +47,7 @@ MICROPROFILE_DECLARE(Vulkan_PipelineCache); | |||
| 47 | 47 | ||
| 48 | namespace { | 48 | namespace { |
| 49 | using Shader::Backend::SPIRV::EmitSPIRV; | 49 | using Shader::Backend::SPIRV::EmitSPIRV; |
| 50 | using Shader::Maxwell::MergeDualVertexPrograms; | ||
| 50 | using Shader::Maxwell::TranslateProgram; | 51 | using Shader::Maxwell::TranslateProgram; |
| 51 | using VideoCommon::ComputeEnvironment; | 52 | using VideoCommon::ComputeEnvironment; |
| 52 | using VideoCommon::FileEnvironment; | 53 | using VideoCommon::FileEnvironment; |
| @@ -287,22 +288,32 @@ std::unique_ptr<GraphicsPipeline> PipelineCache::CreateGraphicsPipeline( | |||
| 287 | LOG_INFO(Render_Vulkan, "0x{:016x}", key.Hash()); | 288 | LOG_INFO(Render_Vulkan, "0x{:016x}", key.Hash()); |
| 288 | size_t env_index{0}; | 289 | size_t env_index{0}; |
| 289 | std::array<Shader::IR::Program, Maxwell::MaxShaderProgram> programs; | 290 | std::array<Shader::IR::Program, Maxwell::MaxShaderProgram> programs; |
| 291 | bool uses_vertex_a{}; | ||
| 292 | std::size_t start_value_processing{}; | ||
| 290 | for (size_t index = 0; index < Maxwell::MaxShaderProgram; ++index) { | 293 | for (size_t index = 0; index < Maxwell::MaxShaderProgram; ++index) { |
| 291 | if (key.unique_hashes[index] == 0) { | 294 | if (key.unique_hashes[index] == 0) { |
| 292 | continue; | 295 | continue; |
| 293 | } | 296 | } |
| 297 | uses_vertex_a |= index == 0; | ||
| 294 | Shader::Environment& env{*envs[env_index]}; | 298 | Shader::Environment& env{*envs[env_index]}; |
| 295 | ++env_index; | 299 | ++env_index; |
| 296 | 300 | ||
| 297 | const u32 cfg_offset{static_cast<u32>(env.StartAddress() + sizeof(Shader::ProgramHeader))}; | 301 | const u32 cfg_offset{static_cast<u32>(env.StartAddress() + sizeof(Shader::ProgramHeader))}; |
| 298 | Shader::Maxwell::Flow::CFG cfg(env, pools.flow_block, cfg_offset); | 302 | Shader::Maxwell::Flow::CFG cfg(env, pools.flow_block, cfg_offset, index == 0); |
| 299 | programs[index] = TranslateProgram(pools.inst, pools.block, env, cfg); | 303 | if (!uses_vertex_a || index != 1) { |
| 304 | programs[index] = TranslateProgram(pools.inst, pools.block, env, cfg); | ||
| 305 | continue; | ||
| 306 | } | ||
| 307 | Shader::IR::Program& program_va{programs[0]}; | ||
| 308 | Shader::IR::Program program_vb{TranslateProgram(pools.inst, pools.block, env, cfg)}; | ||
| 309 | programs[index] = MergeDualVertexPrograms(program_va, program_vb, env); | ||
| 310 | start_value_processing = 1; | ||
| 300 | } | 311 | } |
| 301 | std::array<const Shader::Info*, Maxwell::MaxShaderStage> infos{}; | 312 | std::array<const Shader::Info*, Maxwell::MaxShaderStage> infos{}; |
| 302 | std::array<vk::ShaderModule, Maxwell::MaxShaderStage> modules; | 313 | std::array<vk::ShaderModule, Maxwell::MaxShaderStage> modules; |
| 303 | 314 | ||
| 304 | u32 binding{0}; | 315 | u32 binding{0}; |
| 305 | for (size_t index = 0; index < Maxwell::MaxShaderProgram; ++index) { | 316 | for (size_t index = start_value_processing; index < Maxwell::MaxShaderProgram; ++index) { |
| 306 | if (key.unique_hashes[index] == 0) { | 317 | if (key.unique_hashes[index] == 0) { |
| 307 | continue; | 318 | continue; |
| 308 | } | 319 | } |