From 3eb59c0074978cb4687779365dbe664e2e18e0b2 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Mon, 29 Apr 2002 18:46:50 +0000 Subject: [PATCH] Changes so that iMemory.h doesn't include DerivedTypes.h git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@2404 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/VMCore/AsmWriter.cpp | 1 + lib/VMCore/iMemory.cpp | 18 ++++++++++++++++++ 2 files changed, 19 insertions(+) diff --git a/lib/VMCore/AsmWriter.cpp b/lib/VMCore/AsmWriter.cpp index 8e5de342561..90ce6ba5175 100644 --- a/lib/VMCore/AsmWriter.cpp +++ b/lib/VMCore/AsmWriter.cpp @@ -11,6 +11,7 @@ #include "llvm/Assembly/CachedWriter.h" #include "llvm/Assembly/Writer.h" #include "llvm/SlotCalculator.h" +#include "llvm/DerivedTypes.h" #include "llvm/Module.h" #include "llvm/Function.h" #include "llvm/GlobalVariable.h" diff --git a/lib/VMCore/iMemory.cpp b/lib/VMCore/iMemory.cpp index 09d9d156bf6..0a62d1cae06 100644 --- a/lib/VMCore/iMemory.cpp +++ b/lib/VMCore/iMemory.cpp @@ -6,6 +6,7 @@ #include "llvm/iMemory.h" #include "llvm/Constants.h" +#include "llvm/DerivedTypes.h" static inline const Type *checkType(const Type *Ty) { assert(Ty && "Invalid indices for type!"); @@ -32,6 +33,11 @@ bool AllocationInst::isArrayAllocation() const { getOperand(0) != ConstantUInt::get(Type::UIntTy, 1); } +const Type *AllocationInst::getAllocatedType() const { + return getType()->getElementType(); +} + + //===----------------------------------------------------------------------===// // MemAccessInst Implementation //===----------------------------------------------------------------------===// @@ -130,3 +136,15 @@ GetElementPtrInst::GetElementPtrInst(Value *Ptr, const std::vector &Idx, for (unsigned i = 0, E = Idx.size(); i != E; ++i) Operands.push_back(Use(Idx[i], this)); } + + +//===----------------------------------------------------------------------===// +// FreeInst Implementation +//===----------------------------------------------------------------------===// + +FreeInst::FreeInst(Value *Ptr) : Instruction(Type::VoidTy, Free, "") { + assert(Ptr->getType()->isPointerType() && "Can't free nonpointer!"); + Operands.reserve(1); + Operands.push_back(Use(Ptr, this)); +} +