mirror of
https://github.com/starr-dusT/yuzu-mainline
synced 2024-03-05 21:12:25 -08:00
7dafa96ab5
Put all varyings into a single std::bitset with helpers to access it. Implement passthrough geometry shaders using host's.
36 lines
909 B
C++
36 lines
909 B
C++
// Copyright 2021 yuzu Emulator Project
|
|
// Licensed under GPLv2 or any later version
|
|
// Refer to the license.txt file included.
|
|
|
|
#pragma once
|
|
|
|
#include <array>
|
|
#include <string>
|
|
|
|
#include "shader_recompiler/frontend/ir/abstract_syntax_list.h"
|
|
#include "shader_recompiler/frontend/ir/basic_block.h"
|
|
#include "shader_recompiler/program_header.h"
|
|
#include "shader_recompiler/shader_info.h"
|
|
#include "shader_recompiler/stage.h"
|
|
|
|
namespace Shader::IR {
|
|
|
|
struct Program {
|
|
AbstractSyntaxList syntax_list;
|
|
BlockList blocks;
|
|
BlockList post_order_blocks;
|
|
Info info;
|
|
Stage stage{};
|
|
std::array<u32, 3> workgroup_size{};
|
|
OutputTopology output_topology{};
|
|
u32 output_vertices{};
|
|
u32 invocations{};
|
|
u32 local_memory_size{};
|
|
u32 shared_memory_size{};
|
|
bool is_geometry_passthrough{};
|
|
};
|
|
|
|
[[nodiscard]] std::string DumpProgram(const Program& program);
|
|
|
|
} // namespace Shader::IR
|