- All garlic stuff is moved into garlic/ - Group the overlay index by sections - Add a garlic/default.nix link to the main default.nix, so we can build derivations at garlic/
		
			
				
	
	
		
			129 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			129 lines
		
	
	
		
			3.6 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
| {
 | |
|   super
 | |
| , self
 | |
| , bsc
 | |
| , callPackage
 | |
| }:
 | |
| 
 | |
| {
 | |
|   unsafeDevelop = callPackage ./develop/default.nix {
 | |
|         extraInputs = with self; [
 | |
|           coreutils htop procps-ng vim which strace
 | |
|           tmux gdb kakoune universal-ctags bashInteractive
 | |
|           glibcLocales ncurses git screen curl
 | |
|           # Add more nixpkgs packages here...
 | |
|           bsc.slurm bsc.clangOmpss2 bsc.icc bsc.mcxx bsc.perf
 | |
|           # Add more bscpkgs packages here...
 | |
|         ];
 | |
|   };
 | |
| 
 | |
|   develop = bsc.garlic.stages.exec rec {
 | |
|     nextStage = bsc.garlic.stages.isolate {
 | |
|       nextStage = bsc.garlic.unsafeDevelop;
 | |
|       nixPrefix = bsc.garlic.targetMachine.config.nixPrefix;
 | |
|       extraMounts = [ "/tmp:$TMPDIR" ];
 | |
|     };
 | |
|     nixPrefix = bsc.garlic.targetMachine.config.nixPrefix;
 | |
|     # This hack uploads all dependencies to MN4
 | |
|     pre = let
 | |
|       nixPrefix = bsc.garlic.targetMachine.config.nixPrefix;
 | |
|       stageProgram = bsc.garlicTools.stageProgram;
 | |
|     in
 | |
|     ''
 | |
|       # Hack to upload this to MN4: @upload-to-mn@
 | |
| 
 | |
|       # Create a link to the develop script
 | |
|       ln -fs ${nixPrefix}${stageProgram nextStage} .nix-develop
 | |
|     '';
 | |
|     post = "\n";
 | |
|   };
 | |
| 
 | |
|   # Configuration for the machines
 | |
|   machines = callPackage ./machines.nix { };
 | |
| 
 | |
|   report = callPackage ./report.nix {
 | |
|     fig = bsc.garlic.fig;
 | |
|   };
 | |
| 
 | |
|   sedReport = callPackage ./sedReport.nix {
 | |
|     fig = bsc.garlic.fig;
 | |
|   };
 | |
| 
 | |
|   bundleReport = callPackage ./bundleReport.nix {
 | |
|     fig = bsc.garlic.fig;
 | |
|   };
 | |
| 
 | |
|   reportTar = callPackage ./reportTar.nix {
 | |
|     fig = bsc.garlic.fig;
 | |
|   };
 | |
| 
 | |
|   # Use the configuration for the following target machine
 | |
|   targetMachine = bsc.garlic.machines.mn4;
 | |
| 
 | |
|   # Load some helper functions to generate app variants
 | |
| 
 | |
|   stdexp = callPackage ./stdexp.nix {
 | |
|     inherit (bsc.garlic) targetMachine stages;
 | |
|   };
 | |
| 
 | |
|   # Execution stages
 | |
|   stages = {
 | |
|     sbatch     = callPackage ./stages/sbatch.nix { };
 | |
|     srun       = callPackage ./stages/srun.nix { };
 | |
|     control    = callPackage ./stages/control.nix { };
 | |
|     exec       = callPackage ./stages/exec.nix { };
 | |
|     extrae     = callPackage ./stages/extrae.nix { };
 | |
|     valgrind   = callPackage ./stages/valgrind.nix { };
 | |
|     perf       = callPackage ./stages/perf.nix { };
 | |
|     isolate    = callPackage ./stages/isolate { };
 | |
|     runexp     = callPackage ./stages/runexp { };
 | |
|     trebuchet  = callPackage ./stages/trebuchet.nix { };
 | |
|     strace     = callPackage ./stages/strace.nix { };
 | |
|     unit       = callPackage ./stages/unit.nix { };
 | |
|     experiment = callPackage ./stages/experiment.nix { };
 | |
|   };
 | |
| 
 | |
|   # Tests (move to bsc ?)
 | |
|   mpptest = callPackage ./mpptest { };
 | |
| 
 | |
|   ppong = callPackage ./ppong {
 | |
|     mpi = bsc.mpi;
 | |
|   };
 | |
| 
 | |
|   hist = callPackage ./pp/hist { };
 | |
| 
 | |
|   tool = callPackage ./sh/default.nix {
 | |
|     sshHost = "mn1";
 | |
|   };
 | |
| 
 | |
|   # Post processing tools
 | |
|   pp = with bsc.garlicTools; rec {
 | |
|     store = callPackage ./pp/store.nix { };
 | |
|     resultFromTrebuchet = trebuchetStage: (store {
 | |
|       experimentStage = getExperimentStage trebuchetStage;
 | |
|       inherit trebuchetStage;
 | |
|     });
 | |
|     timetable = callPackage ./pp/timetable.nix { };
 | |
|     rPlot = callPackage ./pp/rplot.nix { };
 | |
|     timetableFromTrebuchet = tre: timetable (resultFromTrebuchet tre);
 | |
|     mergeDatasets = callPackage ./pp/merge.nix { };
 | |
| 
 | |
|     # Takes a list of experiments and returns a file that contains
 | |
|     # all timetable results from the experiments.
 | |
|     merge = exps: mergeDatasets (map timetableFromTrebuchet exps);
 | |
|   };
 | |
| 
 | |
|   # Apps for Garlic
 | |
|   apps = callPackage ./apps/index.nix { };
 | |
| 
 | |
|   # Experiments
 | |
|   exp = callPackage ./exp/index.nix { };
 | |
| 
 | |
|   # Datasets used in the figures
 | |
|   ds = callPackage ./ds/index.nix { };
 | |
| 
 | |
|   # Figures generated from the experiments
 | |
|   fig = callPackage ./fig/index.nix { };
 | |
| 
 | |
| }
 |