blob: a74d5446d14463bdf72df90cdc582afa22fe5a9b (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
//===-- 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/Expr.h"
#include "llvm/IR/Type.h"
#include "llvm/IR/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.
ref<Expr> Expr::createSExtToPointerWidth(ref<Expr> e) {
return SExtExpr::create(e, Context::get().getPointerWidth());
}
ref<Expr> Expr::createZExtToPointerWidth(ref<Expr> e) {
return ZExtExpr::create(e, Context::get().getPointerWidth());
}
ref<ConstantExpr> Expr::createPointer(uint64_t v) {
return ConstantExpr::create(v, Context::get().getPointerWidth());
}
|