111 lines
3 KiB
Nix
111 lines
3 KiB
Nix
|
{ stdenv
|
||
|
, lib
|
||
|
, fetchFromGitHub
|
||
|
, fetchpatch
|
||
|
, cmake
|
||
|
, llvmPackages_9
|
||
|
, clang_9
|
||
|
, python3
|
||
|
, zlib
|
||
|
, z3
|
||
|
, stp
|
||
|
, cryptominisat
|
||
|
, gperftools
|
||
|
, sqlite
|
||
|
, gtest
|
||
|
, lit
|
||
|
, debug ? false
|
||
|
}:
|
||
|
|
||
|
let
|
||
|
kleePython = python3.withPackages (ps: with ps; [ tabulate ]);
|
||
|
in
|
||
|
stdenv.mkDerivation rec {
|
||
|
pname = "klee";
|
||
|
version = "2.2";
|
||
|
src = fetchFromGitHub {
|
||
|
owner = "klee";
|
||
|
repo = "klee";
|
||
|
rev = "v${version}";
|
||
|
sha256 = "Ar3BKfADjJvvP0dI9+x/l3RDs8ncx4jmO7ol4MgOr4M=";
|
||
|
};
|
||
|
buildInputs = [
|
||
|
llvmPackages_9.llvm clang_9 z3 stp cryptominisat
|
||
|
gperftools sqlite
|
||
|
];
|
||
|
nativeBuildInputs = [
|
||
|
cmake
|
||
|
];
|
||
|
checkInputs = [
|
||
|
gtest
|
||
|
|
||
|
# Should appear BEFORE lit, since lit passes through python rather
|
||
|
# than the python environment we make.
|
||
|
kleePython
|
||
|
(lit.override { python3 = kleePython; })
|
||
|
];
|
||
|
|
||
|
cmakeFlags = let
|
||
|
buildType = if debug then "Debug" else "Release";
|
||
|
in
|
||
|
[
|
||
|
"-DCMAKE_BUILD_TYPE=${buildType}"
|
||
|
"-DKLEE_RUNTIME_BUILD_TYPE=${buildType}"
|
||
|
"-DENABLE_POSIX_RUNTIME=ON"
|
||
|
"-DENABLE_UNIT_TESTS=ON"
|
||
|
"-DENABLE_SYSTEM_TESTS=ON"
|
||
|
"-DGTEST_SRC_DIR=${gtest.src}"
|
||
|
"-DGTEST_INCLUDE_DIR=${gtest.src}/googletest/include"
|
||
|
"-Wno-dev"
|
||
|
];
|
||
|
|
||
|
# Silence various warnings during the compilation of fortified bitcode.
|
||
|
NIX_CFLAGS_COMPILE = ["-Wno-macro-redefined"];
|
||
|
|
||
|
prePatch = ''
|
||
|
patchShebangs .
|
||
|
'';
|
||
|
|
||
|
/* This patch is currently necessary for the unit test suite to run correctly.
|
||
|
* See https://www.mail-archive.com/klee-dev@imperial.ac.uk/msg03136.html
|
||
|
* and https://github.com/klee/klee/pull/1458 for more information.
|
||
|
*/
|
||
|
patches = map fetchpatch [
|
||
|
{
|
||
|
name = "fix-gtest";
|
||
|
sha256 = "F+/6videwJZz4sDF9lnV4B8lMx6W11KFJ0Q8t1qUDf4=";
|
||
|
url = "https://github.com/klee/klee/pull/1458.patch";
|
||
|
}
|
||
|
];
|
||
|
|
||
|
doCheck = true;
|
||
|
checkTarget = "check";
|
||
|
|
||
|
meta = with lib; {
|
||
|
description = "A symbolic virtual machine built on top of LLVM";
|
||
|
longDescription = ''
|
||
|
KLEE is a symbolic virtual machine built on top of the LLVM compiler
|
||
|
infrastructure. Currently, there are two primary components:
|
||
|
|
||
|
1. 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/.
|
||
|
|
||
|
2. A POSIX/Linux emulation layer oriented towards supporting uClibc, with
|
||
|
additional support for making parts of the operating system environment
|
||
|
symbolic.
|
||
|
|
||
|
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.
|
||
|
'';
|
||
|
homepage = "https://klee.github.io/";
|
||
|
license = licenses.ncsa;
|
||
|
platforms = [ "x86_64-linux" ];
|
||
|
maintainers = with maintainers; [ numinit ];
|
||
|
};
|
||
|
}
|