mirror of
https://git.eden-emu.dev/eden-emu/eden
synced 2026-05-14 10:46:58 +02:00
[vulkan] Small patch for tesselation vs an already handling with topology patch list.
This commit is contained in:
parent
b1821cb60e
commit
76bb5fc18b
2 changed files with 7 additions and 1 deletions
|
|
@ -98,6 +98,9 @@ public:
|
||||||
bool UsesExtendedDynamicState2LogicOp() const noexcept {
|
bool UsesExtendedDynamicState2LogicOp() const noexcept {
|
||||||
return key.state.extended_dynamic_state_2_logic_op != 0;
|
return key.state.extended_dynamic_state_2_logic_op != 0;
|
||||||
}
|
}
|
||||||
|
bool HasTessellationStages() const noexcept {
|
||||||
|
return static_cast<bool>(spv_modules[1]) || static_cast<bool>(spv_modules[2]);
|
||||||
|
}
|
||||||
GraphicsPipeline& operator=(GraphicsPipeline&&) noexcept = delete;
|
GraphicsPipeline& operator=(GraphicsPipeline&&) noexcept = delete;
|
||||||
GraphicsPipeline(GraphicsPipeline&&) noexcept = delete;
|
GraphicsPipeline(GraphicsPipeline&&) noexcept = delete;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1991,11 +1991,14 @@ void RasterizerVulkan::UpdateDepthCompareOp(Tegra::Engines::Maxwell3D::Regs& reg
|
||||||
}
|
}
|
||||||
|
|
||||||
void RasterizerVulkan::UpdatePrimitiveTopology([[maybe_unused]] Tegra::Engines::Maxwell3D::Regs& regs) {
|
void RasterizerVulkan::UpdatePrimitiveTopology([[maybe_unused]] Tegra::Engines::Maxwell3D::Regs& regs) {
|
||||||
|
GraphicsPipeline* pipeline = pipeline_cache.CurrentGraphicsPipeline();
|
||||||
const auto topology = maxwell3d->draw_manager->GetDrawState().topology;
|
const auto topology = maxwell3d->draw_manager->GetDrawState().topology;
|
||||||
if (!state_tracker.ChangePrimitiveTopology(topology)) {
|
if (!state_tracker.ChangePrimitiveTopology(topology)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const auto vk_topology = MaxwellToVK::PrimitiveTopology(device, topology);
|
const auto vk_topology = pipeline && pipeline->HasTessellationStages()
|
||||||
|
? VK_PRIMITIVE_TOPOLOGY_PATCH_LIST
|
||||||
|
: MaxwellToVK::PrimitiveTopology(device, topology);
|
||||||
scheduler.Record([vk_topology](vk::CommandBuffer cmdbuf) {
|
scheduler.Record([vk_topology](vk::CommandBuffer cmdbuf) {
|
||||||
cmdbuf.SetPrimitiveTopologyEXT(vk_topology);
|
cmdbuf.SetPrimitiveTopologyEXT(vk_topology);
|
||||||
});
|
});
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue