2018-09-11 01:00:55 +00:00
|
|
|
// Copyright 2018 yuzu Emulator Project
|
|
|
|
// Licensed under GPLv2 or any later version
|
|
|
|
// Refer to the license.txt file included.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include "common/bit_field.h"
|
|
|
|
#include "common/common_funcs.h"
|
2018-09-11 16:08:06 +00:00
|
|
|
#include "common/common_types.h"
|
2018-09-11 01:00:55 +00:00
|
|
|
|
|
|
|
namespace Tegra::Shader {
|
|
|
|
|
|
|
|
enum class OutputTopology : u32 {
|
|
|
|
PointList = 1,
|
|
|
|
LineStrip = 6,
|
|
|
|
TriangleStrip = 7,
|
|
|
|
};
|
|
|
|
|
|
|
|
// Documentation in:
|
|
|
|
// http://download.nvidia.com/open-gpu-doc/Shader-Program-Header/1/Shader-Program-Header.html#ImapTexture
|
|
|
|
struct Header {
|
|
|
|
union {
|
|
|
|
BitField<0, 5, u32> sph_type;
|
|
|
|
BitField<5, 5, u32> version;
|
|
|
|
BitField<10, 4, u32> shader_type;
|
|
|
|
BitField<14, 1, u32> mrt_enable;
|
|
|
|
BitField<15, 1, u32> kills_pixels;
|
|
|
|
BitField<16, 1, u32> does_global_store;
|
|
|
|
BitField<17, 4, u32> sass_version;
|
|
|
|
BitField<21, 5, u32> reserved;
|
|
|
|
BitField<26, 1, u32> does_load_or_store;
|
|
|
|
BitField<27, 1, u32> does_fp64;
|
|
|
|
BitField<28, 4, u32> stream_out_mask;
|
|
|
|
} common0;
|
|
|
|
|
|
|
|
union {
|
|
|
|
BitField<0, 24, u32> shader_local_memory_low_size;
|
|
|
|
BitField<24, 8, u32> per_patch_attribute_count;
|
|
|
|
} common1;
|
|
|
|
|
|
|
|
union {
|
|
|
|
BitField<0, 24, u32> shader_local_memory_high_size;
|
|
|
|
BitField<24, 8, u32> threads_per_input_primitive;
|
|
|
|
} common2;
|
|
|
|
|
|
|
|
union {
|
|
|
|
BitField<0, 24, u32> shader_local_memory_crs_size;
|
|
|
|
BitField<24, 4, OutputTopology> output_topology;
|
|
|
|
BitField<28, 4, u32> reserved;
|
|
|
|
} common3;
|
|
|
|
|
|
|
|
union {
|
|
|
|
BitField<0, 12, u32> max_output_vertices;
|
|
|
|
BitField<12, 8, u32> store_req_start; // NOTE: not used by geometry shaders.
|
|
|
|
BitField<24, 4, u32> reserved;
|
|
|
|
BitField<12, 8, u32> store_req_end; // NOTE: not used by geometry shaders.
|
|
|
|
} common4;
|
|
|
|
|
|
|
|
union {
|
|
|
|
struct {
|
|
|
|
INSERT_PADDING_BYTES(3); // ImapSystemValuesA
|
|
|
|
INSERT_PADDING_BYTES(1); // ImapSystemValuesB
|
|
|
|
INSERT_PADDING_BYTES(16); // ImapGenericVector[32]
|
|
|
|
INSERT_PADDING_BYTES(2); // ImapColor
|
2018-11-23 04:57:49 +00:00
|
|
|
union {
|
|
|
|
BitField<0, 8, u16> clip_distances;
|
|
|
|
BitField<8, 1, u16> point_sprite_s;
|
|
|
|
BitField<9, 1, u16> point_sprite_t;
|
|
|
|
BitField<10, 1, u16> fog_coordinate;
|
|
|
|
BitField<12, 1, u16> tessellation_eval_point_u;
|
|
|
|
BitField<13, 1, u16> tessellation_eval_point_v;
|
|
|
|
BitField<14, 1, u16> instance_id;
|
|
|
|
BitField<15, 1, u16> vertex_id;
|
|
|
|
};
|
2018-09-11 01:00:55 +00:00
|
|
|
INSERT_PADDING_BYTES(5); // ImapFixedFncTexture[10]
|
|
|
|
INSERT_PADDING_BYTES(1); // ImapReserved
|
|
|
|
INSERT_PADDING_BYTES(3); // OmapSystemValuesA
|
|
|
|
INSERT_PADDING_BYTES(1); // OmapSystemValuesB
|
|
|
|
INSERT_PADDING_BYTES(16); // OmapGenericVector[32]
|
|
|
|
INSERT_PADDING_BYTES(2); // OmapColor
|
|
|
|
INSERT_PADDING_BYTES(2); // OmapSystemValuesC
|
|
|
|
INSERT_PADDING_BYTES(5); // OmapFixedFncTexture[10]
|
|
|
|
INSERT_PADDING_BYTES(1); // OmapReserved
|
2018-09-11 16:08:06 +00:00
|
|
|
} vtg;
|
2018-09-11 01:00:55 +00:00
|
|
|
|
|
|
|
struct {
|
|
|
|
INSERT_PADDING_BYTES(3); // ImapSystemValuesA
|
|
|
|
INSERT_PADDING_BYTES(1); // ImapSystemValuesB
|
|
|
|
INSERT_PADDING_BYTES(32); // ImapGenericVector[32]
|
|
|
|
INSERT_PADDING_BYTES(2); // ImapColor
|
|
|
|
INSERT_PADDING_BYTES(2); // ImapSystemValuesC
|
|
|
|
INSERT_PADDING_BYTES(10); // ImapFixedFncTexture[10]
|
|
|
|
INSERT_PADDING_BYTES(2); // ImapReserved
|
2018-09-11 16:08:06 +00:00
|
|
|
struct {
|
|
|
|
u32 target;
|
|
|
|
union {
|
|
|
|
BitField<0, 1, u32> sample_mask;
|
|
|
|
BitField<1, 1, u32> depth;
|
|
|
|
BitField<2, 30, u32> reserved;
|
|
|
|
};
|
2018-09-11 01:00:55 +00:00
|
|
|
} omap;
|
2018-09-11 16:08:06 +00:00
|
|
|
bool IsColorComponentOutputEnabled(u32 render_target, u32 component) const {
|
|
|
|
const u32 bit = render_target * 4 + component;
|
|
|
|
return omap.target & (1 << bit);
|
|
|
|
}
|
|
|
|
} ps;
|
|
|
|
};
|
2018-10-20 01:48:21 +00:00
|
|
|
|
|
|
|
u64 GetLocalMemorySize() {
|
|
|
|
return (common1.shader_local_memory_low_size |
|
|
|
|
(common2.shader_local_memory_high_size << 24));
|
|
|
|
}
|
2018-09-11 01:00:55 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
static_assert(sizeof(Header) == 0x50, "Incorrect structure size");
|
|
|
|
|
|
|
|
} // namespace Tegra::Shader
|