KLEE
is a symbolic virtual machine built on top of the LLVM compiler
infrastructure. This version contains parts that implement the
Tracer-X approach to
symbolic execution. This approach builds upon the experience with
TRACER symbolic execution
tool where it combines the core technology of TRACER with advanced
symbolic execution approaches. The Tracer-X extension is still being
actively developed by its team and not yet ready for release. There
are several example
programs that we use
for testing it.
Currently in this version, there are three primary components:
-
The core symbolic virtual machine engine; this is responsible for executing LLVM bitcode modules with support for symbolic values. This is comprised of the code in lib/.
-
A POSIX/Linux emulation layer oriented towards supporting uClibc, with additional support for making parts of the operating system environment symbolic.
-
The Tracer-X extension that implements TRACER technology and is plugged into the KLEE's core symbolic virtual machine engine.
Additionally, there is a simple library for replaying computed inputs on native code (for closed programs). There is also a more complicated infrastructure for replaying the inputs generated for the POSIX/Linux emulation layer, which handles running native programs in an environment that matches a computed test input, including setting up files, pipes, environment variables, and passing command line arguments.
Coverage information for KLEE can be found here.
For further information on KLEE, see its webpage.
For further information on Tracer-X see its webpage.