[llvm] InlineCost: Use index sizes rather than pointer sizes in a few cases. (PR #119326)

Owen Anderson via llvm-commits llvm-commits at lists.llvm.org
Mon Dec 9 21:21:49 PST 2024


https://github.com/resistor created https://github.com/llvm/llvm-project/pull/119326

Rename a variable to clarify that it is an index size as well.

Co-authored-by: Alex Richardson <Alexander.Richardson at cl.cam.ac.uk>


>From 4ac5e9174b00f17628105062dc886484432bfaaf Mon Sep 17 00:00:00 2001
From: Owen Anderson <resistor at mac.com>
Date: Tue, 10 Dec 2024 18:19:35 +1300
Subject: [PATCH] InlineCost: Use index sizes rather than pointer sizes in a
 few cases.

Rename a variable to clarify that it is an index size as well.

Co-authored-by: Alex Richardson <Alexander.Richardson at cl.cam.ac.uk>
---
 llvm/lib/Analysis/InlineCost.cpp | 14 +++++++-------
 1 file changed, 7 insertions(+), 7 deletions(-)

diff --git a/llvm/lib/Analysis/InlineCost.cpp b/llvm/lib/Analysis/InlineCost.cpp
index 85287a39f2caad..c416ea6a35f753 100644
--- a/llvm/lib/Analysis/InlineCost.cpp
+++ b/llvm/lib/Analysis/InlineCost.cpp
@@ -1438,8 +1438,8 @@ void CallAnalyzer::disableLoadElimination() {
 /// Returns false if unable to compute the offset for any reason. Respects any
 /// simplified values known during the analysis of this callsite.
 bool CallAnalyzer::accumulateGEPOffset(GEPOperator &GEP, APInt &Offset) {
-  unsigned IntPtrWidth = DL.getIndexTypeSizeInBits(GEP.getType());
-  assert(IntPtrWidth == Offset.getBitWidth());
+  unsigned IndexWidth = DL.getIndexTypeSizeInBits(GEP.getType());
+  assert(IndexWidth == Offset.getBitWidth());
 
   for (gep_type_iterator GTI = gep_type_begin(GEP), GTE = gep_type_end(GEP);
        GTI != GTE; ++GTI) {
@@ -1454,12 +1454,12 @@ bool CallAnalyzer::accumulateGEPOffset(GEPOperator &GEP, APInt &Offset) {
     if (StructType *STy = GTI.getStructTypeOrNull()) {
       unsigned ElementIdx = OpC->getZExtValue();
       const StructLayout *SL = DL.getStructLayout(STy);
-      Offset += APInt(IntPtrWidth, SL->getElementOffset(ElementIdx));
+      Offset += APInt(IndexWidth, SL->getElementOffset(ElementIdx));
       continue;
     }
 
-    APInt TypeSize(IntPtrWidth, GTI.getSequentialElementStride(DL));
-    Offset += OpC->getValue().sextOrTrunc(IntPtrWidth) * TypeSize;
+    APInt TypeSize(IndexWidth, GTI.getSequentialElementStride(DL));
+    Offset += OpC->getValue().sextOrTrunc(IndexWidth) * TypeSize;
   }
   return true;
 }
@@ -1743,7 +1743,7 @@ bool CallAnalyzer::visitPtrToInt(PtrToIntInst &I) {
   // integer is large enough to represent the pointer.
   unsigned IntegerSize = I.getType()->getScalarSizeInBits();
   unsigned AS = I.getOperand(0)->getType()->getPointerAddressSpace();
-  if (IntegerSize == DL.getPointerSizeInBits(AS)) {
+  if (IntegerSize == DL.getIndexSizeInBits(AS)) {
     std::pair<Value *, APInt> BaseAndOffset =
         ConstantOffsetPtrs.lookup(I.getOperand(0));
     if (BaseAndOffset.first)
@@ -1773,7 +1773,7 @@ bool CallAnalyzer::visitIntToPtr(IntToPtrInst &I) {
   // modifications provided the integer is not too large.
   Value *Op = I.getOperand(0);
   unsigned IntegerSize = Op->getType()->getScalarSizeInBits();
-  if (IntegerSize <= DL.getPointerTypeSizeInBits(I.getType())) {
+  if (IntegerSize <= DL.getIndexTypeSizeInBits(I.getType())) {
     std::pair<Value *, APInt> BaseAndOffset = ConstantOffsetPtrs.lookup(Op);
     if (BaseAndOffset.first)
       ConstantOffsetPtrs[&I] = BaseAndOffset;



More information about the llvm-commits mailing list