//===-- 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 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(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::createCoerceToPointerType(ref e) { return ZExtExpr::create(e, Context::get().getPointerWidth()); } ref Expr::createPointer(uint64_t v) { return ConstantExpr::create(v, Context::get().getPointerWidth()); }