mirror of
				https://github.com/YosysHQ/yosys
				synced 2025-11-04 13:29:12 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			48 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			48 lines
		
	
	
	
		
			1.7 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
{
 | 
						|
  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;
 | 
						|
        };
 | 
						|
        # TODO: don't override src when ./abc is empty
 | 
						|
        # which happens when the command used is `nix build` and not `nix build ?submodules=1`
 | 
						|
        abc-verifier = pkgs.abc-verifier;
 | 
						|
        yosys = pkgs.clangStdenv.mkDerivation {
 | 
						|
          name = "yosys";
 | 
						|
          src = ./. ;
 | 
						|
          buildInputs = with pkgs; [ clang bison flex libffi tcl readline python3 zlib git pkg-configUpstream llvmPackages.bintools ];
 | 
						|
          checkInputs = with pkgs; [ gtest ];
 | 
						|
          propagatedBuildInputs = [ abc-verifier ];
 | 
						|
          preConfigure = "make config-clang";
 | 
						|
          checkTarget = "unit-test";
 | 
						|
          installPhase = ''
 | 
						|
            make install PREFIX=$out ABCEXTERNAL=yosys-abc
 | 
						|
            ln -s ${abc-verifier}/bin/abc $out/bin/yosys-abc
 | 
						|
          '';
 | 
						|
					buildPhase = ''
 | 
						|
            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 {
 | 
						|
        packages.default = yosys;
 | 
						|
        defaultPackage = yosys;
 | 
						|
        devShell = pkgs.mkShell {
 | 
						|
          buildInputs = with pkgs; [ clang llvmPackages.bintools gcc bison flex libffi tcl readline python3 zlib git gtest abc-verifier verilog boost python3Packages.boost ];
 | 
						|
        };
 | 
						|
      }
 | 
						|
    );
 | 
						|
}
 |