68 lines
1.5 KiB
Nix
68 lines
1.5 KiB
Nix
|
{ stdenv
|
||
|
, fetchFromGitHub
|
||
|
, fetchpatch
|
||
|
, lib
|
||
|
, arch
|
||
|
, ocamlPackages
|
||
|
, ocaml
|
||
|
, zlib
|
||
|
, z3
|
||
|
}:
|
||
|
|
||
|
|
||
|
stdenv.mkDerivation rec {
|
||
|
pname = "sail-riscv";
|
||
|
version = "0.5";
|
||
|
|
||
|
src = fetchFromGitHub {
|
||
|
owner = "riscv";
|
||
|
repo = pname;
|
||
|
rev = version;
|
||
|
hash = "sha256-7PZNNUMaCZEBf0lOCqkquewRgZPooBOjIbGF7JlLnEo=";
|
||
|
};
|
||
|
|
||
|
nativeBuildInputs = with ocamlPackages; [ ocamlbuild findlib ocaml z3 sail ];
|
||
|
buildInputs = with ocamlPackages; [ zlib linksem ];
|
||
|
strictDeps = true;
|
||
|
|
||
|
patches = [
|
||
|
(fetchpatch {
|
||
|
url = "https://github.com/riscv/sail-riscv/pull/250/commits/8bd37c484b83a8ce89c8bb7a001b8ae34dc4d77f.patch";
|
||
|
hash = "sha256-tDgkGhcbT6phoCAvilxMI56YUuUqQFgvh+2QduOjdMg=";
|
||
|
})
|
||
|
];
|
||
|
|
||
|
postPatch = ''
|
||
|
rm -r prover_snapshots
|
||
|
'' + lib.optionalString stdenv.hostPlatform.isDarwin ''
|
||
|
substituteInPlace Makefile --replace "-flto" ""
|
||
|
'';
|
||
|
|
||
|
makeFlags = [
|
||
|
"SAIL=sail"
|
||
|
"ARCH=${arch}"
|
||
|
"SAIL_DIR=${ocamlPackages.sail}/share/sail"
|
||
|
"LEM_DIR=${ocamlPackages.sail}/share/lem"
|
||
|
];
|
||
|
|
||
|
installPhase = ''
|
||
|
runHook preInstall
|
||
|
|
||
|
mkdir -p $out/bin
|
||
|
cp c_emulator/riscv_sim_${arch} $out/bin
|
||
|
mkdir $out/share/
|
||
|
cp -r generated_definitions/{coq,hol4,isabelle} $out/share/
|
||
|
|
||
|
runHook postInstall
|
||
|
'';
|
||
|
|
||
|
|
||
|
meta = with lib; {
|
||
|
homepage = "https://github.com/riscv/sail-riscv";
|
||
|
description = "Formal specification of the RISC-V architecture, written in Sail";
|
||
|
maintainers = with maintainers; [ genericnerdyusername ];
|
||
|
broken = stdenv.hostPlatform.isDarwin && stdenv.hostPlatform.isAarch64;
|
||
|
license = licenses.bsd2;
|
||
|
};
|
||
|
}
|