[clang] [HLSL] Constant buffers codegen (PR #124886)
Justin Bogner via cfe-commits
cfe-commits at lists.llvm.org
Tue Feb 18 15:48:17 PST 2025
================
@@ -0,0 +1,39 @@
+//===- HLSLTargetInfo.h ---------------------------------------------------===//
+//
+// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
+// See https://llvm.org/LICENSE.txt for license information.
+// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
+//
+//===----------------------------------------------------------------------===//
+
+#include "ABIInfoImpl.h"
+#include "TargetInfo.h"
+
+using namespace clang;
+using namespace clang::CodeGen;
+
+//===----------------------------------------------------------------------===//
+// Target codegen info implementation common between DirectX and SPIR/SPIR-V.
+//===----------------------------------------------------------------------===//
+
+class CommonHLSLTargetCodeGenInfo : public TargetCodeGenInfo {
+public:
+ CommonHLSLTargetCodeGenInfo(std::unique_ptr<ABIInfo> Info)
+ : TargetCodeGenInfo(std::move(Info)) {}
+
+ // Returns LLVM target extension type "dx.Layout" or "spv.Layout"
+ // for given structure type and layout data. The first number in
+ // the Layout is the size followed by offsets for each struct element.
+ virtual llvm::Type *getHLSLLayoutType(CodeGenModule &CGM,
+ llvm::StructType *LayoutStructTy,
+ SmallVector<unsigned> Layout) const {
+ return nullptr;
+ };
+
+protected:
+ // Creates a layout type for given struct with HLSL constant buffer layout
+ // taking into account Packoffsets, if provided.
+ virtual llvm::Type *createHLSLBufferLayoutType(
+ CodeGenModule &CGM, const clang::RecordType *StructType,
+ const SmallVector<unsigned> *Packoffsets = nullptr) const;
----------------
bogner wrote:
Does this need to be virtual? I don't see why subclasses would override this...
https://github.com/llvm/llvm-project/pull/124886
More information about the cfe-commits
mailing list