2008-02-28 01:57:57 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
|
|
|
* University Research and Technology
|
|
|
|
* Corporation. All rights reserved.
|
2008-02-28 05:32:23 +00:00
|
|
|
* Copyright (c) 2004-2008 The University of Tennessee and The University
|
2008-02-28 01:57:57 +00:00
|
|
|
* of Tennessee Research Foundation. All rights
|
|
|
|
* reserved.
|
|
|
|
* Copyright (c) 2004-2005 High Performance Computing Center Stuttgart,
|
|
|
|
* University of Stuttgart. All rights reserved.
|
|
|
|
* Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
* All rights reserved.
|
|
|
|
* Copyright (c) 2007 Sun Microsystems, Inc. All rights reserved.
|
|
|
|
* Copyright (c) 2007 Cisco Systems, Inc. All rights reserved.
|
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @file
|
|
|
|
*
|
|
|
|
* Global params for OpenRTE
|
|
|
|
*/
|
|
|
|
#ifndef ORTE_RUNTIME_ORTE_GLOBALS_H
|
|
|
|
#define ORTE_RUNTIME_ORTE_GLOBALS_H
|
|
|
|
|
|
|
|
#include "orte_config.h"
|
|
|
|
#include "orte/types.h"
|
|
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
#ifdef HAVE_SYS_TIME_H
|
|
|
|
#include <sys/time.h>
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include "opal/threads/mutex.h"
|
|
|
|
#include "opal/threads/condition.h"
|
2008-02-28 05:32:23 +00:00
|
|
|
#include "opal/class/opal_pointer_array.h"
|
2008-02-28 01:57:57 +00:00
|
|
|
|
|
|
|
#include "orte/mca/plm/plm_types.h"
|
|
|
|
#include "orte/mca/rmaps/rmaps_types.h"
|
|
|
|
#include "orte/util/proc_info.h"
|
2008-06-18 03:15:56 +00:00
|
|
|
#include "orte/runtime/runtime.h"
|
2008-08-05 15:09:29 +00:00
|
|
|
#include "orte/runtime/orte_wait.h"
|
2008-02-28 01:57:57 +00:00
|
|
|
|
2008-09-01 17:15:01 +00:00
|
|
|
|
|
|
|
BEGIN_C_DECLS
|
|
|
|
|
|
|
|
ORTE_DECLSPEC extern int orte_debug_verbosity;
|
|
|
|
ORTE_DECLSPEC extern char *orte_prohibited_session_dirs;
|
|
|
|
ORTE_DECLSPEC extern bool orte_xml_output;
|
|
|
|
ORTE_DECLSPEC extern bool orte_help_want_aggregate;
|
|
|
|
|
|
|
|
/* Shortcut for some commonly used names */
|
|
|
|
#define ORTE_NAME_WILDCARD (&orte_name_wildcard)
|
|
|
|
ORTE_DECLSPEC extern orte_process_name_t orte_name_wildcard; /** instantiated in orte/runtime/orte_init.c */
|
|
|
|
#define ORTE_NAME_INVALID (&orte_name_invalid)
|
|
|
|
ORTE_DECLSPEC extern orte_process_name_t orte_name_invalid; /** instantiated in orte/runtime/orte_init.c */
|
|
|
|
|
|
|
|
#define ORTE_PROC_MY_NAME (&orte_process_info.my_name)
|
|
|
|
|
|
|
|
/* define a special name that belongs to orterun */
|
|
|
|
#define ORTE_PROC_MY_HNP (&orte_process_info.my_hnp)
|
|
|
|
|
|
|
|
/* define the name of my daemon */
|
|
|
|
#define ORTE_PROC_MY_DAEMON (&orte_process_info.my_daemon)
|
|
|
|
|
|
|
|
/* See comment in orte/tools/orterun/debuggers.c about this MCA
|
|
|
|
param */
|
|
|
|
ORTE_DECLSPEC extern bool orte_in_parallel_debugger;
|
|
|
|
|
|
|
|
|
|
|
|
#if ORTE_DISABLE_FULL_SUPPORT
|
|
|
|
|
|
|
|
/* These types are used in interface functions that should never be
|
|
|
|
used or implemented in the non-full interface, but need to be
|
|
|
|
declared for various reasons. So have a dummy type to keep things
|
|
|
|
simple (and throw an error if someone does try to use them) */
|
|
|
|
struct orte_job_t;
|
|
|
|
typedef struct orte_job_t orte_job_t;
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
2008-02-28 01:57:57 +00:00
|
|
|
#define ORTE_GLOBAL_ARRAY_BLOCK_SIZE 64
|
|
|
|
#define ORTE_GLOBAL_ARRAY_MAX_SIZE INT_MAX
|
|
|
|
|
2008-03-05 01:46:30 +00:00
|
|
|
/* define a default error return code for ORTE */
|
|
|
|
#define ORTE_ERROR_DEFAULT_EXIT_CODE 1
|
2008-02-28 01:57:57 +00:00
|
|
|
|
2008-08-05 15:09:29 +00:00
|
|
|
/**
|
|
|
|
* Define a macro for updating the orte_exit_status
|
|
|
|
* The macro provides a convenient way of doing this
|
|
|
|
* so that we can add thread locking at some point
|
|
|
|
* since the orte_exit_status is a global variable.
|
|
|
|
*
|
|
|
|
* Ensure that we do not overwrite the exit status if it has
|
|
|
|
* already been set to some non-zero value. If we don't make
|
|
|
|
* this check, then different parts of the code could overwrite
|
|
|
|
* each other's exit status in the case of abnormal termination.
|
|
|
|
*
|
|
|
|
* For example, if a process aborts, we would record the initial
|
|
|
|
* exit code from the aborted process. However, subsequent processes
|
|
|
|
* will have been aborted by signal as we kill the job. We don't want
|
|
|
|
* the subsequent processes to overwrite the original exit code so
|
|
|
|
* we can tell the user the exit code from the process that caused
|
|
|
|
* the whole thing to happen.
|
|
|
|
*/
|
|
|
|
#define ORTE_UPDATE_EXIT_STATUS(newstatus) \
|
|
|
|
do { \
|
|
|
|
if (0 == orte_exit_status && 0 != newstatus) { \
|
|
|
|
OPAL_OUTPUT_VERBOSE((1, orte_debug_output, \
|
|
|
|
"%s:%s(%d) updating exit status to %d", \
|
|
|
|
ORTE_NAME_PRINT(ORTE_PROC_MY_NAME), \
|
|
|
|
__FILE__, __LINE__, newstatus)); \
|
|
|
|
orte_exit_status = newstatus; \
|
|
|
|
} \
|
|
|
|
} while(0);
|
|
|
|
|
|
|
|
|
2008-02-28 01:57:57 +00:00
|
|
|
/* global type definitions used by RTE - instanced in orte_globals.c */
|
|
|
|
|
|
|
|
/************
|
|
|
|
* Declare this to allow us to use it before fully
|
|
|
|
* defining it - resolves potential circular definition
|
|
|
|
*/
|
|
|
|
struct orte_proc_t;
|
|
|
|
/************/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Information about a specific application to be launched in the RTE.
|
|
|
|
*/
|
|
|
|
typedef struct {
|
|
|
|
/** Parent object */
|
|
|
|
opal_object_t super;
|
|
|
|
/** Unique index when multiple apps per job */
|
2008-04-30 19:49:53 +00:00
|
|
|
int8_t idx;
|
2008-02-28 01:57:57 +00:00
|
|
|
/** Absolute pathname of argv[0] */
|
|
|
|
char *app;
|
|
|
|
/** Number of copies of this process that are to be launched */
|
|
|
|
orte_std_cntr_t num_procs;
|
|
|
|
/** Standard argv-style array, including a final NULL pointer */
|
|
|
|
char **argv;
|
|
|
|
/** Standard environ-style array, including a final NULL pointer */
|
|
|
|
char **env;
|
|
|
|
/** Current working directory for this app */
|
|
|
|
char *cwd;
|
|
|
|
/** Whether the cwd was set by the user or by the system */
|
|
|
|
bool user_specified_cwd;
|
|
|
|
/* Any hostfile that was specified */
|
|
|
|
char *hostfile;
|
|
|
|
/* Hostfile for adding hosts to an existing allocation */
|
|
|
|
char *add_hostfile;
|
2008-03-05 22:12:27 +00:00
|
|
|
/** argv of hosts passed in to -host */
|
|
|
|
char ** dash_host;
|
|
|
|
/** Prefix directory for this app (or NULL if no override necessary) */
|
2008-02-28 01:57:57 +00:00
|
|
|
char *prefix_dir;
|
|
|
|
/** Preload the binary on the remote machine (in PLS via FileM) */
|
|
|
|
bool preload_binary;
|
|
|
|
/** Preload the comma separated list of files to the remote machines cwd */
|
|
|
|
char * preload_files;
|
|
|
|
/** Destination directory for the preloaded files
|
|
|
|
* If NULL then the absolute and relative paths are obeyed */
|
|
|
|
char * preload_files_dest_dir;
|
|
|
|
} orte_app_context_t;
|
|
|
|
|
|
|
|
ORTE_DECLSPEC OBJ_CLASS_DECLARATION(orte_app_context_t);
|
|
|
|
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
/** Base object so this can be put on a list */
|
|
|
|
opal_list_item_t super;
|
|
|
|
/* index of this node object in global array */
|
|
|
|
orte_std_cntr_t index;
|
|
|
|
/** String node name */
|
|
|
|
char *name;
|
2008-04-30 19:49:53 +00:00
|
|
|
/* daemon on this node */
|
2008-02-28 01:57:57 +00:00
|
|
|
struct orte_proc_t *daemon;
|
|
|
|
/* whether or not this daemon has been launched */
|
|
|
|
bool daemon_launched;
|
|
|
|
/** Launch id - needed by some systems to launch a proc on this node */
|
|
|
|
int32_t launch_id;
|
|
|
|
/** number of procs on this node */
|
|
|
|
orte_vpid_t num_procs;
|
|
|
|
/* array of pointers to procs on this node */
|
2008-02-28 05:32:23 +00:00
|
|
|
opal_pointer_array_t *procs;
|
2008-04-30 19:49:53 +00:00
|
|
|
/* next node rank on this node */
|
2008-09-25 13:39:08 +00:00
|
|
|
orte_node_rank_t next_node_rank;
|
2008-02-28 01:57:57 +00:00
|
|
|
/* whether or not we are oversubscribed */
|
|
|
|
bool oversubscribed;
|
|
|
|
/** The node architecture, as reported by the remote node. This
|
|
|
|
* value is a bit-map that identifies whether or not the node
|
|
|
|
* is big/little endian, etc.
|
|
|
|
*/
|
|
|
|
int32_t arch;
|
|
|
|
/** State of this node */
|
|
|
|
orte_node_state_t state;
|
|
|
|
/** A "soft" limit on the number of slots available on the node.
|
|
|
|
This will typically correspond to the number of physical CPUs
|
|
|
|
that we have been allocated on this note and would be the
|
|
|
|
"ideal" number of processes for us to launch. */
|
|
|
|
orte_std_cntr_t slots;
|
|
|
|
/** How many processes have already been launched, used by one or
|
|
|
|
more jobs on this node. */
|
|
|
|
orte_std_cntr_t slots_inuse;
|
|
|
|
/** This represents the number of slots we (the allocator) are
|
|
|
|
attempting to allocate to the current job - or the number of
|
|
|
|
slots allocated to a specific job on a query for the jobs
|
|
|
|
allocations */
|
|
|
|
orte_std_cntr_t slots_alloc;
|
|
|
|
/** A "hard" limit (if set -- a value of 0 implies no hard limit)
|
|
|
|
on the number of slots that can be allocated on a given
|
|
|
|
node. This is for some environments (e.g. grid) there may be
|
|
|
|
fixed limits on the number of slots that can be used.
|
|
|
|
|
|
|
|
This value also could have been a boolean - but we may want to
|
|
|
|
allow the hard limit be different than the soft limit - in
|
|
|
|
other words allow the node to be oversubscribed up to a
|
|
|
|
specified limit. For example, if we have two processors, we
|
|
|
|
may want to allow up to four processes but no more. */
|
|
|
|
orte_std_cntr_t slots_max;
|
|
|
|
/** Username on this node, if specified */
|
|
|
|
char *username;
|
2008-03-18 09:39:07 +00:00
|
|
|
char *slot_list;
|
2008-02-28 01:57:57 +00:00
|
|
|
} orte_node_t;
|
|
|
|
ORTE_DECLSPEC OBJ_CLASS_DECLARATION(orte_node_t);
|
|
|
|
|
2008-03-06 21:56:00 +00:00
|
|
|
/* define a set of flags to control the launch of a job */
|
2008-09-25 13:39:08 +00:00
|
|
|
#define ORTE_JOB_CONTROL_LOCAL_SPAWN (uint16_t) 0x0001
|
|
|
|
#define ORTE_JOB_CONTROL_NON_ORTE_JOB (uint16_t) 0x0002
|
|
|
|
#define ORTE_JOB_CONTROL_DEBUGGER_DAEMON (uint16_t) 0x0004
|
|
|
|
#define ORTE_JOB_CONTROL_FORWARD_OUTPUT (uint16_t) 0x0008
|
|
|
|
#define ORTE_JOB_CONTROL_DO_NOT_MONITOR (uint16_t) 0x0010
|
|
|
|
#define ORTE_JOB_CONTROL_FORWARD_COMM (uint16_t) 0x0020
|
2008-03-06 21:56:00 +00:00
|
|
|
|
2008-02-28 01:57:57 +00:00
|
|
|
typedef struct {
|
|
|
|
/** Base object so this can be put on a list */
|
|
|
|
opal_list_item_t super;
|
|
|
|
/* jobid for this job */
|
|
|
|
orte_jobid_t jobid;
|
|
|
|
/* app_context array for this job */
|
2008-02-28 05:32:23 +00:00
|
|
|
opal_pointer_array_t *apps;
|
2008-02-28 01:57:57 +00:00
|
|
|
/* number of app_contexts in the array */
|
|
|
|
orte_std_cntr_t num_apps;
|
2008-03-06 21:56:00 +00:00
|
|
|
/* flags to control the launch of this job - see above
|
|
|
|
* for description of supported flags
|
|
|
|
*/
|
|
|
|
uint16_t controls;
|
2008-02-28 01:57:57 +00:00
|
|
|
/* total slots allocated to this job */
|
|
|
|
orte_std_cntr_t total_slots_alloc;
|
|
|
|
/* number of procs in this job */
|
|
|
|
orte_vpid_t num_procs;
|
|
|
|
/* array of pointers to procs in this job */
|
2008-02-28 05:32:23 +00:00
|
|
|
opal_pointer_array_t *procs;
|
2008-02-28 01:57:57 +00:00
|
|
|
/* map of the job */
|
|
|
|
orte_job_map_t *map;
|
|
|
|
/* bookmark for where we are in mapping - this
|
|
|
|
* indicates the node where we stopped
|
|
|
|
*/
|
|
|
|
orte_node_t *bookmark;
|
|
|
|
/** Whether or not to override oversubscription based on local
|
|
|
|
* hardware - used to indicate uncertainty in number of
|
|
|
|
* actual processors available on this node
|
|
|
|
*/
|
|
|
|
bool oversubscribe_override;
|
|
|
|
/* state of the overall job */
|
|
|
|
orte_job_state_t state;
|
|
|
|
/* number of procs launched */
|
|
|
|
orte_vpid_t num_launched;
|
|
|
|
/* number of procs reporting contact info */
|
|
|
|
orte_vpid_t num_reported;
|
|
|
|
/* number of procs terminated */
|
|
|
|
orte_vpid_t num_terminated;
|
|
|
|
/* did this job abort? */
|
|
|
|
bool abort;
|
|
|
|
/* proc that caused that to happen */
|
|
|
|
struct orte_proc_t *aborted_proc;
|
|
|
|
#if OPAL_ENABLE_FT == 1
|
|
|
|
/* ckpt state */
|
|
|
|
size_t ckpt_state;
|
|
|
|
/* snapshot reference */
|
|
|
|
char *ckpt_snapshot_ref;
|
|
|
|
/* snapshot location */
|
|
|
|
char *ckpt_snapshot_loc;
|
|
|
|
#endif
|
|
|
|
} orte_job_t;
|
|
|
|
ORTE_DECLSPEC OBJ_CLASS_DECLARATION(orte_job_t);
|
|
|
|
|
|
|
|
struct orte_proc_t {
|
|
|
|
/** Base object so this can be put on a list */
|
|
|
|
opal_list_item_t super;
|
|
|
|
/* process name */
|
|
|
|
orte_process_name_t name;
|
|
|
|
/* pid */
|
|
|
|
pid_t pid;
|
2008-04-30 19:49:53 +00:00
|
|
|
/* local rank amongst my peers on the node
|
|
|
|
* where this is running - this value is
|
|
|
|
* needed by MPI procs so that the lowest
|
|
|
|
* rank on a node can perform certain fns -
|
|
|
|
* e.g., open an sm backing file
|
|
|
|
*/
|
2008-09-25 13:39:08 +00:00
|
|
|
orte_local_rank_t local_rank;
|
2008-04-30 19:49:53 +00:00
|
|
|
/* local rank on the node across all procs
|
|
|
|
* and jobs known to this HNP - this is
|
|
|
|
* needed so that procs can do things like
|
|
|
|
* know which static IP port to use
|
|
|
|
*/
|
2008-09-25 13:39:08 +00:00
|
|
|
orte_node_rank_t node_rank;
|
2008-02-28 01:57:57 +00:00
|
|
|
/* process state */
|
|
|
|
orte_proc_state_t state;
|
|
|
|
/* exit code */
|
|
|
|
orte_exit_code_t exit_code;
|
|
|
|
/* the app_context that generated this proc */
|
2008-04-30 19:49:53 +00:00
|
|
|
int8_t app_idx;
|
2008-02-28 01:57:57 +00:00
|
|
|
/* a cpu list, if specified by the user */
|
|
|
|
char *slot_list;
|
|
|
|
/* pointer to the node where this proc is executing */
|
|
|
|
orte_node_t *node;
|
|
|
|
/* name of the node where this proc is executing - this
|
|
|
|
* is used simply to pass that info to a calling
|
|
|
|
* tool since it may not have a node array available
|
|
|
|
*/
|
|
|
|
char *nodename;
|
|
|
|
/* RML contact info */
|
|
|
|
char *rml_uri;
|
2008-06-02 21:46:34 +00:00
|
|
|
/* seconds when last heartbeat was detected */
|
|
|
|
int beat;
|
2008-02-28 01:57:57 +00:00
|
|
|
#if OPAL_ENABLE_FT == 1
|
|
|
|
/* ckpt state */
|
|
|
|
size_t ckpt_state;
|
|
|
|
/* snapshot reference */
|
|
|
|
char *ckpt_snapshot_ref;
|
|
|
|
/* snapshot location */
|
|
|
|
char *ckpt_snapshot_loc;
|
|
|
|
#endif
|
|
|
|
};
|
|
|
|
typedef struct orte_proc_t orte_proc_t;
|
|
|
|
ORTE_DECLSPEC OBJ_CLASS_DECLARATION(orte_proc_t);
|
|
|
|
|
2008-04-30 19:49:53 +00:00
|
|
|
|
|
|
|
typedef struct {
|
Repair the MPI-2 dynamic operations. This includes:
1. repair of the linear and direct routed modules
2. repair of the ompi/pubsub/orte module to correctly init routes to the ompi-server, and correctly handle failure to correctly parse the provided ompi-server URI
3. modification of orterun to accept both "file" and "FILE" for designating where the ompi-server URI is to be found - purely a convenience feature
4. resolution of a message ordering problem during the connect/accept handshake that allowed the "send-first" proc to attempt to send to the "recv-first" proc before the HNP had actually updated its routes.
Let this be a further reminder to all - message ordering is NOT guaranteed in the OOB
5. Repair the ompi/dpm/orte module to correctly init routes during connect/accept.
Reminder to all: messages sent to procs in another job family (i.e., started by a different mpirun) are ALWAYS routed through the respective HNPs. As per the comments in orte/routed, this is REQUIRED to maintain connect/accept (where only the root proc on each side is capable of init'ing the routes), allow communication between mpirun's using different routing modules, and to minimize connections on tools such as ompi-server. It is all taken care of "under the covers" by the OOB to ensure that a route back to the sender is maintained, even when the different mpirun's are using different routed modules.
6. corrections in the orte/odls to ensure proper identification of daemons participating in a dynamic launch
7. corrections in build/nidmap to support update of an existing nidmap during dynamic launch
8. corrected implementation of the update_arch function in the ESS, along with consolidation of a number of ESS operations into base functions for easier maintenance. The ability to support info from multiple jobs was added, although we don't currently do so - this will come later to support further fault recovery strategies
9. minor updates to several functions to remove unnecessary and/or no longer used variables and envar's, add some debugging output, etc.
10. addition of a new macro ORTE_PROC_IS_DAEMON that resolves to true if the provided proc is a daemon
There is still more cleanup to be done for efficiency, but this at least works.
Tested on single-node Mac, multi-node SLURM via odin. Tests included connect/accept, publish/lookup/unpublish, comm_spawn, comm_spawn_multiple, and singleton comm_spawn.
Fixes ticket #1256
This commit was SVN r18804.
2008-07-03 17:53:37 +00:00
|
|
|
/* base object */
|
|
|
|
opal_object_t super;
|
2008-04-30 19:49:53 +00:00
|
|
|
/* nodename */
|
|
|
|
char *name;
|
Repair the MPI-2 dynamic operations. This includes:
1. repair of the linear and direct routed modules
2. repair of the ompi/pubsub/orte module to correctly init routes to the ompi-server, and correctly handle failure to correctly parse the provided ompi-server URI
3. modification of orterun to accept both "file" and "FILE" for designating where the ompi-server URI is to be found - purely a convenience feature
4. resolution of a message ordering problem during the connect/accept handshake that allowed the "send-first" proc to attempt to send to the "recv-first" proc before the HNP had actually updated its routes.
Let this be a further reminder to all - message ordering is NOT guaranteed in the OOB
5. Repair the ompi/dpm/orte module to correctly init routes during connect/accept.
Reminder to all: messages sent to procs in another job family (i.e., started by a different mpirun) are ALWAYS routed through the respective HNPs. As per the comments in orte/routed, this is REQUIRED to maintain connect/accept (where only the root proc on each side is capable of init'ing the routes), allow communication between mpirun's using different routing modules, and to minimize connections on tools such as ompi-server. It is all taken care of "under the covers" by the OOB to ensure that a route back to the sender is maintained, even when the different mpirun's are using different routed modules.
6. corrections in the orte/odls to ensure proper identification of daemons participating in a dynamic launch
7. corrections in build/nidmap to support update of an existing nidmap during dynamic launch
8. corrected implementation of the update_arch function in the ESS, along with consolidation of a number of ESS operations into base functions for easier maintenance. The ability to support info from multiple jobs was added, although we don't currently do so - this will come later to support further fault recovery strategies
9. minor updates to several functions to remove unnecessary and/or no longer used variables and envar's, add some debugging output, etc.
10. addition of a new macro ORTE_PROC_IS_DAEMON that resolves to true if the provided proc is a daemon
There is still more cleanup to be done for efficiency, but this at least works.
Tested on single-node Mac, multi-node SLURM via odin. Tests included connect/accept, publish/lookup/unpublish, comm_spawn, comm_spawn_multiple, and singleton comm_spawn.
Fixes ticket #1256
This commit was SVN r18804.
2008-07-03 17:53:37 +00:00
|
|
|
/* vpid of this job family's daemon on this node */
|
2008-05-28 18:38:47 +00:00
|
|
|
orte_vpid_t daemon;
|
2008-04-30 19:49:53 +00:00
|
|
|
/* arch of node */
|
|
|
|
uint32_t arch;
|
|
|
|
} orte_nid_t;
|
Repair the MPI-2 dynamic operations. This includes:
1. repair of the linear and direct routed modules
2. repair of the ompi/pubsub/orte module to correctly init routes to the ompi-server, and correctly handle failure to correctly parse the provided ompi-server URI
3. modification of orterun to accept both "file" and "FILE" for designating where the ompi-server URI is to be found - purely a convenience feature
4. resolution of a message ordering problem during the connect/accept handshake that allowed the "send-first" proc to attempt to send to the "recv-first" proc before the HNP had actually updated its routes.
Let this be a further reminder to all - message ordering is NOT guaranteed in the OOB
5. Repair the ompi/dpm/orte module to correctly init routes during connect/accept.
Reminder to all: messages sent to procs in another job family (i.e., started by a different mpirun) are ALWAYS routed through the respective HNPs. As per the comments in orte/routed, this is REQUIRED to maintain connect/accept (where only the root proc on each side is capable of init'ing the routes), allow communication between mpirun's using different routing modules, and to minimize connections on tools such as ompi-server. It is all taken care of "under the covers" by the OOB to ensure that a route back to the sender is maintained, even when the different mpirun's are using different routed modules.
6. corrections in the orte/odls to ensure proper identification of daemons participating in a dynamic launch
7. corrections in build/nidmap to support update of an existing nidmap during dynamic launch
8. corrected implementation of the update_arch function in the ESS, along with consolidation of a number of ESS operations into base functions for easier maintenance. The ability to support info from multiple jobs was added, although we don't currently do so - this will come later to support further fault recovery strategies
9. minor updates to several functions to remove unnecessary and/or no longer used variables and envar's, add some debugging output, etc.
10. addition of a new macro ORTE_PROC_IS_DAEMON that resolves to true if the provided proc is a daemon
There is still more cleanup to be done for efficiency, but this at least works.
Tested on single-node Mac, multi-node SLURM via odin. Tests included connect/accept, publish/lookup/unpublish, comm_spawn, comm_spawn_multiple, and singleton comm_spawn.
Fixes ticket #1256
This commit was SVN r18804.
2008-07-03 17:53:37 +00:00
|
|
|
ORTE_DECLSPEC OBJ_CLASS_DECLARATION(orte_nid_t);
|
2008-04-30 19:49:53 +00:00
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
/* index to node */
|
|
|
|
int32_t node;
|
|
|
|
/* local rank */
|
2008-09-25 13:39:08 +00:00
|
|
|
orte_local_rank_t local_rank;
|
2008-04-30 19:49:53 +00:00
|
|
|
/* node rank */
|
2008-09-25 13:39:08 +00:00
|
|
|
orte_node_rank_t node_rank;
|
2008-04-30 19:49:53 +00:00
|
|
|
} orte_pmap_t;
|
|
|
|
|
Repair the MPI-2 dynamic operations. This includes:
1. repair of the linear and direct routed modules
2. repair of the ompi/pubsub/orte module to correctly init routes to the ompi-server, and correctly handle failure to correctly parse the provided ompi-server URI
3. modification of orterun to accept both "file" and "FILE" for designating where the ompi-server URI is to be found - purely a convenience feature
4. resolution of a message ordering problem during the connect/accept handshake that allowed the "send-first" proc to attempt to send to the "recv-first" proc before the HNP had actually updated its routes.
Let this be a further reminder to all - message ordering is NOT guaranteed in the OOB
5. Repair the ompi/dpm/orte module to correctly init routes during connect/accept.
Reminder to all: messages sent to procs in another job family (i.e., started by a different mpirun) are ALWAYS routed through the respective HNPs. As per the comments in orte/routed, this is REQUIRED to maintain connect/accept (where only the root proc on each side is capable of init'ing the routes), allow communication between mpirun's using different routing modules, and to minimize connections on tools such as ompi-server. It is all taken care of "under the covers" by the OOB to ensure that a route back to the sender is maintained, even when the different mpirun's are using different routed modules.
6. corrections in the orte/odls to ensure proper identification of daemons participating in a dynamic launch
7. corrections in build/nidmap to support update of an existing nidmap during dynamic launch
8. corrected implementation of the update_arch function in the ESS, along with consolidation of a number of ESS operations into base functions for easier maintenance. The ability to support info from multiple jobs was added, although we don't currently do so - this will come later to support further fault recovery strategies
9. minor updates to several functions to remove unnecessary and/or no longer used variables and envar's, add some debugging output, etc.
10. addition of a new macro ORTE_PROC_IS_DAEMON that resolves to true if the provided proc is a daemon
There is still more cleanup to be done for efficiency, but this at least works.
Tested on single-node Mac, multi-node SLURM via odin. Tests included connect/accept, publish/lookup/unpublish, comm_spawn, comm_spawn_multiple, and singleton comm_spawn.
Fixes ticket #1256
This commit was SVN r18804.
2008-07-03 17:53:37 +00:00
|
|
|
typedef struct {
|
|
|
|
/* base object */
|
|
|
|
opal_object_t super;
|
|
|
|
/* jobid */
|
|
|
|
orte_jobid_t job;
|
|
|
|
/* array of data for procs */
|
|
|
|
opal_value_array_t pmap;
|
|
|
|
} orte_jmap_t;
|
|
|
|
ORTE_DECLSPEC OBJ_CLASS_DECLARATION(orte_jmap_t);
|
|
|
|
|
2008-02-28 01:57:57 +00:00
|
|
|
/**
|
|
|
|
* Get a job data object
|
|
|
|
* We cannot just reference a job data object with its jobid as
|
|
|
|
* the jobid is no longer an index into the array. This change
|
|
|
|
* was necessitated by modification of the jobid to include
|
|
|
|
* an mpirun-unique qualifer to eliminate any global name
|
|
|
|
* service
|
|
|
|
*/
|
|
|
|
ORTE_DECLSPEC orte_job_t* orte_get_job_data_object(orte_jobid_t job);
|
|
|
|
|
|
|
|
/* global variables used by RTE - instanced in orte_globals.c */
|
2008-06-18 03:15:56 +00:00
|
|
|
ORTE_DECLSPEC extern bool orte_reuse_daemons, orte_timing;
|
2008-02-28 01:57:57 +00:00
|
|
|
ORTE_DECLSPEC extern bool orte_debug_daemons_flag, orte_debug_daemons_file_flag;
|
2008-08-14 18:59:01 +00:00
|
|
|
ORTE_DECLSPEC extern bool orte_leave_session_attached;
|
2008-04-17 13:50:59 +00:00
|
|
|
ORTE_DECLSPEC extern bool orte_do_not_launch;
|
2008-02-28 01:57:57 +00:00
|
|
|
ORTE_DECLSPEC extern bool orted_spin_flag;
|
2008-03-28 02:20:37 +00:00
|
|
|
ORTE_DECLSPEC extern bool orte_static_ports;
|
2008-04-30 19:49:53 +00:00
|
|
|
ORTE_DECLSPEC extern int32_t orte_contiguous_nodes;
|
2008-04-01 20:32:17 +00:00
|
|
|
ORTE_DECLSPEC extern bool orte_keep_fqdn_hostnames;
|
2008-05-29 13:38:27 +00:00
|
|
|
ORTE_DECLSPEC extern int orted_debug_failure;
|
2008-06-02 21:46:34 +00:00
|
|
|
ORTE_DECLSPEC extern int orted_debug_failure_delay;
|
2008-06-24 17:50:56 +00:00
|
|
|
ORTE_DECLSPEC extern bool orte_homogeneous_nodes;
|
|
|
|
ORTE_DECLSPEC extern bool orte_hetero_apps;
|
2008-08-19 15:19:30 +00:00
|
|
|
ORTE_DECLSPEC extern bool orte_never_launched;
|
2008-09-23 15:46:34 +00:00
|
|
|
ORTE_DECLSPEC extern bool orte_devel_level_output;
|
2008-02-28 01:57:57 +00:00
|
|
|
|
|
|
|
ORTE_DECLSPEC extern char **orte_launch_environ;
|
2008-04-14 18:26:08 +00:00
|
|
|
ORTE_DECLSPEC extern opal_pointer_array_t orte_daemonmap;
|
|
|
|
|
2008-07-25 17:13:22 +00:00
|
|
|
ORTE_DECLSPEC extern bool orte_hnp_is_allocated;
|
2008-08-04 14:25:19 +00:00
|
|
|
ORTE_DECLSPEC extern bool orte_allocation_required;
|
2008-07-25 17:13:22 +00:00
|
|
|
|
Per the July technical meeting:
Standardize the handling of the orte launch agent option across PLMs. This has been a consistent complaint I have received - each PLM would register its own MCA param to get input on the launch agent for remote nodes (in fact, one or two didn't, but most did). This would then get handled in various and contradictory ways.
Some PLMs would accept only a one-word input. Others accepted multi-word args such as "valgrind orted", but then some would error by putting any prefix specified on the cmd line in front of the incorrect argument.
For example, while using the rsh launcher, if you specified "valgrind orted" as your launch agent and had "--prefix foo" on you cmd line, you would attempt to execute "ssh foo/valgrind orted" - which obviously wouldn't work.
This was all -very- confusing to users, who had to know which PLM was being used so they could even set the right mca param in the first place! And since we don't warn about non-recognized or non-used mca params, half of the time they would wind up not doing what they thought they were telling us to do.
To solve this problem, we did the following:
1. removed all mca params from the individual plms for the launch agent
2. added a new mca param "orte_launch_agent" for this purpose. To further simplify for users, this comes with a new cmd line option "--launch-agent" that can take a multi-word string argument. The value of the param defaults to "orted".
3. added a PLM base function that processes the orte_launch_agent value and adds the contents to a provided argv array. This can subsequently be harvested at-will to handle multi-word values
4. modified the PLMs to use this new function. All the PLMs except for the rsh PLM required very minor change - just called the function and moved on. The rsh PLM required much larger changes as - because of the rsh/ssh cmd line limitations - we had to correctly prepend any provided prefix to the correct argv entry.
5. added a new opal_argv_join_range function that allows the caller to "join" argv entries between two specified indices
Please let me know of any problems. I tried to make this as clean as possible, but cannot compile all PLMs to ensure all is correct.
This commit was SVN r19097.
2008-07-30 18:26:24 +00:00
|
|
|
ORTE_DECLSPEC extern char *orte_launch_agent;
|
2008-02-28 01:57:57 +00:00
|
|
|
ORTE_DECLSPEC extern char **orted_cmd_line;
|
2008-08-05 15:09:29 +00:00
|
|
|
|
2008-08-13 17:47:24 +00:00
|
|
|
ORTE_DECLSPEC extern orte_job_t *orte_debugger_daemon;
|
|
|
|
ORTE_DECLSPEC extern bool orte_enable_debug_cospawn_while_running;
|
|
|
|
ORTE_DECLSPEC extern int orte_debugger_check_rate;
|
|
|
|
|
2008-08-05 15:09:29 +00:00
|
|
|
/* exit triggers and flags */
|
|
|
|
ORTE_DECLSPEC extern orte_trigger_event_t orte_exit, orteds_exit;
|
2008-02-28 01:57:57 +00:00
|
|
|
ORTE_DECLSPEC extern int orte_exit_status;
|
|
|
|
ORTE_DECLSPEC extern bool orte_abnormal_term_ordered;
|
2008-06-02 21:46:34 +00:00
|
|
|
ORTE_DECLSPEC extern bool orte_shutdown_in_progress;
|
|
|
|
|
|
|
|
ORTE_DECLSPEC extern int orte_heartbeat_rate;
|
|
|
|
ORTE_DECLSPEC extern int orte_startup_timeout;
|
Afraid this has a couple of things mixed into the commit. Couldn't be helped - had missed one commit prior to running out the door on vacation.
Fix race conditions in abnormal terminations. We had done a first-cut at this in a prior commit. However, the window remained partially open due to the fact that the HNP has multiple paths leading to orte_finalize. Most of our frameworks don't care if they are finalized more than once, but one of them does, which meant we segfaulted if orte_finalize got called more than once. Besides, we really shouldn't be doing that anyway.
So we now introduce a set of atomic locks that prevent us from multiply calling abort, attempting to call orte_finalize, etc. My initial tests indicate this is working cleanly, but since it is a race condition issue, more testing will have to be done before we know for sure that this problem has been licked.
Also, some updates relevant to the tool comm library snuck in here. Since those also touched the orted code (as did the prior changes), I didn't want to attempt to separate them out - besides, they are coming in soon anyway. More on them later as that functionality approaches completion.
This commit was SVN r17843.
2008-03-17 17:58:59 +00:00
|
|
|
|
2008-02-28 01:57:57 +00:00
|
|
|
ORTE_DECLSPEC extern int orte_timeout_usec_per_proc;
|
|
|
|
ORTE_DECLSPEC extern float orte_max_timeout;
|
|
|
|
|
2008-03-05 04:54:57 +00:00
|
|
|
ORTE_DECLSPEC extern char *orte_default_hostfile;
|
|
|
|
|
2008-05-01 19:19:34 +00:00
|
|
|
ORTE_DECLSPEC extern opal_buffer_t *orte_tree_launch_cmd;
|
|
|
|
|
2008-02-28 01:57:57 +00:00
|
|
|
/* global arrays for data storage */
|
2008-02-28 05:32:23 +00:00
|
|
|
ORTE_DECLSPEC extern opal_pointer_array_t *orte_job_data;
|
|
|
|
ORTE_DECLSPEC extern opal_pointer_array_t *orte_node_pool;
|
2008-02-28 01:57:57 +00:00
|
|
|
|
2008-06-18 03:15:56 +00:00
|
|
|
#endif /* ORTE_DISABLE_FULL_SUPPORT */
|
2008-02-28 01:57:57 +00:00
|
|
|
|
|
|
|
END_C_DECLS
|
|
|
|
|
|
|
|
#endif /* ORTE_RUNTIME_ORTE_GLOBALS_H */
|