2005-06-30 21:28:35 +00:00
|
|
|
/*
|
2005-11-05 19:57:48 +00:00
|
|
|
* Copyright (c) 2004-2005 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.
|
2005-06-30 21:28:35 +00:00
|
|
|
* 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.
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
* Copyright (c) 2006 Cisco Systems, Inc. All rights reserved.
|
2007-02-15 18:03:20 +00:00
|
|
|
* Copyright (c) 2006-2007 Mellanox Technologies. All rights reserved.
|
2005-06-30 21:28:35 +00:00
|
|
|
* $COPYRIGHT$
|
|
|
|
*
|
|
|
|
* Additional copyrights may follow
|
|
|
|
*
|
|
|
|
* $HEADER$
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
#include "ompi_config.h"
|
2006-02-12 01:33:29 +00:00
|
|
|
#include "ompi/constants.h"
|
2005-07-03 23:09:55 +00:00
|
|
|
#include "opal/event/event.h"
|
2006-12-19 08:34:48 +00:00
|
|
|
#include "opal/include/opal/align.h"
|
2005-07-04 01:36:20 +00:00
|
|
|
#include "opal/util/if.h"
|
2005-07-04 00:13:44 +00:00
|
|
|
#include "opal/util/argv.h"
|
2005-07-03 23:31:27 +00:00
|
|
|
#include "opal/util/output.h"
|
2006-06-05 21:23:45 +00:00
|
|
|
#include "opal/util/show_help.h"
|
2006-06-05 20:02:41 +00:00
|
|
|
#include "ompi/proc/proc.h"
|
2006-02-12 01:33:29 +00:00
|
|
|
#include "ompi/mca/pml/pml.h"
|
|
|
|
#include "ompi/mca/btl/btl.h"
|
|
|
|
#include "opal/sys/timer.h"
|
2006-09-19 13:27:05 +00:00
|
|
|
#include "opal/sys/atomic.h"
|
2005-06-30 21:28:35 +00:00
|
|
|
|
2006-02-12 01:33:29 +00:00
|
|
|
#include "opal/mca/base/mca_base_param.h"
|
|
|
|
#include "orte/mca/errmgr/errmgr.h"
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
#include "orte/util/sys_info.h"
|
2006-02-12 01:33:29 +00:00
|
|
|
#include "ompi/mca/mpool/base/base.h"
|
2006-12-17 12:26:41 +00:00
|
|
|
#include "ompi/mca/mpool/rdma/mpool_rdma.h"
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
#include "ompi/mca/btl/base/base.h"
|
2005-06-30 21:28:35 +00:00
|
|
|
#include "btl_openib.h"
|
|
|
|
#include "btl_openib_frag.h"
|
|
|
|
#include "btl_openib_endpoint.h"
|
2006-03-26 08:30:50 +00:00
|
|
|
#include "btl_openib_eager_rdma.h"
|
2006-06-05 20:02:41 +00:00
|
|
|
#include "btl_openib_proc.h"
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
#include "btl_openib_ini.h"
|
|
|
|
#include "btl_openib_mca.h"
|
2005-07-12 13:38:54 +00:00
|
|
|
|
2006-02-12 01:33:29 +00:00
|
|
|
#include "ompi/datatype/convertor.h"
|
|
|
|
#include "ompi/mca/mpool/mpool.h"
|
2005-07-12 13:38:54 +00:00
|
|
|
#include <sysfs/libsysfs.h>
|
|
|
|
#include <infiniband/verbs.h>
|
2005-07-15 15:13:19 +00:00
|
|
|
#include <errno.h>
|
|
|
|
#include <string.h> /* for strerror()*/
|
2005-07-12 13:38:54 +00:00
|
|
|
|
2006-02-12 01:33:29 +00:00
|
|
|
#include "ompi/mca/pml/base/pml_base_module_exchange.h"
|
2005-09-30 22:58:09 +00:00
|
|
|
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
/*
|
|
|
|
* Local functions
|
|
|
|
*/
|
|
|
|
static int btl_openib_component_open(void);
|
|
|
|
static int btl_openib_component_close(void);
|
|
|
|
static int btl_openib_modex_send(void);
|
|
|
|
static void btl_openib_control(struct mca_btl_base_module_t* btl,
|
|
|
|
mca_btl_base_tag_t tag,
|
|
|
|
mca_btl_base_descriptor_t* descriptor,
|
|
|
|
void* cbdata);
|
|
|
|
static int init_one_port(opal_list_t *btl_list, mca_btl_openib_hca_t *hca,
|
|
|
|
uint8_t port_num, struct ibv_port_attr *ib_port_attr);
|
|
|
|
static int init_one_hca(opal_list_t *btl_list, struct ibv_device* ib_dev);
|
|
|
|
static mca_btl_base_module_t **btl_openib_component_init(
|
|
|
|
int *num_btl_modules, bool enable_progress_threads,
|
|
|
|
bool enable_mpi_threads);
|
2006-08-30 20:21:47 +00:00
|
|
|
static void merge_values(ompi_btl_openib_ini_values_t *target,
|
|
|
|
ompi_btl_openib_ini_values_t *src);
|
2006-09-12 09:17:59 +00:00
|
|
|
static int btl_openib_handle_incoming(mca_btl_openib_module_t *openib_btl,
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
mca_btl_openib_endpoint_t *endpoint,
|
|
|
|
mca_btl_openib_frag_t *frag,
|
2006-09-12 09:17:59 +00:00
|
|
|
size_t byte_len, const int prio);
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
static char* btl_openib_component_status_to_string(enum ibv_wc_status status);
|
|
|
|
static int btl_openib_component_progress(void);
|
2006-11-02 16:15:21 +00:00
|
|
|
static int btl_openib_module_progress(mca_btl_openib_module_t *openib_btl);
|
2006-09-05 16:00:18 +00:00
|
|
|
static void btl_openib_frag_progress_pending(
|
|
|
|
mca_btl_openib_module_t* openib_btl, mca_btl_base_endpoint_t *endpoint,
|
2006-09-28 11:41:45 +00:00
|
|
|
const int prio);
|
2006-12-17 12:26:41 +00:00
|
|
|
static int openib_reg_mr(void *reg_data, void *base, size_t size,
|
|
|
|
mca_mpool_base_registration_t *reg);
|
|
|
|
static int openib_dereg_mr(void *reg_data, mca_mpool_base_registration_t *reg);
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
|
|
|
|
|
2005-06-30 21:28:35 +00:00
|
|
|
mca_btl_openib_component_t mca_btl_openib_component = {
|
|
|
|
{
|
|
|
|
/* First, the mca_base_component_t struct containing meta information
|
|
|
|
about the component itself */
|
|
|
|
|
|
|
|
{
|
|
|
|
/* Indicate that we are a pml v1.0.0 component (which also implies a
|
|
|
|
specific MCA version) */
|
|
|
|
|
2006-08-17 22:02:01 +00:00
|
|
|
MCA_BTL_BASE_VERSION_1_0_1,
|
2005-06-30 21:28:35 +00:00
|
|
|
|
2005-07-12 19:02:39 +00:00
|
|
|
"openib", /* MCA component name */
|
Major simplifications to component versioning:
- After long discussions and ruminations on how we run components in
LAM/MPI, made the decision that, by default, all components included
in Open MPI will use the version number of their parent project
(i.e., OMPI or ORTE). They are certaint free to use a different
number, but this simplification makes the common cases easy:
- components are only released when the parent project is released
- it is easy (trivial?) to distinguish which version component goes
with with version of the parent project
- removed all autogen/configure code for templating the version .h
file in components
- made all ORTE components use ORTE_*_VERSION for version numbers
- made all OMPI components use OMPI_*_VERSION for version numbers
- removed all VERSION files from components
- configure now displays OPAL, ORTE, and OMPI version numbers
- ditto for ompi_info
- right now, faking it -- OPAL and ORTE and OMPI will always have the
same version number (i.e., they all come from the same top-level
VERSION file). But this paves the way for the Great Configure
Reorganization, where, among other things, each project will have
its own version number.
So all in all, we went from a boatload of version numbers to
[effectively] three. That's pretty good. :-)
This commit was SVN r6344.
2005-07-04 20:12:36 +00:00
|
|
|
OMPI_MAJOR_VERSION, /* MCA component major version */
|
|
|
|
OMPI_MINOR_VERSION, /* MCA component minor version */
|
|
|
|
OMPI_RELEASE_VERSION, /* MCA component release version */
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
btl_openib_component_open, /* component open */
|
|
|
|
btl_openib_component_close /* component close */
|
2005-06-30 21:28:35 +00:00
|
|
|
},
|
|
|
|
|
|
|
|
/* Next the MCA v1.0.0 component meta data */
|
|
|
|
|
|
|
|
{
|
|
|
|
/* Whether the component is checkpointable or not */
|
|
|
|
|
|
|
|
false
|
|
|
|
},
|
|
|
|
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
btl_openib_component_init,
|
|
|
|
btl_openib_component_progress,
|
2005-06-30 21:28:35 +00:00
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Called by MCA framework to open the component, registers
|
|
|
|
* component parameters.
|
|
|
|
*/
|
|
|
|
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
int btl_openib_component_open(void)
|
2005-06-30 21:28:35 +00:00
|
|
|
{
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
int ret;
|
2006-06-09 18:02:45 +00:00
|
|
|
|
2005-06-30 21:28:35 +00:00
|
|
|
/* initialize state */
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
mca_btl_openib_component.ib_num_btls = 0;
|
|
|
|
mca_btl_openib_component.openib_btls = NULL;
|
2005-06-30 21:28:35 +00:00
|
|
|
|
|
|
|
/* initialize objects */
|
2005-07-03 16:22:16 +00:00
|
|
|
OBJ_CONSTRUCT(&mca_btl_openib_component.ib_procs, opal_list_t);
|
2005-06-30 21:28:35 +00:00
|
|
|
|
|
|
|
/* register IB component parameters */
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
ret = btl_openib_register_mca_params();
|
|
|
|
|
|
|
|
mca_btl_openib_component.max_send_size =
|
|
|
|
mca_btl_openib_module.super.btl_max_send_size;
|
|
|
|
mca_btl_openib_component.eager_limit =
|
|
|
|
mca_btl_openib_module.super.btl_eager_limit;
|
|
|
|
|
|
|
|
return ret;
|
2005-06-30 21:28:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* component cleanup - sanity checking of queue lengths
|
|
|
|
*/
|
|
|
|
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
static int btl_openib_component_close(void)
|
2005-06-30 21:28:35 +00:00
|
|
|
{
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
ompi_btl_openib_ini_finalize();
|
2005-06-30 21:28:35 +00:00
|
|
|
return OMPI_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2005-09-30 22:58:09 +00:00
|
|
|
|
|
|
|
/*
|
2005-10-02 18:58:57 +00:00
|
|
|
* Register OPENIB port information. The MCA framework
|
2005-09-30 22:58:09 +00:00
|
|
|
* will make this available to all peers.
|
|
|
|
*/
|
|
|
|
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
static int btl_openib_modex_send(void)
|
2005-09-30 22:58:09 +00:00
|
|
|
{
|
2006-06-01 02:32:18 +00:00
|
|
|
int rc, i;
|
2005-09-30 22:58:09 +00:00
|
|
|
size_t size;
|
|
|
|
mca_btl_openib_port_info_t *ports = NULL;
|
|
|
|
|
|
|
|
size = mca_btl_openib_component.ib_num_btls * sizeof (mca_btl_openib_port_info_t);
|
|
|
|
if (size != 0) {
|
|
|
|
ports = (mca_btl_openib_port_info_t *)malloc (size);
|
|
|
|
if (NULL == ports) {
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
BTL_ERROR(("Failed malloc: %s:%d\n", __FILE__, __LINE__));
|
2005-09-30 22:58:09 +00:00
|
|
|
return OMPI_ERR_OUT_OF_RESOURCE;
|
|
|
|
}
|
|
|
|
|
|
|
|
for (i = 0; i < mca_btl_openib_component.ib_num_btls; i++) {
|
|
|
|
mca_btl_openib_module_t *btl = &mca_btl_openib_component.openib_btls[i];
|
|
|
|
ports[i] = btl->port_info;
|
2007-01-12 23:14:45 +00:00
|
|
|
#if !defined(WORDS_BIGENDIAN) && OMPI_ENABLE_HETEROGENEOUS_SUPPORT
|
|
|
|
MCA_BTL_OPENIB_PORT_INFO_HTON(ports[i]);
|
|
|
|
#endif
|
2005-09-30 22:58:09 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
rc = mca_pml_base_modex_send (&mca_btl_openib_component.super.btl_version, ports, size);
|
|
|
|
if (NULL != ports) {
|
|
|
|
free (ports);
|
|
|
|
}
|
|
|
|
return rc;
|
|
|
|
}
|
|
|
|
|
2005-11-10 20:15:02 +00:00
|
|
|
/*
|
|
|
|
* Callback function on control message.
|
|
|
|
*/
|
|
|
|
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
static void btl_openib_control(struct mca_btl_base_module_t* btl,
|
|
|
|
mca_btl_base_tag_t tag,
|
|
|
|
mca_btl_base_descriptor_t* descriptor,
|
|
|
|
void* cbdata)
|
2005-11-10 20:15:02 +00:00
|
|
|
{
|
|
|
|
/* dont return credits used for control messages */
|
|
|
|
mca_btl_openib_frag_t* frag = (mca_btl_openib_frag_t*)descriptor;
|
|
|
|
mca_btl_openib_endpoint_t* endpoint = frag->endpoint;
|
2007-01-04 22:07:37 +00:00
|
|
|
mca_btl_openib_control_header_t *ctl_hdr = frag->segment.seg_addr.pval;
|
2006-03-26 08:30:50 +00:00
|
|
|
mca_btl_openib_eager_rdma_header_t *rdma_hdr;
|
2006-09-05 16:02:09 +00:00
|
|
|
mca_btl_openib_rdma_credits_header_t *credits_hdr;
|
2006-03-26 08:30:50 +00:00
|
|
|
|
2007-01-12 23:14:45 +00:00
|
|
|
|
2005-11-10 20:15:02 +00:00
|
|
|
if(frag->size == mca_btl_openib_component.eager_limit) {
|
2006-03-26 08:30:50 +00:00
|
|
|
/* if not sent via rdma */
|
|
|
|
if(!MCA_BTL_OPENIB_RDMA_FRAG(frag) &&
|
2006-09-05 16:02:09 +00:00
|
|
|
ctl_hdr->type == MCA_BTL_OPENIB_CONTROL_CREDITS) {
|
2006-09-07 13:05:41 +00:00
|
|
|
OPAL_THREAD_ADD32(&endpoint->rd_credits[BTL_OPENIB_HP_QP], -1);
|
2006-03-26 08:30:50 +00:00
|
|
|
}
|
2005-11-10 20:15:02 +00:00
|
|
|
} else {
|
2006-09-07 13:05:41 +00:00
|
|
|
OPAL_THREAD_ADD32(&endpoint->rd_credits[BTL_OPENIB_LP_QP], -1);
|
2005-11-10 20:15:02 +00:00
|
|
|
}
|
2007-01-12 23:14:45 +00:00
|
|
|
|
2006-03-26 08:30:50 +00:00
|
|
|
switch (ctl_hdr->type) {
|
2006-09-05 16:02:09 +00:00
|
|
|
case MCA_BTL_OPENIB_CONTROL_CREDITS:
|
|
|
|
credits_hdr = (mca_btl_openib_rdma_credits_header_t*)ctl_hdr;
|
2007-01-12 23:14:45 +00:00
|
|
|
if(endpoint->nbo) {
|
|
|
|
BTL_OPENIB_RDMA_CREDITS_HEADER_NTOH((*credits_hdr));
|
|
|
|
}
|
2006-09-05 16:02:09 +00:00
|
|
|
if(credits_hdr->rdma_credits)
|
|
|
|
OPAL_THREAD_ADD32(&endpoint->eager_rdma_remote.tokens,
|
|
|
|
credits_hdr->rdma_credits);
|
2007-01-12 23:14:45 +00:00
|
|
|
break;
|
2006-03-26 08:30:50 +00:00
|
|
|
case MCA_BTL_OPENIB_CONTROL_RDMA:
|
|
|
|
rdma_hdr = (mca_btl_openib_eager_rdma_header_t*)ctl_hdr;
|
2007-01-12 23:14:45 +00:00
|
|
|
|
2007-03-05 14:17:50 +00:00
|
|
|
BTL_VERBOSE(("prior to NTOH received rkey %lu, rdma_start.lval %llu, pval %p, ival %u\n",
|
2007-01-12 23:14:45 +00:00
|
|
|
rdma_hdr->rkey,
|
|
|
|
(unsigned long) rdma_hdr->rdma_start.lval,
|
|
|
|
rdma_hdr->rdma_start.pval,
|
2007-03-05 14:17:50 +00:00
|
|
|
rdma_hdr->rdma_start.ival
|
2007-01-12 23:14:45 +00:00
|
|
|
));
|
|
|
|
|
|
|
|
if(endpoint->nbo) {
|
|
|
|
BTL_OPENIB_EAGER_RDMA_CONTROL_HEADER_NTOH((*rdma_hdr));
|
|
|
|
|
2007-03-05 14:17:50 +00:00
|
|
|
BTL_VERBOSE(("received rkey %lu, rdma_start.lval %llu, pval %p, ival %u\n",
|
2007-01-12 23:14:45 +00:00
|
|
|
rdma_hdr->rkey,
|
|
|
|
(unsigned long) rdma_hdr->rdma_start.lval,
|
|
|
|
rdma_hdr->rdma_start.pval,
|
2007-03-05 14:17:50 +00:00
|
|
|
rdma_hdr->rdma_start.ival
|
2007-01-12 23:14:45 +00:00
|
|
|
));
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2007-01-04 22:07:37 +00:00
|
|
|
if (endpoint->eager_rdma_remote.base.pval) {
|
2007-01-12 23:14:45 +00:00
|
|
|
BTL_ERROR(("Got RDMA connect twice!"));
|
2006-03-26 08:30:50 +00:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
endpoint->eager_rdma_remote.rkey = rdma_hdr->rkey;
|
2007-01-12 23:14:45 +00:00
|
|
|
endpoint->eager_rdma_remote.base.lval = rdma_hdr->rdma_start.lval;
|
2006-03-26 08:30:50 +00:00
|
|
|
endpoint->eager_rdma_remote.tokens =
|
|
|
|
mca_btl_openib_component.eager_rdma_num - 1;
|
|
|
|
break;
|
|
|
|
default:
|
2007-01-12 23:14:45 +00:00
|
|
|
BTL_ERROR(("Unknown message type received by BTL"));
|
2006-03-26 08:30:50 +00:00
|
|
|
break;
|
|
|
|
}
|
2005-11-10 20:15:02 +00:00
|
|
|
}
|
|
|
|
|
2006-12-17 12:26:41 +00:00
|
|
|
static int openib_reg_mr(void *reg_data, void *base, size_t size,
|
|
|
|
mca_mpool_base_registration_t *reg)
|
|
|
|
{
|
|
|
|
mca_btl_openib_hca_t *hca = (mca_btl_openib_hca_t*)reg_data;
|
|
|
|
mca_btl_openib_reg_t *openib_reg = (mca_btl_openib_reg_t*)reg;
|
|
|
|
|
|
|
|
openib_reg->mr = ibv_reg_mr(hca->ib_pd, base, size, IBV_ACCESS_LOCAL_WRITE |
|
|
|
|
IBV_ACCESS_REMOTE_WRITE | IBV_ACCESS_REMOTE_READ);
|
|
|
|
|
|
|
|
if(NULL == openib_reg->mr)
|
|
|
|
return OMPI_ERR_OUT_OF_RESOURCE;
|
|
|
|
|
|
|
|
return OMPI_SUCCESS;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int openib_dereg_mr(void *reg_data, mca_mpool_base_registration_t *reg)
|
|
|
|
{
|
|
|
|
mca_btl_openib_reg_t *openib_reg = (mca_btl_openib_reg_t*)reg;
|
|
|
|
|
|
|
|
if(openib_reg->mr != NULL) {
|
|
|
|
if(ibv_dereg_mr(openib_reg->mr)) {
|
|
|
|
opal_output(0, "%s: error unpinning openib memory errno says %s\n",
|
|
|
|
__func__, strerror(errno));
|
|
|
|
return OMPI_ERROR;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
openib_reg->mr = NULL;
|
|
|
|
return OMPI_SUCCESS;
|
|
|
|
}
|
|
|
|
|
2006-06-28 07:23:08 +00:00
|
|
|
static int init_one_port(opal_list_t *btl_list, mca_btl_openib_hca_t *hca,
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
uint8_t port_num, struct ibv_port_attr *ib_port_attr)
|
2006-06-28 07:23:08 +00:00
|
|
|
{
|
|
|
|
uint16_t lid, i, lmc;
|
|
|
|
mca_btl_openib_module_t *openib_btl;
|
|
|
|
mca_btl_base_selected_module_t *ib_selected;
|
2006-09-22 10:27:12 +00:00
|
|
|
union ibv_gid gid;
|
2007-01-12 22:42:20 +00:00
|
|
|
uint64_t subnet_id;
|
2006-09-26 12:12:33 +00:00
|
|
|
|
|
|
|
ibv_query_gid(hca->ib_dev_context, port_num, 0, &gid);
|
2007-01-12 22:42:20 +00:00
|
|
|
subnet_id = ntoh64(gid.global.subnet_prefix);
|
|
|
|
BTL_VERBOSE(("my subnet_id is %016x\n", subnet_id));
|
2007-01-03 22:35:41 +00:00
|
|
|
|
2006-09-26 12:12:33 +00:00
|
|
|
if(mca_btl_openib_component.ib_num_btls > 0 &&
|
2007-01-12 22:42:20 +00:00
|
|
|
IB_DEFAULT_GID_PREFIX == subnet_id &&
|
2006-09-26 12:12:33 +00:00
|
|
|
mca_btl_openib_component.warn_default_gid_prefix) {
|
|
|
|
opal_show_help("help-mpi-btl-openib.txt", "default subnet prefix",
|
|
|
|
true, orte_system_info.nodename);
|
|
|
|
}
|
2006-06-28 07:23:08 +00:00
|
|
|
|
|
|
|
lmc = (1 << ib_port_attr->lmc);
|
|
|
|
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
if (0 != mca_btl_openib_component.max_lmc &&
|
|
|
|
mca_btl_openib_component.max_lmc < lmc) {
|
2006-06-28 07:23:08 +00:00
|
|
|
lmc = mca_btl_openib_component.max_lmc;
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
}
|
2006-06-28 07:23:08 +00:00
|
|
|
|
|
|
|
for(lid = ib_port_attr->lid;
|
|
|
|
lid < ib_port_attr->lid + lmc; lid++){
|
|
|
|
for(i = 0; i < mca_btl_openib_component.btls_per_lid; i++){
|
|
|
|
openib_btl = malloc(sizeof(mca_btl_openib_module_t));
|
|
|
|
if(NULL == openib_btl) {
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
BTL_ERROR(("Failed malloc: %s:%d\n", __FILE__, __LINE__));
|
|
|
|
return OMPI_ERR_OUT_OF_RESOURCE;
|
2006-06-28 07:23:08 +00:00
|
|
|
}
|
|
|
|
memcpy(openib_btl, &mca_btl_openib_module,
|
|
|
|
sizeof(mca_btl_openib_module));
|
|
|
|
memcpy(&openib_btl->ib_port_attr, ib_port_attr,
|
|
|
|
sizeof(struct ibv_port_attr));
|
|
|
|
ib_selected = OBJ_NEW(mca_btl_base_selected_module_t);
|
|
|
|
ib_selected->btl_module = (mca_btl_base_module_t*) openib_btl;
|
|
|
|
openib_btl->hca = hca;
|
|
|
|
openib_btl->port_num = (uint8_t) port_num;
|
|
|
|
openib_btl->lid = lid;
|
|
|
|
openib_btl->src_path_bits = lid - ib_port_attr->lid;
|
2007-01-22 18:49:32 +00:00
|
|
|
/* store the subnet for multi-nic support */
|
2007-01-12 22:42:20 +00:00
|
|
|
openib_btl->port_info.subnet_id = subnet_id;
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
openib_btl->port_info.mtu = hca->mtu;
|
|
|
|
openib_btl->ib_reg[MCA_BTL_TAG_BTL].cbfunc = btl_openib_control;
|
2006-06-28 07:23:08 +00:00
|
|
|
openib_btl->ib_reg[MCA_BTL_TAG_BTL].cbdata = NULL;
|
|
|
|
opal_list_append(btl_list, (opal_list_item_t*) ib_selected);
|
|
|
|
hca->btls++;
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
++mca_btl_openib_component.ib_num_btls;
|
|
|
|
if (-1 != mca_btl_openib_component.ib_max_btls &&
|
|
|
|
mca_btl_openib_component.ib_num_btls >=
|
|
|
|
mca_btl_openib_component.ib_max_btls) {
|
2006-09-25 11:18:20 +00:00
|
|
|
return OMPI_ERR_VALUE_OUT_OF_BOUNDS;
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
}
|
2006-06-28 07:23:08 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
return OMPI_SUCCESS;
|
2006-06-28 07:23:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static int init_one_hca(opal_list_t *btl_list, struct ibv_device* ib_dev)
|
|
|
|
{
|
|
|
|
struct mca_mpool_base_resources_t mpool_resources;
|
|
|
|
mca_btl_openib_hca_t *hca;
|
|
|
|
uint8_t i;
|
|
|
|
int ret = -1;
|
2006-08-30 20:21:47 +00:00
|
|
|
ompi_btl_openib_ini_values_t values, default_values;
|
2006-06-28 07:23:08 +00:00
|
|
|
|
|
|
|
hca = malloc(sizeof(mca_btl_openib_hca_t));
|
|
|
|
if(NULL == hca){
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
BTL_ERROR(("Failed malloc: %s:%d\n", __FILE__, __LINE__));
|
|
|
|
return OMPI_ERR_OUT_OF_RESOURCE;
|
2006-06-28 07:23:08 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
hca->ib_dev = ib_dev;
|
|
|
|
hca->ib_dev_context = ibv_open_device(ib_dev);
|
|
|
|
hca->btls = 0;
|
2006-11-02 16:15:21 +00:00
|
|
|
OBJ_CONSTRUCT(&hca->hca_lock, opal_mutex_t);
|
2006-06-28 07:23:08 +00:00
|
|
|
if(NULL == hca->ib_dev_context){
|
|
|
|
BTL_ERROR(("error obtaining device context for %s errno says %s\n",
|
|
|
|
ibv_get_device_name(ib_dev), strerror(errno)));
|
|
|
|
goto free_hca;
|
|
|
|
}
|
|
|
|
|
|
|
|
if(ibv_query_device(hca->ib_dev_context, &hca->ib_dev_attr)){
|
|
|
|
BTL_ERROR(("error obtaining device attributes for %s errno says %s\n",
|
|
|
|
ibv_get_device_name(ib_dev), strerror(errno)));
|
|
|
|
goto close_hca;
|
|
|
|
}
|
|
|
|
|
2006-08-30 20:21:47 +00:00
|
|
|
/* Load in vendor/part-specific HCA parameters. Note that even if
|
|
|
|
we don't find values for this vendor/part, "values" will be set
|
|
|
|
indicating that it does not have good values */
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
ret = ompi_btl_openib_ini_query(hca->ib_dev_attr.vendor_id,
|
|
|
|
hca->ib_dev_attr.vendor_part_id,
|
|
|
|
&values);
|
2006-08-30 20:21:47 +00:00
|
|
|
if (OMPI_SUCCESS != ret && OMPI_ERR_NOT_FOUND != ret) {
|
|
|
|
/* If we get a serious error, propagate it upwards */
|
|
|
|
goto close_hca;
|
|
|
|
}
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
if (OMPI_ERR_NOT_FOUND == ret) {
|
|
|
|
/* If we didn't find a matching HCA in the INI files, output a
|
|
|
|
warning that we're using default values (unless overridden
|
|
|
|
that we don't want to see these warnings) */
|
|
|
|
if (mca_btl_openib_component.warn_no_hca_params_found) {
|
|
|
|
opal_show_help("help-mpi-btl-openib.txt",
|
|
|
|
"no hca params found", true,
|
|
|
|
orte_system_info.nodename,
|
|
|
|
hca->ib_dev_attr.vendor_id,
|
|
|
|
hca->ib_dev_attr.vendor_part_id);
|
|
|
|
}
|
2006-08-30 20:21:47 +00:00
|
|
|
}
|
|
|
|
/* Note that even if we don't find default values, "values" will
|
|
|
|
be set indicating that it does not have good values */
|
|
|
|
ret = ompi_btl_openib_ini_query(0, 0, &default_values);
|
|
|
|
if (OMPI_SUCCESS != ret && OMPI_ERR_NOT_FOUND != ret) {
|
|
|
|
/* If we get a serious error, propagate it upwards */
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
goto close_hca;
|
2006-08-30 20:21:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* If we did find values for this HCA (or in the defaults
|
|
|
|
section), handle them */
|
|
|
|
merge_values(&values, &default_values);
|
|
|
|
if (values.mtu_set) {
|
|
|
|
switch (values.mtu) {
|
|
|
|
case 256:
|
|
|
|
hca->mtu = IBV_MTU_256;
|
|
|
|
break;
|
|
|
|
case 512:
|
|
|
|
hca->mtu = IBV_MTU_512;
|
|
|
|
break;
|
|
|
|
case 1024:
|
|
|
|
hca->mtu = IBV_MTU_1024;
|
|
|
|
break;
|
|
|
|
case 2048:
|
|
|
|
hca->mtu = IBV_MTU_2048;
|
|
|
|
break;
|
|
|
|
case 4096:
|
|
|
|
hca->mtu = IBV_MTU_4096;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
BTL_ERROR(("invalid MTU value specified in INI file (%d); ignored\n", values.mtu));
|
|
|
|
hca->mtu = mca_btl_openib_component.ib_mtu;
|
|
|
|
break;
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
}
|
2006-08-30 20:21:47 +00:00
|
|
|
} else {
|
|
|
|
hca->mtu = mca_btl_openib_component.ib_mtu;
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
}
|
|
|
|
|
2006-12-14 15:52:13 +00:00
|
|
|
/* If "use eager rdma" was set, then enable it on this HCA */
|
|
|
|
if (values.use_eager_rdma_set) {
|
|
|
|
hca->use_eager_rdma = values.use_eager_rdma;
|
|
|
|
}
|
|
|
|
|
2006-06-28 07:23:08 +00:00
|
|
|
hca->ib_pd = ibv_alloc_pd(hca->ib_dev_context);
|
|
|
|
if(NULL == hca->ib_pd){
|
|
|
|
BTL_ERROR(("error allocating pd for %s errno says %s\n",
|
|
|
|
ibv_get_device_name(ib_dev), strerror(errno)));
|
|
|
|
goto close_hca;
|
|
|
|
}
|
2005-11-10 20:15:02 +00:00
|
|
|
|
2006-12-17 12:26:41 +00:00
|
|
|
mpool_resources.reg_data = (void*)hca;
|
|
|
|
mpool_resources.sizeof_reg = sizeof(mca_btl_openib_reg_t);
|
|
|
|
mpool_resources.register_mem = openib_reg_mr;
|
|
|
|
mpool_resources.deregister_mem = openib_dereg_mr;
|
2006-06-28 07:23:08 +00:00
|
|
|
hca->mpool =
|
|
|
|
mca_mpool_base_module_create(mca_btl_openib_component.ib_mpool_name,
|
|
|
|
hca, &mpool_resources);
|
|
|
|
if(NULL == hca->mpool){
|
|
|
|
BTL_ERROR(("error creating IB memory pool for %s errno says %s\n",
|
|
|
|
ibv_get_device_name(ib_dev), strerror(errno)));
|
|
|
|
goto dealloc_pd;
|
|
|
|
}
|
|
|
|
|
2006-11-02 16:15:21 +00:00
|
|
|
#if OMPI_ENABLE_PROGRESS_THREADS == 1
|
|
|
|
hca->ib_channel = ibv_create_comp_channel(hca->ib_dev_context);
|
|
|
|
if (NULL == hca->ib_channel) {
|
|
|
|
BTL_ERROR(("error creating channel for %s errno says %s\n",
|
|
|
|
ibv_get_device_name(hca->ib_dev),
|
|
|
|
strerror(errno)));
|
|
|
|
goto mpool_destroy;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2006-09-19 08:56:32 +00:00
|
|
|
ret = OMPI_SUCCESS;
|
2006-11-02 16:15:21 +00:00
|
|
|
|
2006-06-28 07:23:08 +00:00
|
|
|
/* Note ports are 1 based hence j = 1 */
|
|
|
|
for(i = 1; i <= hca->ib_dev_attr.phys_port_cnt; i++){
|
|
|
|
struct ibv_port_attr ib_port_attr;
|
|
|
|
|
|
|
|
if(ibv_query_port(hca->ib_dev_context, i, &ib_port_attr)){
|
|
|
|
BTL_ERROR(("error getting port attributes for device %s "
|
|
|
|
"port number %d errno says %s",
|
|
|
|
ibv_get_device_name(ib_dev), i, strerror(errno)));
|
|
|
|
break;
|
|
|
|
}
|
2005-09-30 22:58:09 +00:00
|
|
|
|
2006-06-28 07:23:08 +00:00
|
|
|
if(IBV_PORT_ACTIVE == ib_port_attr.state){
|
|
|
|
ret = init_one_port(btl_list, hca, i, &ib_port_attr);
|
|
|
|
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
if (OMPI_SUCCESS != ret) {
|
2006-09-25 11:18:20 +00:00
|
|
|
/* Out of bounds error indicates that we hit max btl number
|
|
|
|
* don't propagate the error to the caller */
|
|
|
|
if(OMPI_ERR_VALUE_OUT_OF_BOUNDS == ret)
|
|
|
|
ret = OMPI_SUCCESS;
|
2006-06-28 07:23:08 +00:00
|
|
|
break;
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
}
|
2006-06-28 07:23:08 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-11-02 16:15:21 +00:00
|
|
|
if (hca->btls != 0){
|
|
|
|
#if OMPI_ENABLE_PROGRESS_THREADS == 1
|
|
|
|
/* Prepare data for thread, but not starting it */
|
|
|
|
OBJ_CONSTRUCT(&hca->thread, opal_thread_t);
|
|
|
|
hca->thread.t_run = mca_btl_openib_progress_thread;
|
|
|
|
hca->thread.t_arg = hca;
|
|
|
|
hca->progress = false;
|
|
|
|
#endif
|
2006-06-28 07:23:08 +00:00
|
|
|
return ret;
|
2006-11-02 16:15:21 +00:00
|
|
|
}
|
2006-06-28 07:23:08 +00:00
|
|
|
|
2006-11-02 16:15:21 +00:00
|
|
|
#if OMPI_ENABLE_PROGRESS_THREADS == 1
|
|
|
|
ibv_destroy_comp_channel(hca->ib_channel);
|
|
|
|
mpool_destroy:
|
2006-11-06 12:34:56 +00:00
|
|
|
#endif
|
2006-06-28 07:23:08 +00:00
|
|
|
mca_mpool_base_module_destroy(hca->mpool);
|
|
|
|
dealloc_pd:
|
|
|
|
ibv_dealloc_pd(hca->ib_pd);
|
|
|
|
close_hca:
|
|
|
|
ibv_close_device(hca->ib_dev_context);
|
|
|
|
free_hca:
|
|
|
|
free(hca);
|
|
|
|
return ret;
|
|
|
|
}
|
2006-12-17 12:26:41 +00:00
|
|
|
|
2005-06-30 21:28:35 +00:00
|
|
|
/*
|
|
|
|
* IB component initialization:
|
|
|
|
* (1) read interface list from kernel and compare against component parameters
|
|
|
|
* then create a BTL instance for selected interfaces
|
|
|
|
* (2) setup IB listen socket for incoming connection attempts
|
|
|
|
* (3) register BTL parameters with the MCA
|
|
|
|
*/
|
|
|
|
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
static mca_btl_base_module_t**
|
|
|
|
btl_openib_component_init(int *num_btl_modules,
|
|
|
|
bool enable_progress_threads,
|
|
|
|
bool enable_mpi_threads)
|
2005-06-30 21:28:35 +00:00
|
|
|
{
|
|
|
|
struct ibv_device **ib_devs;
|
|
|
|
mca_btl_base_module_t** btls;
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
int i, ret, length, num_devs;
|
2005-07-03 16:22:16 +00:00
|
|
|
opal_list_t btl_list;
|
2005-07-13 00:17:08 +00:00
|
|
|
mca_btl_openib_module_t * openib_btl;
|
2005-06-30 21:28:35 +00:00
|
|
|
mca_btl_base_selected_module_t* ib_selected;
|
2005-07-03 16:22:16 +00:00
|
|
|
opal_list_item_t* item;
|
2006-06-01 02:32:18 +00:00
|
|
|
#if OMPI_MCA_BTL_OPENIB_HAVE_DEVICE_LIST == 0
|
2005-07-19 21:04:22 +00:00
|
|
|
struct dlist *dev_list;
|
|
|
|
struct ibv_device* ib_dev;
|
2006-06-28 07:23:08 +00:00
|
|
|
#endif
|
2006-01-12 23:42:44 +00:00
|
|
|
unsigned short seedv[3];
|
2005-07-19 21:04:22 +00:00
|
|
|
|
2005-06-30 21:28:35 +00:00
|
|
|
/* initialization */
|
|
|
|
*num_btl_modules = 0;
|
|
|
|
num_devs = 0;
|
|
|
|
|
2006-01-12 23:42:44 +00:00
|
|
|
seedv[0] = orte_process_info.my_name->vpid;
|
|
|
|
seedv[1] = opal_sys_timer_get_cycles();
|
|
|
|
seedv[2] = opal_sys_timer_get_cycles();
|
|
|
|
seed48(seedv);
|
2006-01-17 16:23:35 +00:00
|
|
|
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
/* Read in INI files with HCA-specific parameters */
|
|
|
|
if (OMPI_SUCCESS != (ret = ompi_btl_openib_ini_init())) {
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2006-01-17 21:07:34 +00:00
|
|
|
#if OMPI_MCA_BTL_OPENIB_HAVE_DEVICE_LIST
|
|
|
|
ib_devs = ibv_get_device_list(&num_devs);
|
|
|
|
#else
|
2005-06-30 21:28:35 +00:00
|
|
|
/* Determine the number of hca's available on the host */
|
|
|
|
dev_list = ibv_get_devices();
|
2005-09-30 14:58:59 +00:00
|
|
|
if (NULL == dev_list) {
|
|
|
|
mca_btl_base_error_no_nics("OpenIB", "HCA");
|
2005-09-30 22:58:09 +00:00
|
|
|
mca_btl_openib_component.ib_num_btls = 0;
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
btl_openib_modex_send();
|
2005-09-30 14:58:59 +00:00
|
|
|
return NULL;
|
|
|
|
}
|
2005-06-30 21:28:35 +00:00
|
|
|
dlist_start(dev_list);
|
|
|
|
|
|
|
|
dlist_for_each_data(dev_list, ib_dev, struct ibv_device)
|
|
|
|
num_devs++;
|
2006-01-17 16:23:35 +00:00
|
|
|
#endif
|
|
|
|
|
2005-06-30 21:28:35 +00:00
|
|
|
if(0 == num_devs) {
|
2005-09-30 14:58:59 +00:00
|
|
|
mca_btl_base_error_no_nics("OpenIB", "HCA");
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
btl_openib_modex_send();
|
2005-06-30 21:28:35 +00:00
|
|
|
return NULL;
|
|
|
|
}
|
2006-06-27 10:43:03 +00:00
|
|
|
|
2006-01-17 21:07:34 +00:00
|
|
|
#if OMPI_MCA_BTL_OPENIB_HAVE_DEVICE_LIST == 0
|
2005-06-30 21:28:35 +00:00
|
|
|
/* Allocate space for the ib devices */
|
2005-07-13 00:17:08 +00:00
|
|
|
ib_devs = (struct ibv_device**) malloc(num_devs * sizeof(struct ibv_dev*));
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
if(NULL == ib_devs) {
|
|
|
|
BTL_ERROR(("Failed malloc: %s:%d\n", __FILE__, __LINE__));
|
2005-06-30 21:28:35 +00:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
dlist_start(dev_list);
|
|
|
|
|
2005-07-13 00:17:08 +00:00
|
|
|
i = 0;
|
2005-06-30 21:28:35 +00:00
|
|
|
dlist_for_each_data(dev_list, ib_dev, struct ibv_device)
|
|
|
|
ib_devs[i++] = ib_dev;
|
2006-01-17 16:23:35 +00:00
|
|
|
#endif
|
2005-06-30 21:28:35 +00:00
|
|
|
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
/* We must loop through all the hca id's, get their handles and
|
|
|
|
for each hca we query the number of ports on the hca and set up
|
|
|
|
a distinct btl module for each hca port */
|
2005-06-30 21:28:35 +00:00
|
|
|
|
2005-07-03 16:22:16 +00:00
|
|
|
OBJ_CONSTRUCT(&btl_list, opal_list_t);
|
2005-07-03 22:45:48 +00:00
|
|
|
OBJ_CONSTRUCT(&mca_btl_openib_component.ib_lock, opal_mutex_t);
|
2005-06-30 21:28:35 +00:00
|
|
|
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
for (i = 0; i < num_devs &&
|
|
|
|
(-1 == mca_btl_openib_component.ib_max_btls ||
|
|
|
|
mca_btl_openib_component.ib_num_btls <
|
|
|
|
mca_btl_openib_component.ib_max_btls); i++){
|
|
|
|
if (OMPI_SUCCESS != (ret = init_one_hca(&btl_list, ib_devs[i]))) {
|
|
|
|
break;
|
|
|
|
}
|
2006-09-19 08:56:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if(ret != OMPI_SUCCESS) {
|
|
|
|
opal_show_help("help-mpi-btl-openib.txt",
|
|
|
|
"error in hca init", true, orte_system_info.nodename);
|
|
|
|
}
|
|
|
|
|
|
|
|
if(0 == mca_btl_openib_component.ib_num_btls) {
|
|
|
|
opal_show_help("help-mpi-btl-openib.txt",
|
|
|
|
"no active ports found", true, orte_system_info.nodename);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2005-06-30 21:28:35 +00:00
|
|
|
/* Allocate space for btl modules */
|
2006-06-28 07:23:08 +00:00
|
|
|
mca_btl_openib_component.openib_btls =
|
|
|
|
malloc(sizeof(mca_btl_openib_module_t) *
|
|
|
|
mca_btl_openib_component.ib_num_btls);
|
2005-06-30 21:28:35 +00:00
|
|
|
|
2005-07-12 13:38:54 +00:00
|
|
|
if(NULL == mca_btl_openib_component.openib_btls) {
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
BTL_ERROR(("Failed malloc: %s:%d\n", __FILE__, __LINE__));
|
2005-06-30 21:28:35 +00:00
|
|
|
return NULL;
|
|
|
|
}
|
2006-06-28 07:23:08 +00:00
|
|
|
btls = malloc(mca_btl_openib_component.ib_num_btls *
|
|
|
|
sizeof(struct mca_btl_openib_module_t*));
|
2005-06-30 21:28:35 +00:00
|
|
|
if(NULL == btls) {
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
BTL_ERROR(("Failed malloc: %s:%d\n", __FILE__, __LINE__));
|
2005-06-30 21:28:35 +00:00
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
/* Copy the btl module structs into a contiguous array and fully
|
|
|
|
initialize them */
|
2005-06-30 21:28:35 +00:00
|
|
|
for(i = 0; i < mca_btl_openib_component.ib_num_btls; i++){
|
2005-07-03 16:22:16 +00:00
|
|
|
item = opal_list_remove_first(&btl_list);
|
2005-06-30 21:28:35 +00:00
|
|
|
ib_selected = (mca_btl_base_selected_module_t*)item;
|
2005-07-12 13:38:54 +00:00
|
|
|
openib_btl = (mca_btl_openib_module_t*) ib_selected->btl_module;
|
2006-06-28 07:23:08 +00:00
|
|
|
memcpy(&(mca_btl_openib_component.openib_btls[i]), openib_btl,
|
|
|
|
sizeof(mca_btl_openib_module_t));
|
2005-07-12 13:38:54 +00:00
|
|
|
free(openib_btl);
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
OBJ_RELEASE(ib_selected);
|
2007-01-09 09:07:32 +00:00
|
|
|
openib_btl = &mca_btl_openib_component.openib_btls[i];
|
2005-06-30 21:28:35 +00:00
|
|
|
|
2006-06-28 07:23:08 +00:00
|
|
|
openib_btl->rd_num = mca_btl_openib_component.rd_num +
|
|
|
|
mca_btl_openib_component.rd_rsv;
|
2005-11-10 20:15:02 +00:00
|
|
|
openib_btl->rd_low = mca_btl_openib_component.rd_low;
|
2005-10-21 02:21:45 +00:00
|
|
|
openib_btl->num_peers = 0;
|
2006-09-05 16:00:18 +00:00
|
|
|
openib_btl->sd_tokens[BTL_OPENIB_HP_QP] =
|
|
|
|
openib_btl->sd_tokens[BTL_OPENIB_LP_QP] = mca_btl_openib_component.srq_sd_max;
|
2005-10-21 02:21:45 +00:00
|
|
|
|
2005-06-30 21:28:35 +00:00
|
|
|
/* Initialize module state */
|
|
|
|
|
2006-09-05 16:00:18 +00:00
|
|
|
OBJ_CONSTRUCT(&openib_btl->pending_frags[BTL_OPENIB_HP_QP], opal_list_t);
|
|
|
|
OBJ_CONSTRUCT(&openib_btl->pending_frags[BTL_OPENIB_LP_QP], opal_list_t);
|
2005-10-21 02:21:45 +00:00
|
|
|
|
2005-07-12 13:38:54 +00:00
|
|
|
OBJ_CONSTRUCT(&openib_btl->ib_lock, opal_mutex_t);
|
|
|
|
OBJ_CONSTRUCT(&openib_btl->send_free_eager, ompi_free_list_t);
|
|
|
|
OBJ_CONSTRUCT(&openib_btl->send_free_max, ompi_free_list_t);
|
|
|
|
OBJ_CONSTRUCT(&openib_btl->send_free_frag, ompi_free_list_t);
|
2006-07-27 14:09:30 +00:00
|
|
|
OBJ_CONSTRUCT(&openib_btl->send_free_control, ompi_free_list_t);
|
2005-06-30 21:28:35 +00:00
|
|
|
|
2005-07-12 13:38:54 +00:00
|
|
|
OBJ_CONSTRUCT(&openib_btl->recv_free_eager, ompi_free_list_t);
|
|
|
|
OBJ_CONSTRUCT(&openib_btl->recv_free_max, ompi_free_list_t);
|
2007-02-28 13:43:38 +00:00
|
|
|
OBJ_CONSTRUCT(&openib_btl->recv_free_frag, ompi_free_list_t);
|
2006-07-30 00:58:40 +00:00
|
|
|
|
2005-06-30 21:28:35 +00:00
|
|
|
/* initialize the memory pool using the hca */
|
2006-06-28 07:23:08 +00:00
|
|
|
openib_btl->super.btl_mpool = openib_btl->hca->mpool;
|
2005-07-12 13:38:54 +00:00
|
|
|
|
2005-06-30 21:28:35 +00:00
|
|
|
/* Initialize pool of send fragments */
|
2007-03-05 14:17:50 +00:00
|
|
|
length = sizeof(mca_btl_openib_send_frag_eager_t) +
|
2005-06-30 21:28:35 +00:00
|
|
|
sizeof(mca_btl_openib_header_t) +
|
2006-03-26 08:30:50 +00:00
|
|
|
sizeof(mca_btl_openib_footer_t) +
|
2006-07-23 12:33:49 +00:00
|
|
|
openib_btl->super.btl_eager_limit;
|
2006-12-19 08:34:48 +00:00
|
|
|
|
2007-03-05 14:17:50 +00:00
|
|
|
openib_btl->eager_rdma_frag_size = OPAL_ALIGN(
|
|
|
|
sizeof(mca_btl_openib_header_t) +
|
|
|
|
sizeof(mca_btl_openib_footer_t) +
|
|
|
|
openib_btl->super.btl_eager_limit,
|
|
|
|
mca_btl_openib_component.buffer_alignment, size_t);
|
2006-03-26 08:30:50 +00:00
|
|
|
|
2006-07-20 14:39:05 +00:00
|
|
|
ompi_free_list_init_ex(&openib_btl->send_free_eager,
|
|
|
|
length,
|
|
|
|
mca_btl_openib_component.buffer_alignment,
|
2005-06-30 21:28:35 +00:00
|
|
|
OBJ_CLASS(mca_btl_openib_send_frag_eager_t),
|
|
|
|
mca_btl_openib_component.ib_free_list_num,
|
|
|
|
mca_btl_openib_component.ib_free_list_max,
|
|
|
|
mca_btl_openib_component.ib_free_list_inc,
|
2005-09-12 22:28:23 +00:00
|
|
|
openib_btl->super.btl_mpool);
|
2005-06-30 21:28:35 +00:00
|
|
|
|
2007-03-05 14:17:50 +00:00
|
|
|
length = sizeof(mca_btl_openib_recv_frag_eager_t) +
|
|
|
|
sizeof(mca_btl_openib_header_t) +
|
|
|
|
sizeof(mca_btl_openib_footer_t) +
|
|
|
|
openib_btl->super.btl_eager_limit;
|
|
|
|
|
2006-07-20 14:39:05 +00:00
|
|
|
ompi_free_list_init_ex(&openib_btl->recv_free_eager,
|
2005-06-30 21:28:35 +00:00
|
|
|
length,
|
2006-07-20 14:39:05 +00:00
|
|
|
mca_btl_openib_component.buffer_alignment,
|
2005-06-30 21:28:35 +00:00
|
|
|
OBJ_CLASS(mca_btl_openib_recv_frag_eager_t),
|
|
|
|
mca_btl_openib_component.ib_free_list_num,
|
|
|
|
mca_btl_openib_component.ib_free_list_max,
|
|
|
|
mca_btl_openib_component.ib_free_list_inc,
|
2005-09-12 22:28:23 +00:00
|
|
|
openib_btl->super.btl_mpool);
|
2006-01-12 23:42:44 +00:00
|
|
|
|
2007-03-05 14:17:50 +00:00
|
|
|
length = sizeof(mca_btl_openib_send_frag_max_t) +
|
2005-06-30 21:28:35 +00:00
|
|
|
sizeof(mca_btl_openib_header_t) +
|
2006-07-23 12:33:49 +00:00
|
|
|
openib_btl->super.btl_max_send_size;
|
2005-06-30 21:28:35 +00:00
|
|
|
|
2006-07-20 14:39:05 +00:00
|
|
|
ompi_free_list_init_ex(&openib_btl->send_free_max,
|
|
|
|
length,
|
|
|
|
mca_btl_openib_component.buffer_alignment,
|
2005-06-30 21:28:35 +00:00
|
|
|
OBJ_CLASS(mca_btl_openib_send_frag_max_t),
|
|
|
|
mca_btl_openib_component.ib_free_list_num,
|
|
|
|
mca_btl_openib_component.ib_free_list_max,
|
|
|
|
mca_btl_openib_component.ib_free_list_inc,
|
2005-09-12 22:28:23 +00:00
|
|
|
openib_btl->super.btl_mpool);
|
2005-07-12 13:38:54 +00:00
|
|
|
|
2007-03-05 14:17:50 +00:00
|
|
|
length = sizeof(mca_btl_openib_recv_frag_max_t) +
|
|
|
|
sizeof(mca_btl_openib_header_t) +
|
|
|
|
openib_btl->super.btl_max_send_size;
|
|
|
|
|
2005-06-30 21:28:35 +00:00
|
|
|
/* Initialize pool of receive fragments */
|
2006-07-20 14:39:05 +00:00
|
|
|
ompi_free_list_init_ex(&openib_btl->recv_free_max,
|
2005-06-30 21:28:35 +00:00
|
|
|
length,
|
2006-07-20 14:39:05 +00:00
|
|
|
mca_btl_openib_component.buffer_alignment,
|
2007-03-05 14:17:50 +00:00
|
|
|
OBJ_CLASS(mca_btl_openib_recv_frag_max_t),
|
2005-06-30 21:28:35 +00:00
|
|
|
mca_btl_openib_component.ib_free_list_num,
|
|
|
|
mca_btl_openib_component.ib_free_list_max,
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
mca_btl_openib_component.ib_free_list_inc,
|
|
|
|
openib_btl->super.btl_mpool);
|
2005-06-30 21:28:35 +00:00
|
|
|
|
2007-03-05 14:17:50 +00:00
|
|
|
length = sizeof(mca_btl_openib_send_frag_control_t) +
|
2006-07-27 14:09:30 +00:00
|
|
|
sizeof(mca_btl_openib_header_t) +
|
|
|
|
sizeof(mca_btl_openib_footer_t) +
|
|
|
|
sizeof(mca_btl_openib_eager_rdma_header_t);
|
|
|
|
|
|
|
|
ompi_free_list_init_ex(&openib_btl->send_free_control,
|
|
|
|
length,
|
|
|
|
mca_btl_openib_component.buffer_alignment,
|
|
|
|
OBJ_CLASS(mca_btl_openib_send_frag_control_t),
|
|
|
|
mca_btl_openib_component.ib_free_list_num,
|
|
|
|
-1,
|
|
|
|
mca_btl_openib_component.ib_free_list_inc,
|
|
|
|
openib_btl->super.btl_mpool);
|
|
|
|
|
2006-07-23 12:33:49 +00:00
|
|
|
length = sizeof(mca_btl_openib_frag_t);
|
2005-06-30 21:28:35 +00:00
|
|
|
|
2005-07-12 13:38:54 +00:00
|
|
|
ompi_free_list_init(&openib_btl->send_free_frag,
|
2005-06-30 21:28:35 +00:00
|
|
|
length,
|
|
|
|
OBJ_CLASS(mca_btl_openib_send_frag_frag_t),
|
|
|
|
mca_btl_openib_component.ib_free_list_num,
|
|
|
|
mca_btl_openib_component.ib_free_list_max,
|
|
|
|
mca_btl_openib_component.ib_free_list_inc,
|
2006-06-27 08:50:12 +00:00
|
|
|
NULL);
|
2006-01-12 23:42:44 +00:00
|
|
|
|
2007-02-28 13:43:38 +00:00
|
|
|
ompi_free_list_init(&openib_btl->recv_free_frag,
|
|
|
|
length,
|
|
|
|
OBJ_CLASS(mca_btl_openib_recv_frag_frag_t),
|
|
|
|
mca_btl_openib_component.ib_free_list_num,
|
|
|
|
mca_btl_openib_component.ib_free_list_max,
|
|
|
|
mca_btl_openib_component.ib_free_list_inc,
|
|
|
|
NULL);
|
|
|
|
|
2006-03-26 08:30:50 +00:00
|
|
|
orte_pointer_array_init(&openib_btl->eager_rdma_buffers,
|
|
|
|
mca_btl_openib_component.max_eager_rdma,
|
|
|
|
mca_btl_openib_component.max_eager_rdma,
|
|
|
|
0);
|
|
|
|
openib_btl->eager_rdma_buffers_count = 0;
|
2006-11-01 07:27:32 +00:00
|
|
|
|
2006-09-05 16:04:04 +00:00
|
|
|
orte_pointer_array_init(&openib_btl->endpoints, 10, INT_MAX, 100);
|
2005-07-12 13:38:54 +00:00
|
|
|
btls[i] = &openib_btl->super;
|
2005-06-30 21:28:35 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Post OOB receive to support dynamic connection setup */
|
|
|
|
mca_btl_openib_post_recv();
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
btl_openib_modex_send();
|
2005-06-30 21:28:35 +00:00
|
|
|
|
|
|
|
*num_btl_modules = mca_btl_openib_component.ib_num_btls;
|
2006-01-17 21:07:34 +00:00
|
|
|
#if OMPI_MCA_BTL_OPENIB_HAVE_DEVICE_LIST
|
2006-01-17 16:23:35 +00:00
|
|
|
ibv_free_device_list(ib_devs);
|
|
|
|
#else
|
|
|
|
free(ib_devs);
|
|
|
|
#endif
|
2005-06-30 21:28:35 +00:00
|
|
|
return btls;
|
|
|
|
}
|
|
|
|
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
|
2006-08-30 20:21:47 +00:00
|
|
|
static void merge_values(ompi_btl_openib_ini_values_t *target,
|
|
|
|
ompi_btl_openib_ini_values_t *src)
|
|
|
|
{
|
|
|
|
if (!target->mtu_set && src->mtu_set) {
|
|
|
|
target->mtu = src->mtu;
|
|
|
|
target->mtu_set = true;
|
|
|
|
}
|
2006-12-14 15:52:13 +00:00
|
|
|
|
|
|
|
if (!target->use_eager_rdma_set && src->use_eager_rdma_set) {
|
|
|
|
target->use_eager_rdma = src->use_eager_rdma;
|
|
|
|
target->use_eager_rdma_set = true;
|
|
|
|
}
|
2006-08-30 20:21:47 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2006-09-12 09:17:59 +00:00
|
|
|
static int btl_openib_handle_incoming(mca_btl_openib_module_t *openib_btl,
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
mca_btl_openib_endpoint_t *endpoint,
|
|
|
|
mca_btl_openib_frag_t *frag,
|
2006-09-12 09:17:59 +00:00
|
|
|
size_t byte_len, const int prio)
|
2006-03-26 08:30:50 +00:00
|
|
|
{
|
2006-09-12 09:17:59 +00:00
|
|
|
ompi_free_list_t *free_list;
|
2007-01-12 23:14:45 +00:00
|
|
|
if(endpoint->nbo) {
|
|
|
|
BTL_OPENIB_HEADER_NTOH((*(frag->hdr)));
|
|
|
|
}
|
2006-09-12 09:17:59 +00:00
|
|
|
if(BTL_OPENIB_HP_QP == prio)
|
|
|
|
free_list = &openib_btl->recv_free_eager;
|
|
|
|
else
|
|
|
|
free_list = &openib_btl->recv_free_max;
|
|
|
|
|
|
|
|
/* advance the segment address past the header and subtract from the
|
|
|
|
* length..*/
|
|
|
|
frag->segment.seg_len = byte_len - sizeof(mca_btl_openib_header_t);
|
2006-03-26 08:30:50 +00:00
|
|
|
|
|
|
|
/* call registered callback */
|
|
|
|
openib_btl->ib_reg[frag->hdr->tag].cbfunc(&openib_btl->super,
|
|
|
|
frag->hdr->tag, &frag->base,
|
|
|
|
openib_btl->ib_reg[frag->hdr->tag].cbdata);
|
|
|
|
|
2006-09-05 16:04:04 +00:00
|
|
|
if(BTL_OPENIB_IS_RDMA_CREDITS(frag->hdr->credits) &&
|
|
|
|
BTL_OPENIB_CREDITS(frag->hdr->credits) > 0)
|
|
|
|
OPAL_THREAD_ADD32(&endpoint->eager_rdma_remote.tokens,
|
|
|
|
BTL_OPENIB_CREDITS(frag->hdr->credits));
|
|
|
|
else
|
|
|
|
if(!mca_btl_openib_component.use_srq && frag->hdr->credits > 0)
|
2006-09-12 09:17:59 +00:00
|
|
|
OPAL_THREAD_ADD32(&endpoint->sd_tokens[prio],
|
2006-09-05 16:04:04 +00:00
|
|
|
frag->hdr->credits);
|
|
|
|
|
2006-03-26 08:30:50 +00:00
|
|
|
if (!MCA_BTL_OPENIB_RDMA_FRAG(frag)) {
|
2006-09-12 09:17:59 +00:00
|
|
|
OMPI_FREE_LIST_RETURN(free_list, (ompi_free_list_item_t*) frag);
|
2006-03-26 08:30:50 +00:00
|
|
|
} else {
|
|
|
|
mca_btl_openib_frag_t *tf;
|
|
|
|
OPAL_THREAD_LOCK(&endpoint->eager_rdma_local.lock);
|
|
|
|
MCA_BTL_OPENIB_RDMA_MAKE_REMOTE(frag->ftr);
|
|
|
|
while (endpoint->eager_rdma_local.tail !=
|
|
|
|
endpoint->eager_rdma_local.head) {
|
|
|
|
tf = MCA_BTL_OPENIB_GET_LOCAL_RDMA_FRAG(endpoint,
|
|
|
|
endpoint->eager_rdma_local.tail);
|
|
|
|
if (MCA_BTL_OPENIB_RDMA_FRAG_LOCAL (tf))
|
|
|
|
break;
|
|
|
|
OPAL_THREAD_ADD32(&endpoint->eager_rdma_local.credits, 1);
|
|
|
|
MCA_BTL_OPENIB_RDMA_NEXT_INDEX(endpoint->eager_rdma_local.tail);
|
|
|
|
}
|
|
|
|
OPAL_THREAD_UNLOCK(&endpoint->eager_rdma_local.lock);
|
|
|
|
}
|
|
|
|
|
2007-01-04 22:07:37 +00:00
|
|
|
if (!endpoint->eager_rdma_local.base.pval &&
|
2007-01-12 23:14:45 +00:00
|
|
|
endpoint->use_eager_rdma &&
|
2006-09-12 09:17:59 +00:00
|
|
|
BTL_OPENIB_HP_QP == prio &&
|
2006-03-26 08:30:50 +00:00
|
|
|
openib_btl->eager_rdma_buffers_count <
|
|
|
|
mca_btl_openib_component.max_eager_rdma &&
|
|
|
|
OPAL_THREAD_ADD32(&endpoint->eager_recv_count, 1) ==
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
mca_btl_openib_component.eager_rdma_threshold) {
|
|
|
|
mca_btl_openib_endpoint_connect_eager_rdma(endpoint);
|
|
|
|
}
|
2006-03-26 08:30:50 +00:00
|
|
|
|
2006-09-05 16:04:04 +00:00
|
|
|
/* repost receive descriptors if receive not by RDMA */
|
|
|
|
if(!MCA_BTL_OPENIB_RDMA_FRAG(frag)) {
|
|
|
|
if(mca_btl_openib_component.use_srq) {
|
2006-09-12 09:17:59 +00:00
|
|
|
OPAL_THREAD_ADD32((int32_t*)&openib_btl->srd_posted[prio], -1);
|
|
|
|
mca_btl_openib_post_srr(openib_btl, 0, prio);
|
2006-09-05 16:04:04 +00:00
|
|
|
} else {
|
2006-09-12 09:17:59 +00:00
|
|
|
OPAL_THREAD_ADD32((int32_t*)&endpoint->rd_posted[prio], -1);
|
|
|
|
btl_openib_endpoint_post_rr(endpoint, 0, prio);
|
2006-03-26 08:30:50 +00:00
|
|
|
}
|
2006-09-05 16:04:04 +00:00
|
|
|
}
|
2006-03-26 08:30:50 +00:00
|
|
|
|
2006-09-05 16:04:04 +00:00
|
|
|
/* nothing to progress for SRQ case */
|
|
|
|
if(!mca_btl_openib_component.use_srq) {
|
2006-09-12 09:17:59 +00:00
|
|
|
btl_openib_frag_progress_pending(openib_btl, endpoint, prio);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* check to see if we need to return credits */
|
|
|
|
if(btl_openib_check_send_credits(endpoint, prio)) {
|
|
|
|
mca_btl_openib_endpoint_send_credits(endpoint, prio);
|
2006-03-26 08:30:50 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return OMPI_SUCCESS;
|
|
|
|
}
|
|
|
|
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
static char* btl_openib_component_status_to_string(enum ibv_wc_status status)
|
|
|
|
{
|
|
|
|
switch(status) {
|
|
|
|
case IBV_WC_SUCCESS:
|
|
|
|
return "SUCCESS";
|
|
|
|
break;
|
|
|
|
case IBV_WC_LOC_LEN_ERR:
|
|
|
|
return "LOCAL LENGTH ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_LOC_QP_OP_ERR:
|
|
|
|
return "LOCAL QP OPERATION ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_LOC_EEC_OP_ERR:
|
|
|
|
return "LOCAL EEC OPERATION ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_LOC_PROT_ERR:
|
|
|
|
return "LOCAL PROTOCOL ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_WR_FLUSH_ERR:
|
|
|
|
return "WORK REQUEST FLUSHED ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_MW_BIND_ERR:
|
|
|
|
return "MEMORY WINDOW BIND ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_BAD_RESP_ERR:
|
|
|
|
return "BAD RESPONSE ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_LOC_ACCESS_ERR:
|
|
|
|
return "LOCAL ACCESS ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_REM_INV_REQ_ERR:
|
|
|
|
return "INVALID REQUEST ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_REM_ACCESS_ERR:
|
|
|
|
return "REMOTE ACCESS ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_REM_OP_ERR:
|
|
|
|
return "REMOTE OPERATION ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_RETRY_EXC_ERR:
|
|
|
|
return "RETRY EXCEEDED ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_RNR_RETRY_EXC_ERR:
|
|
|
|
return "RECEIVER NOT READY RETRY EXCEEEDED ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_LOC_RDD_VIOL_ERR:
|
|
|
|
return "LOCAL RDD VIOLATION ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_REM_INV_RD_REQ_ERR:
|
|
|
|
return "INVALID READ REQUEST ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_REM_ABORT_ERR:
|
|
|
|
return "REMOTE ABORT ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_INV_EECN_ERR:
|
|
|
|
return "INVALID EECN ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_INV_EEC_STATE_ERR:
|
|
|
|
return "INVALID EEC STATE ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_FATAL_ERR:
|
|
|
|
return "FATAL ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_RESP_TIMEOUT_ERR:
|
|
|
|
return "RESPONSE TIMEOUT ERROR";
|
|
|
|
break;
|
|
|
|
case IBV_WC_GENERAL_ERR:
|
|
|
|
return "GENERAL ERROR";
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return "STATUS UNDEFINED";
|
|
|
|
break;
|
|
|
|
}
|
2006-06-05 20:02:41 +00:00
|
|
|
}
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
|
|
|
|
|
2006-09-05 16:00:18 +00:00
|
|
|
static inline int btl_openib_frag_progress_one(
|
|
|
|
mca_btl_openib_module_t* openib_btl,
|
|
|
|
mca_btl_openib_frag_t* frag)
|
|
|
|
{
|
|
|
|
int res;
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
|
2006-09-05 16:00:18 +00:00
|
|
|
switch(frag->wr_desc.sr_desc.opcode) {
|
|
|
|
case IBV_WR_SEND:
|
|
|
|
res = mca_btl_openib_endpoint_send(frag->endpoint, frag);
|
|
|
|
break;
|
|
|
|
case IBV_WR_RDMA_WRITE:
|
|
|
|
res = mca_btl_openib_put((mca_btl_base_module_t*) openib_btl,
|
|
|
|
frag->endpoint,
|
|
|
|
(mca_btl_base_descriptor_t*) frag);
|
|
|
|
break;
|
|
|
|
case IBV_WR_RDMA_READ:
|
|
|
|
res = mca_btl_openib_get((mca_btl_base_module_t *) openib_btl,
|
|
|
|
frag->endpoint,
|
|
|
|
(mca_btl_base_descriptor_t*) frag);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
res = OMPI_ERROR;
|
|
|
|
BTL_ERROR(("error in posting pending operation, "
|
|
|
|
"invalide opcode %d\n", frag->wr_desc.sr_desc.opcode));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return res;
|
|
|
|
}
|
|
|
|
|
|
|
|
#define BTL_OPENIB_TOKENS(E, P) ((E)->sd_tokens[(P)] + \
|
|
|
|
(((P) == BTL_OPENIB_HP_QP)?(E)->eager_rdma_remote.tokens:0))
|
|
|
|
static void btl_openib_frag_progress_pending(
|
|
|
|
mca_btl_openib_module_t* openib_btl, mca_btl_base_endpoint_t *endpoint,
|
2006-09-28 11:41:45 +00:00
|
|
|
const int prio)
|
2006-09-05 15:59:02 +00:00
|
|
|
{
|
2006-09-05 16:00:18 +00:00
|
|
|
|
|
|
|
opal_list_item_t *frag_item;
|
|
|
|
mca_btl_openib_frag_t* frag;
|
2006-09-28 11:41:45 +00:00
|
|
|
size_t i, len = opal_list_get_size(&endpoint->pending_frags[prio]);
|
2006-09-05 16:00:18 +00:00
|
|
|
|
2006-09-28 11:41:45 +00:00
|
|
|
/* check to see if we need to progress any pending descriptors */
|
|
|
|
for(i = 0; i < len && endpoint->sd_wqe[prio] > 0 &&
|
|
|
|
BTL_OPENIB_TOKENS(endpoint, prio) > 0; i++) {
|
2006-09-05 16:00:18 +00:00
|
|
|
OPAL_THREAD_LOCK(&endpoint->endpoint_lock);
|
|
|
|
frag_item = opal_list_remove_first(&(endpoint->pending_frags[prio]));
|
|
|
|
OPAL_THREAD_UNLOCK(&endpoint->endpoint_lock);
|
|
|
|
if(NULL == (frag = (mca_btl_openib_frag_t *) frag_item))
|
|
|
|
break;
|
|
|
|
if(btl_openib_frag_progress_one(openib_btl, frag) ==
|
|
|
|
OMPI_ERR_OUT_OF_RESOURCE)
|
|
|
|
break;
|
|
|
|
}
|
2006-09-05 15:59:02 +00:00
|
|
|
|
2006-09-28 11:41:45 +00:00
|
|
|
if(BTL_OPENIB_LP_QP == prio) {
|
|
|
|
len = opal_list_get_size(&endpoint->pending_get_frags);
|
|
|
|
for(i = 0; i < len && endpoint->sd_wqe[BTL_OPENIB_LP_QP] > 0 &&
|
|
|
|
endpoint->get_tokens > 0; i++) {
|
|
|
|
OPAL_THREAD_LOCK(&endpoint->endpoint_lock);
|
|
|
|
frag_item = opal_list_remove_first(&(endpoint->pending_get_frags));
|
|
|
|
OPAL_THREAD_UNLOCK(&endpoint->endpoint_lock);
|
|
|
|
if(NULL == (frag = (mca_btl_openib_frag_t *) frag_item))
|
|
|
|
break;
|
|
|
|
if(btl_openib_frag_progress_one(openib_btl, frag) ==
|
|
|
|
OMPI_ERR_OUT_OF_RESOURCE)
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
len = opal_list_get_size(&endpoint->pending_put_frags);
|
|
|
|
for(i = 0; i < len && endpoint->sd_wqe[BTL_OPENIB_LP_QP] > 0; i++) {
|
|
|
|
OPAL_THREAD_LOCK(&endpoint->endpoint_lock);
|
|
|
|
frag_item = opal_list_remove_first(&(endpoint->pending_put_frags));
|
|
|
|
OPAL_THREAD_UNLOCK(&endpoint->endpoint_lock);
|
|
|
|
if(NULL == (frag = (mca_btl_openib_frag_t *) frag_item))
|
|
|
|
break;
|
|
|
|
if(btl_openib_frag_progress_one(openib_btl, frag) ==
|
|
|
|
OMPI_ERR_OUT_OF_RESOURCE)
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-09-05 16:00:18 +00:00
|
|
|
if(!mca_btl_openib_component.use_srq)
|
|
|
|
return;
|
|
|
|
|
2006-09-28 11:41:45 +00:00
|
|
|
len = opal_list_get_size(&openib_btl->pending_frags[prio]);
|
|
|
|
for(i = 0; i < len && openib_btl->sd_tokens[prio] > 0; i++) {
|
2006-09-05 16:00:18 +00:00
|
|
|
/* dequeue resources due to global flow control */
|
|
|
|
OPAL_THREAD_LOCK(&openib_btl->ib_lock);
|
|
|
|
frag_item = opal_list_remove_first(&openib_btl->pending_frags[prio]);
|
|
|
|
OPAL_THREAD_UNLOCK(&openib_btl->ib_lock);
|
|
|
|
if(NULL == (frag = (mca_btl_openib_frag_t *) frag_item))
|
|
|
|
break;
|
|
|
|
if(btl_openib_frag_progress_one(openib_btl, frag) ==
|
|
|
|
OMPI_ERR_OUT_OF_RESOURCE)
|
|
|
|
break;
|
|
|
|
}
|
2006-09-05 15:59:02 +00:00
|
|
|
}
|
|
|
|
|
2006-11-02 16:15:21 +00:00
|
|
|
#if OMPI_ENABLE_PROGRESS_THREADS == 1
|
|
|
|
void* mca_btl_openib_progress_thread(opal_object_t* arg)
|
|
|
|
{
|
|
|
|
mca_btl_openib_module_t* openib_btl;
|
|
|
|
opal_thread_t* thread = (opal_thread_t*)arg;
|
|
|
|
mca_btl_openib_hca_t* hca = thread->t_arg;
|
|
|
|
struct ibv_cq *ev_cq;
|
|
|
|
void *ev_ctx;
|
|
|
|
|
|
|
|
/* This thread enter in a cancel enabled state */
|
|
|
|
pthread_setcancelstate( PTHREAD_CANCEL_ENABLE, NULL );
|
|
|
|
pthread_setcanceltype( PTHREAD_CANCEL_ASYNCHRONOUS, NULL );
|
|
|
|
|
|
|
|
while (hca->progress) {
|
|
|
|
while(opal_progress_threads()) {
|
|
|
|
while(opal_progress_threads())
|
|
|
|
sched_yield();
|
|
|
|
usleep(100); /* give app a chance to re-enter library */
|
|
|
|
}
|
|
|
|
|
|
|
|
if(ibv_get_cq_event(hca->ib_channel, &ev_cq, &ev_ctx))
|
|
|
|
BTL_ERROR(("Failed to get CQ event with error %s",
|
|
|
|
strerror(errno)));
|
|
|
|
if(ibv_req_notify_cq(ev_cq, 0)) {
|
|
|
|
BTL_ERROR(("Couldn't request CQ notification with error %s",
|
|
|
|
strerror(errno)));
|
|
|
|
}
|
|
|
|
openib_btl=(mca_btl_openib_module_t*)ev_ctx;
|
|
|
|
|
|
|
|
if (ev_cq == openib_btl->ib_cq[BTL_OPENIB_LP_QP])
|
|
|
|
ibv_ack_cq_events (openib_btl->ib_cq[BTL_OPENIB_LP_QP], 1);
|
|
|
|
else
|
|
|
|
ibv_ack_cq_events (openib_btl->ib_cq[BTL_OPENIB_HP_QP], 1);
|
|
|
|
|
|
|
|
while(btl_openib_module_progress(openib_btl));
|
|
|
|
}
|
|
|
|
|
|
|
|
return PTHREAD_CANCELED;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2006-09-05 16:00:18 +00:00
|
|
|
/*
|
|
|
|
* IB component progress.
|
|
|
|
*/
|
Bring over all the work from the /tmp/ib-hw-detect branch. In
addition to my design and testing, it was conceptually approved by
Gil, Gleb, Pasha, Brad, and Galen. Functionally [probably somewhat
lightly] tested by Galen. We may still have to shake out some bugs
during the next few months, but it seems to be working for all the
cases that I can throw at it.
Here's a summary of the changes from that branch:
* Move MCA parameter registration to a new file (btl_openib_mca.c):
* Properly check the retun status of registering MCA params
* Check for valid values of MCA parameters
* Make help strings better
* Otherwise, the only default value of an MCA param that was
changed was max_btls; it went from 4 to -1 (meaning: use all
available)
* Properly prototyped internal functions in _component.c
* Made a bunch of functions static that didn't need to be public
* Renamed to remove "mca_" prefix from static functions
* Call new MCA param registration function
* Call new INI file read/lookup/finalize functions
* Updated a bunch of macros to be "BTL_" instead of "ORTE_"
* Be a little more consistent with return values
* Handle -1 for the max_btls MCA param
* Fixed a free() that should have been an OBJ_RELEASE()
* Some re-indenting
* Added INI-file parsing
* New flex file: btl_openib_ini.l
* New default HCA params .ini file (probably to be expanded over
time by other HCA vendors)
* Added more show_help messages for parsing problems
* Read in INI files and cache the values for later lookup
* When component opens an HCA, lookup to see if any corresponding
values were found in the INI files (ID'ed by the HCA vendor_id
and vendor_part_id)
* Added btl_openib_verbose MCA param that shows what the INI-file
stuff does (e.g., shows which MTU your HCA ends up using)
* Added btl_openib_hca_param_files as a colon-delimited list of INI
files to check for values during startup (in order,
left-to-right, just like the MCA base directory param).
* MTU is currently the only value supported in this framework.
* It is not a fatal error if we don't find params for the HCA in
the INI file(s). Instead, just print a warning. New MCA param
btl_openib_warn_no_hca_params_found can be used to disable
printing the warning.
* Add MTU to peer negotiation when making a connection
* Exchange maximum MTU; select the lesser of the two
This commit was SVN r11182.
2006-08-14 19:30:37 +00:00
|
|
|
static int btl_openib_component_progress(void)
|
2005-06-30 21:28:35 +00:00
|
|
|
{
|
2006-11-06 12:34:56 +00:00
|
|
|
int i, j, c;
|
|
|
|
int count = 0, ret;
|
2005-06-30 21:28:35 +00:00
|
|
|
mca_btl_openib_frag_t* frag;
|
2005-07-19 21:04:22 +00:00
|
|
|
mca_btl_openib_endpoint_t* endpoint;
|
2005-11-10 20:15:02 +00:00
|
|
|
|
2006-09-12 09:17:59 +00:00
|
|
|
/* Poll for RDMA completions - if any succeed, we don't process the slower
|
|
|
|
* queues.
|
|
|
|
*/
|
2005-06-30 21:28:35 +00:00
|
|
|
for(i = 0; i < mca_btl_openib_component.ib_num_btls; i++) {
|
2005-07-12 13:38:54 +00:00
|
|
|
mca_btl_openib_module_t* openib_btl = &mca_btl_openib_component.openib_btls[i];
|
2006-03-26 08:30:50 +00:00
|
|
|
|
|
|
|
c = openib_btl->eager_rdma_buffers_count;
|
|
|
|
|
|
|
|
for(j = 0; j < c; j++) {
|
|
|
|
endpoint =
|
|
|
|
orte_pointer_array_get_item(openib_btl->eager_rdma_buffers, j);
|
|
|
|
|
|
|
|
if(!endpoint) /* shouldn't happen */
|
|
|
|
continue;
|
|
|
|
|
|
|
|
OPAL_THREAD_LOCK(&endpoint->eager_rdma_local.lock);
|
|
|
|
frag = MCA_BTL_OPENIB_GET_LOCAL_RDMA_FRAG (endpoint,
|
|
|
|
endpoint->eager_rdma_local.head);
|
|
|
|
|
2006-09-19 13:27:05 +00:00
|
|
|
if(MCA_BTL_OPENIB_RDMA_FRAG_LOCAL(frag)) {
|
|
|
|
uint32_t size;
|
|
|
|
opal_atomic_rmb();
|
2007-01-12 23:14:45 +00:00
|
|
|
if(endpoint->nbo) {
|
|
|
|
BTL_OPENIB_FOOTER_NTOH((*frag->ftr));
|
|
|
|
}
|
2006-09-19 13:27:05 +00:00
|
|
|
size = MCA_BTL_OPENIB_RDMA_FRAG_GET_SIZE(frag->ftr);
|
2006-03-26 08:30:50 +00:00
|
|
|
#if OMPI_ENABLE_DEBUG
|
|
|
|
if (frag->ftr->seq != endpoint->eager_rdma_local.seq)
|
|
|
|
BTL_ERROR(("Eager RDMA wrong SEQ: received %d expected %d",
|
2007-01-12 23:14:45 +00:00
|
|
|
frag->ftr->seq,
|
|
|
|
endpoint->eager_rdma_local.seq));
|
2006-03-26 08:30:50 +00:00
|
|
|
endpoint->eager_rdma_local.seq++;
|
|
|
|
#endif
|
|
|
|
MCA_BTL_OPENIB_RDMA_NEXT_INDEX(endpoint->eager_rdma_local.head);
|
|
|
|
|
|
|
|
OPAL_THREAD_UNLOCK(&endpoint->eager_rdma_local.lock);
|
|
|
|
frag->hdr = (mca_btl_openib_header_t*)(((char*)frag->ftr) -
|
|
|
|
size + sizeof(mca_btl_openib_footer_t));
|
2007-01-04 22:07:37 +00:00
|
|
|
frag->segment.seg_addr.pval = ((unsigned char* )frag->hdr) +
|
|
|
|
sizeof(mca_btl_openib_header_t);
|
2006-08-28 11:03:56 +00:00
|
|
|
|
2006-09-12 09:17:59 +00:00
|
|
|
ret = btl_openib_handle_incoming(openib_btl,
|
2006-03-26 08:30:50 +00:00
|
|
|
frag->endpoint, frag,
|
2006-09-12 09:17:59 +00:00
|
|
|
size - sizeof(mca_btl_openib_footer_t),
|
|
|
|
BTL_OPENIB_HP_QP);
|
2006-08-16 20:21:38 +00:00
|
|
|
if (ret != MPI_SUCCESS) {
|
|
|
|
openib_btl->error_cb(&openib_btl->super,
|
|
|
|
MCA_BTL_ERROR_FLAGS_FATAL);
|
|
|
|
return 0;
|
|
|
|
}
|
2006-03-26 08:30:50 +00:00
|
|
|
count++;
|
|
|
|
} else
|
|
|
|
OPAL_THREAD_UNLOCK(&endpoint->eager_rdma_local.lock);
|
|
|
|
}
|
2006-06-17 21:32:25 +00:00
|
|
|
}
|
|
|
|
if(count) return count;
|
2006-03-26 08:30:50 +00:00
|
|
|
|
2006-06-17 21:32:25 +00:00
|
|
|
for(i = 0; i < mca_btl_openib_component.ib_num_btls; i++) {
|
2006-11-06 12:34:56 +00:00
|
|
|
count += btl_openib_module_progress(&mca_btl_openib_component.openib_btls[i]);
|
2006-11-02 16:15:21 +00:00
|
|
|
}
|
2006-11-06 12:34:56 +00:00
|
|
|
|
|
|
|
return count;
|
2006-11-02 16:15:21 +00:00
|
|
|
}
|
2006-03-26 08:30:50 +00:00
|
|
|
|
2006-11-02 16:15:21 +00:00
|
|
|
static int btl_openib_module_progress(mca_btl_openib_module_t* openib_btl)
|
|
|
|
{
|
|
|
|
static char *qp_name[] = {"HP", "LP"};
|
2006-11-06 12:34:56 +00:00
|
|
|
int qp;
|
2006-11-02 16:15:21 +00:00
|
|
|
int count = 0,ne = 0, ret;
|
|
|
|
mca_btl_openib_frag_t* frag;
|
|
|
|
mca_btl_openib_endpoint_t* endpoint;
|
|
|
|
struct ibv_wc wc;
|
|
|
|
|
|
|
|
for(qp = 0; qp < 2; qp++) {
|
|
|
|
ne = ibv_poll_cq(openib_btl->ib_cq[qp], 1, &wc);
|
|
|
|
|
|
|
|
if(0 == ne)
|
|
|
|
continue;
|
2006-06-05 21:23:45 +00:00
|
|
|
|
2006-11-02 16:15:21 +00:00
|
|
|
if(ne < 0 || wc.status != IBV_WC_SUCCESS)
|
|
|
|
goto error;
|
2007-01-12 23:14:45 +00:00
|
|
|
|
2006-11-02 16:15:21 +00:00
|
|
|
frag = (mca_btl_openib_frag_t*) (unsigned long) wc.wr_id;
|
|
|
|
endpoint = frag->endpoint;
|
|
|
|
/* Handle work completions */
|
|
|
|
switch(wc.opcode) {
|
2006-09-12 09:17:59 +00:00
|
|
|
case IBV_WC_RDMA_READ:
|
|
|
|
assert(BTL_OPENIB_LP_QP == qp);
|
2006-09-28 11:41:45 +00:00
|
|
|
OPAL_THREAD_ADD32(&endpoint->get_tokens, 1);
|
2006-09-12 09:17:59 +00:00
|
|
|
/* fall through */
|
|
|
|
|
2006-03-26 08:30:50 +00:00
|
|
|
case IBV_WC_RDMA_WRITE:
|
2006-09-12 09:17:59 +00:00
|
|
|
if(BTL_OPENIB_LP_QP == qp) {
|
|
|
|
/* process a completed write */
|
|
|
|
frag->base.des_cbfunc(&openib_btl->super, endpoint,
|
|
|
|
&frag->base, OMPI_SUCCESS);
|
|
|
|
|
|
|
|
/* return send wqe */
|
|
|
|
OPAL_THREAD_ADD32(&endpoint->sd_wqe[qp], 1);
|
|
|
|
|
|
|
|
/* check for pending frags */
|
|
|
|
btl_openib_frag_progress_pending(openib_btl, endpoint, qp);
|
|
|
|
|
|
|
|
count++;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
/* fall through for high prio QP */
|
2006-09-05 16:04:04 +00:00
|
|
|
case IBV_WC_SEND:
|
2006-01-12 23:42:44 +00:00
|
|
|
/* Process a completed send */
|
2006-09-05 15:59:02 +00:00
|
|
|
frag->base.des_cbfunc(&openib_btl->super, endpoint, &frag->base,
|
|
|
|
OMPI_SUCCESS);
|
2005-11-10 20:15:02 +00:00
|
|
|
|
2006-01-12 23:42:44 +00:00
|
|
|
/* return send wqe */
|
2006-09-12 09:17:59 +00:00
|
|
|
OPAL_THREAD_ADD32(&endpoint->sd_wqe[qp], 1);
|
2006-09-05 16:00:18 +00:00
|
|
|
if(mca_btl_openib_component.use_srq)
|
2006-09-12 09:17:59 +00:00
|
|
|
OPAL_THREAD_ADD32(&openib_btl->sd_tokens[qp], 1);
|
2006-09-28 11:41:45 +00:00
|
|
|
/* check to see if we need to progress any pending descriptors */
|
2006-09-12 09:17:59 +00:00
|
|
|
btl_openib_frag_progress_pending(openib_btl, endpoint, qp);
|
2006-01-12 23:42:44 +00:00
|
|
|
|
2006-09-12 09:17:59 +00:00
|
|
|
/* check to see if we need to return credits */
|
|
|
|
if(btl_openib_check_send_credits(endpoint, qp)) {
|
|
|
|
mca_btl_openib_endpoint_send_credits(endpoint, qp);
|
2006-09-05 16:00:18 +00:00
|
|
|
}
|
2006-01-12 23:42:44 +00:00
|
|
|
|
2005-11-10 20:15:02 +00:00
|
|
|
count++;
|
|
|
|
break;
|
|
|
|
|
2005-08-18 17:08:27 +00:00
|
|
|
case IBV_WC_RECV:
|
2006-09-05 16:04:04 +00:00
|
|
|
if(wc.wc_flags & IBV_WC_WITH_IMM) {
|
2006-09-12 09:17:59 +00:00
|
|
|
endpoint = (mca_btl_openib_endpoint_t*)
|
|
|
|
orte_pointer_array_get_item(openib_btl->endpoints,
|
|
|
|
wc.imm_data);
|
2006-09-05 16:04:04 +00:00
|
|
|
frag->endpoint = endpoint;
|
|
|
|
}
|
2005-08-18 17:08:27 +00:00
|
|
|
/* Process a RECV */
|
2006-09-12 09:17:59 +00:00
|
|
|
ret = btl_openib_handle_incoming(openib_btl, endpoint, frag,
|
|
|
|
wc.byte_len, qp);
|
2006-08-16 20:21:38 +00:00
|
|
|
if (ret != OMPI_SUCCESS) {
|
2006-09-12 09:17:59 +00:00
|
|
|
openib_btl->error_cb(&openib_btl->super,
|
|
|
|
MCA_BTL_ERROR_FLAGS_FATAL);
|
2006-08-16 20:21:38 +00:00
|
|
|
return 0;
|
|
|
|
}
|
2005-11-10 20:15:02 +00:00
|
|
|
count++;
|
2005-08-18 17:08:27 +00:00
|
|
|
break;
|
2005-11-10 20:15:02 +00:00
|
|
|
|
2005-08-18 17:08:27 +00:00
|
|
|
default:
|
2006-09-12 09:17:59 +00:00
|
|
|
BTL_ERROR(("Unhandled work completion opcode is %d",
|
|
|
|
wc.opcode));
|
|
|
|
openib_btl->error_cb(&openib_btl->super,
|
|
|
|
MCA_BTL_ERROR_FLAGS_FATAL);
|
2005-06-30 21:28:35 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return count;
|
2006-09-12 09:17:59 +00:00
|
|
|
error:
|
2006-09-05 15:59:02 +00:00
|
|
|
if(ne < 0){
|
|
|
|
BTL_ERROR(("error polling %s CQ with %d errno says %s\n",
|
|
|
|
qp_name[qp], ne, strerror(errno)));
|
|
|
|
} else {
|
|
|
|
static int flush_err_printed[] = {0, 0};
|
|
|
|
ompi_proc_t* remote_proc = NULL;
|
|
|
|
frag = (mca_btl_openib_frag_t*) (unsigned long) wc.wr_id;
|
|
|
|
if(frag) {
|
|
|
|
endpoint = (mca_btl_openib_endpoint_t*) frag->endpoint;
|
|
|
|
if(endpoint &&
|
2006-11-02 16:15:21 +00:00
|
|
|
endpoint->endpoint_proc &&
|
|
|
|
endpoint->endpoint_proc->proc_ompi) {
|
2006-09-05 15:59:02 +00:00
|
|
|
remote_proc = endpoint->endpoint_proc->proc_ompi;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if(wc.status != IBV_WC_WR_FLUSH_ERR || !flush_err_printed[qp]++)
|
|
|
|
BTL_PEER_ERROR(remote_proc, ("error polling %s CQ with status %s "
|
|
|
|
"status number %d for wr_id %llu opcode %d",
|
|
|
|
qp_name[qp],
|
|
|
|
btl_openib_component_status_to_string(wc.status),
|
2006-11-02 16:15:21 +00:00
|
|
|
wc.status, wc.wr_id, wc.opcode));
|
2006-09-05 15:59:02 +00:00
|
|
|
if(wc.status == IBV_WC_RETRY_EXC_ERR) {
|
|
|
|
opal_show_help("help-mpi-btl-openib.txt",
|
|
|
|
"btl_openib:retry-exceeded", true);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
openib_btl->error_cb(&openib_btl->super, MCA_BTL_ERROR_FLAGS_FATAL);
|
|
|
|
return count;
|
2005-06-30 21:28:35 +00:00
|
|
|
}
|