xref: /freebsd/contrib/llvm-project/llvm/lib/Target/DirectX/DXILResource.h (revision 0e8011faf58b743cc652e3b2ad0f7671227610df)
1 //===- DXILResource.h - DXIL Resource helper objects ----------------------===//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 ///
9 /// \file This file contains helper objects for working with DXIL Resources.
10 ///
11 //===----------------------------------------------------------------------===//
12 
13 #ifndef LLVM_TARGET_DIRECTX_DXILRESOURCE_H
14 #define LLVM_TARGET_DIRECTX_DXILRESOURCE_H
15 
16 #include "llvm/ADT/SmallVector.h"
17 #include "llvm/ADT/StringRef.h"
18 #include "llvm/Frontend/HLSL/HLSLResource.h"
19 #include "llvm/IR/Metadata.h"
20 #include "llvm/Support/Compiler.h"
21 #include "llvm/Support/DXILABI.h"
22 #include <cstdint>
23 
24 namespace llvm {
25 class Module;
26 class GlobalVariable;
27 
28 namespace dxil {
29 class CBufferDataLayout;
30 
31 class ResourceBase {
32 protected:
33   uint32_t ID;
34   GlobalVariable *GV;
35   StringRef Name;
36   uint32_t Space;
37   uint32_t LowerBound;
38   uint32_t RangeSize;
39   ResourceBase(uint32_t I, hlsl::FrontendResource R);
40 
41   void write(LLVMContext &Ctx, MutableArrayRef<Metadata *> Entries) const;
42 
43   void print(raw_ostream &O, StringRef IDPrefix, StringRef BindingPrefix) const;
44   static StringRef getKindName(dxil::ResourceKind Kind);
45   static void printKind(dxil::ResourceKind Kind, unsigned Alignment,
46                         raw_ostream &OS, bool SRV = false,
47                         bool HasCounter = false, uint32_t SampleCount = 0);
48 
49   static StringRef getElementTypeName(dxil::ElementType CompType);
50   static void printElementType(dxil::ResourceKind Kind,
51                                dxil::ElementType CompType, unsigned Alignment,
52                                raw_ostream &OS);
53 
54 public:
55   struct ExtendedProperties {
56     std::optional<dxil::ElementType> ElementType;
57 
58     // The value ordering of this enumeration is part of the DXIL ABI. Elements
59     // can only be added to the end, and not removed.
60     enum Tags : uint32_t {
61       TypedBufferElementType = 0,
62       StructuredBufferElementStride,
63       SamplerFeedbackKind,
64       Atomic64Use
65     };
66 
67     MDNode *write(LLVMContext &Ctx) const;
68   };
69 };
70 
71 class UAVResource : public ResourceBase {
72   dxil::ResourceKind Shape;
73   bool GloballyCoherent;
74   bool HasCounter;
75   bool IsROV;
76   ResourceBase::ExtendedProperties ExtProps;
77 
78   void parseSourceType(StringRef S);
79 
80 public:
81   UAVResource(uint32_t I, hlsl::FrontendResource R)
82       : ResourceBase(I, R), Shape(R.getResourceKind()), GloballyCoherent(false),
83         HasCounter(false), IsROV(R.getIsROV()), ExtProps{R.getElementType()} {}
84 
85   MDNode *write() const;
86   void print(raw_ostream &O) const;
87 };
88 
89 class ConstantBuffer : public ResourceBase {
90   uint32_t CBufferSizeInBytes = 0; // Cbuffer used size in bytes.
91 public:
92   ConstantBuffer(uint32_t I, hlsl::FrontendResource R);
93   void setSize(CBufferDataLayout &DL);
94   MDNode *write() const;
95   void print(raw_ostream &O) const;
96 };
97 
98 template <typename T> class ResourceTable {
99   StringRef MDName;
100 
101   llvm::SmallVector<T> Data;
102 
103 public:
104   ResourceTable(StringRef Name) : MDName(Name) {}
105   void collect(Module &M);
106   MDNode *write(Module &M) const;
107   void print(raw_ostream &O) const;
108 };
109 
110 // FIXME: Fully computing the resource structures requires analyzing the IR
111 // because some flags are set based on what operations are performed on the
112 // resource. This partial patch handles some of the leg work, but not all of it.
113 // See issue https://github.com/llvm/llvm-project/issues/57936.
114 class Resources {
115   ResourceTable<UAVResource> UAVs = {"hlsl.uavs"};
116   ResourceTable<ConstantBuffer> CBuffers = {"hlsl.cbufs"};
117 
118 public:
119   void collect(Module &M);
120   void write(Module &M) const;
121   void print(raw_ostream &O) const;
122   LLVM_DUMP_METHOD void dump() const;
123 };
124 
125 } // namespace dxil
126 } // namespace llvm
127 
128 #endif // LLVM_TARGET_DIRECTX_DXILRESOURCE_H
129