Switch from mpich2 to mpich.

This commit is contained in:
Thierry Thomas 2020-06-14 09:14:21 +00:00
parent d7625a0297
commit f37ee436a9
Notes: svn2git 2021-03-31 03:12:20 +00:00
svn path=/head/; revision=538717
4 changed files with 37 additions and 48 deletions

View file

@ -3,6 +3,7 @@
PORTNAME= mumps
DISTVERSION= 5.1.2-aster6
PORTREVISION= 1
CATEGORIES= math
PKGNAMESUFFIX= -edf
@ -14,15 +15,11 @@ LICENSE_NAME= CeCILL-C
LICENSE_FILE= ${WRKSRC}/LICENSE
LICENSE_PERMS= dist-mirror dist-sell pkg-mirror pkg-sell auto-accept
LIB_DEPENDS= libblas.so:math/blas \
liblapack.so:math/lapack \
libmetis.so:math/metis
LIB_DEPENDS= libmetis.so:math/metis
USES= fortran
USES= blaslapack fortran
WRKSRC= ${WRKDIR}/${PORTNAME}-${PORTVERSION:R}
BLAS_LIBS= -lblas
LAPACK_LIBS= -llapack
FORTRANLIBS= -lgfortran
GCCLIBDIR= ${LDFLAGS}
USE_LDCONFIG= yes
@ -31,7 +28,16 @@ MUMPSVERSION= ${PORTVERSION:R}
LIBS= cmumps dmumps mumps_common pord smumps zmumps
PLIST_SUB= VE=${VEM} MUMPSVERSION=${MUMPSVERSION}
OPTIONS_DEFINE= DOCS EXAMPLES
OPTIONS_DEFINE= DOCS EXAMPLES MPI
MPI_BUILD_DEPENDS_OFF= ${LOCALBASE}/lib/libscotch.a:cad/scotch
MPI_BUILD_DEPENDS= ${LOCALBASE}/lib/libptscotch.a:cad/scotch
MPI_LIB_DEPENDS= libmpi.so:net/mpich \
libparmetis.so:math/parmetis \
libscalapack.so:math/scalapack
MPI_PLIST_SUB= WITH_LIBSEQ="@comment "
MPI_PLIST_SUB_OFF= WITH_LIBSEQ=""
MPI_LIBS_OFF= mpiseq
MAKE_JOBS_UNSAFE=yes
@ -40,31 +46,17 @@ MAKE_JOBS_UNSAFE=yes
.ifdef WITH_MPI
PKGNAMESUFFIX+= -mpich
BUILD_DEPENDS+= ${LOCALBASE}/include/mpif.h:net/mpich2 \
${LOCALBASE}/lib/libblacs.a:math/blacs \
${LOCALBASE}/lib/libptscotch.a:cad/scotch \
${LOCALBASE}/lib/libscalapack.a:math/scalapack \
${LOCALBASE}/lib/parmetis/libmetis.a:math/parmetis
LIB_DEPENDS+= liblapack.so:math/lapack
# Note: -l?mumps still requires to be linked with -lblacs + -lscalapack
RUN_DEPENDS+= ${LOCALBASE}/bin/mpirun:net/mpich2 \
${LOCALBASE}/lib/libblacs.a:math/blacs \
${LOCALBASE}/lib/libscalapack.a:math/scalapack
PLIST_SUB+= WITH_LIBSEQ="@comment "
.else
BUILD_DEPENDS+= ${LOCALBASE}/lib/libscotch.a:cad/scotch
PLIST_SUB+= WITH_LIBSEQ=""
LIBS+= mpiseq
.endif
pre-configure:
.ifdef WITH_MPI
post-patch-MPI-on:
${INSTALL_DATA} ${WRKSRC}/Make.inc/Makefile.FREEBSD10.PAR \
${WRKSRC}/Makefile.inc
.else
post-patch-MPI-off:
${INSTALL_DATA} ${WRKSRC}/Make.inc/Makefile.FREEBSD10.SEQ \
${WRKSRC}/Makefile.inc
.endif
pre-configure:
${DIRNAME} `${FC} -print-libgcc-file-name` > ${WRKSRC}/LIBDIR
.for MF in Makefile Makefile.inc PORD/lib/Makefile libseq/Makefile src/Makefile
${REINPLACE_CMD} -e 's+@CC@+${CC}+g ; s+@FC@+${FC}+g ; \
@ -74,8 +66,8 @@ pre-configure:
s+@SOVER@+${VEM}+g; \
s+@GCCLIBDIR@+${GCCLIBDIR}+g; \
s+@FORTRANLIBS@+${FORTRANLIBS}+g; \
s+@BLAS_LIBS@+${BLAS_LIBS}+ ; \
s+@LAPACK_LIBS@+${LAPACK_LIBS}+ ; \
s+@BLAS_LIBS@+${BLASLIB}+ ; \
s+@LAPACK_LIBS@+${LAPACKLIB}+ ; \
s+@LOCALBASE@+${LOCALBASE}+g;' \
${WRKSRC}/${MF}
.endfor
@ -84,10 +76,6 @@ do-install:
${INSTALL_DATA} ${WRKSRC}/include/*.h ${STAGEDIR}${PREFIX}/include
${INSTALL_DATA} ${WRKSRC}/lib/lib*.a ${STAGEDIR}${PREFIX}/lib
${INSTALL_LIB} ${WRKSRC}/lib/lib*.so.${VEM} ${STAGEDIR}${PREFIX}/lib
.ifndef WITH_MPI
${INSTALL_DATA} ${WRKSRC}/libseq/libmpiseq.a ${STAGEDIR}${PREFIX}/lib
${INSTALL_LIB} ${WRKSRC}/libseq/libmpiseq*.so.${VEM} ${STAGEDIR}${PREFIX}/lib
.endif
.for lib in ${LIBS}
(cd ${STAGEDIR}${PREFIX}/lib && ${LN} -sf lib${lib}.so.${VEM} ${STAGEDIR}${PREFIX}/lib/lib${lib}.so)
. endfor
@ -101,6 +89,10 @@ do-install:
${INSTALL_PROGRAM} ${WRKSRC}/examples/${ex} ${STAGEDIR}${EXAMPLESDIR}
. endfor
do-install-MPI-off:
${INSTALL_DATA} ${WRKSRC}/libseq/libmpiseq.a ${STAGEDIR}${PREFIX}/lib
${INSTALL_LIB} ${WRKSRC}/libseq/libmpiseq*.so.${VEM} ${STAGEDIR}${PREFIX}/lib
regression-test: install
.if defined (WITH_MPI) && defined(MAINTAINER_MODE)
. if !exists(${HOME}/.mpd.conf)
@ -108,7 +100,6 @@ regression-test: install
${CHMOD} go-r ${HOME}/.mpd.conf
@${ECHO_MSG} "${HOME}/.mpd.conf has been generated - please change the secret word!"
. endif
${LOCALBASE}/bin/mpd &
(cd ${WRKSRC}/examples && \
${LOCALBASE}/bin/mpirun -np 2 ./ssimpletest < input_simpletest_real ; \
${LOCALBASE}/bin/mpirun -np 2 ./dsimpletest < input_simpletest_real ; \
@ -117,7 +108,6 @@ regression-test: install
${ECHO_MSG} "The solution should be (1,2,3,4,5)" ; \
${LOCALBASE}/bin/mpirun -np 3 ./c_example ; \
${ECHO_MSG} "The solution should be (1,2)")
${LOCALBASE}/bin/mpdallexit
.else
(cd ${WRKSRC}/examples && \
./ssimpletest < input_simpletest_real ; \

View file

@ -1,4 +1,4 @@
--- Make.inc/Makefile.FREEBSD10.PAR.orig 2017-08-08 07:32:58 UTC
--- Make.inc/Makefile.FREEBSD10.PAR.orig 2019-04-03 14:40:12 UTC
+++ Make.inc/Makefile.FREEBSD10.PAR
@@ -20,7 +20,7 @@
#
@ -39,7 +39,7 @@
# The following variables will be used in the compilation process.
# Please note that -Dptscotch and -Dparmetis imply -Dscotch and -Dmetis respectively.
@@ -66,34 +66,34 @@ IORDERINGSC = $(IMETIS) $(IPORD) $(ISCOT
@@ -66,34 +66,34 @@ IORDERINGSC = $(IMETIS) $(IPORD) $(ISCOTCH)
PLAT =
LIBEXT = .a
@ -60,7 +60,7 @@
RANLIB = ranlib
LAPACK = -llapack
-SCALAP = -lscalapack -lblacs
+SCALAP = -L@LOCALBASE@/lib -lblacs -lblacsc -lblacsf77 -lscalapack
+SCALAP = -L@LOCALBASE@/lib -lscalapack -lexecinfo
INCPAR = -I/usr/local/include
-LIBPAR = $(SCALAP) $(LAPACK) -L/usr/local/lib -lmpi
@ -85,5 +85,5 @@
-OPTC = -O -I. #-fopenmp
+OPTC = @CFLAGS@ -I. #-fopenmp
#End Optimized options
INCS = $(INCPAR)
LIBS = $(LIBPAR)

View file

@ -1,4 +1,4 @@
--- Make.inc/Makefile.FREEBSD10.SEQ.orig 2017-08-08 07:32:58 UTC
--- Make.inc/Makefile.FREEBSD10.SEQ.orig 2019-04-03 14:40:12 UTC
+++ Make.inc/Makefile.FREEBSD10.SEQ
@@ -20,7 +20,7 @@
#
@ -29,7 +29,7 @@
#LMETIS = -L$(LMETISDIR) -lparmetis -lmetis
# The following variables will be used in the compilation process.
@@ -66,14 +66,14 @@ IORDERINGSC = $(IMETIS) $(IPORD) $(ISCOT
@@ -66,14 +66,14 @@ IORDERINGSC = $(IMETIS) $(IPORD) $(ISCOTCH)
PLAT =
LIBEXT = .a
@ -69,5 +69,5 @@
-OPTC = -O -I. #-fopenmp
+OPTC = @CFLAGS@ -I. #-fopenmp
#End Optimized options
INCS = $(INCSEQ)
LIBS = $(LIBSEQ)

View file

@ -1,6 +1,6 @@
--- PORD/lib/Makefile.orig 2017-08-08 07:32:58 UTC
--- PORD/lib/Makefile.orig 2019-04-03 14:40:12 UTC
+++ PORD/lib/Makefile
@@ -22,12 +22,17 @@ OBJS = graph.o gbipart.o gbisect.o ddcre
@@ -22,11 +22,16 @@ OBJS = graph.o gbipart.o gbisect.o ddcreate.o ddbisect
# OUTC = -o
.c.o:
@ -14,10 +14,9 @@
+libpord$(LIBEXT): $(OBJS)
+ $(AR) $@ $(OBJS)
$(RANLIB) $@
+
+libpord.so.@SOVER@: $(OBJS)
+ $(CC) -shared $(OBJS) -Wl,-soname,libpord$(PLAT).so.@SOVER@ -o libpord$(PLAT).so.@SOVER@
+
clean:
rm -f *.o