forked from rarias/bscpkgs
		
	WIP: forgot to add the folder
This commit is contained in:
		
							parent
							
								
									b5fb3730ac
								
							
						
					
					
						commit
						6bd7e12cff
					
				
							
								
								
									
										211
									
								
								garlic/exp/hpcg/extrae.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										211
									
								
								garlic/exp/hpcg/extrae.xml
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,211 @@ | ||||
| <?xml version='1.0'?> | ||||
| 
 | ||||
| <!-- Here comes the Extrae configuration. | ||||
|      As a general rule, "enabled" means that the feature is enabled :)  If | ||||
|      it's not enabled, then the value can be set to some default. | ||||
| --> | ||||
| 
 | ||||
| <!-- Must we activate the tracing? Which is the tracing mode? (detail/bursts) Where is it located? Which kind of trace? Version of the XML parser?--> | ||||
| <trace enabled="yes" | ||||
|  home="/nix/store/j80mlqa12d1baifg30jsx2smv90akzvc-extrae" | ||||
|  initial-mode="detail" | ||||
|  type="paraver" | ||||
| > | ||||
| 
 | ||||
|   <!-- Configuration of some MPI dependant values --> | ||||
|   <mpi enabled="yes"> | ||||
|     <!-- Gather counters in the MPI routines? --> | ||||
|     <counters enabled="yes" /> | ||||
|   </mpi> | ||||
| 
 | ||||
|   <!-- Emit information of the callstack --> | ||||
|   <callers enabled="yes"> | ||||
|     <!-- At MPI calls, select depth level --> | ||||
|     <mpi enabled="yes">1-3</mpi> | ||||
|     <!-- At sampling points, select depth level --> | ||||
| 		<sampling enabled="yes">1-5</sampling> | ||||
| 		<!-- At dynamic memory system calls --> | ||||
| 		<dynamic-memory enabled="no">1-3</dynamic-memory> | ||||
| 		<!-- At I/O system calls --> | ||||
| 		<input-output enabled="no">1-3</input-output> | ||||
| 		<!-- At other system calls --> | ||||
| 	  <syscall enabled="no">1-3</syscall> | ||||
|   </callers> | ||||
| 
 | ||||
|   <!-- Configuration of some OpenMP dependant values --> | ||||
|   <openmp enabled="no" ompt="no"> | ||||
|     <!-- If the library instruments OpenMP, shall we gather info about locks? | ||||
|          Obtaining such information can make the final trace quite large. | ||||
|     --> | ||||
| 		<locks enabled="no" /> | ||||
| 		<!-- Gather info about taskloops? --> | ||||
| 		<taskloop enabled="no" /> | ||||
|     <!-- Gather counters in the OpenMP routines? --> | ||||
|     <counters enabled="yes" /> | ||||
|   </openmp> | ||||
| 
 | ||||
|   <!-- Configuration of some pthread dependant values --> | ||||
|   <pthread enabled="no"> | ||||
|     <!-- If the library instruments pthread, shall we gather info about locks, | ||||
| 	       mutexs and conds? | ||||
|          Obtaining such information can make the final trace quite large. | ||||
|     --> | ||||
|     <locks enabled="no" /> | ||||
|     <!-- Gather counters in the pthread routines? --> | ||||
|     <counters enabled="yes" /> | ||||
|   </pthread> | ||||
| 
 | ||||
|   <!-- Configuration of User Functions --> | ||||
|   <user-functions enabled="no" list="/home/bsc41/bsc41273/user-functions.dat" exclude-automatic-functions="no"> | ||||
|     <!-- Gather counters on the UF routines? --> | ||||
|     <counters enabled="yes" /> | ||||
|   </user-functions> | ||||
| 
 | ||||
|   <!-- Configure which software/hardware counters must be collected --> | ||||
|   <counters enabled="yes"> | ||||
|     <!-- Configure the CPU hardware counters. You can define here as many sets | ||||
|          as you want. You can also define if MPI/OpenMP calls must report such | ||||
|          counters. | ||||
|          Starting-set property defines which set is chosen from every task. | ||||
|          Possible values are: | ||||
|            - cyclic : The sets are distributed in a cyclic fashion among all | ||||
|            tasks. So Task 0 takes set 1, Task 1 takes set 2,... | ||||
|            - block  : The sets are distributed in block fashion among all tasks. | ||||
|            Task [0..i-1] takes set 1, Task [i..2*i-1] takes set 2, ... | ||||
|            - Number : All the tasks will start with the given set  | ||||
|            (from 1..N). | ||||
|     --> | ||||
|     <cpu enabled="yes" starting-set-distribution="1"> | ||||
|       <!-- In this example, we configure two sets of counters. The first will  | ||||
|            be changed into the second after 5 calls to some collective | ||||
|            operation on MPI_COMM_WORLD. Once the second is activated, it will | ||||
|            turn to the first after 5seconds (aprox. depending on the MPI calls | ||||
|            granularity) | ||||
|            If you want that any set be counting forever, just don't set | ||||
|            changeat-globalops, or, changeat-time. | ||||
| 
 | ||||
|            Each set has it's own properties. | ||||
|            domain -> in which domain must PAPI obtain the information (see | ||||
|                        PAPI info) | ||||
|            changeat-globalops=num -> choose the next set after num | ||||
|                        MPI_COMM_WORLD operations | ||||
|            changeat-time=numTime -> choose the next set after num Time | ||||
|                        (for example 5s, 15m (for ms), 10M (for minutes),..) | ||||
|       --> | ||||
|       <set enabled="yes" domain="all"> | ||||
|         PAPI_TOT_INS,PAPI_TOT_CYC | ||||
|       </set> | ||||
|     </cpu> | ||||
| 
 | ||||
|     <!-- Do we want to gather information of the network counters? | ||||
|          Nowadays we can gather information about MX/GM cards. | ||||
|      --> | ||||
|     <network enabled="no" /> | ||||
| 
 | ||||
|     <!-- Obtain resource usage information --> | ||||
|     <resource-usage enabled="no" /> | ||||
| 
 | ||||
|     <!-- Obtain malloc statistics --> | ||||
|     <memory-usage enabled="no" /> | ||||
|   </counters> | ||||
| 
 | ||||
|   <!-- Define the characteristics of the tracing storage. If not defined, | ||||
|        or set, the tracing will send the traces to the current directory | ||||
|        with a default output name. | ||||
|   --> | ||||
|   <storage enabled="no"> | ||||
|     <!-- The intermediate files will take the name of the application --> | ||||
|     <trace-prefix enabled="yes">TRACE</trace-prefix> | ||||
|     <!-- Stop the tracing when the intermediate file reaches this amount of MBs --> | ||||
|     <size enabled="no">5</size> | ||||
|     <!-- Where must we store the MPIT files while the app runs? --> | ||||
|     <temporal-directory enabled="yes">/scratch</temporal-directory> | ||||
|     <!-- Where must we store the MPIT files once the app ends? --> | ||||
|     <final-directory enabled="yes">/gpfs/scratch/bsc41/bsc41273</final-directory> | ||||
|   </storage> | ||||
| 
 | ||||
|   <!-- Buffer configuration --> | ||||
|   <buffer enabled="yes"> | ||||
|     <!-- How many events can we handle before any flush --> | ||||
|     <size enabled="yes">5000000</size> | ||||
|     <!-- Use the event buffer in a circular manner? You can use this option to | ||||
|          trace the last set of events. Needs MPI global routines operating on | ||||
|          MPI_COMM_WORLD communicator to be merged | ||||
|     --> | ||||
|     <circular enabled="no" /> | ||||
|   </buffer> | ||||
| 
 | ||||
|   <!-- Control tracing --> | ||||
|   <trace-control enabled="no"> | ||||
|     <!-- We can start the application with a "latent tracing" and wake it up | ||||
|          once a control file is created. Use the property 'frequency' to | ||||
|          choose at which frequency this check must be done. If not supplied, | ||||
|          it will be checked every 100 global operations on MPI_COMM_WORLD. | ||||
|     --> | ||||
|     <file enabled="no" frequency="5M">/gpfs/scratch/bsc41/bsc41273/control</file> | ||||
|     <!--  | ||||
|     --> | ||||
|     <global-ops enabled="no"></global-ops> | ||||
|   </trace-control> | ||||
| 
 | ||||
|   <others enabled="yes"> | ||||
|     <!-- Want to force a minimum amount of time of tracing? Here we force 10 | ||||
|          minutes --> | ||||
|     <minimum-time enabled="no">10M</minimum-time> | ||||
| 	<!-- Capture the following signals to finish cleanly --> | ||||
|     <finalize-on-signal enabled="yes"  | ||||
|       SIGUSR1="no" SIGUSR2="no" SIGINT="yes" | ||||
|       SIGQUIT="yes" SIGTERM="yes" SIGXCPU="yes" | ||||
|       SIGFPE="yes" SIGSEGV="yes" SIGABRT="yes" | ||||
|     /> | ||||
| 	<!-- Use instrumentation poitns to flush sampling buffer --> | ||||
|     <flush-sampling-buffer-at-instrumentation-point enabled="yes" /> | ||||
|   </others> | ||||
| 
 | ||||
| 
 | ||||
|   <!-- Bursts library enabled? This requires an special library! --> | ||||
|   <bursts enabled="no"> | ||||
|     <!-- Specify the threshold. This is mandatory! In this example, the | ||||
|          threshold is limitted to 500 microseconds | ||||
|      --> | ||||
|     <threshold enabled="yes">500u</threshold> | ||||
|     <!-- Report MPI statistics? --> | ||||
|     <mpi-statistics enabled="yes" /> | ||||
|   </bursts> | ||||
| 
 | ||||
|   <!-- Enable sampling capabilities using system clock. | ||||
|        Type may refer to: default, real, prof and virtual. | ||||
|        Period stands for the sampling period (50ms here) | ||||
|        plus a variability of 10ms, which means periods from  | ||||
|        45 to 55ms. | ||||
|   --> | ||||
|   <sampling enabled="no" type="default" period="50m" variability="10m" /> | ||||
| 
 | ||||
|   <!-- Enable dynamic memory instrumentation (experimental) --> | ||||
|   <dynamic-memory enabled="no" /> | ||||
| 
 | ||||
|   <!-- Enable I/O (read, write) instrumentation (experimental) --> | ||||
|   <input-output enabled="no" internals="no"/> | ||||
| 
 | ||||
| 	<!-- Enable system calls instrumentation (experimental) --> | ||||
|   <syscall enabled="no" /> | ||||
| 
 | ||||
|   <!-- Do merge the intermediate tracefiles into the final tracefile? | ||||
|        Named according to the binary name | ||||
|        options:  | ||||
|        synchronization = { default, task, node, no } (default is node) | ||||
|        max-memory = Number (in Mbytes) max memory used in merge step | ||||
|        joint-states = { yes, no } generate joint states? | ||||
|        keep-mpits = { yes, no } keep mpit files after merge? | ||||
|   --> | ||||
|   <merge enabled="yes"  | ||||
|     synchronization="default" | ||||
|     tree-fan-out="16" | ||||
|     max-memory="512" | ||||
|     joint-states="yes" | ||||
|     keep-mpits="yes" | ||||
|     sort-addresses="yes" | ||||
|     overwrite="yes" | ||||
|   /> | ||||
| 
 | ||||
| </trace> | ||||
							
								
								
									
										169
									
								
								garlic/exp/hpcg/serial.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										169
									
								
								garlic/exp/hpcg/serial.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,169 @@ | ||||
| { | ||||
|   stdenv | ||||
| , nixpkgs | ||||
| , pkgs | ||||
| , genApp | ||||
| , genConfigs | ||||
| , runWrappers | ||||
| }: | ||||
| 
 | ||||
| with stdenv.lib; | ||||
| 
 | ||||
| let | ||||
|   bsc = pkgs.bsc; | ||||
| 
 | ||||
|   # Set variable configuration for the experiment | ||||
|   varConfig = { | ||||
|     cc = [ bsc.icc ]; | ||||
|     gitBranch = [ "garlic/seq" ]; | ||||
|     nx = [ 104 64 ]; | ||||
|     ny = [ 104 64 ]; | ||||
|     nz = [ 104 64 ]; | ||||
|   }; | ||||
| 
 | ||||
|   # Common configuration | ||||
|   common = { | ||||
|     # Resources | ||||
|     ntasksPerNode = "48"; | ||||
|     nodes = "1"; | ||||
| 
 | ||||
|     # Stage configuration | ||||
|     enableSbatch = true; | ||||
|     enableControl = true; | ||||
|     enableExtrae = false; | ||||
|     enablePerf = false; | ||||
|     enableCtf = false; | ||||
| 
 | ||||
|     # MN4 path | ||||
|     nixPrefix = "/gpfs/projects/bsc15/nix"; | ||||
|   }; | ||||
| 
 | ||||
|   # Compute the cartesian product of all configurations | ||||
|   configs = map (conf: conf // common) (genConfigs varConfig); | ||||
| 
 | ||||
|   stageProgram = stage: | ||||
|     if stage ? programPath | ||||
|     then "${stage}${stage.programPath}" else "${stage}"; | ||||
| 
 | ||||
|   w = runWrappers; | ||||
| 
 | ||||
|   sbatch = {stage, conf, ...}: with conf; w.sbatch ( | ||||
|     # Allow a user to define a custom reservation for the job in MareNostrum4, | ||||
|     # by setting the garlic.sbatch.reservation attribute in the  | ||||
|     # ~/.config/nixpkgs/config.nix file. If the attribute is not set, no | ||||
|     # reservation is used. The user reservation may be overwritten by the | ||||
|     # experiment, if the reservation is set like with nodes or ntasksPerNode. | ||||
|     optionalAttrs (pkgs.config ? garlic.sbatch.reservation) { | ||||
|       inherit (pkgs.config.garlic.sbatch) reservation; | ||||
|     } // { | ||||
|       program = stageProgram stage; | ||||
|       exclusive = true; | ||||
|       time = "02:00:00"; | ||||
|       qos = "debug"; | ||||
|       jobName = "hpcg"; | ||||
|       inherit nixPrefix nodes ntasksPerNode; | ||||
|     } | ||||
|   ); | ||||
| 
 | ||||
|   control = {stage, conf, ...}: with conf; w.control { | ||||
|     program = stageProgram stage; | ||||
|   }; | ||||
| 
 | ||||
|   srun = {stage, conf, ...}: with conf; w.srun { | ||||
|     program = stageProgram stage; | ||||
|     srunOptions = "--cpu-bind=verbose,rank"; | ||||
|     inherit nixPrefix; | ||||
|   }; | ||||
| 
 | ||||
|   statspy = {stage, conf, ...}: with conf; w.statspy { | ||||
|     program = stageProgram stage; | ||||
|   }; | ||||
| 
 | ||||
|   perf = {stage, conf, ...}: with conf; w.perf { | ||||
|     program = stageProgram stage; | ||||
|     perfArgs = "sched record -a"; | ||||
|   }; | ||||
| 
 | ||||
|   nixsetup = {stage, conf, ...}: with conf; w.nixsetup { | ||||
|     program = stageProgram stage; | ||||
|     nixsetup = "${nixPrefix}/bin/nix-setup"; | ||||
|   }; | ||||
| 
 | ||||
|   extrae = {stage, conf, ...}: w.extrae { | ||||
|     program = stageProgram stage; | ||||
|     traceLib = "mpi"; # mpi -> libtracempi.so | ||||
|     configFile = ./extrae.xml; | ||||
|   }; | ||||
| 
 | ||||
|   ctf = {stage, conf, ...}: w.argv { | ||||
|     program = stageProgram stage; | ||||
|     env = '' | ||||
|       export NANOS6=ctf | ||||
|       export NANOS6_CTF2PRV=0 | ||||
|     ''; | ||||
|   }; | ||||
| 
 | ||||
|   argv = {stage, conf, ...}: with conf; w.argv { | ||||
|     program = stageProgram stage; | ||||
|     argv = ''( | ||||
|       --nx=${toString nx} | ||||
|       --ny=${toString ny} | ||||
|       --nz=${toString nz} | ||||
|     )''; | ||||
|   }; | ||||
| 
 | ||||
|   bscOverlay = import ../../../overlay.nix; | ||||
| 
 | ||||
|   genPkgs = newOverlay: nixpkgs { | ||||
|     overlays = [ | ||||
|       bscOverlay | ||||
|       newOverlay | ||||
|     ]; | ||||
|   }; | ||||
| 
 | ||||
|   # We may be able to use overlays by invoking the fix function directly, but we | ||||
|   # have to get the definition of the bsc packages and the garlic ones as | ||||
|   # overlays. | ||||
| 
 | ||||
|   hpcgFn = {stage, conf, ...}: with conf; | ||||
|     let | ||||
|       # We set the mpi implementation to the one specified in the conf, so all | ||||
|       # packages in bsc will use that one. | ||||
|       customPkgs = genPkgs (self: super: { | ||||
|         bsc = super.bsc // { mpi = conf.mpi; }; | ||||
|       }); | ||||
|     in | ||||
|     customPkgs.bsc.garlic.hpcg.override { | ||||
|       inherit cc gitBranch; | ||||
|     }; | ||||
| 
 | ||||
|   stages = with common; [] | ||||
|     # Use sbatch to request resources first | ||||
|     ++ optional enableSbatch sbatch | ||||
| 
 | ||||
|     # Repeats the next stages N times | ||||
|     ++ optionals enableControl [ nixsetup control ] | ||||
| 
 | ||||
|     # Executes srun to launch the program in the requested nodes, and | ||||
|     # immediately after enters the nix environment again, as slurmstepd launches | ||||
|     # the next stages from outside the namespace. | ||||
|     ++ [ srun nixsetup ] | ||||
| 
 | ||||
|     # Intrumentation with extrae | ||||
|     ++ optional enableExtrae extrae | ||||
| 
 | ||||
|     # Optionally profile the next stages with perf | ||||
|     ++ optional enablePerf perf | ||||
| 
 | ||||
|     # Optionally profile nanos6 with the new ctf | ||||
|     ++ optional enableCtf ctf | ||||
| 
 | ||||
|     # Execute the nbody app with the argv and env vars | ||||
|     ++ [ argv hpcgFn ]; | ||||
| 
 | ||||
|   # List of actual programs to be executed | ||||
|   jobs = map (conf: w.stagen { inherit conf stages; }) configs; | ||||
| 
 | ||||
| in | ||||
|   # We simply run each program one after another | ||||
|   w.launch jobs | ||||
							
								
								
									
										171
									
								
								garlic/exp/hpcg/tampi.nix
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										171
									
								
								garlic/exp/hpcg/tampi.nix
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,171 @@ | ||||
| { | ||||
|   stdenv | ||||
| , nixpkgs | ||||
| , pkgs | ||||
| , genApp | ||||
| , genConfigs | ||||
| , runWrappers | ||||
| }: | ||||
| 
 | ||||
| with stdenv.lib; | ||||
| 
 | ||||
| let | ||||
|   bsc = pkgs.bsc; | ||||
| 
 | ||||
|   # Set variable configuration for the experiment | ||||
|   varConfig = { | ||||
|     cc = [ bsc.icc ]; | ||||
|     mpi = [ bsc.impi ]; | ||||
|     #gitBranch = [ "garlic/tampi+send+oss+task" ]; | ||||
|     n = [ 104 64 ]; | ||||
|     nodes = [1 2 4]; | ||||
|   }; | ||||
| 
 | ||||
|   # Common configuration | ||||
|   common = { | ||||
|     # Compile time nbody config | ||||
|     gitBranch = "symgs_coloring_more_than_one_block_per_task_halos_blocking_discreete"; | ||||
| 
 | ||||
|     # Resources | ||||
|     ntasksPerNode = "48"; | ||||
| 
 | ||||
|     # Stage configuration | ||||
|     enableSbatch = true; | ||||
|     enableControl = true; | ||||
|     enableExtrae = false; | ||||
|     enablePerf = false; | ||||
|     enableCtf = false; | ||||
| 
 | ||||
|     # MN4 path | ||||
|     nixPrefix = "/gpfs/projects/bsc15/nix"; | ||||
|   }; | ||||
| 
 | ||||
|   # Compute the cartesian product of all configurations | ||||
|   configs = map (conf: conf // common) (genConfigs varConfig); | ||||
| 
 | ||||
|   stageProgram = stage: | ||||
|     if stage ? programPath | ||||
|     then "${stage}${stage.programPath}" else "${stage}"; | ||||
| 
 | ||||
|   w = runWrappers; | ||||
| 
 | ||||
|   sbatch = {stage, conf, ...}: with conf; w.sbatch ( | ||||
|     # Allow a user to define a custom reservation for the job in MareNostrum4, | ||||
|     # by setting the garlic.sbatch.reservation attribute in the  | ||||
|     # ~/.config/nixpkgs/config.nix file. If the attribute is not set, no | ||||
|     # reservation is used. The user reservation may be overwritten by the | ||||
|     # experiment, if the reservation is set like with nodes or ntasksPerNode. | ||||
|     optionalAttrs (pkgs.config ? garlic.sbatch.reservation) { | ||||
|       inherit (pkgs.config.garlic.sbatch) reservation; | ||||
|     } // { | ||||
|       program = stageProgram stage; | ||||
|       exclusive = true; | ||||
|       time = "02:00:00"; | ||||
|       qos = "debug"; | ||||
|       jobName = "nbody-tampi"; | ||||
|       inherit nixPrefix nodes ntasksPerNode; | ||||
|     } | ||||
|   ); | ||||
| 
 | ||||
|   control = {stage, conf, ...}: with conf; w.control { | ||||
|     program = stageProgram stage; | ||||
|   }; | ||||
| 
 | ||||
|   srun = {stage, conf, ...}: with conf; w.srun { | ||||
|     program = stageProgram stage; | ||||
|     srunOptions = "--cpu-bind=verbose,rank"; | ||||
|     inherit nixPrefix; | ||||
|   }; | ||||
| 
 | ||||
|   statspy = {stage, conf, ...}: with conf; w.statspy { | ||||
|     program = stageProgram stage; | ||||
|   }; | ||||
| 
 | ||||
|   perf = {stage, conf, ...}: with conf; w.perf { | ||||
|     program = stageProgram stage; | ||||
|     perfArgs = "sched record -a"; | ||||
|   }; | ||||
| 
 | ||||
|   nixsetup = {stage, conf, ...}: with conf; w.nixsetup { | ||||
|     program = stageProgram stage; | ||||
|     nixsetup = "${nixPrefix}/bin/nix-setup"; | ||||
|   }; | ||||
| 
 | ||||
|   extrae = {stage, conf, ...}: w.extrae { | ||||
|     program = stageProgram stage; | ||||
|     traceLib = "mpi"; # mpi -> libtracempi.so | ||||
|     configFile = ./extrae.xml; | ||||
|   }; | ||||
| 
 | ||||
|   ctf = {stage, conf, ...}: w.argv { | ||||
|     program = stageProgram stage; | ||||
|     env = '' | ||||
|       export NANOS6=ctf | ||||
|       export NANOS6_CTF2PRV=0 | ||||
|     ''; | ||||
|   }; | ||||
| 
 | ||||
|   argv = {stage, conf, ...}: with conf; w.argv { | ||||
|     program = stageProgram stage; | ||||
|     argv = ''( | ||||
|       --nx=${toString n} | ||||
|       --ny=${toString n} | ||||
|       --nz=${toString n} | ||||
|     )''; | ||||
|   }; | ||||
| 
 | ||||
|   bscOverlay = import ../../../overlay.nix; | ||||
| 
 | ||||
|   genPkgs = newOverlay: nixpkgs { | ||||
|     overlays = [ | ||||
|       bscOverlay | ||||
|       newOverlay | ||||
|     ]; | ||||
|   }; | ||||
| 
 | ||||
|   # We may be able to use overlays by invoking the fix function directly, but we | ||||
|   # have to get the definition of the bsc packages and the garlic ones as | ||||
|   # overlays. | ||||
| 
 | ||||
|   hpcgFn = {stage, conf, ...}: with conf; | ||||
|     let | ||||
|       # We set the mpi implementation to the one specified in the conf, so all | ||||
|       # packages in bsc will use that one. | ||||
|       customPkgs = genPkgs (self: super: { | ||||
|         bsc = super.bsc // { mpi = conf.mpi; }; | ||||
|       }); | ||||
|     in | ||||
|     customPkgs.bsc.garlic.hpcg.override { | ||||
|       inherit cc mpi gitBranch; | ||||
|     }; | ||||
| 
 | ||||
|   stages = with common; [] | ||||
|     # Use sbatch to request resources first | ||||
|     ++ optional enableSbatch sbatch | ||||
| 
 | ||||
|     # Repeats the next stages N times | ||||
|     ++ optionals enableControl [ nixsetup control ] | ||||
| 
 | ||||
|     # Executes srun to launch the program in the requested nodes, and | ||||
|     # immediately after enters the nix environment again, as slurmstepd launches | ||||
|     # the next stages from outside the namespace. | ||||
|     ++ [ srun nixsetup ] | ||||
| 
 | ||||
|     # Intrumentation with extrae | ||||
|     ++ optional enableExtrae extrae | ||||
| 
 | ||||
|     # Optionally profile the next stages with perf | ||||
|     ++ optional enablePerf perf | ||||
| 
 | ||||
|     # Optionally profile nanos6 with the new ctf | ||||
|     ++ optional enableCtf ctf | ||||
| 
 | ||||
|     # Execute the nbody app with the argv and env vars | ||||
|     ++ [ argv hpcgFn ]; | ||||
| 
 | ||||
|   # List of actual programs to be executed | ||||
|   jobs = map (conf: w.stagen { inherit conf stages; }) configs; | ||||
| 
 | ||||
| in | ||||
|   # We simply run each program one after another | ||||
|   w.launch jobs | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user
	 Raúl Peñacoba
						Raúl Peñacoba