2009-07-17 02:04:31 +08:00
|
|
|
//===----------------- LLVMContextImpl.h - Implementation ------*- C++ -*--===//
|
2009-06-30 08:48:55 +08:00
|
|
|
//
|
|
|
|
// The LLVM Compiler Infrastructure
|
|
|
|
//
|
|
|
|
// This file is distributed under the University of Illinois Open Source
|
|
|
|
// License. See LICENSE.TXT for details.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
2009-07-01 01:06:46 +08:00
|
|
|
//
|
|
|
|
// This file declares LLVMContextImpl, the opaque implementation
|
|
|
|
// of LLVMContext.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
2009-06-30 08:48:55 +08:00
|
|
|
|
|
|
|
#ifndef LLVM_LLVMCONTEXT_IMPL_H
|
|
|
|
#define LLVM_LLVMCONTEXT_IMPL_H
|
|
|
|
|
2009-07-21 10:47:59 +08:00
|
|
|
#include "llvm/LLVMContext.h"
|
|
|
|
#include "llvm/DerivedTypes.h"
|
2009-07-17 02:04:31 +08:00
|
|
|
#include "llvm/System/RWMutex.h"
|
2009-07-17 03:05:41 +08:00
|
|
|
#include "llvm/ADT/APFloat.h"
|
2009-07-17 02:04:31 +08:00
|
|
|
#include "llvm/ADT/APInt.h"
|
|
|
|
#include "llvm/ADT/DenseMap.h"
|
2009-07-17 07:44:30 +08:00
|
|
|
#include "llvm/ADT/FoldingSet.h"
|
2009-07-17 06:11:26 +08:00
|
|
|
#include "llvm/ADT/StringMap.h"
|
2009-07-17 02:04:31 +08:00
|
|
|
|
2009-06-30 08:48:55 +08:00
|
|
|
namespace llvm {
|
|
|
|
|
2009-07-17 02:04:31 +08:00
|
|
|
class ConstantInt;
|
2009-07-17 03:05:41 +08:00
|
|
|
class ConstantFP;
|
2009-07-17 06:11:26 +08:00
|
|
|
class MDString;
|
2009-07-17 07:44:30 +08:00
|
|
|
class MDNode;
|
2009-07-17 02:04:31 +08:00
|
|
|
class LLVMContext;
|
|
|
|
class Type;
|
2009-07-17 07:44:30 +08:00
|
|
|
class Value;
|
2009-07-17 02:04:31 +08:00
|
|
|
|
|
|
|
struct DenseMapAPIntKeyInfo {
|
|
|
|
struct KeyTy {
|
|
|
|
APInt val;
|
|
|
|
const Type* type;
|
|
|
|
KeyTy(const APInt& V, const Type* Ty) : val(V), type(Ty) {}
|
|
|
|
KeyTy(const KeyTy& that) : val(that.val), type(that.type) {}
|
|
|
|
bool operator==(const KeyTy& that) const {
|
|
|
|
return type == that.type && this->val == that.val;
|
|
|
|
}
|
|
|
|
bool operator!=(const KeyTy& that) const {
|
|
|
|
return !this->operator==(that);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
static inline KeyTy getEmptyKey() { return KeyTy(APInt(1,0), 0); }
|
|
|
|
static inline KeyTy getTombstoneKey() { return KeyTy(APInt(1,1), 0); }
|
|
|
|
static unsigned getHashValue(const KeyTy &Key) {
|
|
|
|
return DenseMapInfo<void*>::getHashValue(Key.type) ^
|
|
|
|
Key.val.getHashValue();
|
|
|
|
}
|
|
|
|
static bool isEqual(const KeyTy &LHS, const KeyTy &RHS) {
|
|
|
|
return LHS == RHS;
|
|
|
|
}
|
|
|
|
static bool isPod() { return false; }
|
|
|
|
};
|
|
|
|
|
2009-07-17 03:05:41 +08:00
|
|
|
struct DenseMapAPFloatKeyInfo {
|
|
|
|
struct KeyTy {
|
|
|
|
APFloat val;
|
|
|
|
KeyTy(const APFloat& V) : val(V){}
|
|
|
|
KeyTy(const KeyTy& that) : val(that.val) {}
|
|
|
|
bool operator==(const KeyTy& that) const {
|
|
|
|
return this->val.bitwiseIsEqual(that.val);
|
|
|
|
}
|
|
|
|
bool operator!=(const KeyTy& that) const {
|
|
|
|
return !this->operator==(that);
|
|
|
|
}
|
|
|
|
};
|
|
|
|
static inline KeyTy getEmptyKey() {
|
|
|
|
return KeyTy(APFloat(APFloat::Bogus,1));
|
|
|
|
}
|
|
|
|
static inline KeyTy getTombstoneKey() {
|
|
|
|
return KeyTy(APFloat(APFloat::Bogus,2));
|
|
|
|
}
|
|
|
|
static unsigned getHashValue(const KeyTy &Key) {
|
|
|
|
return Key.val.getHashValue();
|
|
|
|
}
|
|
|
|
static bool isEqual(const KeyTy &LHS, const KeyTy &RHS) {
|
|
|
|
return LHS == RHS;
|
|
|
|
}
|
|
|
|
static bool isPod() { return false; }
|
|
|
|
};
|
|
|
|
|
2009-07-17 02:04:31 +08:00
|
|
|
class LLVMContextImpl {
|
|
|
|
sys::SmartRWMutex<true> ConstantsLock;
|
|
|
|
|
|
|
|
typedef DenseMap<DenseMapAPIntKeyInfo::KeyTy, ConstantInt*,
|
|
|
|
DenseMapAPIntKeyInfo> IntMapTy;
|
|
|
|
IntMapTy IntConstants;
|
|
|
|
|
2009-07-17 03:05:41 +08:00
|
|
|
typedef DenseMap<DenseMapAPFloatKeyInfo::KeyTy, ConstantFP*,
|
|
|
|
DenseMapAPFloatKeyInfo> FPMapTy;
|
|
|
|
FPMapTy FPConstants;
|
|
|
|
|
2009-07-17 06:11:26 +08:00
|
|
|
StringMap<MDString*> MDStringCache;
|
|
|
|
|
2009-07-17 07:44:30 +08:00
|
|
|
FoldingSet<MDNode> MDNodeSet;
|
|
|
|
|
2009-07-17 02:04:31 +08:00
|
|
|
LLVMContext &Context;
|
2009-07-21 10:47:59 +08:00
|
|
|
ConstantInt *TheTrueVal;
|
|
|
|
ConstantInt *TheFalseVal;
|
|
|
|
|
2009-07-17 02:04:31 +08:00
|
|
|
LLVMContextImpl();
|
|
|
|
LLVMContextImpl(const LLVMContextImpl&);
|
|
|
|
public:
|
2009-07-21 10:47:59 +08:00
|
|
|
LLVMContextImpl(LLVMContext &C) : Context(C), TheTrueVal(0), TheFalseVal(0) {}
|
2009-07-17 02:04:31 +08:00
|
|
|
|
|
|
|
/// Return a ConstantInt with the specified value and an implied Type. The
|
|
|
|
/// type is the integer type that corresponds to the bit width of the value.
|
2009-07-17 03:05:41 +08:00
|
|
|
ConstantInt *getConstantInt(const APInt &V);
|
|
|
|
|
|
|
|
ConstantFP *getConstantFP(const APFloat &V);
|
2009-07-17 06:11:26 +08:00
|
|
|
|
|
|
|
MDString *getMDString(const char *StrBegin, const char *StrEnd);
|
|
|
|
|
2009-07-17 07:44:30 +08:00
|
|
|
MDNode *getMDNode(Value*const* Vals, unsigned NumVals);
|
2009-07-17 06:11:26 +08:00
|
|
|
|
2009-07-22 02:03:38 +08:00
|
|
|
ConstantInt *getTrue() {
|
2009-07-21 10:47:59 +08:00
|
|
|
if (TheTrueVal)
|
|
|
|
return TheTrueVal;
|
|
|
|
else
|
|
|
|
return (TheTrueVal = Context.getConstantInt(IntegerType::get(1), 1));
|
|
|
|
}
|
|
|
|
|
2009-07-22 02:03:38 +08:00
|
|
|
ConstantInt *getFalse() {
|
2009-07-21 10:47:59 +08:00
|
|
|
if (TheFalseVal)
|
|
|
|
return TheFalseVal;
|
|
|
|
else
|
|
|
|
return (TheFalseVal = Context.getConstantInt(IntegerType::get(1), 0));
|
|
|
|
}
|
|
|
|
|
2009-07-17 06:11:26 +08:00
|
|
|
void erase(MDString *M);
|
2009-07-17 07:44:30 +08:00
|
|
|
void erase(MDNode *M);
|
2009-06-30 08:48:55 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2009-07-01 01:06:46 +08:00
|
|
|
#endif
|