182 lines
4.7 KiB
Nix
182 lines
4.7 KiB
Nix
{
|
|
stdenv,
|
|
lib,
|
|
bison,
|
|
boost,
|
|
fetchFromGitHub,
|
|
flex,
|
|
libffi,
|
|
makeWrapper,
|
|
pkg-config,
|
|
python3,
|
|
readline,
|
|
symlinkJoin,
|
|
tcl,
|
|
iverilog,
|
|
zlib,
|
|
yosys,
|
|
yosys-bluespec,
|
|
yosys-ghdl,
|
|
yosys-symbiflow,
|
|
enablePython ? true, # enable python binding
|
|
}:
|
|
|
|
# NOTE: as of late 2020, yosys has switched to an automation robot that
|
|
# automatically tags their repository Makefile with a new build number every
|
|
# day when changes are committed. please MAKE SURE that the version number in
|
|
# the 'version' field exactly matches the YOSYS_VER field in the Yosys
|
|
# makefile!
|
|
#
|
|
# if a change in yosys isn't yet available under a build number like this (i.e.
|
|
# it was very recently merged, within an hour), wait a few hours for the
|
|
# automation robot to tag the new version, like so:
|
|
#
|
|
# https://github.com/YosysHQ/yosys/commit/71ca9a825309635511b64b3ec40e5e5e9b6ad49b
|
|
#
|
|
# note that while most nix packages for "unstable versions" use a date-based
|
|
# version scheme, synchronizing the nix package version here with the unstable
|
|
# yosys version number helps users report better bugs upstream, and is
|
|
# ultimately less confusing than using dates.
|
|
|
|
let
|
|
|
|
# Provides a wrapper for creating a yosys with the specifed plugins preloaded
|
|
#
|
|
# Example:
|
|
#
|
|
# my_yosys = yosys.withPlugins (with yosys.allPlugins; [
|
|
# fasm
|
|
# bluespec
|
|
# ]);
|
|
withPlugins =
|
|
plugins:
|
|
let
|
|
paths = lib.closePropagation plugins;
|
|
module_flags =
|
|
with builtins;
|
|
concatStringsSep " " (map (n: "--add-flags -m --add-flags ${n.plugin}") plugins);
|
|
in
|
|
lib.appendToName "with-plugins" (symlinkJoin {
|
|
inherit (yosys) name;
|
|
paths = paths ++ [ yosys ];
|
|
nativeBuildInputs = [ makeWrapper ];
|
|
postBuild = ''
|
|
wrapProgram $out/bin/yosys \
|
|
--set NIX_YOSYS_PLUGIN_DIRS $out/share/yosys/plugins \
|
|
${module_flags}
|
|
'';
|
|
});
|
|
|
|
allPlugins = {
|
|
bluespec = yosys-bluespec;
|
|
ghdl = yosys-ghdl;
|
|
} // (yosys-symbiflow);
|
|
|
|
boost_python = boost.override {
|
|
enablePython = true;
|
|
python = python3;
|
|
};
|
|
|
|
in
|
|
stdenv.mkDerivation (finalAttrs: {
|
|
pname = "yosys";
|
|
version = "0.47";
|
|
|
|
src = fetchFromGitHub {
|
|
owner = "YosysHQ";
|
|
repo = "yosys";
|
|
rev = "refs/tags/${finalAttrs.version}";
|
|
hash = "sha256-9u9aAPTZyt9vzZwryor3GRCGzs/mu2/XtM0XzV7uHfk=";
|
|
fetchSubmodules = true;
|
|
leaveDotGit = true;
|
|
postFetch = ''
|
|
# set up git hashes as if we used the tarball
|
|
|
|
pushd $out
|
|
git rev-parse HEAD > .gitcommit
|
|
cd $out/abc
|
|
git rev-parse HEAD > .gitcommit
|
|
popd
|
|
|
|
# remove .git now that we are through with it
|
|
find "$out" -name .git -print0 | xargs -0 rm -rf
|
|
'';
|
|
};
|
|
|
|
enableParallelBuilding = true;
|
|
nativeBuildInputs = [
|
|
pkg-config
|
|
bison
|
|
flex
|
|
];
|
|
propagatedBuildInputs = [
|
|
tcl
|
|
readline
|
|
libffi
|
|
zlib
|
|
(python3.withPackages (
|
|
pp: with pp; [
|
|
click
|
|
]
|
|
))
|
|
] ++ lib.optional enablePython boost_python;
|
|
|
|
makeFlags = [ "PREFIX=${placeholder "out"}" ];
|
|
|
|
patches = [
|
|
./plugin-search-dirs.patch
|
|
./fix-clang-build.patch # see https://github.com/YosysHQ/yosys/issues/2011
|
|
];
|
|
|
|
postPatch = ''
|
|
substituteInPlace ./Makefile \
|
|
--replace-fail 'echo UNKNOWN' 'echo ${builtins.substring 0 10 finalAttrs.src.rev}'
|
|
|
|
patchShebangs tests ./misc/yosys-config.in
|
|
'';
|
|
|
|
preBuild =
|
|
''
|
|
chmod -R u+w .
|
|
make config-${if stdenv.cc.isClang or false then "clang" else "gcc"}
|
|
|
|
if ! grep -q "YOSYS_VER := $version" Makefile; then
|
|
echo "ERROR: yosys version in Makefile isn't equivalent to version of the nix package (allegedly ${finalAttrs.version}), failing."
|
|
exit 1
|
|
fi
|
|
''
|
|
+ lib.optionalString enablePython ''
|
|
echo "ENABLE_PYOSYS := 1" >> Makefile.conf
|
|
echo "PYTHON_DESTDIR := $out/${python3.sitePackages}" >> Makefile.conf
|
|
echo "BOOST_PYTHON_LIB := -lboost_python${lib.versions.major python3.version}${lib.versions.minor python3.version}" >> Makefile.conf
|
|
'';
|
|
|
|
preCheck = ''
|
|
# autotest.sh automatically compiles a utility during startup if it's out of date.
|
|
# having N check jobs race to do that creates spurious codesigning failures on macOS.
|
|
# run it once without asking it to do anything so that compilation is done before the jobs start.
|
|
tests/tools/autotest.sh
|
|
'';
|
|
|
|
checkTarget = "test";
|
|
doCheck = true;
|
|
nativeCheckInputs = [ iverilog ];
|
|
|
|
setupHook = ./setup-hook.sh;
|
|
|
|
passthru = {
|
|
inherit withPlugins allPlugins;
|
|
};
|
|
|
|
meta = with lib; {
|
|
description = "Open RTL synthesis framework and tools";
|
|
homepage = "https://yosyshq.net/yosys/";
|
|
license = licenses.isc;
|
|
platforms = platforms.all;
|
|
maintainers = with maintainers; [
|
|
shell
|
|
thoughtpolice
|
|
Luflosi
|
|
];
|
|
};
|
|
})
|