summaryrefslogtreecommitdiff
path: root/var
diff options
context:
space:
mode:
authorAlex Richert <alexander.richert@noaa.gov>2024-04-04 10:48:39 -0700
committerGitHub <noreply@github.com>2024-04-04 12:48:39 -0500
commit3fed320013583a7301ca68ee8cb68d7e3d4ba12a (patch)
tree76d2bcadf58bbc9d89dd7efc046b5d2b4191b705 /var
parent1aa77e695d653fec30a6b6b50c09fffd481b59b2 (diff)
downloadspack-3fed320013583a7301ca68ee8cb68d7e3d4ba12a.tar.gz
spack-3fed320013583a7301ca68ee8cb68d7e3d4ba12a.tar.bz2
spack-3fed320013583a7301ca68ee8cb68d7e3d4ba12a.tar.xz
spack-3fed320013583a7301ca68ee8cb68d7e3d4ba12a.zip
Add MPI and arch bugfixes to SCOTCH (#39264)
* Add MPI and arch bugfixes to SCOTCH * Update scotch/package.py
Diffstat (limited to 'var')
-rw-r--r--var/spack/repos/builtin/packages/scotch/package.py14
-rw-r--r--var/spack/repos/builtin/packages/scotch/parmetis-mpi.patch127
2 files changed, 140 insertions, 1 deletions
diff --git a/var/spack/repos/builtin/packages/scotch/package.py b/var/spack/repos/builtin/packages/scotch/package.py
index 124426d1a0..fbc5ddbeb6 100644
--- a/var/spack/repos/builtin/packages/scotch/package.py
+++ b/var/spack/repos/builtin/packages/scotch/package.py
@@ -39,7 +39,11 @@ class Scotch(CMakePackage, MakefilePackage):
build_system(conditional("cmake", when="@7:"), "makefile", default="cmake")
variant("threads", default=True, description="use POSIX Pthreads within Scotch and PT-Scotch")
- variant("mpi_thread", default=False, description="use multi-threaded algorithms")
+ variant(
+ "mpi_thread",
+ default=False,
+ description="use multi-threaded algorithms in conjunction with MPI",
+ )
variant("mpi", default=True, description="Compile parallel libraries")
variant("compression", default=True, description="May use compressed files")
variant("esmumps", default=False, description="Compile esmumps (needed by mumps)")
@@ -48,6 +52,7 @@ class Scotch(CMakePackage, MakefilePackage):
"metis", default=False, description="Expose vendored METIS/ParMETIS libraries and wrappers"
)
variant("int64", default=False, description="Use int64_t for SCOTCH_Num typedef")
+ variant("noarch", default=False, description="Unset SPACK_TARGET_ARGS")
variant(
"link_error_lib",
default=False,
@@ -69,6 +74,9 @@ class Scotch(CMakePackage, MakefilePackage):
patch("libscotchmetis-return-6.0.5a.patch", when="@6.0.5a")
patch("libscotch-scotcherr-link-7.0.1.patch", when="@7.0.1 +link_error_lib")
+ # Avoid OpenMPI segfaults by using MPI_Comm_F2C for parmetis communicator
+ patch("parmetis-mpi.patch", when="@6.1.1:7.0.3 +metis ^openmpi")
+
# Vendored dependency of METIS/ParMETIS conflicts with standard
# installations
conflicts("metis", when="+metis")
@@ -127,6 +135,10 @@ class CMakeBuilder(spack.build_systems.cmake.CMakeBuilder):
return args
+ @when("+noarch")
+ def setup_build_environment(self, env):
+ env.unset("SPACK_TARGET_ARGS")
+
class MakefileBuilder(spack.build_systems.makefile.MakefileBuilder):
build_directory = "src"
diff --git a/var/spack/repos/builtin/packages/scotch/parmetis-mpi.patch b/var/spack/repos/builtin/packages/scotch/parmetis-mpi.patch
new file mode 100644
index 0000000000..23190ad584
--- /dev/null
+++ b/var/spack/repos/builtin/packages/scotch/parmetis-mpi.patch
@@ -0,0 +1,127 @@
+diff --git a/src/libscotchmetis/parmetis_dgraph_order_f.c b/src/libscotchmetis/parmetis_dgraph_order_f.c
+index 44c2ede..549a834 100644
+--- a/src/libscotchmetis/parmetis_dgraph_order_f.c
++++ b/src/libscotchmetis/parmetis_dgraph_order_f.c
+@@ -46,7 +46,7 @@
+ /** # Version 6.0 : from : 13 sep 2012 **/
+ /** to : 18 may 2019 **/
+ /** # Version 7.0 : from : 21 jan 2023 **/
+-/** to : 21 jan 2023 **/
++/** to : 30 jun 2023 **/
+ /** **/
+ /************************************************************/
+
+@@ -76,11 +76,14 @@ const SCOTCH_Num * const numflag, \
+ const SCOTCH_Num * const options, \
+ SCOTCH_Num * const order, \
+ SCOTCH_Num * const sizes, \
+-MPI_Comm * const commptr, \
++const MPI_Fint * const commptr, \
+ int * const revaptr), \
+ (vtxdist, xadj, adjncy, numflag, options, order, sizes, commptr, revaptr))
+ {
+- *revaptr = SCOTCH_ParMETIS_V3_NodeND (vtxdist, xadj, adjncy, numflag, options, order, sizes, commptr);
++ MPI_Comm commdat;
++
++ commdat = MPI_Comm_f2c (*commptr);
++ *revaptr = SCOTCH_ParMETIS_V3_NodeND (vtxdist, xadj, adjncy, numflag, options, order, sizes, &commdat);
+ }
+
+ /*******************/
+@@ -101,10 +104,13 @@ const SCOTCH_Num * const numflag, \
+ const SCOTCH_Num * const options, \
+ SCOTCH_Num * const order, \
+ SCOTCH_Num * const sizes, \
+-MPI_Comm * const commptr), \
++const MPI_Fint * const commptr), \
+ (vtxdist, xadj, adjncy, numflag, options, order, sizes, commptr))
+ {
+- METISNAMEU (ParMETIS_V3_NodeND) (vtxdist, xadj, adjncy, numflag, options, order, sizes, commptr);
++ MPI_Comm commdat;
++
++ commdat = MPI_Comm_f2c (*commptr);
++ METISNAMEU (ParMETIS_V3_NodeND) (vtxdist, xadj, adjncy, numflag, options, order, sizes, &commdat);
+ }
+
+ #endif /* SCOTCH_METIS_PREFIX */
+diff --git a/src/libscotchmetis/parmetis_dgraph_part_f.c b/src/libscotchmetis/parmetis_dgraph_part_f.c
+index 2b76818..3bf66af 100644
+--- a/src/libscotchmetis/parmetis_dgraph_part_f.c
++++ b/src/libscotchmetis/parmetis_dgraph_part_f.c
+@@ -44,7 +44,7 @@
+ /** # Version 6.0 : from : 13 sep 2012 **/
+ /** to : 18 may 2019 **/
+ /** # Version 7.0 : from : 21 jan 2023 **/
+-/** to : 21 jan 2023 **/
++/** to : 30 jun 2023 **/
+ /** **/
+ /************************************************************/
+
+@@ -81,12 +81,15 @@ const float * const ubvec, \
+ const SCOTCH_Num * const options, \
+ SCOTCH_Num * const edgecut, \
+ SCOTCH_Num * const part, \
+-MPI_Comm * const commptr, \
++const MPI_Fint * const commptr, \
+ int * const revaptr), \
+ (vtxdist, xadj, adjncy, vwgt, adjwgt, wgtflag, numflag, ncon, nparts, tpwgts, ubvec, options, edgecut, part, commptr, revaptr))
+ {
++ MPI_Comm commdat;
++
++ commdat = MPI_Comm_f2c (*commptr);
+ *revaptr = SCOTCH_ParMETIS_V3_PartKway (vtxdist, xadj, adjncy, vwgt, adjwgt, wgtflag, numflag,
+- ncon, nparts, tpwgts, ubvec, options, edgecut, part, commptr);
++ ncon, nparts, tpwgts, ubvec, options, edgecut, part, &commdat);
+ }
+
+ /*
+@@ -111,12 +114,15 @@ const float * const ubvec, \
+ const SCOTCH_Num * const options, \
+ SCOTCH_Num * const edgecut, \
+ SCOTCH_Num * const part, \
+-MPI_Comm * const commptr, \
++const MPI_Fint * const commptr, \
+ int * const revaptr), \
+ (vtxdist, xadj, adjncy, vwgt, adjwgt, wgtflag, numflag, ndims, xyz, ncon, nparts, tpwgts, ubvec, options, edgecut, part, commptr, revaptr))
+ {
++ MPI_Comm commdat;
++
++ commdat = MPI_Comm_f2c (*commptr);
+ *revaptr = SCOTCH_ParMETIS_V3_PartGeomKway (vtxdist, xadj, adjncy, vwgt, adjwgt, wgtflag, numflag,
+- ndims, xyz, ncon, nparts, tpwgts, ubvec, options, edgecut, part, commptr);
++ ndims, xyz, ncon, nparts, tpwgts, ubvec, options, edgecut, part, &commdat);
+ }
+
+ /*******************/
+@@ -144,10 +150,13 @@ const float * const ubvec, \
+ const SCOTCH_Num * const options, \
+ SCOTCH_Num * const edgecut, \
+ SCOTCH_Num * const part, \
+-MPI_Comm * const commptr), \
++const MPI_Fint * const commptr), \
+ (vtxdist, xadj, adjncy, vwgt, adjwgt, wgtflag, numflag, ncon, nparts, tpwgts, ubvec, options, edgecut, part, commptr))
+ {
+- METISNAMEU (ParMETIS_V3_PartKway) (vtxdist, xadj, adjncy, vwgt, adjwgt, wgtflag, numflag, ncon, nparts, tpwgts, ubvec, options, edgecut, part, commptr);
++ MPI_Comm commdat;
++
++ commdat = MPI_Comm_f2c (*commptr);
++ METISNAMEU (ParMETIS_V3_PartKway) (vtxdist, xadj, adjncy, vwgt, adjwgt, wgtflag, numflag, ncon, nparts, tpwgts, ubvec, options, edgecut, part, &commdat);
+ }
+
+ /*
+@@ -172,10 +181,13 @@ const float * const ubvec,
+ const SCOTCH_Num * const options, \
+ SCOTCH_Num * const edgecut, \
+ SCOTCH_Num * const part, \
+-MPI_Comm * const commptr), \
++const MPI_Fint * const commptr), \
+ (vtxdist, xadj, adjncy, vwgt, adjwgt, wgtflag, numflag, ndims, xyz, ncon, nparts, tpwgts, ubvec, options, edgecut, part, commptr))
+ {
+- METISNAMEU (ParMETIS_V3_PartGeomKway) (vtxdist, xadj, adjncy, vwgt, adjwgt, wgtflag, numflag, ndims, xyz, ncon, nparts, tpwgts, ubvec, options, edgecut, part, commptr);
++ MPI_Comm commdat;
++
++ commdat = MPI_Comm_f2c (*commptr);
++ METISNAMEU (ParMETIS_V3_PartGeomKway) (vtxdist, xadj, adjncy, vwgt, adjwgt, wgtflag, numflag, ndims, xyz, ncon, nparts, tpwgts, ubvec, options, edgecut, part, &commdat);
+ }
+
+ #endif /* SCOTCH_METIS_PREFIX */