[llvm-branch-commits] [clang] [llvm] [IRBuilder] Add getByteTy and use it in CreatePtrAdd (PR #106539)

Sergei Barannikov via llvm-branch-commits llvm-branch-commits at lists.llvm.org
Sun Feb 22 10:46:13 PST 2026


https://github.com/s-barannikov updated https://github.com/llvm/llvm-project/pull/106539

>From 2f6854f6acb9e30da7f82ab412d4c6a73d156575 Mon Sep 17 00:00:00 2001
From: Sergei Barannikov <barannikov88 at gmail.com>
Date: Thu, 22 Aug 2024 15:10:58 +0300
Subject: [PATCH 1/2] [IRBuilder] Add getByteTy and use it in CreatePtrAdd

The change requires DataLayout instance to be available, which, in turn,
requires insertion point to be set. In-tree tests detected only one case
when the function was called without setting an insertion point, it was
changed to create a constant expression directly.
---
 llvm/include/llvm/IR/IRBuilder.h              | 10 +++++++--
 .../Instrumentation/SanitizerCoverage.cpp     |  5 ++---
 llvm/unittests/IR/IRBuilderTest.cpp           | 22 +++++++++++++++++++
 3 files changed, 32 insertions(+), 5 deletions(-)

diff --git a/llvm/include/llvm/IR/IRBuilder.h b/llvm/include/llvm/IR/IRBuilder.h
index 94d5943522070..a6b8fd27a7432 100644
--- a/llvm/include/llvm/IR/IRBuilder.h
+++ b/llvm/include/llvm/IR/IRBuilder.h
@@ -542,6 +542,12 @@ class IRBuilderBase {
   // Type creation methods
   //===--------------------------------------------------------------------===//
 
+  /// Fetch the type representing a byte.
+  IntegerType *getByteTy() {
+    const DataLayout &DL = BB->getDataLayout();
+    return Type::getIntNTy(Context, DL.getByteWidth());
+  }
+
   /// Fetch the type representing a single bit
   IntegerType *getInt1Ty() {
     return Type::getInt1Ty(Context);
@@ -2024,12 +2030,12 @@ class IRBuilderBase {
 
   Value *CreatePtrAdd(Value *Ptr, Value *Offset, const Twine &Name = "",
                       GEPNoWrapFlags NW = GEPNoWrapFlags::none()) {
-    return CreateGEP(getInt8Ty(), Ptr, Offset, Name, NW);
+    return CreateGEP(getByteTy(), Ptr, Offset, Name, NW);
   }
 
   Value *CreateInBoundsPtrAdd(Value *Ptr, Value *Offset,
                               const Twine &Name = "") {
-    return CreateGEP(getInt8Ty(), Ptr, Offset, Name,
+    return CreateGEP(getByteTy(), Ptr, Offset, Name,
                      GEPNoWrapFlags::inBounds());
   }
 
diff --git a/llvm/lib/Transforms/Instrumentation/SanitizerCoverage.cpp b/llvm/lib/Transforms/Instrumentation/SanitizerCoverage.cpp
index 7f061e2259711..d3b49730f4c13 100644
--- a/llvm/lib/Transforms/Instrumentation/SanitizerCoverage.cpp
+++ b/llvm/lib/Transforms/Instrumentation/SanitizerCoverage.cpp
@@ -369,14 +369,13 @@ ModuleSanitizerCoverage::CreateSecStartEnd(Module &M, const char *Section,
   GlobalVariable *SecEnd = new GlobalVariable(M, Ty, false, Linkage, nullptr,
                                               getSectionEnd(Section));
   SecEnd->setVisibility(GlobalValue::HiddenVisibility);
-  IRBuilder<> IRB(M.getContext());
   if (!TargetTriple.isOSBinFormatCOFF())
     return std::make_pair(SecStart, SecEnd);
 
   // Account for the fact that on windows-msvc __start_* symbols actually
   // point to a uint64_t before the start of the array.
-  auto GEP =
-      IRB.CreatePtrAdd(SecStart, ConstantInt::get(IntptrTy, sizeof(uint64_t)));
+  Constant *GEP = ConstantExpr::getGetElementPtr(
+      Int8Ty, SecStart, ConstantInt::get(IntptrTy, sizeof(uint64_t)));
   return std::make_pair(GEP, SecEnd);
 }
 
diff --git a/llvm/unittests/IR/IRBuilderTest.cpp b/llvm/unittests/IR/IRBuilderTest.cpp
index 4361594050668..bdc1da3a7a2c2 100644
--- a/llvm/unittests/IR/IRBuilderTest.cpp
+++ b/llvm/unittests/IR/IRBuilderTest.cpp
@@ -579,6 +579,14 @@ TEST_F(IRBuilderTest, DataLayout) {
   EXPECT_FALSE(M->getDataLayout().isLegalInteger(32));
 }
 
+TEST_F(IRBuilderTest, GetByteTy) {
+  IRBuilder<> Builder(BB);
+
+  EXPECT_TRUE(Builder.getByteTy()->isIntegerTy(8));
+  M->setDataLayout("b:32");
+  EXPECT_TRUE(Builder.getByteTy()->isIntegerTy(32));
+}
+
 TEST_F(IRBuilderTest, GetIntTy) {
   IRBuilder<> Builder(BB);
   IntegerType *Ty1 = Builder.getInt1Ty();
@@ -590,6 +598,20 @@ TEST_F(IRBuilderTest, GetIntTy) {
   EXPECT_EQ(IntPtrTy, IntegerType::get(Ctx, IntPtrBitSize));
 }
 
+TEST_F(IRBuilderTest, CreatePtrAdd) {
+  IRBuilder<> Builder(BB);
+
+  M->setDataLayout("b:16-p:32:32");
+  Value *V = Builder.CreatePtrAdd(GV, ConstantInt::get(Ctx, APInt(32, 42)));
+  ASSERT_TRUE(isa<GEPOperator>(V));
+  EXPECT_TRUE(cast<GEPOperator>(V)->getResultElementType()->isIntegerTy(16));
+
+  M->setDataLayout("b:32-p:64:32");
+  V = Builder.CreateInBoundsPtrAdd(GV, ConstantInt::get(Ctx, APInt(64, 42)));
+  ASSERT_TRUE(isa<GEPOperator>(V));
+  EXPECT_TRUE(cast<GEPOperator>(V)->getResultElementType()->isIntegerTy(32));
+}
+
 TEST_F(IRBuilderTest, UnaryOperators) {
   IRBuilder<NoFolder> Builder(BB);
   Value *V = Builder.CreateLoad(GV->getValueType(), GV);

>From 610ce98b772a43c1ef541db2ed8cfdc616363b0f Mon Sep 17 00:00:00 2001
From: Sergei Barannikov <barannikov88 at gmail.com>
Date: Sun, 22 Feb 2026 20:17:40 +0300
Subject: [PATCH 2/2] Use DL in ConstantExpr::getPtrAdd() /
 ConstantExpr::getInBoundsPtrAdd()

---
 clang/lib/CodeGen/CGExprConstant.cpp           |  2 +-
 clang/lib/CodeGen/CGObjCMac.cpp                |  2 +-
 clang/lib/CodeGen/ItaniumCXXABI.cpp            |  3 ++-
 llvm/include/llvm/IR/Constants.h               | 18 +++++++++---------
 llvm/lib/Analysis/ConstantFolding.cpp          |  2 +-
 llvm/lib/Analysis/ScalarEvolution.cpp          | 18 +++++++++---------
 llvm/lib/IR/Constants.cpp                      |  9 +++++++++
 llvm/lib/Transforms/IPO/GlobalSplit.cpp        |  2 +-
 llvm/lib/Transforms/IPO/LowerTypeTests.cpp     |  8 +++++---
 llvm/lib/Transforms/IPO/WholeProgramDevirt.cpp |  2 +-
 .../Instrumentation/IndirectCallPromotion.cpp  |  2 +-
 llvm/unittests/IR/PatternMatch.cpp             |  3 ++-
 .../Utils/CallPromotionUtilsTest.cpp           |  2 +-
 13 files changed, 43 insertions(+), 30 deletions(-)

diff --git a/clang/lib/CodeGen/CGExprConstant.cpp b/clang/lib/CodeGen/CGExprConstant.cpp
index 3f44243e1c35c..c724739a42601 100644
--- a/clang/lib/CodeGen/CGExprConstant.cpp
+++ b/clang/lib/CodeGen/CGExprConstant.cpp
@@ -2161,7 +2161,7 @@ class ConstantLValueEmitter : public ConstStmtVisitor<ConstantLValueEmitter,
     if (!hasNonZeroOffset())
       return C;
 
-    return llvm::ConstantExpr::getPtrAdd(C, getOffset());
+    return llvm::ConstantExpr::getPtrAdd(CGM.getDataLayout(), C, getOffset());
   }
 };
 
diff --git a/clang/lib/CodeGen/CGObjCMac.cpp b/clang/lib/CodeGen/CGObjCMac.cpp
index 1193de379bc9d..e80c90364ac3f 100644
--- a/clang/lib/CodeGen/CGObjCMac.cpp
+++ b/clang/lib/CodeGen/CGObjCMac.cpp
@@ -7369,7 +7369,7 @@ CGObjCNonFragileABIMac::GetClassGlobalForClassRef(const ObjCInterfaceDecl *ID) {
   // Stub classes are pointer-aligned. Classrefs pointing at stub classes
   // must set the least significant bit set to 1.
   auto *Idx = llvm::ConstantInt::get(CGM.Int32Ty, 1);
-  return llvm::ConstantExpr::getPtrAdd(ClassGV, Idx);
+  return llvm::ConstantExpr::getPtrAdd(CGM.getDataLayout(), ClassGV, Idx);
 }
 
 llvm::Value *
diff --git a/clang/lib/CodeGen/ItaniumCXXABI.cpp b/clang/lib/CodeGen/ItaniumCXXABI.cpp
index 397db2ee59408..0fada5f8d3221 100644
--- a/clang/lib/CodeGen/ItaniumCXXABI.cpp
+++ b/clang/lib/CodeGen/ItaniumCXXABI.cpp
@@ -4076,7 +4076,8 @@ void ItaniumRTTIBuilder::BuildVTablePointer(const Type *Ty,
     // The vtable address point is 8 bytes after its start:
     // 4 for the offset to top + 4 for the relative offset to rtti.
     llvm::Constant *Eight = llvm::ConstantInt::get(CGM.Int32Ty, 8);
-    VTable = llvm::ConstantExpr::getInBoundsPtrAdd(VTable, Eight);
+    VTable = llvm::ConstantExpr::getInBoundsPtrAdd(CGM.getDataLayout(), VTable,
+                                                   Eight);
   } else {
     llvm::Constant *Two = llvm::ConstantInt::get(PtrDiffTy, 2);
     VTable = llvm::ConstantExpr::getInBoundsGetElementPtr(CGM.GlobalsInt8PtrTy,
diff --git a/llvm/include/llvm/IR/Constants.h b/llvm/include/llvm/IR/Constants.h
index a1f667353b26e..0b7cc229df6c1 100644
--- a/llvm/include/llvm/IR/Constants.h
+++ b/llvm/include/llvm/IR/Constants.h
@@ -1306,15 +1306,13 @@ class ConstantExpr : public Constant {
                    std::optional<ConstantRange> InRange = std::nullopt,
                    Type *OnlyIfReducedTy = nullptr);
 
-  /// Create a getelementptr i8, ptr, offset constant expression.
+  /// Create a getelementptr iN, ptr, offset constant expression,
+  /// where iN is a byte-sized integer type.
   static Constant *
-  getPtrAdd(Constant *Ptr, Constant *Offset,
+  getPtrAdd(const DataLayout &DL, Constant *Ptr, Constant *Offset,
             GEPNoWrapFlags NW = GEPNoWrapFlags::none(),
             std::optional<ConstantRange> InRange = std::nullopt,
-            Type *OnlyIfReduced = nullptr) {
-    return getGetElementPtr(Type::getInt8Ty(Ptr->getContext()), Ptr, Offset, NW,
-                            InRange, OnlyIfReduced);
-  }
+            Type *OnlyIfReduced = nullptr);
 
   /// Create an "inbounds" getelementptr. See the documentation for the
   /// "inbounds" flag in LangRef.html for details.
@@ -1334,9 +1332,11 @@ class ConstantExpr : public Constant {
     return getGetElementPtr(Ty, C, IdxList, GEPNoWrapFlags::inBounds());
   }
 
-  /// Create a getelementptr inbounds i8, ptr, offset constant expression.
-  static Constant *getInBoundsPtrAdd(Constant *Ptr, Constant *Offset) {
-    return getPtrAdd(Ptr, Offset, GEPNoWrapFlags::inBounds());
+  /// Create a getelementptr inbounds iN, ptr, offset constant expression,
+  /// where iN is a byte-sized integer type.
+  static Constant *getInBoundsPtrAdd(const DataLayout &DL, Constant *Ptr,
+                                     Constant *Offset) {
+    return getPtrAdd(DL, Ptr, Offset, GEPNoWrapFlags::inBounds());
   }
 
   LLVM_ABI static Constant *getExtractElement(Constant *Vec, Constant *Idx,
diff --git a/llvm/lib/Analysis/ConstantFolding.cpp b/llvm/lib/Analysis/ConstantFolding.cpp
index 738d0c063a5e4..e8b13473d2bb2 100644
--- a/llvm/lib/Analysis/ConstantFolding.cpp
+++ b/llvm/lib/Analysis/ConstantFolding.cpp
@@ -984,7 +984,7 @@ Constant *SymbolicallyEvaluateGEP(const GEPOperator *GEP,
 
   // Otherwise canonicalize this to a single ptradd.
   LLVMContext &Ctx = Ptr->getContext();
-  return ConstantExpr::getPtrAdd(Ptr, ConstantInt::get(Ctx, Offset), NW,
+  return ConstantExpr::getPtrAdd(DL, Ptr, ConstantInt::get(Ctx, Offset), NW,
                                  InRange);
 }
 
diff --git a/llvm/lib/Analysis/ScalarEvolution.cpp b/llvm/lib/Analysis/ScalarEvolution.cpp
index 937b5aa77d467..e6d16733d849b 100644
--- a/llvm/lib/Analysis/ScalarEvolution.cpp
+++ b/llvm/lib/Analysis/ScalarEvolution.cpp
@@ -9986,7 +9986,7 @@ const SCEV *ScalarEvolution::getSCEVAtScope(const SCEV *V, const Loop *L) {
 /// will return Constants for objects which aren't represented by a
 /// SCEVConstant, because SCEVConstant is restricted to ConstantInt.
 /// Returns NULL if the SCEV isn't representable as a Constant.
-static Constant *BuildConstantFromSCEV(const SCEV *V) {
+static Constant *BuildConstantFromSCEV(const SCEV *V, const DataLayout &DL) {
   switch (V->getSCEVType()) {
   case scCouldNotCompute:
   case scAddRecExpr:
@@ -9998,21 +9998,21 @@ static Constant *BuildConstantFromSCEV(const SCEV *V) {
     return dyn_cast<Constant>(cast<SCEVUnknown>(V)->getValue());
   case scPtrToAddr: {
     const SCEVPtrToAddrExpr *P2I = cast<SCEVPtrToAddrExpr>(V);
-    if (Constant *CastOp = BuildConstantFromSCEV(P2I->getOperand()))
+    if (Constant *CastOp = BuildConstantFromSCEV(P2I->getOperand(), DL))
       return ConstantExpr::getPtrToAddr(CastOp, P2I->getType());
 
     return nullptr;
   }
   case scPtrToInt: {
     const SCEVPtrToIntExpr *P2I = cast<SCEVPtrToIntExpr>(V);
-    if (Constant *CastOp = BuildConstantFromSCEV(P2I->getOperand()))
+    if (Constant *CastOp = BuildConstantFromSCEV(P2I->getOperand(), DL))
       return ConstantExpr::getPtrToInt(CastOp, P2I->getType());
 
     return nullptr;
   }
   case scTruncate: {
     const SCEVTruncateExpr *ST = cast<SCEVTruncateExpr>(V);
-    if (Constant *CastOp = BuildConstantFromSCEV(ST->getOperand()))
+    if (Constant *CastOp = BuildConstantFromSCEV(ST->getOperand(), DL))
       return ConstantExpr::getTrunc(CastOp, ST->getType());
     return nullptr;
   }
@@ -10020,7 +10020,7 @@ static Constant *BuildConstantFromSCEV(const SCEV *V) {
     const SCEVAddExpr *SA = cast<SCEVAddExpr>(V);
     Constant *C = nullptr;
     for (const SCEV *Op : SA->operands()) {
-      Constant *OpC = BuildConstantFromSCEV(Op);
+      Constant *OpC = BuildConstantFromSCEV(Op, DL);
       if (!OpC)
         return nullptr;
       if (!C) {
@@ -10030,9 +10030,9 @@ static Constant *BuildConstantFromSCEV(const SCEV *V) {
       assert(!C->getType()->isPointerTy() &&
              "Can only have one pointer, and it must be last");
       if (OpC->getType()->isPointerTy()) {
-        // The offsets have been converted to bytes.  We can add bytes using
-        // an i8 GEP.
-        C = ConstantExpr::getPtrAdd(OpC, C);
+        // The offsets have been converted to bytes. We can add bytes using
+        // a ptradd.
+        C = ConstantExpr::getPtrAdd(DL, OpC, C);
       } else {
         C = ConstantExpr::getAdd(C, OpC);
       }
@@ -10265,7 +10265,7 @@ const SCEV *ScalarEvolution::computeSCEVAtScope(const SCEV *V, const Loop *L) {
       const SCEV *OpV = getSCEVAtScope(OrigV, L);
       MadeImprovement |= OrigV != OpV;
 
-      Constant *C = BuildConstantFromSCEV(OpV);
+      Constant *C = BuildConstantFromSCEV(OpV, DL);
       if (!C)
         return V;
       assert(C->getType() == Op->getType() && "Type mismatch");
diff --git a/llvm/lib/IR/Constants.cpp b/llvm/lib/IR/Constants.cpp
index 78ac276f4f3da..d8525d8e09f26 100644
--- a/llvm/lib/IR/Constants.cpp
+++ b/llvm/lib/IR/Constants.cpp
@@ -2575,6 +2575,15 @@ Constant *ConstantExpr::getGetElementPtr(Type *Ty, Constant *C,
   return pImpl->ExprConstants.getOrCreate(ReqTy, Key);
 }
 
+Constant *ConstantExpr::getPtrAdd(const DataLayout &DL, Constant *Ptr,
+                                  Constant *Offset, GEPNoWrapFlags NW,
+                                  std::optional<ConstantRange> InRange,
+                                  Type *OnlyIfReduced) {
+  unsigned ByteWidth = DL.getByteWidth();
+  return getGetElementPtr(Type::getIntNTy(Ptr->getContext(), ByteWidth), Ptr,
+                          Offset, NW, InRange, OnlyIfReduced);
+}
+
 Constant *ConstantExpr::getExtractElement(Constant *Val, Constant *Idx,
                                           Type *OnlyIfReducedTy) {
   assert(Val->getType()->isVectorTy() &&
diff --git a/llvm/lib/Transforms/IPO/GlobalSplit.cpp b/llvm/lib/Transforms/IPO/GlobalSplit.cpp
index ccc91cc355787..ec1618eea9bfd 100644
--- a/llvm/lib/Transforms/IPO/GlobalSplit.cpp
+++ b/llvm/lib/Transforms/IPO/GlobalSplit.cpp
@@ -154,7 +154,7 @@ static bool splitGlobal(GlobalVariable &GV) {
   for (const GEPInfo &Info : Infos) {
     assert(Info.MemberIndex < SplitGlobals.size() && "Invalid member");
     auto *NewGEP = ConstantExpr::getPtrAdd(
-        SplitGlobals[Info.MemberIndex],
+        DL, SplitGlobals[Info.MemberIndex],
         ConstantInt::get(GV.getContext(), Info.MemberRelativeOffset),
         Info.GEP->isInBounds());
     Info.GEP->replaceAllUsesWith(NewGEP);
diff --git a/llvm/lib/Transforms/IPO/LowerTypeTests.cpp b/llvm/lib/Transforms/IPO/LowerTypeTests.cpp
index 518e91628a478..8209c90631819 100644
--- a/llvm/lib/Transforms/IPO/LowerTypeTests.cpp
+++ b/llvm/lib/Transforms/IPO/LowerTypeTests.cpp
@@ -645,7 +645,8 @@ void LowerTypeTestsModule::allocateByteArrays() {
   for (unsigned I = 0; I != ByteArrayInfos.size(); ++I) {
     ByteArrayInfo *BAI = &ByteArrayInfos[I];
     Constant *GEP = ConstantExpr::getInBoundsPtrAdd(
-        ByteArray, ConstantInt::get(IntPtrTy, ByteArrayOffsets[I]));
+        M.getDataLayout(), ByteArray,
+        ConstantInt::get(IntPtrTy, ByteArrayOffsets[I]));
 
     // Create an alias instead of RAUW'ing the gep directly. On x86 this ensures
     // that the pc-relative displacement is folded into the lea instead of the
@@ -1192,8 +1193,9 @@ void LowerTypeTestsModule::lowerTypeTestCalls(
 
     uint64_t GlobalOffset =
         BSI.ByteOffset + ((BSI.BitSize - 1) << BSI.AlignLog2);
-    TIL.OffsetedGlobal = ConstantExpr::getPtrAdd(
-        CombinedGlobalAddr, ConstantInt::get(IntPtrTy, GlobalOffset)),
+    TIL.OffsetedGlobal =
+        ConstantExpr::getPtrAdd(M.getDataLayout(), CombinedGlobalAddr,
+                                ConstantInt::get(IntPtrTy, GlobalOffset)),
     TIL.AlignLog2 = ConstantInt::get(IntPtrTy, BSI.AlignLog2);
     TIL.SizeM1 = ConstantInt::get(IntPtrTy, BSI.BitSize - 1);
     if (BSI.isAllOnes()) {
diff --git a/llvm/lib/Transforms/IPO/WholeProgramDevirt.cpp b/llvm/lib/Transforms/IPO/WholeProgramDevirt.cpp
index 8c2420a45a24c..ebe3924a9e349 100644
--- a/llvm/lib/Transforms/IPO/WholeProgramDevirt.cpp
+++ b/llvm/lib/Transforms/IPO/WholeProgramDevirt.cpp
@@ -1803,7 +1803,7 @@ void DevirtModule::applyUniqueRetValOpt(CallSiteInfo &CSInfo, StringRef FnName,
 }
 
 Constant *DevirtModule::getMemberAddr(const TypeMemberInfo *M) {
-  return ConstantExpr::getPtrAdd(M->Bits->GV,
+  return ConstantExpr::getPtrAdd(this->M.getDataLayout(), M->Bits->GV,
                                  ConstantInt::get(Int64Ty, M->Offset));
 }
 
diff --git a/llvm/lib/Transforms/Instrumentation/IndirectCallPromotion.cpp b/llvm/lib/Transforms/Instrumentation/IndirectCallPromotion.cpp
index f3cdb3518ddcb..4b19159e89f66 100644
--- a/llvm/lib/Transforms/Instrumentation/IndirectCallPromotion.cpp
+++ b/llvm/lib/Transforms/Instrumentation/IndirectCallPromotion.cpp
@@ -217,7 +217,7 @@ static Constant *getVTableAddressPointOffset(GlobalVariable *VTable,
          "Out-of-bound access");
 
   return ConstantExpr::getInBoundsPtrAdd(
-      VTable,
+      M.getDataLayout(), VTable,
       llvm::ConstantInt::get(Type::getInt32Ty(Context), AddressPointOffset));
 }
 
diff --git a/llvm/unittests/IR/PatternMatch.cpp b/llvm/unittests/IR/PatternMatch.cpp
index 220e35d37c0be..feb3973b47202 100644
--- a/llvm/unittests/IR/PatternMatch.cpp
+++ b/llvm/unittests/IR/PatternMatch.cpp
@@ -2606,7 +2606,8 @@ TEST_F(PatternMatchTest, PtrAdd) {
   Constant *Offset = ConstantInt::get(IdxTy, 42);
   Value *PtrAdd = IRB.CreatePtrAdd(Null, Offset);
   Value *OtherGEP = IRB.CreateGEP(IdxTy, Null, Offset);
-  Value *PtrAddConst = ConstantExpr::getPtrAdd(Null, Offset);
+  Value *PtrAddConst =
+      ConstantExpr::getPtrAdd(M->getDataLayout(), Null, Offset);
 
   Value *A, *B;
   EXPECT_TRUE(match(PtrAdd, m_PtrAdd(m_Value(A), m_Value(B))));
diff --git a/llvm/unittests/Transforms/Utils/CallPromotionUtilsTest.cpp b/llvm/unittests/Transforms/Utils/CallPromotionUtilsTest.cpp
index c859b0c799f08..7951db904d71d 100644
--- a/llvm/unittests/Transforms/Utils/CallPromotionUtilsTest.cpp
+++ b/llvm/unittests/Transforms/Utils/CallPromotionUtilsTest.cpp
@@ -44,7 +44,7 @@ static Constant *getVTableAddressPointOffset(GlobalVariable *VTable,
          "Out-of-bound access");
 
   return ConstantExpr::getInBoundsPtrAdd(
-      VTable,
+      M.getDataLayout(), VTable,
       llvm::ConstantInt::get(Type::getInt32Ty(Context), AddressPointOffset));
 }
 



More information about the llvm-branch-commits mailing list