1
1

Thanks Ma for the patch. Correct the multi-rail support and

rename some fields to something more clear.

This commit was SVN r17824.
Этот коммит содержится в:
George Bosilca 2008-03-14 19:17:28 +00:00
родитель 372f9e64c4
Коммит 5e229fe688
3 изменённых файлов: 16 добавлений и 14 удалений

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

@ -54,7 +54,7 @@ static int mca_btl_elan_add_procs( struct mca_btl_base_module_t* btl,
ompi_bitmap_t* reachable )
{
mca_btl_elan_module_t* elan_btl = (mca_btl_elan_module_t*)btl;
int i, rc;
int i, j, rc;
char* filename;
FILE* file;
ELAN_BASE* base;
@ -90,7 +90,10 @@ static int mca_btl_elan_add_procs( struct mca_btl_base_module_t* btl,
OBJ_RELEASE(elan_proc);
continue;
}
fprintf( file, "%s %d\n", ompi_proc->proc_hostname, elan_proc->elan_vp_array[0] );
for( j = 0; j < (int)elan_proc->proc_rail_count; j++ ) {
fprintf( file, "%s %d\n", ompi_proc->proc_hostname,
elan_proc->position_id_array[j] );
}
ompi_bitmap_set_bit(reachable, i);
peers[i] = elan_endpoint;
}

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

@ -28,7 +28,7 @@ OBJ_CLASS_INSTANCE(mca_btl_elan_proc_t,
void mca_btl_elan_proc_construct(mca_btl_elan_proc_t* proc)
{
proc->proc_ompi = 0;
proc->proc_addr_count = 0;
proc->proc_rail_count = 0;
proc->proc_endpoints = 0;
proc->proc_endpoint_count = 0;
OBJ_CONSTRUCT(&proc->proc_lock, opal_mutex_t);
@ -111,14 +111,14 @@ mca_btl_elan_proc_t* mca_btl_elan_proc_create(ompi_proc_t* ompi_proc)
module_proc->proc_guid = ompi_proc->proc_name;
rc = ompi_modex_recv( &mca_btl_elan_component.super.btl_version,
ompi_proc,
(void**)&module_proc->elan_vp_array,
(void**)&module_proc->position_id_array,
&size );
if(rc != OMPI_SUCCESS) {
BTL_ERROR(("mca_base_modex_recv: failed with return value=%d", rc));
OBJ_RELEASE(module_proc);
return NULL;
}
module_proc->proc_addr_count = size / sizeof(unsigned int);;
module_proc->proc_rail_count = size / sizeof(unsigned int);;
/* XXX: Right now, there can be only 1 peer associated
* with a proc. Needs a little bit change in
* mca_btl_elan_proc_t to allow on demand increasing of
@ -126,7 +126,7 @@ mca_btl_elan_proc_t* mca_btl_elan_proc_create(ompi_proc_t* ompi_proc)
*/
module_proc->proc_endpoints = (mca_btl_base_endpoint_t**)
malloc((1+module_proc->proc_addr_count )* sizeof(mca_btl_base_endpoint_t*));
malloc((1+module_proc->proc_rail_count )* sizeof(mca_btl_base_endpoint_t*));
if(NULL == module_proc->proc_endpoints) {
OBJ_RELEASE(module_proc);
return NULL;
@ -144,12 +144,11 @@ int mca_btl_elan_proc_insert( mca_btl_elan_proc_t* module_proc,
mca_btl_base_endpoint_t* module_endpoint )
{
/* insert into endpoint array */
size_t i;
module_endpoint->endpoint_proc = module_proc;
module_proc->proc_endpoints[module_proc->proc_endpoint_count++] = module_endpoint;
for( i = 0; i < module_proc->proc_addr_count; i++ ) {
module_endpoint->elan_vp = module_proc->elan_vp_array[i];
return OMPI_SUCCESS;
}
module_endpoint->endpoint_proc = module_proc;
module_endpoint->elan_vp = module_proc->proc_ompi->proc_name.vpid;
return OMPI_SUCCESS;
}

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

@ -35,9 +35,9 @@ struct mca_btl_elan_proc_t {
orte_process_name_t proc_guid;
/**< globally unique identifier for the process */
unsigned int *elan_vp_array;
unsigned int *position_id_array;
size_t proc_addr_count;
size_t proc_rail_count;
/**< number of addresses published by endpoint */
struct mca_btl_base_endpoint_t **proc_endpoints;