2004-05-27 16:26:36 +00:00
|
|
|
/*
|
|
|
|
* $HEADER$
|
|
|
|
*
|
|
|
|
* $Id: tmpdir.c $
|
|
|
|
*
|
|
|
|
* Function: -
|
|
|
|
*/
|
2004-08-08 19:06:15 +00:00
|
|
|
#define _GNU_SOURCE
|
2004-05-27 16:26:36 +00:00
|
|
|
#include <stdio.h>
|
|
|
|
#include <pwd.h>
|
2004-08-08 02:24:00 +00:00
|
|
|
#include <stddef.h>
|
2004-05-27 16:26:36 +00:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
2004-08-08 02:24:00 +00:00
|
|
|
#include <libgen.h>
|
2004-05-27 16:26:36 +00:00
|
|
|
#include <sys/param.h>
|
|
|
|
#include <sys/types.h>
|
|
|
|
#include <sys/stat.h>
|
2004-08-08 02:24:00 +00:00
|
|
|
|
2004-05-27 16:26:36 +00:00
|
|
|
/*
|
|
|
|
#include <sys/socket.h>
|
|
|
|
#include <netdb.h> MAXHOSTNAMELEN in Solaris
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <errno.h>
|
|
|
|
#include <dirent.h>
|
|
|
|
|
2004-06-07 15:33:53 +00:00
|
|
|
#include <ompi_debug.h>
|
|
|
|
#include <ompi_internal.h>
|
2004-05-27 16:26:36 +00:00
|
|
|
#include <terror.h>
|
|
|
|
#include <typical.h>
|
|
|
|
#include <etc_misc.h>
|
|
|
|
*/
|
|
|
|
|
2004-06-07 15:33:53 +00:00
|
|
|
#include "ompi_config.h"
|
2004-05-27 16:26:36 +00:00
|
|
|
#include "include/constants.h"
|
|
|
|
|
|
|
|
#include "util/sys_info.h"
|
2004-06-29 04:50:40 +00:00
|
|
|
#include "util/proc_info.h"
|
2004-05-27 16:26:36 +00:00
|
|
|
#include "util/os_path.h"
|
|
|
|
#include "util/os_create_dirpath.h"
|
2004-06-29 04:50:40 +00:00
|
|
|
#include "util/session_dir.h"
|
2004-05-27 16:26:36 +00:00
|
|
|
|
2004-06-29 04:50:40 +00:00
|
|
|
int ompi_check_dir(bool create, char *directory);
|
2004-05-27 16:26:36 +00:00
|
|
|
|
|
|
|
#define OMPI_DEFAULT_TMPDIR "tmp"
|
|
|
|
|
2004-06-29 04:50:40 +00:00
|
|
|
int ompi_check_dir(bool create, char *directory)
|
2004-05-27 16:26:36 +00:00
|
|
|
{
|
|
|
|
struct stat buf;
|
|
|
|
mode_t my_mode = S_IRWXU; /* at the least, I need to be able to do anything */
|
|
|
|
|
|
|
|
if (0 == stat(directory, &buf)) { /* exists - check access */
|
|
|
|
if ((buf.st_mode & my_mode) == my_mode) { /* okay, I can work here */
|
2004-06-07 15:33:53 +00:00
|
|
|
return(OMPI_SUCCESS);
|
2004-05-27 16:26:36 +00:00
|
|
|
}
|
|
|
|
}
|
2004-06-01 18:40:16 +00:00
|
|
|
if (create) {
|
2004-06-17 03:26:28 +00:00
|
|
|
return(ompi_os_create_dirpath(directory, my_mode)); /* try to create it with proper mode */
|
2004-06-01 18:40:16 +00:00
|
|
|
}
|
2004-06-07 15:33:53 +00:00
|
|
|
return(OMPI_ERROR); /* couldn't find it, or don't have access rights, and not asked to create it */
|
2004-05-27 16:26:36 +00:00
|
|
|
}
|
|
|
|
|
2004-08-08 02:24:00 +00:00
|
|
|
int ompi_session_dir(bool create, char *prefix, char *user, char *hostid, char *batchid, char *universe, char *job, char *proc)
|
2004-05-27 16:26:36 +00:00
|
|
|
{
|
2004-08-08 02:24:00 +00:00
|
|
|
char *fulldirpath=NULL, *tmp=NULL, *hostname=NULL, *batchname=NULL;
|
|
|
|
char *sessions=NULL, *frontend=NULL;
|
|
|
|
int return_code;
|
2004-05-27 16:26:36 +00:00
|
|
|
|
2004-06-29 04:50:40 +00:00
|
|
|
if (NULL == user || NULL == universe) { /* error conditions - have to provide at least that much */
|
2004-08-08 02:24:00 +00:00
|
|
|
return OMPI_ERROR;
|
2004-06-29 04:50:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (NULL == job && NULL != proc) { /* can't give a proc without a job */
|
2004-08-08 02:24:00 +00:00
|
|
|
return OMPI_ERROR;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (NULL == hostid) { /* check if hostname set elsewhere */
|
|
|
|
if (NULL == ompi_system_info.nodename) { /* don't have a hostname anywhere - error */
|
|
|
|
return_code = OMPI_ERROR;
|
|
|
|
goto CLEANUP;
|
|
|
|
} else {
|
|
|
|
hostname = strdup(ompi_system_info.nodename);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
hostname = strdup(hostid);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (NULL == batchid) {
|
|
|
|
batchname = strdup("0");
|
|
|
|
} else {
|
|
|
|
batchname = batchid;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (0 > asprintf(&frontend, "openmpi-sessions-%s@%s:%s", user, hostname, batchname)) {
|
|
|
|
return_code = OMPI_ERROR;
|
|
|
|
goto CLEANUP;
|
2004-06-29 04:50:40 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (NULL != proc) {
|
2004-08-08 02:24:00 +00:00
|
|
|
if (0 > asprintf(&sessions, "%s%s%s%s%s%s%s", frontend,
|
|
|
|
ompi_system_info.path_sep, universe,
|
|
|
|
ompi_system_info.path_sep, job,
|
|
|
|
ompi_system_info.path_sep, proc)) {
|
|
|
|
return_code = OMPI_ERROR;
|
|
|
|
goto CLEANUP;
|
|
|
|
}
|
2004-06-29 04:50:40 +00:00
|
|
|
} else if (NULL != job) {
|
2004-08-08 02:24:00 +00:00
|
|
|
if (0 > asprintf(&sessions, "%s%s%s%s%s", frontend,
|
|
|
|
ompi_system_info.path_sep, universe,
|
|
|
|
ompi_system_info.path_sep, job)) {
|
|
|
|
return_code = OMPI_ERROR;
|
|
|
|
goto CLEANUP;
|
|
|
|
}
|
2004-06-29 04:50:40 +00:00
|
|
|
} else {
|
2004-08-08 02:24:00 +00:00
|
|
|
if (0 > asprintf(&sessions, "%s%s%s", frontend, ompi_system_info.path_sep, universe)) {
|
|
|
|
return_code = OMPI_ERROR;
|
|
|
|
goto CLEANUP;
|
|
|
|
}
|
2004-06-29 04:50:40 +00:00
|
|
|
}
|
2004-05-27 16:26:36 +00:00
|
|
|
|
2004-08-08 02:24:00 +00:00
|
|
|
if (NULL != prefix) { /* if a prefix is specified, this is the only place we look */
|
|
|
|
fulldirpath = strdup(ompi_os_path(false, prefix, sessions, NULL)); /* make sure it's an absolute pathname */
|
|
|
|
if (OMPI_SUCCESS == ompi_check_dir(create, fulldirpath)) { /* check for existence and access, or create it */
|
|
|
|
return_code = OMPI_SUCCESS;
|
|
|
|
goto COMPLETE;
|
2004-05-27 16:26:36 +00:00
|
|
|
}
|
|
|
|
else {
|
2004-08-08 02:24:00 +00:00
|
|
|
return_code = OMPI_ERROR;
|
|
|
|
goto CLEANUP; /* user specified location, but we can't access it nor create it */
|
2004-05-27 16:26:36 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2004-08-08 02:24:00 +00:00
|
|
|
/* no prefix was specified, so check other options in order */
|
2004-06-07 15:33:53 +00:00
|
|
|
if (NULL != getenv("OMPI_PREFIX_ENV")) {
|
|
|
|
tmp = strdup(getenv("OMPI_PREFIX_ENV"));
|
2004-08-08 02:24:00 +00:00
|
|
|
} else if (NULL != getenv("TMPDIR")) {
|
|
|
|
tmp = strdup(getenv("TMPDIR"));
|
|
|
|
} else if (NULL != getenv("TMP")) {
|
|
|
|
tmp = strdup(getenv("TMP"));
|
|
|
|
} else {
|
|
|
|
tmp = strdup(OMPI_DEFAULT_TMPDIR);
|
2004-05-27 16:26:36 +00:00
|
|
|
}
|
|
|
|
|
2004-08-08 02:24:00 +00:00
|
|
|
fulldirpath = strdup(ompi_os_path(false, tmp, sessions, NULL));
|
|
|
|
if (OMPI_SUCCESS == ompi_check_dir(create, fulldirpath)) { /* check for existence and access, or create it */
|
|
|
|
return_code = OMPI_SUCCESS;
|
|
|
|
goto COMPLETE;
|
|
|
|
} else {
|
|
|
|
return_code = OMPI_ERROR;
|
|
|
|
goto CLEANUP;
|
2004-05-27 16:26:36 +00:00
|
|
|
}
|
2004-08-08 02:24:00 +00:00
|
|
|
|
|
|
|
COMPLETE:
|
|
|
|
if (proc) {
|
|
|
|
ompi_process_info.proc_session_dir = strdup(fulldirpath);
|
|
|
|
fulldirpath = dirname(fulldirpath);
|
2004-05-27 16:26:36 +00:00
|
|
|
}
|
2004-08-08 02:24:00 +00:00
|
|
|
if (job) {
|
|
|
|
ompi_process_info.job_session_dir = strdup(fulldirpath);
|
|
|
|
fulldirpath = dirname(fulldirpath);
|
2004-05-27 16:26:36 +00:00
|
|
|
}
|
2004-08-08 02:24:00 +00:00
|
|
|
ompi_process_info.universe_session_dir = strdup(fulldirpath);
|
2004-05-27 16:26:36 +00:00
|
|
|
|
2004-08-08 02:24:00 +00:00
|
|
|
CLEANUP:
|
|
|
|
if (tmp) {
|
2004-05-27 16:26:36 +00:00
|
|
|
free(tmp);
|
|
|
|
}
|
2004-08-08 02:24:00 +00:00
|
|
|
if (fulldirpath) {
|
|
|
|
free(fulldirpath);
|
2004-05-27 16:26:36 +00:00
|
|
|
}
|
2004-08-08 02:24:00 +00:00
|
|
|
if (frontend) {
|
|
|
|
free(frontend);
|
2004-05-27 16:26:36 +00:00
|
|
|
}
|
2004-08-08 02:24:00 +00:00
|
|
|
if (batchname) {
|
|
|
|
free(batchname);
|
|
|
|
}
|
|
|
|
if (hostname) {
|
|
|
|
free(hostname);
|
2004-05-27 16:26:36 +00:00
|
|
|
}
|
2004-08-08 02:24:00 +00:00
|
|
|
if (sessions) {
|
|
|
|
free(sessions);
|
2004-05-27 16:26:36 +00:00
|
|
|
}
|
2004-08-08 02:24:00 +00:00
|
|
|
|
|
|
|
return return_code;
|
2004-05-27 16:26:36 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2004-08-10 16:05:22 +00:00
|
|
|
int
|
|
|
|
ompi_session_dir_finalize()
|
|
|
|
{
|
|
|
|
/* BWB - fix me, fix me, fix me */
|
|
|
|
printf("WARNING: session directory not removed - "
|
|
|
|
"function not implemented\n");
|
|
|
|
return OMPI_SUCCESS;
|
|
|
|
}
|