2022-09-09 14:08:57 +00:00
|
|
|
{ lib
|
|
|
|
, stdenv
|
|
|
|
, fetchFromGitHub
|
|
|
|
, fetchpatch
|
|
|
|
, cmake
|
|
|
|
, ninja
|
|
|
|
, pkg-config
|
|
|
|
, python3Packages
|
|
|
|
, boost
|
|
|
|
, rapidjson
|
|
|
|
, qtbase
|
|
|
|
, qtsvg
|
|
|
|
, igraph
|
|
|
|
, spdlog
|
|
|
|
, wrapQtAppsHook
|
|
|
|
, graphviz
|
|
|
|
, llvmPackages
|
|
|
|
, z3
|
|
|
|
, fmt_8
|
2020-08-20 17:08:02 +00:00
|
|
|
}:
|
|
|
|
|
2022-09-09 14:08:57 +00:00
|
|
|
let
|
|
|
|
# no stable hal release yet with recent spdlog/fmt support, remove
|
|
|
|
# once 4.0.0 is released - see https://github.com/emsec/hal/issues/452
|
|
|
|
spdlog' = spdlog.override {
|
|
|
|
fmt_8 = fmt_8.overrideAttrs (_: rec {
|
|
|
|
version = "8.0.1";
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "fmtlib";
|
|
|
|
repo = "fmt";
|
|
|
|
rev = version;
|
|
|
|
sha256 = "1mnvxqsan034d2jiqnw2yvkljl7lwvhakmj5bscwp1fpkn655bbw";
|
|
|
|
};
|
|
|
|
});
|
|
|
|
};
|
|
|
|
in stdenv.mkDerivation rec {
|
2021-12-06 16:07:01 +00:00
|
|
|
version = "3.3.0";
|
2020-08-20 17:08:02 +00:00
|
|
|
pname = "hal-hardware-analyzer";
|
|
|
|
|
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "emsec";
|
|
|
|
repo = "hal";
|
|
|
|
rev = "v${version}";
|
2021-12-06 16:07:01 +00:00
|
|
|
sha256 = "sha256-uNpELHhSAVRJL/4iypvnl3nX45SqB419r37lthd2WmQ=";
|
2020-08-20 17:08:02 +00:00
|
|
|
};
|
2022-08-12 12:06:08 +00:00
|
|
|
|
|
|
|
patches = [
|
|
|
|
(fetchpatch {
|
|
|
|
# Fix build with python 3.10
|
|
|
|
# https://github.com/emsec/hal/pull/463
|
|
|
|
name = "hal-fix-python-3.10.patch";
|
|
|
|
url = "https://github.com/emsec/hal/commit/f695f55cb2209676ef76366185b7c419417fbbc9.patch";
|
|
|
|
sha256 = "sha256-HsCdG3tPllUsLw6kQtGaaEGkEHqZPSC2v9k6ycO2I/8=";
|
|
|
|
includes = [ "plugins/gui/src/python/python_context.cpp" ];
|
|
|
|
})
|
|
|
|
];
|
|
|
|
|
2020-08-20 17:08:02 +00:00
|
|
|
# make sure bundled dependencies don't get in the way - install also otherwise
|
|
|
|
# copies them in full to the output, bloating the package
|
|
|
|
postPatch = ''
|
2020-12-25 13:55:36 +00:00
|
|
|
shopt -s extglob
|
|
|
|
rm -rf deps/!(sanitizers-cmake)/*
|
|
|
|
shopt -u extglob
|
2020-08-20 17:08:02 +00:00
|
|
|
'';
|
|
|
|
|
2021-02-05 17:12:51 +00:00
|
|
|
nativeBuildInputs = [ cmake ninja pkg-config ];
|
2022-09-09 14:08:57 +00:00
|
|
|
buildInputs = [ qtbase qtsvg boost rapidjson igraph spdlog' graphviz wrapQtAppsHook z3 ]
|
2020-08-20 17:08:02 +00:00
|
|
|
++ (with python3Packages; [ python pybind11 ])
|
2021-01-17 00:15:33 +00:00
|
|
|
++ lib.optional stdenv.cc.isClang llvmPackages.openmp;
|
2020-08-20 17:08:02 +00:00
|
|
|
|
2021-01-17 00:15:33 +00:00
|
|
|
cmakeFlags = with lib.versions; [
|
2020-08-20 17:08:02 +00:00
|
|
|
"-DHAL_VERSION_RETURN=${version}"
|
|
|
|
"-DHAL_VERSION_MAJOR=${major version}"
|
|
|
|
"-DHAL_VERSION_MINOR=${minor version}"
|
|
|
|
"-DHAL_VERSION_PATCH=${patch version}"
|
|
|
|
"-DHAL_VERSION_TWEAK=0"
|
|
|
|
"-DHAL_VERSION_ADDITIONAL_COMMITS=0"
|
|
|
|
"-DHAL_VERSION_DIRTY=false"
|
|
|
|
"-DHAL_VERSION_BROKEN=false"
|
|
|
|
"-DENABLE_INSTALL_LDCONFIG=off"
|
|
|
|
"-DBUILD_ALL_PLUGINS=on"
|
|
|
|
];
|
|
|
|
# needed for macos build - this is why we use wrapQtAppsHook instead of
|
|
|
|
# the qt mkDerivation - the latter forcibly overrides this.
|
|
|
|
cmakeBuildType = "MinSizeRel";
|
|
|
|
|
2021-01-15 22:18:51 +00:00
|
|
|
meta = with lib; {
|
2020-08-20 17:08:02 +00:00
|
|
|
description = "A comprehensive reverse engineering and manipulation framework for gate-level netlists";
|
|
|
|
homepage = "https://github.com/emsec/hal";
|
2020-12-25 13:55:36 +00:00
|
|
|
license = licenses.mit;
|
|
|
|
platforms = platforms.unix;
|
|
|
|
maintainers = with maintainers; [ ris shamilton ];
|
2020-08-20 17:08:02 +00:00
|
|
|
};
|
|
|
|
}
|