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

332 lines
8.2 KiB
C++
Raw Normal View History

// SPDX-FileCopyrightText: Copyright 2021 yuzu Emulator Project
// SPDX-License-Identifier: GPL-2.0-or-later
2021-02-16 02:10:22 -05:00
#pragma once
#include <array>
#include <sirit/sirit.h>
#include "shader_recompiler/backend/bindings.h"
2021-02-16 02:10:22 -05:00
#include "shader_recompiler/frontend/ir/program.h"
#include "shader_recompiler/profile.h"
#include "shader_recompiler/runtime_info.h"
2021-03-09 15:14:57 -05:00
#include "shader_recompiler/shader_info.h"
2021-02-16 02:10:22 -05: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 15:17:59 -04:00
Id pointer_type;
Id image_type;
2021-04-22 15:17:59 -04:00
u32 count;
};
struct TextureBufferDefinition {
Id id;
u32 count;
};
2021-04-14 20:36:36 -04:00
struct ImageBufferDefinition {
Id id;
Id image_type;
2021-04-22 15:17:59 -04:00
u32 count;
2021-04-14 20:36:36 -04:00
};
2021-04-09 00:45:39 -04:00
struct ImageDefinition {
Id id;
Id image_type;
2021-04-22 15:17:59 -04:00
u32 count;
2021-04-09 00:45:39 -04:00
};
2021-03-09 15:14:57 -05:00
struct UniformDefinitions {
Id U8{};
Id S8{};
Id U16{};
Id S16{};
Id U32{};
Id F32{};
Id U32x2{};
Id U32x4{};
2021-03-09 15:14:57 -05: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 02:10:22 -05:00
class EmitContext final : public Sirit::Module {
public:
explicit EmitContext(const Profile& profile, const RuntimeInfo& runtime_info,
IR::Program& program, Bindings& binding);
2021-02-16 02:10:22 -05: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;
const RuntimeInfo& runtime_info;
Stage stage{};
2021-02-16 02:10:22 -05:00
Id void_id{};
Id U1{};
2021-03-09 15:14:57 -05:00
Id U8{};
Id S8{};
2021-02-19 16:10:18 -05:00
Id U16{};
2021-03-09 15:14:57 -05:00
Id S16{};
2021-02-19 16:10:18 -05:00
Id U64{};
2021-02-16 02:10:22 -05:00
VectorTypes F32;
VectorTypes U32;
VectorTypes S32;
2021-02-16 02:10:22 -05:00
VectorTypes F16;
VectorTypes F64;
Id true_value{};
Id false_value{};
Id u32_zero_value{};
2021-03-28 13:47:52 -04:00
Id f32_zero_value{};
2021-02-16 02:10:22 -05:00
2021-03-09 15:14:57 -05:00
UniformDefinitions uniform_types;
StorageTypeDefinitions storage_types;
2021-03-09 15:14:57 -05: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 01:56:15 -04:00
Id image_buffer_type{};
Id sampled_texture_buffer_type{};
2021-04-23 17:47:54 -04:00
Id image_u32{};
2021-04-06 01:56:15 -04:00
2021-03-09 15:14:57 -05:00
std::array<UniformDefinitions, Info::MAX_CBUFS> cbufs{};
std::array<StorageDefinitions, Info::MAX_SSBOS> ssbos{};
2021-04-22 15:17:59 -04:00
std::vector<TextureBufferDefinition> texture_buffers;
2021-04-14 20:36:36 -04:00
std::vector<ImageBufferDefinition> image_buffers;
2021-04-09 00:45:39 -04:00
std::vector<TextureDefinition> textures;
std::vector<ImageDefinition> images;
2021-02-16 02:10:22 -05:00
Id workgroup_id{};
Id local_invocation_id{};
Id invocation_id{};
Id patch_vertices_in{};
2021-04-16 16:22:59 -04:00
Id sample_id{};
2021-04-11 18:16:12 -04:00
Id is_helper_invocation{};
2021-03-23 20:27:17 -04:00
Id subgroup_local_invocation_id{};
2021-04-04 04:17:17 -04: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 01:55:37 -04:00
Id front_face{};
2021-03-29 14:05:38 -04:00
Id point_coord{};
Id tess_coord{};
2021-03-30 15:52:06 -04:00
Id clip_distances{};
2021-04-14 17:09:18 -04:00
Id layer{};
2021-04-01 02:34:45 -04:00
Id viewport_index{};
Id viewport_mask{};
2021-04-16 00:55:06 -04:00
Id primitive_id{};
2021-03-29 14:05:38 -04:00
2021-03-28 22:23:45 -04:00
Id fswzadd_lut_a{};
Id fswzadd_lut_b{};
2021-02-16 02:10:22 -05:00
2021-04-04 00:47:14 -04:00
Id indexed_load_func{};
Id indexed_store_func{};
Id rescaling_uniform_constant{};
2021-07-25 21:26:23 -04:00
Id rescaling_push_constants{};
Id rescaling_textures_type{};
Id rescaling_images_type{};
2021-07-25 21:26:23 -04:00
u32 rescaling_textures_member_index{};
u32 rescaling_images_member_index{};
u32 rescaling_downfactor_member_index{};
u32 texture_rescaling_index{};
u32 image_rescaling_index{};
2021-07-25 21:26:23 -04:00
Id render_area_push_constant{};
u32 render_are_member_index{};
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 02:07:02 -04:00
Id shared_memory_u32_type{};
Id shared_store_u8_func{};
Id shared_store_u16_func{};
2021-04-11 02:07:02 -04: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 18:52:06 -04: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 17:47:26 -04:00
Id sample_mask{};
2021-03-23 20:27:17 -04:00
Id frag_depth{};
std::vector<Id> interfaces;
Id load_const_func_u8{};
Id load_const_func_u16{};
Id load_const_func_u32{};
Id load_const_func_f32{};
Id load_const_func_u32x2{};
Id load_const_func_u32x4{};
2021-02-16 02:10:22 -05: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 16:10:18 -05:00
void DefineConstantBuffers(const Info& info, u32& binding);
void DefineConstantBufferIndirectFunctions(const Info& info);
2021-02-19 16:10:18 -05:00
void DefineStorageBuffers(const Info& info, u32& binding);
2021-04-06 01:56:15 -04:00
void DefineTextureBuffers(const Info& info, u32& binding);
2021-04-14 20:36:36 -04:00
void DefineImageBuffers(const Info& info, u32& binding);
void DefineTextures(const Info& info, u32& binding, u32& scaling_index);
void DefineImages(const Info& info, u32& binding, u32& scaling_index);
2021-04-04 00:47:14 -04:00
void DefineAttributeMemAccess(const Info& info);
void DefineGlobalMemoryFunctions(const Info& info);
2021-07-25 21:26:23 -04:00
void DefineRescalingInput(const Info& info);
void DefineRescalingInputPushConstant();
void DefineRescalingInputUniformConstant();
void DefineRenderArea(const Info& info);
void DefineInputs(const IR::Program& program);
void DefineOutputs(const IR::Program& program);
2021-02-16 02:10:22 -05:00
};
} // namespace Shader::Backend::SPIRV