mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-01-04 03:53:56 +00:00
119 lines
2.3 KiB
Nix
119 lines
2.3 KiB
Nix
{
|
|
lib,
|
|
stdenv,
|
|
fetchgit,
|
|
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 = "2024-09-10";
|
|
src = fetchgit {
|
|
url = "https://gitee.com/oscc-project/iEDA";
|
|
rev = "a68b691b9d25fafd8c10fae3df7ef3837a42e052";
|
|
sha256 = "sha256-0rSESfNqI3ALipNAInwcYSccq9C0WuXI9na44TyYAgY=";
|
|
};
|
|
|
|
patches = [
|
|
./fix-bump-gcc.patch
|
|
|
|
# We need to build rust projects with rustPlatform
|
|
# and remove hard coded linking to libonnxruntime
|
|
./remove-subprojects-from-cmake.patch
|
|
];
|
|
|
|
postPatch = ''
|
|
substituteInPlace CMakeLists.txt \
|
|
--replace-fail 'set(CMAKE_CXX_FLAGS_RELEASE "$ENV{CXXFLAGS} -O3 -Wall")' 'set(CMAKE_CXX_FLAGS_RELEASE "$ENV{CXXFLAGS} -O2")'
|
|
'';
|
|
|
|
dontBuild = true;
|
|
dontFixup = true;
|
|
installPhase = ''
|
|
cp -r . $out
|
|
'';
|
|
|
|
};
|
|
|
|
rustpkgs = callPackages ./rustpkgs.nix { inherit rootSrc; };
|
|
in
|
|
stdenv.mkDerivation {
|
|
pname = "iEDA";
|
|
version = "0-unstable-2024-10-11";
|
|
|
|
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
|
|
'';
|
|
|
|
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 ];
|
|
mainProgram = "iEDA";
|
|
platforms = lib.platforms.linux;
|
|
};
|
|
}
|