mirror of
https://github.com/skyline-emu/skyline.git
synced 2025-01-11 12:29:09 +01:00
Setup minimal viewport Vulkan pipeline state
This commit is contained in:
parent
fe51db366b
commit
a04d8fb5cf
@ -196,6 +196,9 @@ namespace skyline::gpu::interconnect::maxwell3d {
|
|||||||
ViewportState::ViewportState(dirty::Handle dirtyHandle, DirtyManager &manager, const EngineRegisters &engine, u32 index) : engine{manager, dirtyHandle, engine}, index{index} {}
|
ViewportState::ViewportState(dirty::Handle dirtyHandle, DirtyManager &manager, const EngineRegisters &engine, u32 index) : engine{manager, dirtyHandle, engine}, index{index} {}
|
||||||
|
|
||||||
void ViewportState::Flush(InterconnectContext &ctx, StateUpdateBuilder &builder) {
|
void ViewportState::Flush(InterconnectContext &ctx, StateUpdateBuilder &builder) {
|
||||||
|
if (index != 0 && !ctx.gpu.traits.supportsMultipleViewports)
|
||||||
|
return;
|
||||||
|
|
||||||
if (!engine->viewportScaleOffsetEnable)
|
if (!engine->viewportScaleOffsetEnable)
|
||||||
// https://github.com/Ryujinx/Ryujinx/pull/3328
|
// https://github.com/Ryujinx/Ryujinx/pull/3328
|
||||||
Logger::Warn("Viewport scale/offset disable is unimplemented");
|
Logger::Warn("Viewport scale/offset disable is unimplemented");
|
||||||
|
@ -475,16 +475,28 @@ namespace skyline::gpu::interconnect::maxwell3d {
|
|||||||
.pDynamicStates = dynamicStates.data()
|
.pDynamicStates = dynamicStates.data()
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// Dynamic state will be used instead of these
|
||||||
|
std::array<vk::Rect2D, engine::ViewportCount> emptyScissors{};
|
||||||
|
std::array<vk::Viewport, engine::ViewportCount> emptyViewports{};
|
||||||
|
|
||||||
|
vk::PipelineViewportStateCreateInfo viewportState{
|
||||||
|
.viewportCount = static_cast<u32>(ctx.gpu.traits.supportsMultipleViewports ? engine::ViewportCount : 1),
|
||||||
|
.pViewports = emptyViewports.data(),
|
||||||
|
.scissorCount = static_cast<u32>(ctx.gpu.traits.supportsMultipleViewports ? engine::ViewportCount : 1),
|
||||||
|
.pScissors = emptyScissors.data(),
|
||||||
|
};
|
||||||
|
|
||||||
return ctx.gpu.graphicsPipelineCache.GetCompiledPipeline(cache::GraphicsPipelineCache::PipelineState{
|
return ctx.gpu.graphicsPipelineCache.GetCompiledPipeline(cache::GraphicsPipelineCache::PipelineState{
|
||||||
.shaderStages = shaderStageInfos,
|
.shaderStages = shaderStageInfos,
|
||||||
.vertexState = vertexInputState,
|
.vertexState = vertexInputState,
|
||||||
.inputAssemblyState = inputAssemblyState,
|
.inputAssemblyState = inputAssemblyState,
|
||||||
.tessellationState = tessellationState,
|
.tessellationState = tessellationState,
|
||||||
.viewportState = {},
|
.viewportState = viewportState,
|
||||||
.rasterizationState = rasterizationState,
|
.rasterizationState = rasterizationState,
|
||||||
.multisampleState = multisampleState,
|
.multisampleState = multisampleState,
|
||||||
.depthStencilState = depthStencilState,
|
.depthStencilState = depthStencilState,
|
||||||
.colorBlendState = colorBlendState,
|
.colorBlendState = colorBlendState,
|
||||||
|
.dynamicState = dynamicState,
|
||||||
.colorAttachments = colorAttachments,
|
.colorAttachments = colorAttachments,
|
||||||
.depthStencilAttachment = depthAttachment,
|
.depthStencilAttachment = depthAttachment,
|
||||||
}, layoutBindings);
|
}, layoutBindings);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user