
If PMIX_PACKAGE_RANK is available, uses this value to select between multiple NIC of equal distance between the current process. If this value is not available, try to calculate it by getting the locality string from each local process and assign a package_rank. If everything fails, fall back to using process_id.rank to select the NIC. This last case is not ideal, but has a small chance of occuring, and causes an output to be displayed to notify that this is occuring. Signed-off-by: Nikola Dancejic <dancejic@amazon.com>
109 строки
3.8 KiB
Makefile
109 строки
3.8 KiB
Makefile
#
|
|
# Copyright (c) 2004-2005 The Trustees of Indiana University and Indiana
|
|
# University Research and Technology
|
|
# Corporation. All rights reserved.
|
|
# Copyright (c) 2004-2013 The University of Tennessee and The University
|
|
# of Tennessee Research Foundation. All rights
|
|
# reserved.
|
|
# Copyright (c) 2004-2009 High Performance Computing Center Stuttgart,
|
|
# University of Stuttgart. All rights reserved.
|
|
# Copyright (c) 2004-2005 The Regents of the University of California.
|
|
# All rights reserved.
|
|
# Copyright (c) 2011-2013 NVIDIA Corporation. All rights reserved.
|
|
# Copyright (c) 2014 Cisco Systems, Inc. All rights reserved.
|
|
# Copyright (c) 2015 Intel, Inc. All rights reserved.
|
|
# Copyright (c) 2017 Los Alamos National Security, LLC. All rights
|
|
# reserved.
|
|
# Copyright (c) 2019 Hewlett Packard Enterprise. All rights reserved.
|
|
# $COPYRIGHT$
|
|
#
|
|
# Additional copyrights may follow
|
|
#
|
|
# $HEADER$
|
|
#
|
|
# A word of explanation...
|
|
#
|
|
# This library is linked against various MCA components because the
|
|
# support for ofis is needed in various places.
|
|
#
|
|
# Note that building this common component statically and linking
|
|
# against other dynamic components is *not* supported!
|
|
|
|
AM_CPPFLAGS = $(opal_ofi_CPPFLAGS)
|
|
|
|
dist_opaldata_DATA = help-common-ofi.txt
|
|
|
|
# Header files
|
|
|
|
headers = \
|
|
common_ofi.h
|
|
|
|
# Source files
|
|
|
|
sources = \
|
|
common_ofi.c
|
|
|
|
# As per above, we'll either have an installable or noinst result.
|
|
# The installable one should follow the same MCA prefix naming rules
|
|
# (i.e., libmca_<type>_<name>.la). The noinst one can be named
|
|
# whatever it wants, although libmca_<type>_<name>_noinst.la is
|
|
# recommended.
|
|
|
|
# To simplify components that link to this library, we will *always*
|
|
# have an output libtool library named libmca_<type>_<name>.la -- even
|
|
# for case 2) described above (i.e., so there's no conditional logic
|
|
# necessary in component Makefile.am's that link to this library).
|
|
# Hence, if we're creating a noinst version of this library (i.e.,
|
|
# case 2), we sym link it to the libmca_<type>_<name>.la name
|
|
# (libtool will do the Right Things under the covers). See the
|
|
# all-local and clean-local rules, below, for how this is effected.
|
|
|
|
lib_LTLIBRARIES =
|
|
noinst_LTLIBRARIES =
|
|
comp_inst = lib@OPAL_LIB_PREFIX@mca_common_ofi.la
|
|
comp_noinst = lib@OPAL_LIB_PREFIX@mca_common_ofi_noinst.la
|
|
|
|
|
|
if MCA_BUILD_opal_common_ofi_DSO
|
|
lib_LTLIBRARIES += $(comp_inst)
|
|
else
|
|
noinst_LTLIBRARIES += $(comp_noinst)
|
|
endif
|
|
|
|
lib@OPAL_LIB_PREFIX@mca_common_ofi_la_SOURCES = $(headers) $(sources)
|
|
lib@OPAL_LIB_PREFIX@mca_common_ofi_la_LDFLAGS = \
|
|
$(opal_ofi_LDFLAGS) \
|
|
-version-info $(libmca_opal_common_ofi_so_version)
|
|
lib@OPAL_LIB_PREFIX@mca_common_ofi_la_LIBADD = $(opal_ofi_LIBS)
|
|
|
|
lib@OPAL_LIB_PREFIX@mca_common_ofi_noinst_la_SOURCES = $(headers) $(sources)
|
|
lib@OPAL_LIB_PREFIX@mca_common_ofi_noinst_la_LDFLAGS = $(opal_ofi_LDFLAGS)
|
|
lib@OPAL_LIB_PREFIX@mca_common_ofi_noinst_la_LIBADD = $(opal_ofi_LIBS)
|
|
|
|
# Conditionally install the header files
|
|
|
|
if WANT_INSTALL_HEADERS
|
|
opaldir = $(opalincludedir)/$(subdir)
|
|
opal_HEADERS = $(headers)
|
|
endif
|
|
|
|
# These two rules will sym link the "noinst" libtool library filename
|
|
# to the installable libtool library filename in the case where we are
|
|
# compiling this component statically (case 2), described above).
|
|
|
|
V=0
|
|
OMPI_V_LN_SCOMP = $(ompi__v_LN_SCOMP_$V)
|
|
ompi__v_LN_SCOMP_ = $(ompi__v_LN_SCOMP_$AM_DEFAULT_VERBOSITY)
|
|
ompi__v_LN_SCOMP_0 = @echo " LN_S " `basename $(comp_inst)`;
|
|
|
|
all-local:
|
|
$(OMPI_V_LN_SCOMP) if test -z "$(lib_LTLIBRARIES)"; then \
|
|
rm -f "$(comp_inst)"; \
|
|
$(LN_S) "$(comp_noinst)" "$(comp_inst)"; \
|
|
fi
|
|
|
|
clean-local:
|
|
if test -z "$(lib_LTLIBRARIES)"; then \
|
|
rm -f "$(comp_inst)"; \
|
|
fi
|