2022-01-13 20:06:32 +00:00
|
|
|
{ fetchFromGitHub
|
|
|
|
, gtest
|
|
|
|
, lib
|
|
|
|
, python3
|
|
|
|
, readline
|
|
|
|
, stdenv
|
|
|
|
, yosys
|
|
|
|
, zlib
|
|
|
|
, yosys-symbiflow
|
2022-11-04 12:27:35 +00:00
|
|
|
, uhdm
|
|
|
|
, surelog
|
2022-11-21 17:40:18 +00:00
|
|
|
, flatbuffers
|
2022-01-13 20:06:32 +00:00
|
|
|
}: let
|
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
2022-11-04 12:27:35 +00:00
|
|
|
owner = "chipsalliance";
|
|
|
|
repo = "yosys-f4pga-plugins";
|
2022-11-21 17:40:18 +00:00
|
|
|
rev = "e23ff6db487da9ceea576c53ac33853566c3a84e";
|
|
|
|
hash = "sha256-HJ4br6lQwRrcnkLgV3aecr3T3zcPzA11MfxhRjwIb0I=";
|
2022-01-13 20:06:32 +00:00
|
|
|
};
|
|
|
|
|
2022-11-21 17:40:18 +00:00
|
|
|
version = "2022.11.07";
|
2022-01-13 20:06:32 +00:00
|
|
|
|
|
|
|
# Supported symbiflow plugins.
|
|
|
|
#
|
|
|
|
# The following are disabled:
|
|
|
|
#
|
|
|
|
# "ql-qlf" builds but fails to load the plugin, so is not currently supported.
|
|
|
|
plugins = [
|
|
|
|
"design_introspection"
|
|
|
|
"fasm"
|
|
|
|
"integrateinv"
|
|
|
|
"params"
|
|
|
|
"ql-iob"
|
|
|
|
# "ql-qlf"
|
|
|
|
"sdc"
|
|
|
|
"xdc"
|
2022-11-04 12:27:35 +00:00
|
|
|
"systemverilog"
|
2022-01-13 20:06:32 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
static_gtest = gtest.dev.overrideAttrs (old: {
|
|
|
|
dontDisableStatic = true;
|
|
|
|
disableHardening = [ "pie" ];
|
|
|
|
cmakeFlags = old.cmakeFlags ++ ["-DBUILD_SHARED_LIBS=OFF"];
|
|
|
|
});
|
|
|
|
|
|
|
|
in lib.genAttrs plugins (plugin: stdenv.mkDerivation (rec {
|
|
|
|
pname = "yosys-symbiflow-${plugin}-plugin";
|
|
|
|
inherit src version plugin;
|
|
|
|
enableParallelBuilding = true;
|
|
|
|
|
2022-11-04 12:27:35 +00:00
|
|
|
nativeBuildInputs = [ python3 ];
|
|
|
|
buildInputs = [ yosys readline zlib uhdm surelog ];
|
2022-01-13 20:06:32 +00:00
|
|
|
|
|
|
|
# xdc has an incorrect path to a test which has yet to be patched
|
|
|
|
doCheck = plugin != "xdc";
|
2023-02-02 18:25:31 +00:00
|
|
|
nativeCheckInputs = [ static_gtest ];
|
2022-01-13 20:06:32 +00:00
|
|
|
|
|
|
|
# ql-qlf tries to fetch a yosys script from github
|
|
|
|
# Run the script in preBuild instead.
|
|
|
|
patches = lib.optional ( plugin == "ql-qlf" ) ./symbiflow-pmgen.patch;
|
|
|
|
|
|
|
|
preBuild = ''
|
2022-11-21 17:40:18 +00:00
|
|
|
export LDFLAGS="-L${flatbuffers}/lib"
|
2022-01-13 20:06:32 +00:00
|
|
|
mkdir -p ql-qlf-plugin/pmgen
|
|
|
|
''
|
|
|
|
+ lib.optionalString ( plugin == "ql-qlf" ) ''
|
|
|
|
python3 ${yosys.src}/passes/pmgen/pmgen.py -o ql-qlf-plugin/pmgen/ql-dsp-pm.h -p ql_dsp ql-qlf-plugin/ql_dsp.pmg
|
|
|
|
'';
|
|
|
|
|
|
|
|
# Providing a symlink avoids the need for patching the test makefile
|
|
|
|
postUnpack = ''
|
2022-11-21 17:40:18 +00:00
|
|
|
mkdir -p source/third_party/googletest/build/
|
|
|
|
ln -s ${static_gtest}/lib source/third_party/googletest/build/lib
|
2022-01-13 20:06:32 +00:00
|
|
|
'';
|
|
|
|
|
|
|
|
makeFlags = [
|
|
|
|
"PLUGIN_LIST=${plugin}"
|
|
|
|
];
|
|
|
|
|
|
|
|
buildFlags = [
|
|
|
|
"PLUGINS_DIR=\${out}/share/yosys/plugins/"
|
|
|
|
"DATA_DIR=\${out}/share/yosys/"
|
|
|
|
];
|
|
|
|
|
|
|
|
checkFlags = [
|
|
|
|
"PLUGINS_DIR=\${NIX_BUILD_TOP}/source/${plugin}-plugin"
|
|
|
|
"DATA_DIR=\${NIX_BUILD_TOP}/source/${plugin}-plugin"
|
|
|
|
( "NIX_YOSYS_PLUGIN_DIRS=\${NIX_BUILD_TOP}/source/${plugin}-plugin"
|
|
|
|
# sdc and xdc plugins use design introspection for their tests
|
|
|
|
+ (lib.optionalString ( plugin == "sdc" || plugin == "xdc" )
|
|
|
|
":${yosys-symbiflow.design_introspection}/share/yosys/plugins/")
|
|
|
|
)
|
|
|
|
];
|
|
|
|
|
|
|
|
installFlags = buildFlags;
|
|
|
|
|
|
|
|
meta = with lib; {
|
|
|
|
description = "Symbiflow ${plugin} plugin for Yosys";
|
|
|
|
license = licenses.isc;
|
|
|
|
platforms = platforms.all;
|
|
|
|
maintainers = with maintainers; [ ollieB thoughtpolice ];
|
|
|
|
};
|
|
|
|
}))
|