2004-08-06 19:35:57 +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.
|
2009-04-24 16:39:33 +00:00
|
|
|
# Copyright (c) 2004-2009 High Performance Computing Center Stuttgart,
|
2004-11-28 20:09:25 +00:00
|
|
|
# University of Stuttgart. All rights reserved.
|
2005-03-24 12:43:37 +00:00
|
|
|
# Copyright (c) 2004-2005 The Regents of the University of California.
|
|
|
|
# All rights reserved.
|
2014-03-28 18:24:32 +00:00
|
|
|
# Copyright (c) 2010-2014 Cisco Systems, Inc. All rights reserved.
|
2013-02-26 20:44:56 +00:00
|
|
|
# Copyright (c) 2010-2013 Los Alamos National Security, LLC.
|
2010-08-23 16:04:13 +00:00
|
|
|
# All rights reserved.
|
2004-11-22 01:38:40 +00:00
|
|
|
# $COPYRIGHT$
|
|
|
|
#
|
|
|
|
# Additional copyrights may follow
|
|
|
|
#
|
2004-08-06 19:35:57 +00:00
|
|
|
# $HEADER$
|
|
|
|
#
|
|
|
|
|
2004-08-06 21:40:23 +00:00
|
|
|
# A word of explanation...
|
|
|
|
#
|
|
|
|
# This library is linked against various MCA components because all
|
|
|
|
# shared-memory based components (e.g., mpool, ptl, etc.) need to
|
|
|
|
# share some common code and data. There's two cases:
|
|
|
|
#
|
|
|
|
# 1. libmca_common_sm.la is a shared library. By linking that shared
|
|
|
|
# library to all components that need it, the OS linker will
|
|
|
|
# automatically load it into the process as necessary, and there will
|
|
|
|
# only be one copy (i.e., all the components will share *one* copy of
|
|
|
|
# the code and data).
|
|
|
|
#
|
|
|
|
# 2. libmca_common_sm.la is a static library. In this case, it will
|
|
|
|
# be rolled up into the top-level libmpi.la. It will also be rolled
|
|
|
|
# into each component, but then the component will also be rolled up
|
|
|
|
# into the upper-level libmpi.la. Linkers universally know how to
|
|
|
|
# "figure this out" so that we end up with only one copy of the code
|
|
|
|
# and data.
|
2004-08-27 14:55:41 +00:00
|
|
|
#
|
|
|
|
# Note that building this common component statically and linking
|
|
|
|
# against other dynamic components is *not* supported!
|
2004-08-06 21:40:23 +00:00
|
|
|
|
2004-08-06 19:35:57 +00:00
|
|
|
# Header files
|
|
|
|
|
|
|
|
headers = \
|
2010-08-23 16:04:13 +00:00
|
|
|
common_sm_rml.h \
|
2011-06-21 15:41:57 +00:00
|
|
|
common_sm.h
|
2004-08-06 19:35:57 +00:00
|
|
|
|
2004-08-27 14:55:41 +00:00
|
|
|
# Source files
|
2004-08-06 19:35:57 +00:00
|
|
|
|
2004-08-27 14:55:41 +00:00
|
|
|
sources = \
|
2010-08-23 16:04:13 +00:00
|
|
|
common_sm_rml.c \
|
2011-06-21 15:41:57 +00:00
|
|
|
common_sm.c
|
2010-08-23 16:04:13 +00:00
|
|
|
|
2009-10-02 17:13:56 +00:00
|
|
|
# Help file
|
|
|
|
|
2014-01-07 22:11:15 +00:00
|
|
|
dist_ompidata_DATA = help-mpi-common-sm.txt
|
2009-10-02 17:13:56 +00:00
|
|
|
|
2004-08-27 14:55:41 +00:00
|
|
|
# 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 = libmca_common_sm.la
|
|
|
|
comp_noinst = libmca_common_sm_noinst.la
|
|
|
|
|
2010-09-17 23:04:06 +00:00
|
|
|
if MCA_BUILD_ompi_common_sm_DSO
|
2004-08-27 14:55:41 +00:00
|
|
|
lib_LTLIBRARIES += $(comp_inst)
|
|
|
|
else
|
|
|
|
noinst_LTLIBRARIES += $(comp_noinst)
|
|
|
|
endif
|
|
|
|
|
|
|
|
libmca_common_sm_la_SOURCES = $(headers) $(sources)
|
2009-10-27 20:58:34 +00:00
|
|
|
libmca_common_sm_la_LDFLAGS = -version-info $(libmca_common_sm_so_version)
|
2004-08-27 14:55:41 +00:00
|
|
|
libmca_common_sm_noinst_la_SOURCES = $(libmca_common_sm_la_SOURCES)
|
|
|
|
|
2004-08-06 19:35:57 +00:00
|
|
|
# Conditionally install the header files
|
|
|
|
|
|
|
|
if WANT_INSTALL_HEADERS
|
2014-01-07 22:11:15 +00:00
|
|
|
ompidir = $(ompiincludedir)/$(subdir)
|
2004-08-06 19:35:57 +00:00
|
|
|
ompi_HEADERS = $(headers)
|
|
|
|
endif
|
2004-08-27 14:55:41 +00:00
|
|
|
|
|
|
|
# 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).
|
|
|
|
|
2014-03-28 18:24:32 +00:00
|
|
|
# See Makefile.ompi-rules for an explanation of the "V" macros, below
|
|
|
|
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)`;
|
|
|
|
|
2004-08-27 14:55:41 +00:00
|
|
|
all-local:
|
2014-03-28 18:24:32 +00:00
|
|
|
$(OMPI_V_LN_SCOMP) if test -z "$(lib_LTLIBRARIES)"; then \
|
2004-08-27 14:55:41 +00:00
|
|
|
rm -f "$(comp_inst)"; \
|
|
|
|
$(LN_S) "$(comp_noinst)" "$(comp_inst)"; \
|
|
|
|
fi
|
|
|
|
|
|
|
|
clean-local:
|
|
|
|
if test -z "$(lib_LTLIBRARIES)"; then \
|
|
|
|
rm -f "$(comp_inst)"; \
|
|
|
|
fi
|