aboutsummaryrefslogtreecommitdiff
path: root/src/Ryujinx.Graphics.Gpu/Image/TextureBindingInfo.cs
blob: e9930405b70b06ecc38d0d5385f5444387295e5b (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
using Ryujinx.Graphics.GAL;
using Ryujinx.Graphics.Shader;

namespace Ryujinx.Graphics.Gpu.Image
{
    /// <summary>
    /// Texture binding information.
    /// This is used for textures that needs to be accessed from shaders.
    /// </summary>
    readonly struct TextureBindingInfo
    {
        /// <summary>
        /// Shader sampler target type.
        /// </summary>
        public Target Target { get; }

        /// <summary>
        /// For images, indicates the format specified on the shader.
        /// </summary>
        public FormatInfo FormatInfo { get; }

        /// <summary>
        /// Shader texture host set index.
        /// </summary>
        public int Set { get; }

        /// <summary>
        /// Shader texture host binding point.
        /// </summary>
        public int Binding { get; }

        /// <summary>
        /// For array of textures, this indicates the length of the array. A value of one indicates it is not an array.
        /// </summary>
        public int ArrayLength { get; }

        /// <summary>
        /// Constant buffer slot with the texture handle.
        /// </summary>
        public int CbufSlot { get; }

        /// <summary>
        /// Index of the texture handle on the constant buffer at slot <see cref="CbufSlot"/>.
        /// </summary>
        public int Handle { get; }

        /// <summary>
        /// Flags from the texture descriptor that indicate how the texture is used.
        /// </summary>
        public TextureUsageFlags Flags { get; }

        /// <summary>
        /// Indicates that the binding is for a sampler.
        /// </summary>
        public bool IsSamplerOnly { get; }

        /// <summary>
        /// Constructs the texture binding information structure.
        /// </summary>
        /// <param name="target">The shader sampler target type</param>
        /// <param name="formatInfo">Format of the image as declared on the shader</param>
        /// <param name="set">Shader texture host set index</param>
        /// <param name="binding">The shader texture binding point</param>
        /// <param name="arrayLength">For array of textures, this indicates the length of the array. A value of one indicates it is not an array</param>
        /// <param name="cbufSlot">Constant buffer slot where the texture handle is located</param>
        /// <param name="handle">The shader texture handle (read index into the texture constant buffer)</param>
        /// <param name="flags">The texture's usage flags, indicating how it is used in the shader</param>
        public TextureBindingInfo(Target target, FormatInfo formatInfo, int set, int binding, int arrayLength, int cbufSlot, int handle, TextureUsageFlags flags)
        {
            Target = target;
            FormatInfo = formatInfo;
            Set = set;
            Binding = binding;
            ArrayLength = arrayLength;
            CbufSlot = cbufSlot;
            Handle = handle;
            Flags = flags;
        }

        /// <summary>
        /// Constructs the texture binding information structure.
        /// </summary>
        /// <param name="target">The shader sampler target type</param>
        /// <param name="set">Shader texture host set index</param>
        /// <param name="binding">The shader texture binding point</param>
        /// <param name="arrayLength">For array of textures, this indicates the length of the array. A value of one indicates it is not an array</param>
        /// <param name="cbufSlot">Constant buffer slot where the texture handle is located</param>
        /// <param name="handle">The shader texture handle (read index into the texture constant buffer)</param>
        /// <param name="flags">The texture's usage flags, indicating how it is used in the shader</param>
        /// <param name="isSamplerOnly">Indicates that the binding is for a sampler</param>
        public TextureBindingInfo(
            Target target,
            int set,
            int binding,
            int arrayLength,
            int cbufSlot,
            int handle,
            TextureUsageFlags flags,
            bool isSamplerOnly) : this(target, FormatInfo.Invalid, set, binding, arrayLength, cbufSlot, handle, flags)
        {
            IsSamplerOnly = isSamplerOnly;
        }
    }
}