After talking through the patch with Jeff, we have a couple more fixes to r21766 that should also go over to v1.3 in Ticket #1987.
* Check for {{{dlfcn.h}}} in the self component's configure.m4 (also clean up the .m4 a bit. * Adjust the priority of the BLCR component so that the self component has a higher priority (if the application went to the trouble of writing the routines, why not use them.) The 'self' component checks for the appropriate functions during query, so it know if it -can- be used during component selection. * Adjust some copyrights that I missed before * Fix a warning when casing the result of dlsym() into a function pointer. There is a bit of pointer magic to make this happen (thanks to the following website, and RedHat EL 4 man pages for illustrating it: http://www.opengroup.org/onlinepubs/009695399/functions/dlsym.html Passing to Jeff for a final review of the patch before moving to v1.3. This commit was SVN r21768. The following SVN revision numbers were found above: r21766 --> open-mpi/ompi@91e52d062b
Этот коммит содержится в:
родитель
41f38110ff
Коммит
063f5b2ff6
@ -65,7 +65,7 @@ opal_crs_blcr_component_t mca_crs_blcr_component = {
|
||||
/* opal_output handler */
|
||||
-1,
|
||||
/* Default priority */
|
||||
50
|
||||
10
|
||||
}
|
||||
};
|
||||
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2004-2008 The Trustees of Indiana University.
|
||||
* Copyright (c) 2004-2009 The Trustees of Indiana University.
|
||||
* All rights reserved.
|
||||
* $COPYRIGHT$
|
||||
*
|
||||
|
@ -1,6 +1,6 @@
|
||||
# -*- shell-script -*-
|
||||
#
|
||||
# Copyright (c) 2004-2007 The Trustees of Indiana University.
|
||||
# Copyright (c) 2004-2009 The Trustees of Indiana University.
|
||||
# All rights reserved.
|
||||
# Copyright (c) 2004-2005 The Trustees of the University of Tennessee.
|
||||
# All rights reserved.
|
||||
@ -21,10 +21,26 @@ AC_DEFUN([MCA_crs_self_CONFIG],[
|
||||
# If we don't want FT, don't compile this component
|
||||
AS_IF([test "$ompi_want_ft" = "1"],
|
||||
[crs_self_good="yes"],
|
||||
[$2])
|
||||
[crs_self_good="no"])
|
||||
|
||||
# We need to be able to dlopen the executable for this component to work.
|
||||
AS_IF([test "$OPAL_ENABLE_DLOPEN_SUPPORT" = "1" -a "$crs_self_good" = "yes"],
|
||||
# We need the dlfcn.h so we can access dlsym and friends
|
||||
AS_IF([test "$crs_self_good" = "yes"],
|
||||
[AC_CHECK_HEADER([dlfcn.h],
|
||||
[crs_self_good="yes"],
|
||||
[crs_self_good="no"])],
|
||||
[crs_self_good="no"])
|
||||
|
||||
# If they did not ask for dlopen support,
|
||||
# they probably do not want this component either
|
||||
AS_IF([test "$crs_self_good" = "yes"],
|
||||
[AS_IF([test "$OPAL_ENABLE_DLOPEN_SUPPORT" = "1"],
|
||||
[crs_self_good="yes"],
|
||||
[crs_self_good="no"])],
|
||||
[crs_self_good="no"])
|
||||
|
||||
AS_IF([test "$crs_self_good" = "yes"],
|
||||
[$1],
|
||||
[$2])
|
||||
|
||||
|
||||
])dnl
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2004-2008 The Trustees of Indiana University.
|
||||
* Copyright (c) 2004-2009 The Trustees of Indiana University.
|
||||
* All rights reserved.
|
||||
* Copyright (c) 2004-2005 The Trustees of the University of Tennessee.
|
||||
* All rights reserved.
|
||||
|
@ -1,5 +1,5 @@
|
||||
/*
|
||||
* Copyright (c) 2004-2008 The Trustees of Indiana University.
|
||||
* Copyright (c) 2004-2009 The Trustees of Indiana University.
|
||||
* All rights reserved.
|
||||
* Copyright (c) 2004-2005 The Trustees of the University of Tennessee.
|
||||
* All rights reserved.
|
||||
@ -95,10 +95,13 @@ OBJ_CLASS_INSTANCE(opal_crs_self_snapshot_t,
|
||||
opal_crs_self_destruct);
|
||||
|
||||
|
||||
typedef void (*opal_crs_self_dlsym_dummy_fn_t)(void);
|
||||
|
||||
/************************************
|
||||
* Locally Global vars & functions :)
|
||||
************************************/
|
||||
static void * crs_self_find_function(void * handle, char *prefix, char *suffix);
|
||||
static int crs_self_find_function(char *prefix, char *suffix,
|
||||
opal_crs_self_dlsym_dummy_fn_t *fn_ptr);
|
||||
|
||||
static int self_update_snapshot_metadata(opal_crs_self_snapshot_t *snapshot);
|
||||
|
||||
@ -163,40 +166,25 @@ int opal_crs_self_component_query(mca_base_module_t **module, int *priority)
|
||||
static int opal_crs_self_extract_callbacks(void)
|
||||
{
|
||||
bool callback_matched = true;
|
||||
void * executable = NULL;
|
||||
|
||||
/*
|
||||
* Open the executable so that we can lookup the necessary symbols
|
||||
*/
|
||||
executable = dlopen(NULL, RTLD_LOCAL|RTLD_LAZY);
|
||||
if ( NULL == executable) {
|
||||
opal_show_help("help-opal-crs-self.txt", "self:lt_dlopen",
|
||||
true);
|
||||
return OPAL_ERROR;
|
||||
}
|
||||
opal_crs_self_dlsym_dummy_fn_t loc_fn;
|
||||
|
||||
/*
|
||||
* Find the function names
|
||||
*/
|
||||
mca_crs_self_component.ucb_checkpoint_fn = (opal_crs_self_checkpoint_callback_fn_t)
|
||||
crs_self_find_function(executable,
|
||||
mca_crs_self_component.prefix,
|
||||
SUFFIX_CHECKPOINT);
|
||||
crs_self_find_function(mca_crs_self_component.prefix,
|
||||
SUFFIX_CHECKPOINT,
|
||||
&loc_fn);
|
||||
mca_crs_self_component.ucb_checkpoint_fn = (opal_crs_self_checkpoint_callback_fn_t)loc_fn;
|
||||
|
||||
mca_crs_self_component.ucb_continue_fn = (opal_crs_self_continue_callback_fn_t)
|
||||
crs_self_find_function(executable,
|
||||
mca_crs_self_component.prefix,
|
||||
SUFFIX_CONTINUE);
|
||||
crs_self_find_function(mca_crs_self_component.prefix,
|
||||
SUFFIX_CONTINUE,
|
||||
&loc_fn);
|
||||
mca_crs_self_component.ucb_continue_fn = (opal_crs_self_continue_callback_fn_t)loc_fn;
|
||||
|
||||
mca_crs_self_component.ucb_restart_fn = (opal_crs_self_restart_callback_fn_t)
|
||||
crs_self_find_function(executable,
|
||||
mca_crs_self_component.prefix,
|
||||
SUFFIX_RESTART);
|
||||
|
||||
/*
|
||||
* Done with executable, close it
|
||||
*/
|
||||
dlclose(executable);
|
||||
crs_self_find_function(mca_crs_self_component.prefix,
|
||||
SUFFIX_RESTART,
|
||||
&loc_fn);
|
||||
mca_crs_self_component.ucb_restart_fn = (opal_crs_self_restart_callback_fn_t)loc_fn;
|
||||
|
||||
/*
|
||||
* Sanity check
|
||||
@ -557,19 +545,21 @@ int opal_crs_self_reg_thread(void)
|
||||
/******************
|
||||
* Local functions
|
||||
******************/
|
||||
static void * crs_self_find_function(void * handle, char *prefix, char *suffix){
|
||||
static int crs_self_find_function(char *prefix, char *suffix,
|
||||
opal_crs_self_dlsym_dummy_fn_t *fn_ptr) {
|
||||
char *func_to_find = NULL;
|
||||
void * ptr = NULL;
|
||||
|
||||
if( NULL == prefix || 0 >= strlen(prefix) ) {
|
||||
opal_output(mca_crs_self_component.super.output_handle,
|
||||
"crs:self: crs_self_find_function: Error: prefix is NULL or empty string!");
|
||||
return NULL;
|
||||
*fn_ptr = NULL;
|
||||
return OPAL_ERROR;
|
||||
}
|
||||
if( NULL == suffix || 0 >= strlen(suffix) ) {
|
||||
opal_output(mca_crs_self_component.super.output_handle,
|
||||
"crs:self: crs_self_find_function: Error: suffix is NULL or empty string!");
|
||||
return NULL;
|
||||
*fn_ptr = NULL;
|
||||
return OPAL_ERROR;
|
||||
}
|
||||
|
||||
opal_output_verbose(10, mca_crs_self_component.super.output_handle,
|
||||
@ -578,8 +568,13 @@ static void * crs_self_find_function(void * handle, char *prefix, char *suffix){
|
||||
|
||||
asprintf(&func_to_find, "%s_%s", prefix, suffix);
|
||||
|
||||
ptr = dlsym(handle, func_to_find);
|
||||
if( NULL == ptr) {
|
||||
/* The RTLD_DEFAULT is a special handle that searches the default libraries
|
||||
* including the current application for the indicated symbol. This allows
|
||||
* us to not have to dlopen/dlclose the executable. A bit of short hand
|
||||
* really.
|
||||
*/
|
||||
*((void**) fn_ptr) = dlsym(RTLD_DEFAULT, func_to_find);
|
||||
if( NULL == fn_ptr) {
|
||||
opal_output_verbose(12, mca_crs_self_component.super.output_handle,
|
||||
"crs:self: crs_self_find_function: WARNING: Function \"%s\" not found",
|
||||
func_to_find);
|
||||
@ -590,10 +585,11 @@ static void * crs_self_find_function(void * handle, char *prefix, char *suffix){
|
||||
func_to_find);
|
||||
}
|
||||
|
||||
if( NULL == func_to_find)
|
||||
if( NULL == func_to_find) {
|
||||
free(func_to_find);
|
||||
}
|
||||
|
||||
return ptr;
|
||||
return OPAL_SUCCESS;
|
||||
}
|
||||
|
||||
/*
|
||||
|
@ -1,6 +1,6 @@
|
||||
-*- text -*-
|
||||
#
|
||||
# Copyright (c) 2004-2007 The Trustees of Indiana University and Indiana
|
||||
# Copyright (c) 2004-2009 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
|
||||
|
Загрузка…
x
Ссылка в новой задаче
Block a user