self: /* Future last stage */ super: /* Previous stage */ let inherit (self.lib) callPackageWith; inherit (self.lib) callPackagesWith; callPackage = callPackageWith (self // self.bsc); # --------------------------------------------------------- # # BSC Packages # --------------------------------------------------------- # bsc = { # Default MPI implementation to use. Will be overwritten by the # experiments. mpi = self.bsc.openmpi; perf = callPackage ./bsc/perf/default.nix { kernel = self.linuxPackages_4_9.kernel; systemtap = self.linuxPackages_4_9.systemtap; }; # ParaStation MPI pscom = callPackage ./bsc/parastation/pscom.nix { }; psmpi = callPackage ./bsc/parastation/psmpi.nix { }; osumb = callPackage ./bsc/osu/default.nix { }; mpich = callPackage ./bsc/mpich/default.nix { }; mpichDebug = self.mpich.override { enableDebug = true; }; # Default Intel MPI version is 2019 (the last one) impi = self.bsc.intelMpi; intelMpi = self.bsc.intelMpi2019; intelMpi2019 = callPackage ./bsc/intel-mpi/default.nix { # Intel MPI provides a debug version of the MPI library, but # by default we use the release variant for performance enableDebug = false; }; # By default we use Intel compiler 2020 update 1 iccUnwrapped = self.bsc.icc2020Unwrapped; icc2020Unwrapped = callPackage ./bsc/intel-compiler/icc2020.nix { intel-mpi = self.bsc.intelMpi; }; # A wrapper script that puts all the flags and environment vars properly and # calls the intel compiler binary icc = callPackage ./bsc/intel-compiler/default.nix { iccUnwrapped = self.bsc.iccUnwrapped; intelLicense = self.bsc.intelLicense; }; intelLicense = callPackage ./bsc/intel-compiler/license.nix { }; pmix2 = callPackage ./bsc/pmix/pmix2.nix { }; slurm17 = callPackage ./bsc/slurm/default.nix { pmix = self.bsc.pmix2; }; slurm17-libpmi2 = callPackage ./bsc/slurm/pmi2.nix { pmix = self.bsc.pmix2; }; openmpi-mn4 = callPackage ./bsc/openmpi/default.nix { pmix = self.bsc.pmix2; pmi2 = self.bsc.slurm17-libpmi2; enableCxx = true; }; openmpi = self.bsc.openmpi-mn4; fftw = callPackage ./bsc/fftw/default.nix { }; extrae = callPackage ./bsc/extrae/default.nix { }; tampi = callPackage ./bsc/tampi/default.nix { }; mcxxGit = callPackage ./bsc/mcxx/default.nix { bison = self.bison_3_5; }; mcxxRarias = callPackage ./bsc/mcxx/rarias.nix { bison = self.bison_3_5; }; mcxx = self.bsc.mcxxGit; # Use nanos6 git by default nanos6 = self.bsc.nanos6Git; nanos6Latest = callPackage ./bsc/nanos6/default.nix { }; nanos6Git = callPackage ./bsc/nanos6/git.nix { }; vtk = callPackage ./bsc/vtk/default.nix { inherit (self.xorg) libX11 xorgproto libXt; }; dummy = callPackage ./bsc/dummy/default.nix { }; clangOmpss2Unwrapped = callPackage ./bsc/llvm-ompss2/clang.nix { stdenv = self.llvmPackages_10.stdenv; enableDebug = false; }; clangOmpss2 = callPackage bsc/llvm-ompss2/default.nix { clangOmpss2Unwrapped = self.bsc.clangOmpss2Unwrapped; }; stdenvOmpss2 = self.clangStdenv.override { cc = self.bsc.clangOmpss2; }; cpic = callPackage ./bsc/apps/cpic/default.nix { stdenv = self.bsc.stdenvOmpss2; mpi = self.bsc.mpi; tampi = self.bsc.tampi; }; mpptest = callPackage ./bsc/mpptest/default.nix { }; garlic = { # Load some helper functions to generate app variants inherit (import ./garlic/gen.nix) genApps genApp genConfigs; mpptest = callPackage ./garlic/mpptest { }; ppong = callPackage ./garlic/ppong { mpi = self.bsc.mpi; }; nbody = callPackage ./garlic/nbody { cc = self.bsc.icc; mpi = self.bsc.mpi; tampi = self.bsc.tampi; mcxx = self.bsc.mcxx; gitBranch = "garlic/seq"; }; saiph = callPackage ./garlic/saiph { stdenv = self.bsc.stdenvOmpss2; }; # Execution wrappers runWrappers = { sbatch = callPackage ./garlic/stages/sbatch.nix { }; srun = callPackage ./garlic/stages/srun.nix { }; launch = callPackage ./garlic/stages/launcher.nix { }; control = callPackage ./garlic/stages/control.nix { }; nixsetup = callPackage ./garlic/stages/nix-setup.nix { }; argv = callPackage ./garlic/stages/argv.nix { }; statspy = callPackage ./garlic/stages/statspy.nix { }; extrae = callPackage ./garlic/stages/extrae.nix { }; stagen = callPackage ./garlic/stages/stagen.nix { }; perf = callPackage ./garlic/stages/perf.nix { }; }; # Perf is tied to a linux kernel specific version #linuxPackages = self.linuxPackages_4_4; #perfWrapper = callPackage ./garlic/perf.nix { # perf = self.linuxPackages.perf; #}; exp = { noise = callPackage ./garlic/exp/noise.nix { }; nbody = { bs = callPackage ./garlic/exp/nbody/bs.nix { pkgs = self // self.bsc.garlic; nixpkgs = import ; genApp = self.bsc.garlic.genApp; genConfigs = self.bsc.garlic.genConfigs; runWrappers = self.bsc.garlic.runWrappers; }; tampi = callPackage ./garlic/exp/nbody/tampi.nix { pkgs = self // self.bsc.garlic; nixpkgs = import ; genApp = self.bsc.garlic.genApp; genConfigs = self.bsc.garlic.genConfigs; runWrappers = self.bsc.garlic.runWrappers; }; # mpi = callPackage ./bsc/garlic/exp/nbody/mpi.nix { }; }; saiph = { numcomm = callPackage ./garlic/exp/saiph/numcomm.nix { pkgs = self // self.bsc.garlic; nixpkgs = import ; genApp = self.bsc.garlic.genApp; genConfigs = self.bsc.garlic.genConfigs; runWrappers = self.bsc.garlic.runWrappers; }; }; osu = rec { latency-internode = callPackage ./garlic/exp/osu/latency.nix { }; latency-intranode = callPackage ./garlic/exp/osu/latency.nix { interNode = false; }; latency = latency-internode; }; }; }; }; in { bsc = bsc; # Alias garlic = bsc.garlic; # Alias exp = bsc.garlic.exp; }