/* * Copyright (c) 2004-2007 The Trustees of Indiana University and Indiana * University Research and Technology * Corporation. All rights reserved. * Copyright (c) 2004-2005 The University of Tennessee and The University * 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) 2008 Sun Microsystems, Inc. All rights reserved. * $COPYRIGHT$ * * Additional copyrights may follow * * $HEADER$ */ #include "orte_config.h" #include "orte/constants.h" #include #include #ifdef HAVE_UNISTD_H #include #endif #ifdef HAVE_SYS_TYPES_H #include #endif #ifdef HAVE_SYS_STAT_H #include #endif #ifdef HAVE_SYS_PARAM_H #include #endif #ifdef HAVE_UNISTD_H #include #endif #ifdef HAVE_NETDB_H #include #endif #include #include "opal/util/basename.h" #include "opal/util/path.h" #include "opal/util/opal_environ.h" #include "opal/mca/base/mca_base_param.h" #include "orte/mca/errmgr/errmgr.h" #include "orte/util/context_fns.h" int orte_util_check_context_cwd(orte_app_context_t *context, bool want_chdir) { bool good = true; char *tmp; char hostname[MAXHOSTNAMELEN]; struct stat buf; /* Use hostname in a few messages below */ gethostname(hostname, sizeof(hostname)); /* If the directory does not exist, or stat() otherwise fails to get info about it, then set good = false. */ if (!(0 == stat(context->cwd, &buf) && S_ISDIR(buf.st_mode))) { good = false; } /* If the directory does exist, and we want to chdir, and the chdir fails, then set good = false. */ if (good && want_chdir && 0 != chdir(context->cwd)) { good = false; } /* If either of the above failed, go into this block */ if (!good) { /* See if the directory was a user-specified directory. If it was, barf because they specifically asked for something we can't provide. */ if (context->user_specified_cwd) { return ORTE_ERR_WDIR_NOT_FOUND; } /* If the user didn't specifically ask for it, then it was a system-supplied default directory, so it's ok to not go there. Try to go to the $HOME directory instead. */ tmp = getenv("HOME"); if (NULL != tmp) { /* Try $HOME. Same 2 tests as above. */ good = true; if (!(0 == stat(tmp, &buf) && S_ISDIR(buf.st_mode))) { good = false; } if (good && want_chdir && 0 != chdir(tmp)) { good = false; } if (!good) { return ORTE_ERR_WDIR_NOT_FOUND; } /* Reset the pwd in this local copy of the context */ if (NULL != context->cwd) free(context->cwd); context->cwd = strdup(tmp); } /* If we couldn't find $HOME, then just take whatever the default directory is -- assumedly there *is* one, or we wouldn't be running... */ } /* All happy */ return ORTE_SUCCESS; } int orte_util_check_context_app(orte_app_context_t *context, char **env) { char *tmp; /* If the app is a naked filename, we need to do a path search for it. orterun will send in whatever the user specified (e.g., "orterun -np 2 uptime"), so in some cases, we need to search the path to verify that we can find it. Here's the possibilities: 1. The user specified an absolute pathname for the executable. We simply need to verify that it exists and we can run it. 2. The user specified a relative pathname for the executable. Ditto with #1 -- based on the cwd, we need to verify that it exists and we can run it. 3. The user specified a naked filename. We need to search the path, find a match, and verify that we can run it. Note that in some cases, we won't be doing this work here -- bproc, for example, does not use the fork pls for launching, so it does this same work over there. */ tmp = opal_basename(context->argv[0]); if (strlen(tmp) == strlen(context->argv[0])) { /* If this is a naked executable -- no relative or absolute pathname -- then search the PATH for it */ free(tmp); tmp = opal_path_findv(context->argv[0], X_OK, env, context->cwd); if (NULL == tmp) { return ORTE_ERR_EXE_NOT_FOUND; } if (NULL != context->app) free(context->app); context->app = tmp; } else { if (0 != access(context->app, X_OK)) { return ORTE_ERR_EXE_NOT_ACCESSIBLE; } } /* All was good */ return ORTE_SUCCESS; }