From 49ac6e6468499ac744f59c1940616f95a89fd990 Mon Sep 17 00:00:00 2001 From: Aleix Roca Nonell Date: Fri, 5 Sep 2025 11:09:16 +0200 Subject: [PATCH] Do not force derviation inputs, use booleans instead --- overlay.nix | 7 ++++--- pkgs/llvm-ompss2/default.nix | 26 +++++++++++++++++++------- 2 files changed, 23 insertions(+), 10 deletions(-) diff --git a/overlay.nix b/overlay.nix index d55b740..b450091 100644 --- a/overlay.nix +++ b/overlay.nix @@ -13,10 +13,11 @@ let bench6 = callPackage ./pkgs/bench6/default.nix { }; bigotes = callPackage ./pkgs/bigotes/default.nix { }; clangOmpss2 = callPackage ./pkgs/llvm-ompss2/default.nix { }; - clangOmpss2Nanos6 = callPackage ./pkgs/llvm-ompss2/default.nix { ompss2rt = final.nanos6; }; - clangOmpss2Nodes = callPackage ./pkgs/llvm-ompss2/default.nix { ompss2rt = final.nodes; openmp = final.openmp; }; - clangOmpss2NodesOmpv = callPackage ./pkgs/llvm-ompss2/default.nix { ompss2rt = final.nodes; openmp = final.openmpv; }; + clangOmpss2Nanos6 = callPackage ./pkgs/llvm-ompss2/default.nix { useNanos6 = true; }; + clangOmpss2Nodes = callPackage ./pkgs/llvm-ompss2/default.nix { useNodes = true; useOpenmp = true; }; + clangOmpss2NodesOmpv = callPackage ./pkgs/llvm-ompss2/default.nix { useNodes = true; useOpenmpV = true; }; clangOmpss2Unwrapped = callPackage ./pkgs/llvm-ompss2/clang.nix { }; + #extrae = callPackage ./pkgs/extrae/default.nix { }; # Broken and outdated #gpi-2 = callPackage ./pkgs/gpi-2/default.nix { }; # Broken: https://jungle.bsc.es/git/rarias/bscpkgs/issues/7 intelPackages_2023 = callPackage ./pkgs/intel-oneapi/2023.nix { }; diff --git a/pkgs/llvm-ompss2/default.nix b/pkgs/llvm-ompss2/default.nix index e735f56..d7442e4 100644 --- a/pkgs/llvm-ompss2/default.nix +++ b/pkgs/llvm-ompss2/default.nix @@ -3,25 +3,37 @@ , lib , gcc , clangOmpss2Unwrapped -, openmp ? null + +, openmp +, useOpenmp ? false +, openmpv +, useOpenmpV ? false +, nanos6 +, useNanos6 ? false +, nodes +, useNodes ? false + , wrapCCWith , llvmPackages_latest -, ompss2rt ? null }: with lib; let - usingNodesAndOmpv = (openmp.pname == "openmp-v" && ompss2rt.pname == "nodes"); - sameNosv = openmp.nosv == ompss2rt.nosv; + omp = if useOpenmp then openmp else if useOpenmpV then openmpv else null; + ompss2rt = if useNanos6 then nanos6 else if useNodes then nodes else null; + usingNodesAndOmpv = (omp.pname == "openmp-v" && ompss2rt.pname == "nodes"); + sameNosv = omp.nosv == ompss2rt.nosv; in assert assertMsg (usingNodesAndOmpv -> sameNosv) "OpenMP-V and NODES must share the same nOS-V"; +assert assertMsg (useOpenmp -> !useOpenmpV) "Either OpenMP or OpenMP-V may be enabled, but not both"; +assert assertMsg (useNanos6 -> !useNodes) "Either Nanos6 or NODES may be enabled, but not both"; let homevar = if ompss2rt.pname == "nanos6" then "NANOS6_HOME" else "NODES_HOME"; rtname = if ompss2rt.pname == "nanos6" then "libnanos6" else "libnodes"; - ompname = if openmp.pname == "openmp-v" then "libompv" else "libomp"; + ompname = if omp.pname == "openmp-v" then "libompv" else "libomp"; # We need to replace the lld linker from bintools with our linker just built, @@ -40,7 +52,7 @@ let in wrapCCWith { inherit cc bintools; # extraPackages adds packages to depsTargetTargetPropagated - extraPackages = optional (openmp != null) openmp; + extraPackages = optional (omp != null) omp; extraBuildCommands = '' echo "-target ${targetConfig}" >> $out/nix-support/cc-cflags #echo "-fuse-ld=lld" >> $out/nix-support/cc-cflags @@ -60,7 +72,7 @@ in wrapCCWith { wrap ${targetConfig}clang++ $wrapper $ccPath/clang++ wrap ${targetConfig}clang $wrapper $ccPath/clang - '' + optionalString (openmp != null) '' + '' + optionalString (omp != null) '' echo "export OPENMP_RUNTIME=${ompname}" >> $out/nix-support/cc-wrapper-hook '' + optionalString (ompss2rt != null) '' echo "export OMPSS2_RUNTIME=${rtname}" >> $out/nix-support/cc-wrapper-hook