From 913d18f567a50f21e4f60788f9dd571e46b9b142 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Mon, 29 Apr 2002 18:46:50 +0000 Subject: Changes so that iMemory.h doesn't include DerivedTypes.h llvm-svn: 2404 --- llvm/lib/VMCore/iMemory.cpp | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) (limited to 'llvm/lib/VMCore/iMemory.cpp') diff --git a/llvm/lib/VMCore/iMemory.cpp b/llvm/lib/VMCore/iMemory.cpp index 09d9d156bf6..0a62d1cae06 100644 --- a/llvm/lib/VMCore/iMemory.cpp +++ b/llvm/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)); +} + -- cgit v1.2.3