srun: add postSrun hook
This commit is contained in:
		
							parent
							
								
									4afda7dbfb
								
							
						
					
					
						commit
						b0af9b8608
					
				| @ -8,6 +8,7 @@ | ||||
| , cpuBind | ||||
| , nixPrefix | ||||
| , preSrun ? "" | ||||
| , postSrun ? "" | ||||
| , srunOptions ? "" | ||||
| , output ? "stdout.log" | ||||
| , error ? "stderr.log" | ||||
| @ -26,14 +27,17 @@ stdenv.mkDerivation rec { | ||||
| 
 | ||||
|     ${preSrun} | ||||
| 
 | ||||
|     exec ${slurm}/bin/srun \ | ||||
|     ${slurm}/bin/srun \ | ||||
|       --mpi=pmi2 \ | ||||
|       --cpu-bind=${cpuBind} \ | ||||
|       --output=${output} \ | ||||
|       --error=${error} \ | ||||
|       ${srunOptions} \ | ||||
|       ${nixPrefix}${stageProgram nextStage} | ||||
| 
 | ||||
|     ${postSrun} | ||||
|     EOF | ||||
| 
 | ||||
|     chmod +x $out | ||||
|   ''; | ||||
| } | ||||
|  | ||||
| @ -76,12 +76,12 @@ rec { | ||||
|       inherit nextStage; | ||||
|     }; | ||||
| 
 | ||||
|     srun = {nextStage, conf, preSrun ? "", ...}: ( | ||||
|     srun = {nextStage, conf, preSrun ? "", postSrun ? "", ...}: ( | ||||
|       assert (assertMsg (!(conf ? cpuBind)) | ||||
|         "cpuBind is no longer available in the standard srun stage"); | ||||
|       stages.srun { | ||||
|         inherit (conf) nixPrefix; | ||||
|         inherit nextStage preSrun; | ||||
|         inherit nextStage preSrun postSrun; | ||||
| 
 | ||||
|         # Binding is set to cores always | ||||
|         cpuBind = "cores,verbose"; | ||||
|  | ||||
		Reference in New Issue
	
	Block a user