1
1

Complete integration of job_control

Signed-off-by: Ralph Castain <rhc@open-mpi.org>
Этот коммит содержится в:
Ralph Castain 2018-08-20 16:10:50 -07:00
родитель 9948084130
Коммит 5cfa2a7fca
6 изменённых файлов: 18 добавлений и 36 удалений

Просмотреть файл

@ -98,7 +98,8 @@ enum {
OPAL_ERR_HEARTBEAT_ALERT = (OPAL_ERR_BASE - 67), OPAL_ERR_HEARTBEAT_ALERT = (OPAL_ERR_BASE - 67),
OPAL_ERR_FILE_ALERT = (OPAL_ERR_BASE - 68), OPAL_ERR_FILE_ALERT = (OPAL_ERR_BASE - 68),
OPAL_ERR_MODEL_DECLARED = (OPAL_ERR_BASE - 69), OPAL_ERR_MODEL_DECLARED = (OPAL_ERR_BASE - 69),
OPAL_PMIX_LAUNCH_DIRECTIVE = (OPAL_ERR_BASE - 70) OPAL_PMIX_LAUNCH_DIRECTIVE = (OPAL_ERR_BASE - 70),
OPAL_OPERATION_SUCCEEDED = (OPAL_ERR_BASE - 71)
}; };
#define OPAL_ERR_MAX (OPAL_ERR_BASE - 100) #define OPAL_ERR_MAX (OPAL_ERR_BASE - 100)

Просмотреть файл

@ -185,6 +185,7 @@ pmix_status_t pmix1_convert_opalrc(int rc)
case OPAL_ERROR: case OPAL_ERROR:
return PMIX_ERROR; return PMIX_ERROR;
case OPAL_SUCCESS: case OPAL_SUCCESS:
case OPAL_OPERATION_SUCCEEDED:
return PMIX_SUCCESS; return PMIX_SUCCESS;
default: default:
return PMIX_ERROR; return PMIX_ERROR;

Просмотреть файл

@ -440,6 +440,7 @@ pmix_status_t ext2x_convert_opalrc(int rc)
case OPAL_ERROR: case OPAL_ERROR:
return PMIX_ERROR; return PMIX_ERROR;
case OPAL_SUCCESS: case OPAL_SUCCESS:
case OPAL_OPERATION_SUCCEEDED:
return PMIX_SUCCESS; return PMIX_SUCCESS;
default: default:
return rc; return rc;

Просмотреть файл

@ -364,37 +364,13 @@ void pmix3x_event_hdlr(size_t evhdlr_registration_id,
return; return;
} }
static void cleanup_cbfunc(pmix_status_t status,
pmix_info_t *info, size_t ninfo,
void *cbdata,
pmix_release_cbfunc_t release_fn,
void *release_cbdata)
{
opal_pmix_lock_t *lk = (opal_pmix_lock_t*)cbdata;
OPAL_POST_OBJECT(lk);
/* let the library release the data and cleanup from
* the operation */
if (NULL != release_fn) {
release_fn(release_cbdata);
}
/* release the block */
lk->status = pmix3x_convert_rc(status);
OPAL_PMIX_WAKEUP_THREAD(lk);
}
static int pmix3x_register_cleanup(char *path, bool directory, bool ignore, bool jobscope) static int pmix3x_register_cleanup(char *path, bool directory, bool ignore, bool jobscope)
{ {
opal_pmix_lock_t lk;
pmix_info_t pinfo[3]; pmix_info_t pinfo[3];
size_t n, ninfo=0; size_t n, ninfo=0;
pmix_status_t rc; pmix_status_t rc;
int ret; int ret;
OPAL_PMIX_CONSTRUCT_LOCK(&lk);
if (ignore) { if (ignore) {
/* they want this path ignored */ /* they want this path ignored */
PMIX_INFO_LOAD(&pinfo[ninfo], PMIX_CLEANUP_IGNORE, path, PMIX_STRING); PMIX_INFO_LOAD(&pinfo[ninfo], PMIX_CLEANUP_IGNORE, path, PMIX_STRING);
@ -415,18 +391,12 @@ static int pmix3x_register_cleanup(char *path, bool directory, bool ignore, bool
/* if they want this applied to the job, then indicate so */ /* if they want this applied to the job, then indicate so */
if (jobscope) { if (jobscope) {
rc = PMIx_Job_control_nb(NULL, 0, pinfo, ninfo, cleanup_cbfunc, (void*)&lk); rc = PMIx_Job_control_nb(NULL, 0, pinfo, ninfo, NULL, NULL);
} else { } else {
/* only applies to us */ /* only applies to us */
rc = PMIx_Job_control_nb(&mca_pmix_pmix3x_component.myproc, 1, pinfo, ninfo, cleanup_cbfunc, (void*)&lk); rc = PMIx_Job_control_nb(&mca_pmix_pmix3x_component.myproc, 1, pinfo, ninfo, NULL, NULL);
} }
if (PMIX_SUCCESS != rc) { ret = pmix3x_convert_rc(rc);
ret = pmix3x_convert_rc(rc);
} else {
OPAL_PMIX_WAIT_THREAD(&lk);
ret = lk.status;
}
OPAL_PMIX_DESTRUCT_LOCK(&lk);
for (n=0; n < ninfo; n++) { for (n=0; n < ninfo; n++) {
PMIX_INFO_DESTRUCT(&pinfo[n]); PMIX_INFO_DESTRUCT(&pinfo[n]);
} }
@ -536,6 +506,10 @@ pmix_status_t pmix3x_convert_opalrc(int rc)
return PMIX_ERROR; return PMIX_ERROR;
case OPAL_SUCCESS: case OPAL_SUCCESS:
return PMIX_SUCCESS; return PMIX_SUCCESS;
case OPAL_OPERATION_SUCCEEDED:
return PMIX_OPERATION_SUCCEEDED;
default: default:
return rc; return rc;
} }
@ -629,6 +603,10 @@ int pmix3x_convert_rc(pmix_status_t rc)
return OPAL_ERROR; return OPAL_ERROR;
case PMIX_SUCCESS: case PMIX_SUCCESS:
return OPAL_SUCCESS; return OPAL_SUCCESS;
case PMIX_OPERATION_SUCCEEDED:
return OPAL_OPERATION_SUCCEEDED;
default: default:
return rc; return rc;
} }

Просмотреть файл

@ -11,7 +11,7 @@
* All rights reserved. * All rights reserved.
* Copyright (c) 2014 Research Organization for Information Science * Copyright (c) 2014 Research Organization for Information Science
* and Technology (RIST). All rights reserved. * and Technology (RIST). All rights reserved.
* Copyright (c) 2015-2017 Intel, Inc. All rights reserved. * Copyright (c) 2015-2018 Intel, Inc. All rights reserved.
* $COPYRIGHT$ * $COPYRIGHT$
* *
* Additional copyrights may follow * Additional copyrights may follow
@ -93,6 +93,7 @@ enum {
ORTE_ERR_PROC_ABORTING = OPAL_ERR_PROC_ABORTING, ORTE_ERR_PROC_ABORTING = OPAL_ERR_PROC_ABORTING,
ORTE_ERR_NODE_DOWN = OPAL_ERR_NODE_DOWN, ORTE_ERR_NODE_DOWN = OPAL_ERR_NODE_DOWN,
ORTE_ERR_NODE_OFFLINE = OPAL_ERR_NODE_OFFLINE, ORTE_ERR_NODE_OFFLINE = OPAL_ERR_NODE_OFFLINE,
ORTE_OPERATION_SUCCEEDED = OPAL_OPERATION_SUCCEEDED,
/* error codes specific to ORTE - don't forget to update /* error codes specific to ORTE - don't forget to update
orte/util/error_strings.c when adding new error codes!! orte/util/error_strings.c when adding new error codes!!

Просмотреть файл

@ -1186,5 +1186,5 @@ int pmix_server_job_ctrl_fn(const opal_process_name_t *requestor,
} }
} }
return ORTE_SUCCESS; return ORTE_OPERATION_SUCCEEDED;
} }