/[escript]/trunk/bin/run-escript
ViewVC logotype

Contents of /trunk/bin/run-escript

Parent Directory Parent Directory | Revision Log Revision Log


Revision 4665 - (show annotations)
Mon Feb 10 03:29:02 2014 UTC (5 years, 7 months ago) by caltinay
File size: 17318 byte(s)
This should help running on raijin without damaging anything.

1 #!/usr/bin/env bash
2
3 # Escript/Finley wrapper for python
4 # Sets LD_LIBRARY_PATH and PYTHONPATH and then runs either python or the MPI launcher
5
6 #Extra paths can be configured about a page further down
7 #Search for EXTRA_PATH=""
8
9 #set to 1 if performing this is a standalone build and ../../pkg contains the relevant tools
10 STANDALONE=0
11
12 #set to 1 if this is part of a packaged build (.deb) and files will be installed in standard locations
13 #rather than everything in a single directory
14 #Do not use this together with $STANDALONE
15 STDLOCATION=0
16
17 #Now we find the location of this script
18 #Note that this location should be absolute but does not need to be unique
19 scriptdir=""
20 CURDIR=`pwd`
21
22 #Environment vars which control operations:
23 # ESCRIPT_NUM_NODES, ESCRIPT_NUM_PROCS, ESCRIPT_NUM_THREADS, ESCRIPT_HOSTFILE, ESCRIPT_CREATESTDFILES
24
25 HOSTFILE=/tmp/escript.$USER.$$
26 HOSTFILE2=/tmp/escript2.$USER.$$
27
28 #Begin finding ESCRIPT_ROOT
29 if [ $STDLOCATION -ne 0 ]
30 then
31 ESCRIPT_ROOT=/usr/lib/python-escript
32 else
33 # We don't know the escript root so we need to work it out from the invocation
34 # Need to match if the name contains /
35 if [[ $0 =~ / ]]
36 then
37 # We are not using the PATH to find the script
38 cd "`dirname $0`"
39 scriptdir=`pwd`
40 cd "$CURDIR"
41 else
42 # name does not contain / therefore we are using
43 tscriptdir=`which $0`
44 if [ $? -ne 0 ]
45 then
46 echo "Error! Unable to determine script directory. Exiting."
47 exit 1
48 fi
49 scriptdir=`dirname $tscriptdir`
50 fi
51
52 cd "$scriptdir/.."
53 ESCRIPT_ROOT=`pwd`
54 cd ..
55 ESCRIPT_PARENT=`pwd`
56 cd "$CURDIR"
57
58 fi
59 ##### End finding ESCRIPT_ROOT ########
60
61 PYTHON_MPI_NULL="$ESCRIPT_ROOT/lib/pythonMPI"
62 PYTHON_MPI_REDIRECT="$ESCRIPT_ROOT/lib/pythonMPIredirect"
63 PYTHON_CMD=python
64
65 # if possible please express paths relative to $ESCRIPT_ROOT unless
66 # they are in an unrelated location
67
68 EXTRA_DYLD_LIBRARY_PATH=""
69 EXTRA_PATH=$ESCRIPT_ROOT/bin
70 EXTRA_PYTHONPATH=$ESCRIPT_ROOT
71
72 if [ $STDLOCATION -eq 1 ]
73 then
74 EXTRA_LD_LIBRARY_PATH=/usr/lib/python-escript
75 else
76 EXTRA_LD_LIBRARY_PATH=$ESCRIPT_ROOT/lib
77 fi
78
79
80 if [ $STANDALONE -eq 1 ]
81 then
82 EXTRA_PATH=$ESCRIPT_PARENT/pkg/python/bin:$ESCRIPT_PARENT/pkg/scons/bin:$EXTRA_PATH
83 EXTRA_LD_LIBRARY_PATH=$ESCRIPT_PARENT/pkg/boost/lib:$ESCRIPT_PARENT/pkg/netcdf/lib/:$EXTRA_LD_LIBRARY_PATH
84 EXTRA_LD_LIBRARY_PATH=$EXTRA_LD_LIBRARY_PATH
85 EXTRA_LD_LIBRARY_PATH=$ESCRIPT_PARENT/pkg/python/lib:$EXTRA_LD_LIBRARY_PATH
86 EXTRA_PYTHONPATH=$ESCRIPT_PARENT/pkg/numpy/lib/python2.6/site-packages:$ESCRIPT_PARENT/pkg/matplotlib/lib/python2.6/site-packages:$EXTRA_PYTHONPATH
87 fi
88
89
90 BUILDINFO_FILE="$ESCRIPT_ROOT/lib/buildvars"
91 if [ "$STDLOCATION" = "1" ]
92 then
93 BUILDINFO_FILE=/usr/lib/python-escript/buildvars
94 fi
95 if [ ! -r "$BUILDINFO_FILE" ]; then
96 if [ "$1" = "-e" ]; then
97 echo "export LD_LIBRARY_PATH=$EXTRA_LD_LIBRARY_PATH:\$LD_LIBRARY_PATH"
98 echo "export PYTHONPATH=$EXTRA_PYTHONPATH:\$PYTHONPATH"
99 echo "export PATH=$EXTRA_PATH:\$PATH"
100 if [ "`uname`" = "Darwin" ]
101 then
102 echo "export DYLD_LIBRARY_PATH=$EXTRA_DYLD_LIBRARY_PATH:$EXTRA_LD_LIBRARY_PATH:\$DYLD_LIBRARY_PATH"
103 fi
104 exit 0
105 fi
106 echo "Error! Unable to read escript build information. Exiting."
107 exit 1
108 fi
109
110 get_buildvar () {
111 echo `grep "^$1=" "$BUILDINFO_FILE" |cut -d= -f2`
112 }
113
114 #
115 # Add VisIt paths if required
116 #
117 WITH_VISIT=`get_buildvar visit`
118 if [ "$WITH_VISIT" = "1" ]; then
119 VISIT_BIN=`which visit 2>/dev/null`
120 if [ $? -eq 0 ]; then
121 VISIT_PY_PATH=`$VISIT_BIN -env | grep LIBPATH | cut -d= -f2`
122 EXTRA_PYTHONPATH=$EXTRA_PYTHONPATH:$VISIT_PY_PATH
123 EXTRA_LD_LIBRARY_PATH=$EXTRA_LD_LIBRARY_PATH:$VISIT_PY_PATH
124 elif [ ! -z $ESCRIPT_VERBOSE ]; then
125 echo "VisIt module enabled but VisIt not in path!"
126 fi
127 fi
128
129 HELP_TEXT="
130 Usage: run-escript [options] script.py [arguments...]
131 -n nn number of nodes to use
132 -p np number of MPI processes to spawn per node
133 -t nt number of OpenMP threads to use
134 -f file name of MPI hostfile
135 -c print compile information for escript and exit
136 -V print escript version and exit
137 -i interactive mode
138 -b do not invoke python (run non-python programs)
139 -e print export statements for environment and exit
140 -o redirect output from MPI to files
141 -v print diagnostics
142 -x run in new xterm instance
143 -m tool run with valgrind {tool=m[emcheck]/c[allgrind]}
144 script.py Your python script
145 arguments... The optional command-line arguments to your script
146 "
147
148 if [ "$1" = "--help" ]; then
149 echo "$HELP_TEXT"
150 exit 0
151 fi
152 #==============================================================================
153
154 # Parse the command-line options
155 while getopts 'bn:p:t:f:echim:oVvx' option
156 do
157 case "$option" in
158 "b") DO_BINARY=y
159 ;;
160 "m") DO_VALGRIND=$OPTARG
161 ;;
162 "n") ESCRIPT_NUM_NODES=$OPTARG
163 ;;
164 "p") ESCRIPT_NUM_PROCS=$OPTARG
165 ;;
166 "t") ESCRIPT_NUM_THREADS=$OPTARG
167 ;;
168 "f") ESCRIPT_HOSTFILE=$OPTARG
169 ;;
170 "c") cat "$BUILDINFO_FILE"
171 exit 0
172 ;;
173 "V") echo "escript-development(build "`get_buildvar svn_revision`")"
174 exit 0
175 ;;
176 "h") echo "$HELP_TEXT"
177 exit 0
178 ;;
179 "i") DO_INTERACTIVE=y
180 ;;
181 "e") echo "export LD_LIBRARY_PATH=$EXTRA_LD_LIBRARY_PATH:\$LD_LIBRARY_PATH"
182 echo "export PYTHONPATH=$EXTRA_PYTHONPATH:\$PYTHONPATH"
183 echo "export PATH=$EXTRA_PATH:\$PATH"
184 if [ "`uname`" = "Darwin" ]
185 then
186 echo "export DYLD_LIBRARY_PATH=$EXTRA_DYLD_LIBRARY_PATH:$EXTRA_LD_LIBRARY_PATH:\$DYLD_LIBRARY_PATH"
187 fi
188 exit 0
189 ;;
190 "o") ESCRIPT_CREATESTDFILES=y
191 ;;
192 "v") ESCRIPT_VERBOSE=y
193 ;;
194 "x") DO_XTERM=y
195 ;;
196 ?) echo "$HELP_TEXT"
197 exit 1
198 ;;
199 esac
200 done
201 shift `expr $OPTIND - 1`
202 #==============================================
203 #
204 # Read MPI_FLAVOUR and WITH_OPENMP from the buildvars
205 #
206 MPI_FLAVOUR=`get_buildvar mpi`
207 WITH_OPENMP=`get_buildvar openmp`
208
209 if [ ! -z $ESCRIPT_VERBOSE ]; then
210 echo "MPI flavour is $MPI_FLAVOUR."
211 if [ "$WITH_OPENMP" = "1" ]; then echo "OpenMP enabled."; fi
212 fi
213
214 #
215 # extend path variables
216 #
217 export PATH=$EXTRA_PATH:$PATH
218 export LD_LIBRARY_PATH=$EXTRA_LD_LIBRARY_PATH:$LD_LIBRARY_PATH
219 export PYTHONPATH=$EXTRA_PYTHONPATH:$PYTHONPATH
220 EXPORT_ENV="PATH,LD_LIBRARY_PATH,PYTHONPATH"
221 if [ "`uname`" = "Darwin" ]
222 then
223 export DYLD_LIBRARY_PATH=$EXTRA_DYLD_LIBRARY_PATH:$EXTRA_LD_LIBRARY_PATH:$DYLD_LIBRARY_PATH
224 EXPORT_ENV="$EXPORT_ENV,DYLD_LIBRARY_PATH"
225 fi
226 if [ ! -z $ESCRIPT_VERBOSE ]
227 then
228 echo "PATH = $PATH "
229 echo "LD_LIBRARY_PATH = $LD_LIBRARY_PATH "
230 echo "PYTHONPATH = $PYTHONPATH "
231 if [ ! -z $DYLD_LIBRARY_PATH ]; then echo "DYLD_LIBRARY_PATH = $DYLD_LIBRARY_PATH "; fi
232 fi
233 #==============================================
234 #
235 # Ensure the variables have sensible values
236 #
237 if [ "$MPI_FLAVOUR" = "none" ]
238 then
239 if [ ! -z "$ESCRIPT_NUM_NODES" ]; then
240 if [ $ESCRIPT_NUM_NODES -gt 1 ]; then
241 echo "Warning: MPI disabled but number of nodes set. Option ignored."
242 fi
243 fi
244 if [ ! -z "$ESCRIPT_NUM_PROCS" ]; then
245 if [ $ESCRIPT_NUM_PROCS -gt 1 ]; then
246 echo "Warning: MPI disabled but number of processors per node set. Option ignored."
247 fi
248 fi
249 if [ ! -z "$ESCRIPT_HOSTFILE" ]
250 then
251 echo "Warning: MPI disabled but host file is given. Option ignored."
252 fi
253 ESCRIPT_NUM_NODES=1
254 ESCRIPT_NUM_PROCS=1
255 else
256 # use the PBS_NODEFILE if not otherwise specified
257 if [ ! -z "$PBS_NODEFILE" ] && [ -z "$ESCRIPT_HOSTFILE" ]
258 then
259 ESCRIPT_HOSTFILE=$PBS_NODEFILE
260 fi
261
262 if [ ! -z "$ESCRIPT_HOSTFILE" ]
263 then
264 if [ -f "$ESCRIPT_HOSTFILE" ]
265 then
266 cat "$ESCRIPT_HOSTFILE" | sort -u > $HOSTFILE
267 NUM_HOSTS=`cat "$HOSTFILE" | wc -l`
268 if [ ! -z $ESCRIPT_NUM_NODES ]
269 then
270 if [ $NUM_HOSTS -ne $ESCRIPT_NUM_NODES ]
271 then
272 echo "number of hosts selected in the host file $ESCRIPT_HOSTFILE needs to match the requested number of nodes $ESCRIPT_NUM_NODES."
273 exit 1
274 fi
275 else
276 ESCRIPT_NUM_NODES=$NUM_HOSTS
277 fi
278 else
279 echo "cannot find hostfile $ESCRIPT_HOSTFILE."
280 exit 1
281 fi
282 else
283 HOSTFILE=''
284 fi
285
286 if [ -z $ESCRIPT_NUM_NODES ]
287 then
288 ESCRIPT_NUM_NODES=1
289 fi
290
291 if [ -z $ESCRIPT_NUM_PROCS ]
292 then
293 ESCRIPT_NUM_PROCS=1
294 fi
295
296 if [ ! -z $ESCRIPT_VERBOSE ]
297 then
298 echo "ESCRIPT_NUM_NODES = $ESCRIPT_NUM_NODES "
299 echo "ESCRIPT_NUM_PROCS = $ESCRIPT_NUM_PROCS "
300 fi
301 fi
302
303 if [ "$WITH_OPENMP" = "1" ]
304 then
305 if [ -z $ESCRIPT_NUM_THREADS ]
306 then
307 ESCRIPT_NUM_THREADS=$OMP_NUM_THREADS
308 if [ -z $ESCRIPT_NUM_THREADS ]
309 then
310 ESCRIPT_NUM_THREADS=1
311 fi
312 fi
313 if [ ! -z $ESCRIPT_VERBOSE ]
314 then
315 echo "ESCRIPT_NUM_THREADS is $ESCRIPT_NUM_THREADS."
316 fi
317 else
318 if [ ! -z $ESCRIPT_NUM_THREADS ] && [ $ESCRIPT_NUM_THREADS != 1 ]
319 then
320 echo "Warning: OpenMP is disabled but number of threads requested is $ESCRIPT_NUM_THREADS!=1. Running without threads."
321 fi
322 ESCRIPT_NUM_THREADS=1
323 fi
324 #
325 # Now we compute total number of Processes
326 #
327 TOTPROC=$((ESCRIPT_NUM_NODES * ESCRIPT_NUM_PROCS))
328 if [ $? -ne 0 ] #Some compute error
329 then #This could happen if the args were not a number
330 echo "expression of total number of processors = $ESCRIPT_NUM_NODES * $ESCRIPT_NUM_PROCS is not numerical."
331 exit 1
332 fi
333
334 #
335 # Test to ensure people aren't trying to combine interactive and multi-process
336 #
337 if ([ ! -z $DO_INTERACTIVE ] || [ $# -eq 0 ]) && ([ $TOTPROC -gt 1 ])
338 then
339 echo "Interactive mode cannot be used with more than one process"
340 exit 1
341 fi
342
343 if [ $TOTPROC -gt 1 ]
344 then
345 if [ "$ESCRIPT_CREATESTDFILES" = "y" ]
346 then
347 PYTHON_MPI=$PYTHON_MPI_REDIRECT
348 else
349 PYTHON_MPI=$PYTHON_MPI_NULL
350 fi
351 else
352 PYTHON_MPI=$PYTHON_MPI_NULL
353 fi
354 #==============================================================================
355 # Must have at least one command-line arg: the python script
356 if [ $# -eq 0 ]
357 then
358 if [ ! -z $DO_BINARY ]
359 then
360 echo "No program to run was specified. Exiting."
361 exit 1
362 else
363 DO_INTERACTIVE=y
364 fi
365 fi
366
367 #==============================================================================
368
369 if [ ! -z $DO_XTERM ]
370 then
371 EXEC_CMD="xterm -e"
372 else
373 EXEC_CMD=""
374 fi
375
376 if [ ! -z "$DO_VALGRIND" ]
377 then
378 VALGRIND_BIN=`which valgrind 2>/dev/null`
379 if [ $? -eq 0 ]; then
380 LOGDIR=$ESCRIPT_ROOT/valgrind_logs
381 [ -d $LOGDIR ] || mkdir $LOGDIR
382 if [ ${DO_VALGRIND:0:1} = "c" ];
383 then
384 # run callgrind
385 LOGFILE=${LOGDIR}/callgrind.%p.xml
386 VALGRIND="valgrind --tool=callgrind --callgrind-out-file=$LOGFILE"
387 EXEC_CMD="$EXEC_CMD $VALGRIND"
388 else
389 # run memcheck by default
390 LAST_N=`ls -1 $LOGDIR|grep "^memcheck"|tail -1|cut -d. -f2`
391 NEW_N=`printf "%04d" $((10#$LAST_N + 1))`
392 LOGFILE=${LOGDIR}/memcheck.${NEW_N}.xml
393 VALGRIND="valgrind --tool=memcheck --xml=yes --show-reachable=yes --error-limit=no --gen-suppressions=all --suppressions=$ESCRIPT_ROOT/scripts/escript.supp --leak-check=full --xml-file=$LOGFILE"
394 EXEC_CMD="$EXEC_CMD $VALGRIND"
395 fi
396 else
397 echo "Execution with valgrind requested but valgrind not in path!"
398 exit 1
399 fi
400 fi
401
402 if [ ! -z $DO_BINARY ]
403 then
404 EXEC_CMD="$EXEC_CMD $@"
405 else
406 # Check to see if the python version we were compiled with matches the
407 # one of PYTHON_CMD.
408 compfull=`get_buildvar python_version`
409 compversion=`echo $compfull | cut -d. -f1,2`
410 compmajor=`echo $compfull | cut -d. -f1`
411 if [ "$PYTHON_CMD" = "python" ] # if people have customised the command they
412 then # might not want us changing it
413 if [ "$compmajor" = "3" ]
414 then
415 PYTHON_CMD=python3
416 fi
417 fi
418 intversion=`$PYTHON_CMD -c 'from __future__ import print_function;import sys;print("%d.%d"%(sys.version_info[0], sys.version_info[1]))'`
419 if [ "$compversion" != "$intversion" ]
420 then
421 echo "Python versions do not match. Escript was compiled for "$compversion"."
422 echo "Current version of Python appears to be "$intversion"."
423 exit 1
424 fi
425 if [ "$MPI_FLAVOUR" = "none" ]
426 then
427 if [ ! -z $DO_INTERACTIVE ]
428 then
429 EXEC_CMD="$EXEC_CMD $PYTHON_CMD -i $@"
430 else
431 EXEC_CMD="$EXEC_CMD $PYTHON_CMD $@"
432 fi
433 else
434 if [ ! -z $DO_INTERACTIVE ]
435 then
436 EXEC_CMD="$EXEC_CMD $PYTHON_MPI -i $@"
437 else
438 EXEC_CMD="$EXEC_CMD $PYTHON_MPI $@"
439 fi
440 fi
441 fi
442 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "Command to be executed is \"$EXEC_CMD\"."; fi
443 #==============================================================================
444 #
445 # now we start to spawn things:
446 #
447 if [ "$WITH_OPENMP" = "1" ]
448 then
449 export OMP_NUM_THREADS=$ESCRIPT_NUM_THREADS
450 EXPORT_ENV="$EXPORT_ENV,OMP_NUM_THREADS"
451 fi
452 EXIT_CODE=1
453 #=============== no MPI ===================================
454 if [ "$MPI_FLAVOUR" = "none" ]
455 then
456 $EXEC_CMD
457 EXIT_CODE=$?
458 #=============== OpenMPI ===================================
459 elif [ "$MPI_FLAVOUR" = "OPENMPI" ]
460 then
461 if [ ! -z "$HOSTFILE" ]
462 then
463 HOST_LIST=`sort -u "$HOSTFILE" | awk 'BEGIN{S=""}{if (S == "") { S = $0 } else {S = S "," $0}}END{print S}'`
464 CMD="mpirun --gmca mpi_warn_on_fork 0 -x ${EXPORT_ENV//,/ -x } --bysocket --bind-to-socket --host $HOST_LIST -np $TOTPROC $EXEC_CMD"
465 else
466 CMD="mpirun --gmca mpi_warn_on_fork 0 -x ${EXPORT_ENV//,/ -x } --cpus-per-rank $ESCRIPT_NUM_THREADS -np $TOTPROC $EXEC_CMD"
467 fi
468 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "MPI command is \"$CMD\"."; fi
469 $CMD
470 EXIT_CODE=$?
471
472 #=============== Intel MPI ===================================
473 elif [ "$MPI_FLAVOUR" = "INTELMPI" ]
474 then
475
476 if [ "$WITH_OPENMP" = "1" ]
477 then
478 export I_MPI_PIN_DOMAIN=omp
479 EXPORT_ENV="$EXPORT_ENV, I_MPI_PIN_DOMAIN"
480 fi
481
482 if [ ! -z "$HOSTFILE" ]
483 then
484 mpdboot -n $ESCRIPT_NUM_NODES -r ssh -f "$HOSTFILE"
485 if [ $? -ne 0 ]
486 then
487 echo "mpdboot with host file $ESCRIPT_HOSTFILE for $ESCRIPT_NUM_NODES nodes failed."
488 exit 1
489 else
490 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "mpdboot was started with host file $ESCRIPT_HOSTFILE for $ESCRIPT_NUM_NODES nodes."; fi
491 fi
492 else
493 mpdboot -n 1 -r ssh
494 if [ $? -ne 0 ]
495 then
496 echo "mpdboot failed."
497 exit 1
498 else
499 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "mpdboot was started."; fi
500 fi
501 fi
502 CMD="mpiexec -perhost $ESCRIPT_NUM_PROCS -envall -n $TOTPROC $EXEC_CMD"
503 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "MPI command is \"$CMD\"."; fi
504 $CMD
505 EXIT_CODE=$?
506 mpdallexit
507 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "mpdallexit executed."; fi
508 #=============== SGI's MPIMPT ===================================
509 elif [ "$MPI_FLAVOUR" = "MPT" ]
510 then
511 export MPI_NUM_MEMORY_REGIONS=0
512 EXPORT_ENV="$EXPORT_ENV,MPI_NUM_MEMORY_REGIONS"
513 if [ ! -z "$HOSTFILE" ]
514 then
515 HOST_LIST=`awk 'BEGIN{S=""}{if (S == "") { S = $0 } else {S = S "," $0}}END{print S}' "$HOSTFILE"`
516 CMD="mpirun $HOST_LIST -np $ESCRIPT_NUM_PROCS $EXEC_CMD"
517 else
518 CMD="mpirun -np $TOTPROC $EXEC_CMD"
519 fi
520 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "MPI command is \"$CMD\"."; fi
521 $CMD
522 EXIT_CODE=$?
523 #=============== MPICH ===================================
524 elif [ "$MPI_FLAVOUR" = "MPICH" ]
525 then
526 if [ ! -z "$HOSTFILE" ]
527 then
528 touch "$HOSTFILE2"
529 for (( i=1;i<=$ESCRIPT_NUM_PROCS;i+=1 )) ; do cat "$HOSTFILE" >> "$HOSTFILE2" ; done
530 CMD="mpirun -machinefile \"$HOSTFILE2\" -np $TOTPROC $EXEC_CMD"
531 else
532 CMD="mpirun -np $TOTPROC $EXEC_CMD"
533 fi
534 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "MPI command is \"$CMD\"."; fi
535 $CMD
536 EXIT_CODE=$?
537 #=============== MPICH2 ===================================
538 elif [ "$MPI_FLAVOUR" = "MPICH2" ]
539 then
540 if [ ! -z "$HOSTFILE" ]
541 then
542 mpdboot -n $ESCRIPT_NUM_NODES -r ssh -f "$HOSTFILE"
543 if [ $? -ne 0 ]
544 then
545 echo "mpdboot with host file $ESCRIPT_HOSTFILE for $ESCRIPT_NUM_NODES nodes failed."
546 exit 1
547 else
548 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "mpdboot was started with host file $ESCRIPT_HOSTFILE for $ESCRIPT_NUM_NODES nodes."; fi
549 fi
550 else
551 mpdboot -n 1 -r ssh
552 if [ $? -ne 0 ]
553 then
554 echo "mpdboot failed."
555 exit 1
556 else
557 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "mpdboot was started."; fi
558 fi
559 fi
560 CMD="mpiexec -genvlist $EXPORT_ENV -np $TOTPROC $EXEC_CMD"
561 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "MPI command is \"$CMD\"."; fi
562 $CMD
563 EXIT_CODE=$?
564 mpdallexit
565 if [ ! -z $ESCRIPT_VERBOSE ]; then echo "mpdallexit executed."; fi
566 else
567 echo "unknown MPI flavour '$MPI_FLAVOUR'."
568 fi
569 exit $EXIT_CODE
570

Properties

Name Value
svn:executable *
svn:mergeinfo /branches/3.4/bin/run-escript:4453-4490 /branches/lapack2681/bin/escript:2682-2741 /branches/pasowrap/bin/run-escript:3661-3674 /branches/py3_attempt2/bin/run-escript:3871-3891 /branches/release3.4/bin/run-escript:4452 /branches/restext/bin/escript:2610-2624 /branches/ripleygmg_from_3668/bin/run-escript:3669-3791 /branches/stage3.0/bin/escript:2569-2590 /branches/symbolic_from_3470/bin/run-escript:3471-3974 /branches/symbolic_from_3470/ripley/test/python/bin/run-escript:3517-3974 /release/3.0/bin/escript:2591-2601 /trunk/ripley/test/python/bin/run-escript:3480-3515

  ViewVC Help
Powered by ViewVC 1.1.26