2022-04-23 01:59:50 -07:00
|
|
|
// SPDX-FileCopyrightText: Copyright 2021 yuzu Emulator Project
|
|
|
|
// SPDX-License-Identifier: GPL-2.0-or-later
|
2021-02-11 11:39:06 -08:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <array>
|
2021-05-01 16:50:27 -07:00
|
|
|
#include <bitset>
|
2022-09-10 02:09:45 -07:00
|
|
|
#include <map>
|
2021-02-11 11:39:06 -08:00
|
|
|
|
2021-02-15 23:10:22 -08:00
|
|
|
#include "common/common_types.h"
|
2021-03-09 12:14:57 -08:00
|
|
|
#include "shader_recompiler/frontend/ir/type.h"
|
2021-06-23 22:41:09 -07:00
|
|
|
#include "shader_recompiler/varying_state.h"
|
2021-02-15 23:10:22 -08:00
|
|
|
|
2021-03-08 13:31:53 -08:00
|
|
|
#include <boost/container/small_vector.hpp>
|
2021-02-11 11:39:06 -08:00
|
|
|
#include <boost/container/static_vector.hpp>
|
|
|
|
|
|
|
|
namespace Shader {
|
|
|
|
|
2022-11-09 08:58:10 -08:00
|
|
|
enum class ReplaceConstant : u32 {
|
|
|
|
BaseInstance,
|
|
|
|
BaseVertex,
|
2023-01-03 07:01:25 -08:00
|
|
|
DrawID,
|
2022-11-09 08:58:10 -08:00
|
|
|
};
|
|
|
|
|
2021-03-08 13:31:53 -08:00
|
|
|
enum class TextureType : u32 {
|
|
|
|
Color1D,
|
|
|
|
ColorArray1D,
|
|
|
|
Color2D,
|
|
|
|
ColorArray2D,
|
|
|
|
Color3D,
|
|
|
|
ColorCube,
|
|
|
|
ColorArrayCube,
|
2021-04-05 22:56:15 -07:00
|
|
|
Buffer,
|
2022-08-09 19:10:32 -07:00
|
|
|
Color2DRect,
|
2021-03-08 13:31:53 -08:00
|
|
|
};
|
2022-08-09 19:10:32 -07:00
|
|
|
constexpr u32 NUM_TEXTURE_TYPES = 9;
|
2021-04-08 21:45:39 -07:00
|
|
|
|
2022-11-03 23:39:42 -07:00
|
|
|
enum class TexturePixelFormat : u32 {
|
|
|
|
A8B8G8R8_SNORM,
|
|
|
|
R8_SNORM,
|
|
|
|
R8G8_SNORM,
|
|
|
|
R16G16B16A16_SNORM,
|
|
|
|
R16G16_SNORM,
|
|
|
|
R16_SNORM,
|
|
|
|
OTHER
|
|
|
|
};
|
|
|
|
|
2021-04-08 21:45:39 -07:00
|
|
|
enum class ImageFormat : u32 {
|
|
|
|
Typeless,
|
|
|
|
R8_UINT,
|
|
|
|
R8_SINT,
|
|
|
|
R16_UINT,
|
|
|
|
R16_SINT,
|
|
|
|
R32_UINT,
|
|
|
|
R32G32_UINT,
|
|
|
|
R32G32B32A32_UINT,
|
|
|
|
};
|
2021-03-08 13:31:53 -08:00
|
|
|
|
2021-03-27 00:59:58 -07:00
|
|
|
enum class Interpolation {
|
|
|
|
Smooth,
|
|
|
|
Flat,
|
|
|
|
NoPerspective,
|
|
|
|
};
|
|
|
|
|
2021-04-08 21:45:39 -07:00
|
|
|
struct ConstantBufferDescriptor {
|
|
|
|
u32 index;
|
|
|
|
u32 count;
|
2022-10-21 14:58:37 -07:00
|
|
|
|
|
|
|
auto operator<=>(const ConstantBufferDescriptor&) const = default;
|
2021-04-08 21:45:39 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
struct StorageBufferDescriptor {
|
2021-03-08 13:31:53 -08:00
|
|
|
u32 cbuf_index;
|
|
|
|
u32 cbuf_offset;
|
|
|
|
u32 count;
|
2021-04-08 21:45:39 -07:00
|
|
|
bool is_written;
|
2022-10-21 14:58:37 -07:00
|
|
|
|
|
|
|
auto operator<=>(const StorageBufferDescriptor&) const = default;
|
2021-03-08 13:31:53 -08:00
|
|
|
};
|
|
|
|
|
2021-04-05 22:56:15 -07:00
|
|
|
struct TextureBufferDescriptor {
|
2021-04-20 15:48:45 -07:00
|
|
|
bool has_secondary;
|
2021-04-05 22:56:15 -07:00
|
|
|
u32 cbuf_index;
|
|
|
|
u32 cbuf_offset;
|
2022-03-06 10:54:40 -08:00
|
|
|
u32 shift_left;
|
2021-04-20 15:48:45 -07:00
|
|
|
u32 secondary_cbuf_index;
|
|
|
|
u32 secondary_cbuf_offset;
|
2022-03-06 10:54:40 -08:00
|
|
|
u32 secondary_shift_left;
|
2021-04-05 22:56:15 -07:00
|
|
|
u32 count;
|
2021-04-22 12:17:59 -07:00
|
|
|
u32 size_shift;
|
2022-10-21 14:58:37 -07:00
|
|
|
|
|
|
|
auto operator<=>(const TextureBufferDescriptor&) const = default;
|
2021-04-05 22:56:15 -07:00
|
|
|
};
|
2021-04-08 21:45:39 -07:00
|
|
|
using TextureBufferDescriptors = boost::container::small_vector<TextureBufferDescriptor, 6>;
|
2021-04-05 22:56:15 -07:00
|
|
|
|
2021-04-14 17:36:36 -07:00
|
|
|
struct ImageBufferDescriptor {
|
|
|
|
ImageFormat format;
|
|
|
|
bool is_written;
|
2021-06-15 14:23:57 -07:00
|
|
|
bool is_read;
|
2021-04-14 17:36:36 -07:00
|
|
|
u32 cbuf_index;
|
|
|
|
u32 cbuf_offset;
|
|
|
|
u32 count;
|
2021-04-22 12:17:59 -07:00
|
|
|
u32 size_shift;
|
2022-10-21 14:58:37 -07:00
|
|
|
|
|
|
|
auto operator<=>(const ImageBufferDescriptor&) const = default;
|
2021-04-14 17:36:36 -07:00
|
|
|
};
|
|
|
|
using ImageBufferDescriptors = boost::container::small_vector<ImageBufferDescriptor, 2>;
|
|
|
|
|
2021-04-08 21:45:39 -07:00
|
|
|
struct TextureDescriptor {
|
|
|
|
TextureType type;
|
|
|
|
bool is_depth;
|
2021-04-20 15:48:45 -07:00
|
|
|
bool has_secondary;
|
2021-04-08 21:45:39 -07:00
|
|
|
u32 cbuf_index;
|
|
|
|
u32 cbuf_offset;
|
2022-03-06 10:54:40 -08:00
|
|
|
u32 shift_left;
|
2021-04-20 15:48:45 -07:00
|
|
|
u32 secondary_cbuf_index;
|
|
|
|
u32 secondary_cbuf_offset;
|
2022-03-06 10:54:40 -08:00
|
|
|
u32 secondary_shift_left;
|
2021-03-08 13:31:53 -08:00
|
|
|
u32 count;
|
2021-04-22 12:17:59 -07:00
|
|
|
u32 size_shift;
|
2022-10-21 14:58:37 -07:00
|
|
|
|
|
|
|
auto operator<=>(const TextureDescriptor&) const = default;
|
2021-03-08 13:31:53 -08:00
|
|
|
};
|
2021-04-08 21:45:39 -07:00
|
|
|
using TextureDescriptors = boost::container::small_vector<TextureDescriptor, 12>;
|
2021-03-08 13:31:53 -08:00
|
|
|
|
2021-04-08 21:45:39 -07:00
|
|
|
struct ImageDescriptor {
|
|
|
|
TextureType type;
|
|
|
|
ImageFormat format;
|
|
|
|
bool is_written;
|
2021-06-15 14:23:57 -07:00
|
|
|
bool is_read;
|
2021-03-08 13:31:53 -08:00
|
|
|
u32 cbuf_index;
|
|
|
|
u32 cbuf_offset;
|
|
|
|
u32 count;
|
2021-04-22 12:17:59 -07:00
|
|
|
u32 size_shift;
|
2022-10-21 14:58:37 -07:00
|
|
|
|
|
|
|
auto operator<=>(const ImageDescriptor&) const = default;
|
2021-03-08 13:31:53 -08:00
|
|
|
};
|
2021-04-08 21:45:39 -07:00
|
|
|
using ImageDescriptors = boost::container::small_vector<ImageDescriptor, 4>;
|
2021-03-08 13:31:53 -08:00
|
|
|
|
2021-02-11 11:39:06 -08:00
|
|
|
struct Info {
|
2022-04-04 13:44:01 -07:00
|
|
|
static constexpr size_t MAX_INDIRECT_CBUFS{14};
|
2021-02-15 23:10:22 -08:00
|
|
|
static constexpr size_t MAX_CBUFS{18};
|
2021-04-22 16:32:38 -07:00
|
|
|
static constexpr size_t MAX_SSBOS{32};
|
2021-02-15 23:10:22 -08:00
|
|
|
|
|
|
|
bool uses_workgroup_id{};
|
|
|
|
bool uses_local_invocation_id{};
|
2021-04-15 18:46:11 -07:00
|
|
|
bool uses_invocation_id{};
|
2022-10-30 04:59:11 -07:00
|
|
|
bool uses_invocation_info{};
|
2021-04-16 13:22:59 -07:00
|
|
|
bool uses_sample_id{};
|
2021-04-11 15:16:12 -07:00
|
|
|
bool uses_is_helper_invocation{};
|
2021-03-25 08:31:37 -07:00
|
|
|
bool uses_subgroup_invocation_id{};
|
2021-05-10 14:21:28 -07:00
|
|
|
bool uses_subgroup_shuffles{};
|
2021-04-15 18:46:11 -07:00
|
|
|
std::array<bool, 30> uses_patches{};
|
2021-03-19 15:28:31 -07:00
|
|
|
|
2021-06-23 22:41:09 -07:00
|
|
|
std::array<Interpolation, 32> interpolation{};
|
|
|
|
VaryingState loads;
|
|
|
|
VaryingState stores;
|
|
|
|
VaryingState passthrough;
|
2021-05-31 00:19:31 -07:00
|
|
|
|
2022-09-10 02:09:45 -07:00
|
|
|
std::map<IR::Attribute, IR::Attribute> legacy_stores_mapping;
|
|
|
|
|
2021-04-03 21:47:14 -07:00
|
|
|
bool loads_indexed_attributes{};
|
2021-03-19 15:28:31 -07:00
|
|
|
|
|
|
|
std::array<bool, 8> stores_frag_color{};
|
2021-04-16 14:47:26 -07:00
|
|
|
bool stores_sample_mask{};
|
2021-03-19 15:28:31 -07:00
|
|
|
bool stores_frag_depth{};
|
2021-05-31 00:19:31 -07:00
|
|
|
|
2021-04-15 18:46:11 -07:00
|
|
|
bool stores_tess_level_outer{};
|
|
|
|
bool stores_tess_level_inner{};
|
2021-05-31 00:19:31 -07:00
|
|
|
|
2021-04-03 21:47:14 -07:00
|
|
|
bool stores_indexed_attributes{};
|
2021-05-31 00:19:31 -07:00
|
|
|
|
2021-05-01 16:50:27 -07:00
|
|
|
bool stores_global_memory{};
|
2021-03-19 15:28:31 -07:00
|
|
|
|
2021-02-15 23:10:22 -08:00
|
|
|
bool uses_fp16{};
|
|
|
|
bool uses_fp64{};
|
2021-02-19 22:30:13 -08:00
|
|
|
bool uses_fp16_denorms_flush{};
|
|
|
|
bool uses_fp16_denorms_preserve{};
|
|
|
|
bool uses_fp32_denorms_flush{};
|
|
|
|
bool uses_fp32_denorms_preserve{};
|
2021-03-09 12:14:57 -08:00
|
|
|
bool uses_int8{};
|
|
|
|
bool uses_int16{};
|
|
|
|
bool uses_int64{};
|
2021-03-08 13:31:53 -08:00
|
|
|
bool uses_image_1d{};
|
|
|
|
bool uses_sampled_1d{};
|
|
|
|
bool uses_sparse_residency{};
|
2021-03-19 15:28:31 -07:00
|
|
|
bool uses_demote_to_helper_invocation{};
|
2021-03-23 17:27:17 -07:00
|
|
|
bool uses_subgroup_vote{};
|
2021-04-04 01:17:17 -07:00
|
|
|
bool uses_subgroup_mask{};
|
2021-03-28 19:23:45 -07:00
|
|
|
bool uses_fswzadd{};
|
2021-04-18 00:07:48 -07:00
|
|
|
bool uses_derivatives{};
|
2021-04-10 22:37:03 -07:00
|
|
|
bool uses_typeless_image_reads{};
|
2021-04-11 17:02:44 -07:00
|
|
|
bool uses_typeless_image_writes{};
|
2021-04-23 14:47:54 -07:00
|
|
|
bool uses_image_buffers{};
|
2021-04-10 23:07:02 -07:00
|
|
|
bool uses_shared_increment{};
|
|
|
|
bool uses_shared_decrement{};
|
|
|
|
bool uses_global_increment{};
|
|
|
|
bool uses_global_decrement{};
|
|
|
|
bool uses_atomic_f32_add{};
|
|
|
|
bool uses_atomic_f16x2_add{};
|
|
|
|
bool uses_atomic_f16x2_min{};
|
|
|
|
bool uses_atomic_f16x2_max{};
|
|
|
|
bool uses_atomic_f32x2_add{};
|
|
|
|
bool uses_atomic_f32x2_min{};
|
|
|
|
bool uses_atomic_f32x2_max{};
|
2021-05-25 19:13:50 -07:00
|
|
|
bool uses_atomic_s32_min{};
|
|
|
|
bool uses_atomic_s32_max{};
|
2021-04-13 01:32:21 -07:00
|
|
|
bool uses_int64_bit_atomics{};
|
2021-04-19 12:33:23 -07:00
|
|
|
bool uses_global_memory{};
|
2021-04-23 14:47:54 -07:00
|
|
|
bool uses_atomic_image_u32{};
|
2021-06-13 16:12:03 -07:00
|
|
|
bool uses_shadow_lod{};
|
2021-07-21 18:25:34 -07:00
|
|
|
bool uses_rescaling_uniform{};
|
2022-03-17 10:30:21 -07:00
|
|
|
bool uses_cbuf_indirect{};
|
2022-09-01 07:05:11 -07:00
|
|
|
bool uses_render_area{};
|
2021-02-15 23:10:22 -08:00
|
|
|
|
2021-03-09 12:14:57 -08:00
|
|
|
IR::Type used_constant_buffer_types{};
|
2021-04-13 01:32:21 -07:00
|
|
|
IR::Type used_storage_buffer_types{};
|
2022-03-17 11:45:38 -07:00
|
|
|
IR::Type used_indirect_cbuf_types{};
|
2021-03-09 12:14:57 -08:00
|
|
|
|
2021-02-15 23:10:22 -08:00
|
|
|
u32 constant_buffer_mask{};
|
2021-06-01 22:15:07 -07:00
|
|
|
std::array<u32, MAX_CBUFS> constant_buffer_used_sizes{};
|
2021-05-01 16:50:27 -07:00
|
|
|
u32 nvn_buffer_base{};
|
|
|
|
std::bitset<16> nvn_buffer_used{};
|
2021-02-15 23:10:22 -08:00
|
|
|
|
2022-11-30 14:16:00 -08:00
|
|
|
bool requires_layer_emulation{};
|
|
|
|
IR::Attribute emulated_layer{};
|
|
|
|
|
2021-02-15 23:10:22 -08:00
|
|
|
boost::container::static_vector<ConstantBufferDescriptor, MAX_CBUFS>
|
|
|
|
constant_buffer_descriptors;
|
|
|
|
boost::container::static_vector<StorageBufferDescriptor, MAX_SSBOS> storage_buffers_descriptors;
|
2021-04-05 22:56:15 -07:00
|
|
|
TextureBufferDescriptors texture_buffer_descriptors;
|
2021-04-14 17:36:36 -07:00
|
|
|
ImageBufferDescriptors image_buffer_descriptors;
|
2021-04-06 16:14:55 -07:00
|
|
|
TextureDescriptors texture_descriptors;
|
2021-04-08 21:45:39 -07:00
|
|
|
ImageDescriptors image_descriptors;
|
2021-02-11 11:39:06 -08:00
|
|
|
};
|
|
|
|
|
2021-07-25 18:26:23 -07:00
|
|
|
template <typename Descriptors>
|
|
|
|
u32 NumDescriptors(const Descriptors& descriptors) {
|
|
|
|
u32 num{};
|
|
|
|
for (const auto& desc : descriptors) {
|
|
|
|
num += desc.count;
|
|
|
|
}
|
|
|
|
return num;
|
|
|
|
}
|
|
|
|
|
2021-02-11 11:39:06 -08:00
|
|
|
} // namespace Shader
|