mirror of
https://git.suyu.dev/suyu/suyu
synced 2025-01-09 16:03:21 +00:00
37 lines
1.7 KiB
C++
37 lines
1.7 KiB
C++
// SPDX-FileCopyrightText: Copyright 2021 yuzu Emulator Project
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
|
|
|
#pragma once
|
|
|
|
#include "shader_recompiler/environment.h"
|
|
#include "shader_recompiler/frontend/ir/basic_block.h"
|
|
#include "shader_recompiler/frontend/ir/program.h"
|
|
#include "shader_recompiler/frontend/maxwell/control_flow.h"
|
|
#include "shader_recompiler/object_pool.h"
|
|
#include "shader_recompiler/runtime_info.h"
|
|
|
|
namespace Shader {
|
|
struct HostTranslateInfo;
|
|
}
|
|
|
|
namespace Shader::Maxwell {
|
|
|
|
[[nodiscard]] IR::Program TranslateProgram(ObjectPool<IR::Inst>& inst_pool,
|
|
ObjectPool<IR::Block>& block_pool, Environment& env,
|
|
Flow::CFG& cfg, const HostTranslateInfo& host_info);
|
|
|
|
[[nodiscard]] IR::Program MergeDualVertexPrograms(IR::Program& vertex_a, IR::Program& vertex_b,
|
|
Environment& env_vertex_b);
|
|
|
|
void ConvertLegacyToGeneric(IR::Program& program, const RuntimeInfo& runtime_info);
|
|
|
|
// Maxwell v1 and older Nvidia cards don't support setting gl_Layer from non-geometry stages.
|
|
// This creates a workaround by setting the layer as a generic output and creating a
|
|
// passthrough geometry shader that reads the generic and sets the layer.
|
|
[[nodiscard]] IR::Program GenerateGeometryPassthrough(ObjectPool<IR::Inst>& inst_pool,
|
|
ObjectPool<IR::Block>& block_pool,
|
|
const HostTranslateInfo& host_info,
|
|
IR::Program& source_program,
|
|
Shader::OutputTopology output_topology);
|
|
|
|
} // namespace Shader::Maxwell
|