summaryrefslogtreecommitdiff
path: root/mk/mpi.buildlink3.mk
diff options
context:
space:
mode:
authorasau <asau@pkgsrc.org>2010-05-16 11:07:39 +0000
committerasau <asau@pkgsrc.org>2010-05-16 11:07:39 +0000
commit33e06c4f86de5b15d214bddf4b066368c5a306f8 (patch)
tree413f1376cc04267973bfb6f3990eaf0311594644 /mk/mpi.buildlink3.mk
parent719c6f9135f07477922780dce62fd57693b3b1c8 (diff)
downloadpkgsrc-33e06c4f86de5b15d214bddf4b066368c5a306f8.tar.gz
Introduce common point to depend on MPI:
- detect and use already installed MPI package; - use MPI_TYPE to determine which MPI package to use. Support MPICH2 and OpenMPI.
Diffstat (limited to 'mk/mpi.buildlink3.mk')
-rw-r--r--mk/mpi.buildlink3.mk39
1 files changed, 39 insertions, 0 deletions
diff --git a/mk/mpi.buildlink3.mk b/mk/mpi.buildlink3.mk
new file mode 100644
index 00000000000..6c360f417ea
--- /dev/null
+++ b/mk/mpi.buildlink3.mk
@@ -0,0 +1,39 @@
+# $NetBSD: mpi.buildlink3.mk,v 1.1 2010/05/16 11:07:39 asau Exp $
+#
+# This Makefile fragment is meant to be included by packages
+# that use any MPI implementation instead of one particular one.
+# The available MPI implementations are "mpich" and "openmpi".
+#
+# === User-settable variables ===
+#
+# MPI_TYPE
+# This value represents the type of MPI we wish to use on the system.
+#
+# Possible: mpich, openmpi
+# Default: mpich
+
+.if !defined(MPI_BUILDLINK3_MK)
+MPI_BUILDLINK3_MK= # define it
+
+.include "../../mk/bsd.prefs.mk"
+
+# Try to find if we have anything installed already
+.if exists($(LOCALBASE)/bin/mpicc)
+_MPI_PACKAGE!= $(PKG_INFO) -Q PKGPATH -F $(LOCALBASE)/bin/mpicc
+MPI_TYPE?= $(_MPI_PACKAGE:T)
+.else
+
+MPI_TYPE?= mpich # default to MPICH due to backward compatibility
+.if $(MPI_TYPE) == "mpich"
+_MPI_PACKAGE= parallel/mpi-ch
+.elif $(MPI_TYPE) == "openmpi"
+_MPI_PACKAGE= parallel/openmpi
+.else # invalid or unimplemented type
+PKG_FAIL_REASON= \
+ "${MPI_TYPE} is not an acceptable MPI type for ${PKGNAME}."
+.endif
+.endif
+
+.include "../../$(_MPI_PACKAGE)/buildlink3.mk"
+
+.endif # MPI_BUILDLINK3_MK