[llvm] [DirectX] Documenting Root Signature Binary representation (PR #131011)
via llvm-commits
llvm-commits at lists.llvm.org
Thu Mar 13 13:25:21 PDT 2025
================
@@ -400,3 +400,258 @@ SFI0 Part
The SFI0 part encodes a 64-bit unsigned integer bitmask of the feature flags.
This denotes which optional features the shader requires. The flag values are
defined in `llvm/include/llvm/BinaryFormat/DXContainerConstants.def <https://github.com/llvm/llvm-project/blob/main/llvm/include/llvm/BinaryFormat/DXContainerConstants.def>`_.
+
+Root Signature (RTS0) Part
+--------------------------
+.. _RTS0:
+
+The Root Signature defines the interface between the shader and the pipeline,
+specifying which resources are bound to the shader and how they are accessed.
+This structure serves as a contract between the application and the GPU,
+establishing a layout for resource binding that both the shader compiler and
+the runtime can understand.
+
+The Root Signature consists of a header followed by a collection of root parameters
+and static samplers. The structure uses a versioned design with offset-based references
+to allow for flexible serialization and deserialization.
+
+Root Signature Header
+~~~~~~~~~~~~~~~~~~~~~
+
+.. code-block:: c
+
+ struct RootSignatureHeader {
+ uint32_t Version;
+ uint32_t NumParameters;
+ uint32_t ParametersOffset;
+ uint32_t NumStaticSamplers;
+ uint32_t StaticSamplerOffset;
+ uint32_t Flags;
+ }
+
+
+The `RootSignatureHeader` structure contains the top-level information about a root signature:
+
+#. **Version**: Specifies the version of the root signature format. This allows for backward
+ compatibility as the format evolves.
+#. **NumParameters**: The number of root parameters contained in this root signature.
+#. **ParametersOffset**: Byte offset from the beginning of RST0 section to the array of root
+ parameters header.
+#. **NumStaticSamplers**: The number of static samplers defined in the root signature.
+#. **StaticSamplerOffset**: Byte offset to the array of static samplers.
+#. **Flags**: Bit flags that define global behaviors for the root signature, such as whether
+ to deny vertex shader access to certain resources.
+
+This header allows readers to navigate the binary representation of the root signature by
+providing counts and offsets to locate each component within the serialized data.
+
+Root Parameter Header
----------------
joaosaffran wrote:
The root parameter header is unique, so you will have a single header followed by multiple parameters.
https://github.com/llvm/llvm-project/pull/131011
More information about the llvm-commits
mailing list