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