mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-09-30 04:56:49 +00:00
Hoist the GEP constant address offset computation to a common home on
the GEP instruction class. This is part of the continued refactoring and cleaning of the infrastructure used by SROA. This particular operation is also done in a few other places which I'll try to refactor to share this implementation. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@169852 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
05749cff9b
commit
4ced4ee94b
@ -29,7 +29,6 @@
|
|||||||
#include "llvm/InstVisitor.h"
|
#include "llvm/InstVisitor.h"
|
||||||
#include "llvm/IntrinsicInst.h"
|
#include "llvm/IntrinsicInst.h"
|
||||||
#include "llvm/Support/Compiler.h"
|
#include "llvm/Support/Compiler.h"
|
||||||
#include "llvm/Support/GetElementPtrTypeIterator.h"
|
|
||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
|
||||||
|
@ -29,9 +29,10 @@
|
|||||||
|
|
||||||
namespace llvm {
|
namespace llvm {
|
||||||
|
|
||||||
|
class APInt;
|
||||||
class ConstantInt;
|
class ConstantInt;
|
||||||
class ConstantRange;
|
class ConstantRange;
|
||||||
class APInt;
|
class DataLayout;
|
||||||
class LLVMContext;
|
class LLVMContext;
|
||||||
|
|
||||||
enum AtomicOrdering {
|
enum AtomicOrdering {
|
||||||
@ -850,6 +851,16 @@ public:
|
|||||||
/// isInBounds - Determine whether the GEP has the inbounds flag.
|
/// isInBounds - Determine whether the GEP has the inbounds flag.
|
||||||
bool isInBounds() const;
|
bool isInBounds() const;
|
||||||
|
|
||||||
|
/// \brief Accumulate the constant address offset of this GEP if possible.
|
||||||
|
///
|
||||||
|
/// This routine accepts an APInt into which it will accumulate the constant
|
||||||
|
/// offset of this GEP if the GEP is in fact constant. If the GEP is not
|
||||||
|
/// all-constant, it returns false and the value of the offset APInt is
|
||||||
|
/// undefined (it is *not* preserved!). The APInt passed into this routine
|
||||||
|
/// must be at least as wide as the IntPtr type for the address space of
|
||||||
|
/// the base GEP pointer.
|
||||||
|
bool accumulateConstantOffset(const DataLayout &DL, APInt &Offset) const;
|
||||||
|
|
||||||
// Methods for support type inquiry through isa, cast, and dyn_cast:
|
// Methods for support type inquiry through isa, cast, and dyn_cast:
|
||||||
static inline bool classof(const Instruction *I) {
|
static inline bool classof(const Instruction *I) {
|
||||||
return (I->getOpcode() == Instruction::GetElementPtr);
|
return (I->getOpcode() == Instruction::GetElementPtr);
|
||||||
|
@ -32,27 +32,5 @@ bool detail::PtrUseVisitorBase::adjustOffsetForGEP(GetElementPtrInst &GEPI) {
|
|||||||
if (!IsOffsetKnown)
|
if (!IsOffsetKnown)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
for (gep_type_iterator GTI = gep_type_begin(GEPI), GTE = gep_type_end(GEPI);
|
return GEPI.accumulateConstantOffset(DL, Offset);
|
||||||
GTI != GTE; ++GTI) {
|
|
||||||
ConstantInt *OpC = dyn_cast<ConstantInt>(GTI.getOperand());
|
|
||||||
if (!OpC)
|
|
||||||
return false;
|
|
||||||
if (OpC->isZero())
|
|
||||||
continue;
|
|
||||||
|
|
||||||
// Handle a struct index, which adds its field offset to the pointer.
|
|
||||||
if (StructType *STy = dyn_cast<StructType>(*GTI)) {
|
|
||||||
unsigned ElementIdx = OpC->getZExtValue();
|
|
||||||
const StructLayout *SL = DL.getStructLayout(STy);
|
|
||||||
Offset += APInt(Offset.getBitWidth(),
|
|
||||||
SL->getElementOffset(ElementIdx));
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
// For array or vector indices, scale the index by the size of the type.
|
|
||||||
APInt Index = OpC->getValue().sextOrTrunc(Offset.getBitWidth());
|
|
||||||
Offset += Index * APInt(Offset.getBitWidth(),
|
|
||||||
DL.getTypeAllocSize(GTI.getIndexedType()));
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
@ -15,6 +15,7 @@
|
|||||||
#include "llvm/Instructions.h"
|
#include "llvm/Instructions.h"
|
||||||
#include "LLVMContextImpl.h"
|
#include "LLVMContextImpl.h"
|
||||||
#include "llvm/Constants.h"
|
#include "llvm/Constants.h"
|
||||||
|
#include "llvm/DataLayout.h"
|
||||||
#include "llvm/DerivedTypes.h"
|
#include "llvm/DerivedTypes.h"
|
||||||
#include "llvm/Function.h"
|
#include "llvm/Function.h"
|
||||||
#include "llvm/Module.h"
|
#include "llvm/Module.h"
|
||||||
@ -22,6 +23,7 @@
|
|||||||
#include "llvm/Support/CallSite.h"
|
#include "llvm/Support/CallSite.h"
|
||||||
#include "llvm/Support/ConstantRange.h"
|
#include "llvm/Support/ConstantRange.h"
|
||||||
#include "llvm/Support/ErrorHandling.h"
|
#include "llvm/Support/ErrorHandling.h"
|
||||||
|
#include "llvm/Support/GetElementPtrTypeIterator.h"
|
||||||
#include "llvm/Support/MathExtras.h"
|
#include "llvm/Support/MathExtras.h"
|
||||||
using namespace llvm;
|
using namespace llvm;
|
||||||
|
|
||||||
@ -1423,6 +1425,37 @@ bool GetElementPtrInst::isInBounds() const {
|
|||||||
return cast<GEPOperator>(this)->isInBounds();
|
return cast<GEPOperator>(this)->isInBounds();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool GetElementPtrInst::accumulateConstantOffset(const DataLayout &DL,
|
||||||
|
APInt &Offset) const {
|
||||||
|
assert(Offset.getBitWidth() ==
|
||||||
|
DL.getPointerSizeInBits(getPointerAddressSpace()) &&
|
||||||
|
"The offset must have exactly as many bits as our pointer.");
|
||||||
|
|
||||||
|
for (gep_type_iterator GTI = gep_type_begin(this), GTE = gep_type_end(this);
|
||||||
|
GTI != GTE; ++GTI) {
|
||||||
|
ConstantInt *OpC = dyn_cast<ConstantInt>(GTI.getOperand());
|
||||||
|
if (!OpC)
|
||||||
|
return false;
|
||||||
|
if (OpC->isZero())
|
||||||
|
continue;
|
||||||
|
|
||||||
|
// Handle a struct index, which adds its field offset to the pointer.
|
||||||
|
if (StructType *STy = dyn_cast<StructType>(*GTI)) {
|
||||||
|
unsigned ElementIdx = OpC->getZExtValue();
|
||||||
|
const StructLayout *SL = DL.getStructLayout(STy);
|
||||||
|
Offset += APInt(Offset.getBitWidth(),
|
||||||
|
SL->getElementOffset(ElementIdx));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// For array or vector indices, scale the index by the size of the type.
|
||||||
|
APInt Index = OpC->getValue().sextOrTrunc(Offset.getBitWidth());
|
||||||
|
Offset += Index * APInt(Offset.getBitWidth(),
|
||||||
|
DL.getTypeAllocSize(GTI.getIndexedType()));
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
// ExtractElementInst Implementation
|
// ExtractElementInst Implementation
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
Loading…
Reference in New Issue
Block a user