diff options
Diffstat (limited to 'lib/Core/Context.cpp')
-rw-r--r-- | lib/Core/Context.cpp | 56 |
1 files changed, 56 insertions, 0 deletions
diff --git a/lib/Core/Context.cpp b/lib/Core/Context.cpp new file mode 100644 index 00000000..590b2080 --- /dev/null +++ b/lib/Core/Context.cpp @@ -0,0 +1,56 @@ +//===-- Context.cpp -------------------------------------------------------===// +// +// The KLEE Symbolic Virtual Machine +// +// This file is distributed under the University of Illinois Open Source +// License. See LICENSE.TXT for details. +// +//===----------------------------------------------------------------------===// + +#include "Context.h" + +#include "klee/Expr.h" + +#include "llvm/Type.h" +#include "llvm/DerivedTypes.h" + +#include <cassert> + +using namespace klee; + +static bool Initialized = false; +static Context TheContext; + +void Context::initialize(bool IsLittleEndian, Expr::Width PointerWidth) { + assert(!Initialized && "Duplicate context initialization!"); + TheContext = Context(IsLittleEndian, PointerWidth); + Initialized = true; +} + +const Context &Context::get() { + assert(Initialized && "Context has not been initialized!"); + return TheContext; +} + +// FIXME: This is a total hack, just to avoid a layering issue until this stuff +// moves out of Expr. + +Expr::Width Expr::getWidthForLLVMType(const llvm::Type *t) { + switch (t->getTypeID()) { + default: + assert(0 && "non-primitive type argument to Expr::getTypeForLLVMType()\n"); + case llvm::Type::IntegerTyID: return cast<llvm::IntegerType>(t)->getBitWidth(); + case llvm::Type::FloatTyID: return Expr::Int32; + case llvm::Type::DoubleTyID: return Expr::Int64; + case llvm::Type::X86_FP80TyID: return 80; + case llvm::Type::PointerTyID: return Context::get().getPointerWidth(); + } +} + +ref<Expr> Expr::createCoerceToPointerType(ref<Expr> e) { + return ZExtExpr::create(e, Context::get().getPointerWidth()); +} + +ref<ConstantExpr> Expr::createPointer(uint64_t v) { + return ConstantExpr::create(v, Context::get().getPointerWidth()); +} |