Files
nixpkgs/pkgs/by-name/ie/ieda/package.nix
Dark Steveneq 646b892680
Some checks failed
Periodic Merges (6h) / master → staging-nixos (push) Failing after 12m50s
Periodic Merges (6h) / master → staging-next (push) Failing after 12m54s
Periodic Merges (24h) / merge-base(master,staging) → haskell-updates (push) Failing after 11m54s
Periodic Merges (6h) / staging-next → staging (push) Failing after 12m13s
Periodic Merges (24h) / staging-next-25.05 → staging-25.05 (push) Failing after 13m24s
Periodic Merges (24h) / release-25.05 → staging-next-25.05 (push) Failing after 14m28s
push sheeet
2025-10-09 14:15:47 +02:00

147 lines
3.3 KiB
Nix

{
lib,
stdenv,
fetchgit,
fetchpatch,
callPackages,
cmake,
ninja,
flex,
bison,
zlib,
tcl,
boost,
eigen,
yaml-cpp,
libunwind,
glog,
gtest,
gflags,
metis,
gmp,
python3,
onnxruntime,
}:
let
rootSrc = stdenv.mkDerivation {
pname = "iEDA-src";
version = "2025-06-30";
src = fetchgit {
url = "https://gitee.com/oscc-project/iEDA";
rev = "689f172c726c3934d49577f09adb5b09804f11e5";
sha256 = "sha256-JJePIn+NUScb+3o67vT31BoKHcfBuE9osV4SrcicFds=";
};
patches = [
# This patch is to fix the build error caused by the missing of the header file,
# and remove some libs or path that they hard-coded in the source code.
# Should be removed after we upstream these changes.
(fetchpatch {
url = "https://github.com/Emin017/iEDA/commit/c17e42a3673afd9c7ace9374f85290a85354bb78.patch";
hash = "sha256-xa1oSy3OZ5r0TigGywzpVPvpPnA7L6RIcNktfFen4AA=";
})
# This patch is to fix the compile error on the newer version of gcc/g++
# We remove some forward declarations which are not allowed in newer versions of gcc/g++
# Should be removed after we upstream these changes.
(fetchpatch {
url = "https://github.com/Emin017/iEDA/commit/f5464cc40a2c671c5d405f16b509e2fa8d54f7f1.patch";
hash = "sha256-uVMV/CjkX9oLexHJbQvnEDOET/ZqsEPreI6EQb3Z79s=";
})
];
postPatch = ''
# Comment out the iCTS test cases that will fail due to some linking issues on aarch64-linux
sed -i '17,28s/^/# /' src/operation/iCTS/test/CMakeLists.txt
'';
dontBuild = true;
dontFixup = true;
installPhase = ''
cp -r . $out
'';
};
rustpkgs = callPackages ./rustpkgs.nix { inherit rootSrc; };
in
stdenv.mkDerivation {
pname = "iEDA";
version = "0-unstable-2025-06-30";
src = rootSrc;
nativeBuildInputs = [
cmake
ninja
flex
bison
python3
tcl
];
cmakeFlags = [
(lib.cmakeBool "CMD_BUILD" true)
(lib.cmakeBool "SANITIZER" false)
(lib.cmakeBool "BUILD_STATIC_LIB" false)
];
preConfigure = ''
cmakeFlags+=" -DCMAKE_RUNTIME_OUTPUT_DIRECTORY:FILEPATH=$out/bin -DCMAKE_LIBRARY_OUTPUT_DIRECTORY:FILEPATH=$out/lib"
'';
buildInputs = [
rustpkgs.iir-rust
rustpkgs.sdf_parse
rustpkgs.spef-parser
rustpkgs.vcd_parser
rustpkgs.verilog-parser
rustpkgs.liberty-parser
gtest
glog
gflags
boost
onnxruntime
eigen
yaml-cpp
libunwind
metis
gmp
tcl
zlib
];
postInstall = ''
# Tests rely on hardcoded path, so they should not be included
rm $out/bin/*test $out/bin/*Test $out/bin/test_* $out/bin/*_app
# Copy scripts to the share directory for the test
mkdir -p $out/share/scripts
cp -r $src/scripts/hello.tcl $out/share/scripts/
'';
installCheckPhase = ''
runHook preInstallCheck
# Run the tests
$out/bin/iEDA -script $out/share/scripts/hello.tcl
runHook postInstallCheck
'';
doInstallCheck = true;
enableParallelBuild = true;
meta = {
description = "Open-source EDA infracstructure and tools from Netlist to GDS for ASIC design";
homepage = "https://gitee.com/oscc-project/iEDA";
license = lib.licenses.mulan-psl2;
maintainers = with lib.maintainers; [
xinyangli
Emin017
];
mainProgram = "iEDA";
platforms = lib.platforms.linux;
};
}