1
1
openmpi/orte/test/system/pspawn.c
Ralph Castain b5bf0a7f1d Add a new posix_spawn component to the ODLS framework.
Only selectable when specifically requested via "-mca odls pspawn"

Note that there are several concerns:
  * we aren't getting SIGCHLD calls when the procs terminate
  * we aren't seeing the IO pipes close on termination, though
    we are getting output forwarded to mpirun
  * I haven't found a way to bind the child process prior to exec.
    If we want to use this method, we probably need someone to
    implement a cgroup component for the orte/rtc framework

Signed-off-by: Ralph Castain <rhc@open-mpi.org>
2017-11-30 18:01:31 -08:00

46 строки
960 B
C

/* -*- C -*-
*
* $HEADER$
*
* The most basic of MPI applications
*/
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <errno.h>
#include <spawn.h>
#include "opal/util/argv.h"
int main(int argc, char* argv[])
{
int rc;
char **pargv = NULL;
pid_t pid;
posix_spawn_file_actions_t factions;
posix_spawnattr_t attrs;
rc = posix_spawnattr_init(&attrs);
if (0 != rc) {
fprintf(stderr, "ERROR INIT ATTRS: %d\n", errno);
exit(1);
}
rc = posix_spawn_file_actions_init(&factions);
if (0 != rc) {
fprintf(stderr, "ERROR INIT FACTIONS: %d\n", errno);
exit(1);
}
posix_spawn_file_actions_addclose(&factions, fileno(stdin));
opal_argv_append_nosize(&pargv, "hostname");
rc = posix_spawn(&pid, "/usr/bin/hostname", NULL, NULL, pargv, NULL);
posix_spawn_file_actions_destroy(&factions);
posix_spawnattr_destroy(&attrs);
sleep(1);
return 0;
}