yuzu/src/shader_recompiler/backend/spirv/emit_context.h

305 lines
7.2 KiB
C++
Raw Normal View History

2021-02-16 07:10:22 +00:00
// 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_view>
#include <sirit/sirit.h>
#include "shader_recompiler/backend/bindings.h"
2021-02-16 07:10:22 +00:00
#include "shader_recompiler/frontend/ir/program.h"
#include "shader_recompiler/profile.h"
2021-03-09 20:14:57 +00:00
#include "shader_recompiler/shader_info.h"
2021-02-16 07:10:22 +00:00
namespace Shader::Backend::SPIRV {
using Sirit::Id;
class VectorTypes {
public:
void Define(Sirit::Module& sirit_ctx, Id base_type, std::string_view name);
[[nodiscard]] Id operator[](size_t size) const noexcept {
return defs[size - 1];
}
private:
std::array<Id, 4> defs{};
};
struct TextureDefinition {
Id id;
Id sampled_type;
2021-04-22 19:17:59 +00:00
Id pointer_type;
Id image_type;
2021-04-22 19:17:59 +00:00
u32 count;
};
struct TextureBufferDefinition {
Id id;
u32 count;
};
2021-04-15 00:36:36 +00:00
struct ImageBufferDefinition {
Id id;
Id image_type;
2021-04-22 19:17:59 +00:00
u32 count;
2021-04-15 00:36:36 +00:00
};
2021-04-09 04:45:39 +00:00
struct ImageDefinition {
Id id;
Id image_type;
2021-04-22 19:17:59 +00:00
u32 count;
2021-04-09 04:45:39 +00:00
};
2021-03-09 20:14:57 +00:00
struct UniformDefinitions {
Id U8{};
Id S8{};
Id U16{};
Id S16{};
Id U32{};
Id F32{};
Id U32x2{};
Id U32x4{};
2021-03-09 20:14:57 +00:00
};
struct StorageTypeDefinition {
Id array{};
Id element{};
};
struct StorageTypeDefinitions {
StorageTypeDefinition U8{};
StorageTypeDefinition S8{};
StorageTypeDefinition U16{};
StorageTypeDefinition S16{};
StorageTypeDefinition U32{};
StorageTypeDefinition U64{};
StorageTypeDefinition F32{};
StorageTypeDefinition U32x2{};
StorageTypeDefinition U32x4{};
};
struct StorageDefinitions {
Id U8{};
Id S8{};
Id U16{};
Id S16{};
Id U32{};
Id F32{};
Id U64{};
Id U32x2{};
Id U32x4{};
};
struct GenericElementInfo {
Id id{};
u32 first_element{};
u32 num_components{};
};
2021-02-16 07:10:22 +00:00
class EmitContext final : public Sirit::Module {
public:
explicit EmitContext(const Profile& profile, IR::Program& program, Bindings& binding);
2021-02-16 07:10:22 +00:00
~EmitContext();
[[nodiscard]] Id Def(const IR::Value& value);
[[nodiscard]] Id BitOffset8(const IR::Value& offset);
[[nodiscard]] Id BitOffset16(const IR::Value& offset);
Id Const(u32 value) {
return Constant(U32[1], value);
}
Id Const(u32 element_1, u32 element_2) {
return ConstantComposite(U32[2], Const(element_1), Const(element_2));
}
Id Const(u32 element_1, u32 element_2, u32 element_3) {
return ConstantComposite(U32[3], Const(element_1), Const(element_2), Const(element_3));
}
Id Const(u32 element_1, u32 element_2, u32 element_3, u32 element_4) {
return ConstantComposite(U32[4], Const(element_1), Const(element_2), Const(element_3),
Const(element_4));
}
Id SConst(s32 value) {
return Constant(S32[1], value);
}
Id SConst(s32 element_1, s32 element_2) {
return ConstantComposite(S32[2], SConst(element_1), SConst(element_2));
}
Id SConst(s32 element_1, s32 element_2, s32 element_3) {
return ConstantComposite(S32[3], SConst(element_1), SConst(element_2), SConst(element_3));
}
Id SConst(s32 element_1, s32 element_2, s32 element_3, s32 element_4) {
return ConstantComposite(S32[4], SConst(element_1), SConst(element_2), SConst(element_3),
SConst(element_4));
}
Id Const(f32 value) {
return Constant(F32[1], value);
}
const Profile& profile;
Stage stage{};
2021-02-16 07:10:22 +00:00
Id void_id{};
Id U1{};
2021-03-09 20:14:57 +00:00
Id U8{};
Id S8{};
2021-02-19 21:10:18 +00:00
Id U16{};
2021-03-09 20:14:57 +00:00
Id S16{};
2021-02-19 21:10:18 +00:00
Id U64{};
2021-02-16 07:10:22 +00:00
VectorTypes F32;
VectorTypes U32;
VectorTypes S32;
2021-02-16 07:10:22 +00:00
VectorTypes F16;
VectorTypes F64;
Id true_value{};
Id false_value{};
Id u32_zero_value{};
2021-03-28 17:47:52 +00:00
Id f32_zero_value{};
2021-02-16 07:10:22 +00:00
2021-03-09 20:14:57 +00:00
UniformDefinitions uniform_types;
StorageTypeDefinitions storage_types;
2021-03-09 20:14:57 +00:00
Id private_u32{};
Id shared_u8{};
Id shared_u16{};
Id shared_u32{};
Id shared_u64{};
Id shared_u32x2{};
Id shared_u32x4{};
Id input_f32{};
Id input_u32{};
Id input_s32{};
Id output_f32{};
Id output_u32{};
2021-04-06 05:56:15 +00:00
Id image_buffer_type{};
Id sampled_texture_buffer_type{};
2021-04-23 21:47:54 +00:00
Id image_u32{};
2021-04-06 05:56:15 +00:00
2021-03-09 20:14:57 +00:00
std::array<UniformDefinitions, Info::MAX_CBUFS> cbufs{};
std::array<StorageDefinitions, Info::MAX_SSBOS> ssbos{};
2021-04-22 19:17:59 +00:00
std::vector<TextureBufferDefinition> texture_buffers;
2021-04-15 00:36:36 +00:00
std::vector<ImageBufferDefinition> image_buffers;
2021-04-09 04:45:39 +00:00
std::vector<TextureDefinition> textures;
std::vector<ImageDefinition> images;
2021-02-16 07:10:22 +00:00
Id workgroup_id{};
Id local_invocation_id{};
Id invocation_id{};
2021-04-16 20:22:59 +00:00
Id sample_id{};
2021-04-11 22:16:12 +00:00
Id is_helper_invocation{};
2021-03-24 00:27:17 +00:00
Id subgroup_local_invocation_id{};
2021-04-04 08:17:17 +00:00
Id subgroup_mask_eq{};
Id subgroup_mask_lt{};
Id subgroup_mask_le{};
Id subgroup_mask_gt{};
Id subgroup_mask_ge{};
Id instance_id{};
Id instance_index{};
Id base_instance{};
Id vertex_id{};
Id vertex_index{};
Id base_vertex{};
2021-03-27 05:55:37 +00:00
Id front_face{};
2021-03-29 18:05:38 +00:00
Id point_coord{};
Id tess_coord{};
2021-03-30 19:52:06 +00:00
Id clip_distances{};
2021-04-14 21:09:18 +00:00
Id layer{};
2021-04-01 06:34:45 +00:00
Id viewport_index{};
Id viewport_mask{};
2021-04-16 04:55:06 +00:00
Id primitive_id{};
2021-03-29 18:05:38 +00:00
2021-03-29 02:23:45 +00:00
Id fswzadd_lut_a{};
Id fswzadd_lut_b{};
2021-02-16 07:10:22 +00:00
2021-04-04 04:47:14 +00:00
Id indexed_load_func{};
Id indexed_store_func{};
Id local_memory{};
Id shared_memory_u8{};
Id shared_memory_u16{};
Id shared_memory_u32{};
Id shared_memory_u64{};
Id shared_memory_u32x2{};
Id shared_memory_u32x4{};
2021-04-11 06:07:02 +00:00
Id shared_memory_u32_type{};
Id shared_store_u8_func{};
Id shared_store_u16_func{};
2021-04-11 06:07:02 +00:00
Id increment_cas_shared{};
Id increment_cas_ssbo{};
Id decrement_cas_shared{};
Id decrement_cas_ssbo{};
Id f32_add_cas{};
Id f16x2_add_cas{};
Id f16x2_min_cas{};
Id f16x2_max_cas{};
Id f32x2_add_cas{};
Id f32x2_min_cas{};
Id f32x2_max_cas{};
Id load_global_func_u32{};
Id load_global_func_u32x2{};
Id load_global_func_u32x4{};
Id write_global_func_u32{};
Id write_global_func_u32x2{};
Id write_global_func_u32x4{};
Id input_position{};
std::array<Id, 32> input_generics{};
2021-03-26 22:52:06 +00:00
Id output_point_size{};
Id output_position{};
std::array<std::array<GenericElementInfo, 4>, 32> output_generics{};
Id output_tess_level_outer{};
Id output_tess_level_inner{};
std::array<Id, 30> patches{};
std::array<Id, 8> frag_color{};
2021-04-16 21:47:26 +00:00
Id sample_mask{};
2021-03-24 00:27:17 +00:00
Id frag_depth{};
std::vector<Id> interfaces;
2021-02-16 07:10:22 +00:00
private:
void DefineCommonTypes(const Info& info);
void DefineCommonConstants();
void DefineInterfaces(const IR::Program& program);
void DefineLocalMemory(const IR::Program& program);
void DefineSharedMemory(const IR::Program& program);
void DefineSharedMemoryFunctions(const IR::Program& program);
2021-02-19 21:10:18 +00:00
void DefineConstantBuffers(const Info& info, u32& binding);
void DefineStorageBuffers(const Info& info, u32& binding);
2021-04-06 05:56:15 +00:00
void DefineTextureBuffers(const Info& info, u32& binding);
2021-04-15 00:36:36 +00:00
void DefineImageBuffers(const Info& info, u32& binding);
void DefineTextures(const Info& info, u32& binding);
2021-04-09 04:45:39 +00:00
void DefineImages(const Info& info, u32& binding);
2021-04-04 04:47:14 +00:00
void DefineAttributeMemAccess(const Info& info);
void DefineGlobalMemoryFunctions(const Info& info);
void DefineInputs(const Info& info);
void DefineOutputs(const IR::Program& program);
2021-02-16 07:10:22 +00:00
};
} // namespace Shader::Backend::SPIRV