2007-04-04 13:24:39 +00:00
|
|
|
/*file .c : spawned the file Exe*/
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <unistd.h>
|
|
|
|
#include "mpi.h"
|
|
|
|
#include <pthread.h>
|
|
|
|
#include <signal.h>
|
|
|
|
#include <sys/time.h>
|
|
|
|
#include <errno.h>
|
|
|
|
#define EXE_TEST "./loop_child"
|
|
|
|
|
|
|
|
|
2007-04-04 15:38:23 +00:00
|
|
|
int main(int argc, char **argv)
|
|
|
|
{
|
|
|
|
int iter, err, rank, size;
|
|
|
|
MPI_Comm comm, merged;
|
2007-04-04 13:24:39 +00:00
|
|
|
|
|
|
|
/* MPI environnement */
|
|
|
|
|
2007-04-04 15:38:23 +00:00
|
|
|
printf("parent*******************************\n");
|
|
|
|
printf("parent: Launching MPI*\n");
|
2007-04-04 13:24:39 +00:00
|
|
|
|
|
|
|
MPI_Init( &argc, &argv);
|
|
|
|
|
2007-04-04 15:38:23 +00:00
|
|
|
for (iter = 0; iter < 1000; ++iter) {
|
|
|
|
MPI_Comm_spawn(EXE_TEST, NULL, 1, MPI_INFO_NULL,
|
|
|
|
0, MPI_COMM_WORLD, &comm, &err);
|
|
|
|
printf("parent: MPI_Comm_spawn #%d return : %d\n", iter, err);
|
2007-04-04 13:24:39 +00:00
|
|
|
|
2007-04-04 15:38:23 +00:00
|
|
|
MPI_Intercomm_merge(comm, 0, &merged);
|
|
|
|
MPI_Comm_rank(merged, &rank);
|
|
|
|
MPI_Comm_size(merged, &size);
|
|
|
|
printf("parent: MPI_Comm_spawn #%d rank %d, size %d\n",
|
|
|
|
iter, rank, size);
|
2007-04-04 13:24:39 +00:00
|
|
|
// sleep(2);
|
2007-04-04 15:38:23 +00:00
|
|
|
MPI_Comm_free(&merged);
|
2007-04-04 13:24:39 +00:00
|
|
|
}
|
|
|
|
|
2007-04-04 15:38:23 +00:00
|
|
|
MPI_Finalize();
|
|
|
|
printf("parent: End .\n" );
|
2007-04-04 13:24:39 +00:00
|
|
|
return 0;
|
|
|
|
}
|