-
Notifications
You must be signed in to change notification settings - Fork 5
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
2 changed files
with
90 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,84 @@ | ||
{ | ||
pkgs, | ||
python_ot, | ||
verilator_ot, | ||
ncurses5, | ||
patchelf, | ||
stdenv, | ||
edaTools ? [], | ||
... | ||
}: let | ||
# If SONAME is specified, lookup cache files created by ldconfig will only use the SONAME and will ignore | ||
# the filename, this casues libtinfo.so to not be found under FHS. Patch ncurses5 to provide a libtinfo.so | ||
# with proper SONAME. | ||
ncurses5-patched = | ||
pkgs.runCommand "ncurses5" { | ||
outputs = ["out" "dev" "man"]; | ||
} '' | ||
cp -r ${ncurses5} $out | ||
chmod +w $out/lib | ||
cp -L --no-preserve=mode --remove-destination `realpath $out/lib/libtinfo.so.5` $out/lib/libtinfo.so.5 | ||
${patchelf}/bin/patchelf --set-soname libtinfo.so.5 $out/lib/libtinfo.so.5 | ||
cp -r ${ncurses5.dev} $dev | ||
cp -r ${ncurses5.man} $man | ||
''; | ||
edaExtraDeps = with pkgs; [elfutils openssl]; | ||
in | ||
(pkgs.buildFHSEnv { | ||
name = "opentitan"; | ||
targetPkgs = _: | ||
with pkgs; | ||
[ | ||
bazelisk | ||
|
||
python_ot | ||
verilator_ot | ||
|
||
# For serde-annotate which can be built with just cargo | ||
rustup | ||
|
||
# Bazel downloads Rust compilers which are not patchelfed and they need this. | ||
zlib | ||
openssl | ||
curl | ||
|
||
(wrapCCWith { | ||
cc = gcc-unwrapped; | ||
# Bazel rules_rust expects build PIE binary in opt build but doesn't request PIE/PIC, so force PIC | ||
nixSupport.cc-cflags = ["-fPIC"]; | ||
}) | ||
|
||
python_ot | ||
libxcrypt-legacy | ||
|
||
# Bazel filters out all environment including PKG_CONFIG_PATH. Append this inside wrapper. | ||
(pkg-config.override { | ||
extraBuildCommands = '' | ||
echo "export PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/usr/lib/pkgconfig" >> $out/nix-support/utils.bash | ||
''; | ||
}) | ||
udev | ||
libftdi1 | ||
libusb1 # needed for libftdi1 pkg-config | ||
ncurses5-patched | ||
|
||
srecord | ||
|
||
# For documentation | ||
hugo | ||
doxygen | ||
] | ||
++ map (tool: | ||
tool.override { | ||
extraDependencies = edaExtraDeps; | ||
}) | ||
edaTools; | ||
extraOutputsToInstall = ["dev"]; | ||
|
||
extraBwrapArgs = [ | ||
# OpenSSL included in the Python downloaded by Bazel makes use of these paths. | ||
"--symlink ${pkgs.openssl.out}/etc/ssl/openssl.cnf /etc/ssl/openssl.cnf" | ||
"--symlink /etc/ssl/certs/ca-certificates.crt /etc/ssl/cert.pem" | ||
]; | ||
}) | ||
.env |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters