yosys/flake.nix

49 lines
1.7 KiB
Nix
Raw Permalink Normal View History

{
description = "A nix flake for the Yosys synthesis suite";
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
flake-utils.url = "github:numtide/flake-utils";
};
outputs = { self, nixpkgs, flake-utils }:
flake-utils.lib.eachDefaultSystem (system:
let
pkgs = import nixpkgs {
inherit system;
};
2024-05-10 17:42:53 -05:00
# TODO: don't override src when ./abc is empty
# which happens when the command used is `nix build` and not `nix build ?submodules=1`
2024-11-11 08:45:11 -06:00
abc-verifier = pkgs.abc-verifier;
2024-05-21 05:50:23 -05:00
yosys = pkgs.clangStdenv.mkDerivation {
name = "yosys";
src = ./. ;
2024-11-11 08:45:11 -06:00
buildInputs = with pkgs; [ clang bison flex libffi tcl readline python3 zlib git pkg-configUpstream llvmPackages.bintools ];
checkInputs = with pkgs; [ gtest ];
2024-05-10 17:42:53 -05:00
propagatedBuildInputs = [ abc-verifier ];
preConfigure = "make config-clang";
2024-11-11 08:45:11 -06:00
checkTarget = "unit-test";
installPhase = ''
2024-05-10 17:42:53 -05:00
make install PREFIX=$out ABCEXTERNAL=yosys-abc
ln -s ${abc-verifier}/bin/abc $out/bin/yosys-abc
'';
buildPhase = ''
2024-05-10 17:42:53 -05:00
make -j$(nproc) ABCEXTERNAL=yosys-abc
'';
meta = with pkgs.lib; {
description = "Yosys Open SYnthesis Suite";
homepage = "https://yosyshq.net/yosys/";
license = licenses.isc;
maintainers = with maintainers; [ ];
};
};
in {
2024-05-21 05:50:23 -05:00
packages.default = yosys;
defaultPackage = yosys;
devShell = pkgs.mkShell {
2024-11-11 08:45:11 -06:00
buildInputs = with pkgs; [ clang llvmPackages.bintools gcc bison flex libffi tcl readline python3 zlib git gtest abc-verifier verilog boost python3Packages.boost ];
};
}
);
}