Merge pull request #83234 from kwohlfahrt/quartus
quartus: expose CLI executables + increase device support
This commit is contained in:
commit
fb00dea38c
@ -1,25 +1,58 @@
|
|||||||
{ buildFHSUserEnv, makeDesktopItem, stdenv, lib, requireFile, unstick, cycloneVSupport ? true }:
|
{ buildFHSUserEnv, makeDesktopItem, writeScript, stdenv, lib, requireFile, unstick,
|
||||||
|
supportedDevices ? [ "Arria II" "Cyclone V" "Cyclone IV" "Cyclone 10 LP" "MAX II/V" "MAX 10 FPGA" ] }:
|
||||||
|
|
||||||
let
|
let
|
||||||
|
deviceIds = {
|
||||||
|
"Arria II" = "arria_lite";
|
||||||
|
"Cyclone V" = "cyclonev";
|
||||||
|
"Cyclone IV" = "cyclone";
|
||||||
|
"Cyclone 10 LP" = "cyclone10lp";
|
||||||
|
"MAX II/V" = "max";
|
||||||
|
"MAX 10 FPGA" = "max10";
|
||||||
|
};
|
||||||
|
|
||||||
|
supportedDeviceIds =
|
||||||
|
assert lib.assertMsg (lib.all (name: lib.hasAttr name deviceIds) supportedDevices)
|
||||||
|
"Supported devices are: ${lib.concatStringsSep ", " (lib.attrNames deviceIds)}";
|
||||||
|
lib.listToAttrs (map (name: {
|
||||||
|
inherit name;
|
||||||
|
value = deviceIds.${name};
|
||||||
|
}) supportedDevices);
|
||||||
|
|
||||||
|
unsupportedDeviceIds = lib.filterAttrs (name: value:
|
||||||
|
!(lib.hasAttr name supportedDeviceIds)
|
||||||
|
) deviceIds;
|
||||||
|
|
||||||
quartus = stdenv.mkDerivation rec {
|
quartus = stdenv.mkDerivation rec {
|
||||||
version = "19.1.0.670";
|
version = "19.1.0.670";
|
||||||
pname = "quartus-prime-lite";
|
pname = "quartus-prime-lite-unwrapped";
|
||||||
|
|
||||||
src = let
|
src = let
|
||||||
require = {name, sha256}: requireFile {
|
require = {name, sha256}: requireFile {
|
||||||
inherit name sha256;
|
inherit name sha256;
|
||||||
url = "${meta.homepage}/${lib.versions.majorMinor version}/?edition=lite&platform=linux";
|
url = "${meta.homepage}/${lib.versions.majorMinor version}/?edition=lite&platform=linux";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
hashes = {
|
||||||
|
"arria_lite" = "1flj9w0vb2p9f9zll136izr6qvmxn0lg72bvaqxs3sxc9vj06wm1";
|
||||||
|
"cyclonev" = "0bqxpvjgph0y6slk0jq75mcqzglmqkm0jsx10y9xz5llm6zxzqab";
|
||||||
|
"cyclone" = "0pzs8y4s3snxg4g6lrb21qi88abm48g279xzd98qv17qxb2z82rr";
|
||||||
|
"cyclone10lp" = "1ccxq8n20y40y47zddkijcv41w3cddvydddr3m4844q31in3nxha";
|
||||||
|
"max" = "1cxzbqscxvlcy74dpqmvlnxjyyxfwcx3spygpvpwi6dfj3ipgm2z";
|
||||||
|
"max10" = "14k83javivbk65mpb17wdwsyb8xk7x9gzj9x0wnd24mmijrvdy9s";
|
||||||
|
};
|
||||||
|
|
||||||
|
devicePackages = map (id: {
|
||||||
|
name = "${id}-${version}.qdz";
|
||||||
|
sha256 = lib.getAttr id hashes;
|
||||||
|
}) (lib.attrValues supportedDeviceIds);
|
||||||
in map require ([{
|
in map require ([{
|
||||||
name = "QuartusLiteSetup-${version}-linux.run";
|
name = "QuartusLiteSetup-${version}-linux.run";
|
||||||
sha256 = "15vxvqxqdk29ahlw3lkm1nzxyhzy4626wb9s5f2h6sjgq64r8m7f";
|
sha256 = "15vxvqxqdk29ahlw3lkm1nzxyhzy4626wb9s5f2h6sjgq64r8m7f";
|
||||||
} {
|
} {
|
||||||
name = "ModelSimSetup-${version}-linux.run";
|
name = "ModelSimSetup-${version}-linux.run";
|
||||||
sha256 = "0j1vfr91jclv88nam2plx68arxmz4g50sqb840i60wqd5b0l3y6r";
|
sha256 = "0j1vfr91jclv88nam2plx68arxmz4g50sqb840i60wqd5b0l3y6r";
|
||||||
}] ++ lib.optional cycloneVSupport {
|
}] ++ devicePackages);
|
||||||
name = "cyclonev-${version}.qdz";
|
|
||||||
sha256 = "0bqxpvjgph0y6slk0jq75mcqzglmqkm0jsx10y9xz5llm6zxzqab";
|
|
||||||
});
|
|
||||||
|
|
||||||
nativeBuildInputs = [ unstick ];
|
nativeBuildInputs = [ unstick ];
|
||||||
|
|
||||||
@ -37,27 +70,22 @@ let
|
|||||||
disabledComponents = [
|
disabledComponents = [
|
||||||
"quartus_help"
|
"quartus_help"
|
||||||
"quartus_update"
|
"quartus_update"
|
||||||
|
# not modelsim_ase
|
||||||
"modelsim_ae"
|
"modelsim_ae"
|
||||||
# Devices
|
] ++ (lib.attrValues unsupportedDeviceIds);
|
||||||
"arria_lite"
|
|
||||||
"cyclone"
|
|
||||||
"cyclone10lp"
|
|
||||||
"max"
|
|
||||||
"max10"
|
|
||||||
] ++ lib.optional (!cycloneVSupport) "cyclonev";
|
|
||||||
in ''
|
in ''
|
||||||
${lib.concatMapStringsSep "\n" copyInstaller installers}
|
${lib.concatMapStringsSep "\n" copyInstaller installers}
|
||||||
${lib.concatMapStringsSep "\n" copyComponent components}
|
${lib.concatMapStringsSep "\n" copyComponent components}
|
||||||
|
|
||||||
unstick $TEMP/${(builtins.head installers).name} \
|
unstick $TEMP/${(builtins.head installers).name} \
|
||||||
--disable-components ${lib.concatStringsSep "," disabledComponents} \
|
--disable-components ${lib.concatStringsSep "," disabledComponents} \
|
||||||
--mode unattended --installdir $out --accept_eula 1
|
--mode unattended --installdir $out --accept_eula 1
|
||||||
|
|
||||||
# This patch is from https://wiki.archlinux.org/index.php/Altera_Design_Software
|
# This patch is from https://wiki.archlinux.org/index.php/Altera_Design_Software
|
||||||
patch --force --strip 0 --directory $out < ${./vsim.patch}
|
patch --force --strip 0 --directory $out < ${./vsim.patch}
|
||||||
|
|
||||||
rm -r $out/uninstall $out/logs
|
rm -r $out/uninstall $out/logs
|
||||||
'';
|
'';
|
||||||
|
|
||||||
meta = {
|
meta = {
|
||||||
homepage = "https://fpgasoftware.intel.com";
|
homepage = "https://fpgasoftware.intel.com";
|
||||||
@ -69,17 +97,17 @@ let
|
|||||||
};
|
};
|
||||||
|
|
||||||
desktopItem = makeDesktopItem {
|
desktopItem = makeDesktopItem {
|
||||||
name = quartus.name;
|
name = "quartus-prime-lite";
|
||||||
exec = "quartus";
|
exec = "quartus";
|
||||||
icon = "quartus";
|
icon = "quartus";
|
||||||
desktopName = "Quartus";
|
desktopName = "Quartus";
|
||||||
genericName = "Quartus FPGA IDE";
|
genericName = "Quartus Prime";
|
||||||
categories = "Development;";
|
categories = "Development;";
|
||||||
};
|
};
|
||||||
|
|
||||||
# I think modelsim_ase/linux/vlm checksums itself, so use FHSUserEnv instead of `patchelf`
|
# I think modelsim_ase/linux/vlm checksums itself, so use FHSUserEnv instead of `patchelf`
|
||||||
in buildFHSUserEnv {
|
in buildFHSUserEnv rec {
|
||||||
name = "quartus-prime-lite";
|
name = "quartus-prime-lite"; # wrapped
|
||||||
|
|
||||||
targetPkgs = pkgs: with pkgs; [
|
targetPkgs = pkgs: with pkgs; [
|
||||||
# quartus requirements
|
# quartus requirements
|
||||||
@ -110,10 +138,43 @@ in buildFHSUserEnv {
|
|||||||
xorg.libXrender
|
xorg.libXrender
|
||||||
];
|
];
|
||||||
|
|
||||||
extraInstallCommands = ''
|
passthru = {
|
||||||
mkdir -p $out/share/applications
|
unwrapped = quartus;
|
||||||
cp ${desktopItem}/share/applications/* $out/share/applications
|
};
|
||||||
|
|
||||||
|
extraInstallCommands = let
|
||||||
|
quartusExecutables = (map (c: "quartus/bin/quartus_${c}") [
|
||||||
|
"asm" "cdb" "cpf" "drc" "eda" "fit" "jbcc" "jli" "map" "pgm" "pow"
|
||||||
|
"sh" "si" "sim" "sta" "stp" "tan"
|
||||||
|
]) ++ [ "quartus/bin/quartus" ];
|
||||||
|
|
||||||
|
qsysExecutables = map (c: "quartus/sopc_builder/bin/qsys-${c}") [
|
||||||
|
"generate" "edit" "script"
|
||||||
|
];
|
||||||
|
# Should we install all executables ?
|
||||||
|
modelsimExecutables = map (c: "modelsim_ase/bin/${c}") [
|
||||||
|
"vsim" "vlog" "vlib"
|
||||||
|
];
|
||||||
|
in ''
|
||||||
|
mkdir -p $out/share/applications $out/share/icons/128x128
|
||||||
|
ln -s ${desktopItem}/share/applications/* $out/share/applications
|
||||||
|
ln -s ${quartus}/licenses/images/dc_quartus_panel_logo.png $out/share/icons/128x128/quartus.png
|
||||||
|
|
||||||
|
mkdir -p $out/quartus/bin $out/quartus/sopc_builder/bin $out/modelsim_ase/bin
|
||||||
|
WRAPPER=$out/bin/${name}
|
||||||
|
EXECUTABLES="${lib.concatStringsSep " " (quartusExecutables ++ qsysExecutables ++ modelsimExecutables)}"
|
||||||
|
for executable in $EXECUTABLES; do
|
||||||
|
echo "#!${stdenv.shell}" >> $out/$executable
|
||||||
|
echo "$WRAPPER ${quartus}/$executable \$@" >> $out/$executable
|
||||||
|
done
|
||||||
|
|
||||||
|
cd $out
|
||||||
|
chmod +x $EXECUTABLES
|
||||||
|
# link into $out/bin so executables become available on $PATH
|
||||||
|
ln --symbolic --relative --target-directory ./bin $EXECUTABLES
|
||||||
'';
|
'';
|
||||||
|
|
||||||
runScript = "${quartus}/quartus/bin/quartus";
|
runScript = writeScript "${name}-wrapper" ''
|
||||||
|
exec $@
|
||||||
|
'';
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user