vtk-h: use cmake base pkg, overhaul recipe (#28898)
Co-authored-by: Massimiliano Culpo <massimiliano.culpo@gmail.com>
This commit is contained in:
parent
6ac3186132
commit
f35d8c4102
@ -27,7 +27,7 @@ def cmake_cache_entry(name, value, vtype=None):
|
|||||||
return 'set({0} "{1}" CACHE {2} "")\n\n'.format(name, value, vtype)
|
return 'set({0} "{1}" CACHE {2} "")\n\n'.format(name, value, vtype)
|
||||||
|
|
||||||
|
|
||||||
class VtkH(Package, CudaPackage):
|
class VtkH(CMakePackage, CudaPackage):
|
||||||
"""VTK-h is a toolkit of scientific visualization algorithms for emerging
|
"""VTK-h is a toolkit of scientific visualization algorithms for emerging
|
||||||
processor architectures. VTK-h brings together several projects like VTK-m
|
processor architectures. VTK-h brings together several projects like VTK-m
|
||||||
and DIY2 to provide a toolkit with hybrid parallel capabilities."""
|
and DIY2 to provide a toolkit with hybrid parallel capabilities."""
|
||||||
@ -62,6 +62,8 @@ class VtkH(Package, CudaPackage):
|
|||||||
|
|
||||||
variant("shared", default=True, description="Build vtk-h as shared libs")
|
variant("shared", default=True, description="Build vtk-h as shared libs")
|
||||||
variant("mpi", default=True, description="build mpi support")
|
variant("mpi", default=True, description="build mpi support")
|
||||||
|
# set to false for systems that implicitly link mpi
|
||||||
|
variant('blt_find_mpi', default=True, description='Use BLT CMake Find MPI logic')
|
||||||
variant("serial", default=True, description="build serial (non-mpi) libraries")
|
variant("serial", default=True, description="build serial (non-mpi) libraries")
|
||||||
variant("openmp", default=(sys.platform != 'darwin'),
|
variant("openmp", default=(sys.platform != 'darwin'),
|
||||||
description="build openmp support")
|
description="build openmp support")
|
||||||
@ -69,95 +71,63 @@ class VtkH(Package, CudaPackage):
|
|||||||
variant("contourtree", default=False, description="Enable contour tree support")
|
variant("contourtree", default=False, description="Enable contour tree support")
|
||||||
|
|
||||||
# Certain CMake versions have been found to break for our use cases
|
# Certain CMake versions have been found to break for our use cases
|
||||||
depends_on("cmake@3.14.1:3.14,3.18.2:", type='build')
|
depends_on("cmake@3.14.1:3.14.99,3.18.2:", type='build')
|
||||||
|
|
||||||
depends_on("mpi", when="+mpi")
|
depends_on("mpi", when="+mpi")
|
||||||
|
depends_on("cuda", when="+cuda")
|
||||||
|
depends_on("vtk-m+fpic")
|
||||||
|
|
||||||
depends_on("vtk-m~tbb")
|
# use vtk-m 1.7 or newer for vtk-h 0.8 or newer
|
||||||
depends_on("vtk-m@:1.6", when="@:0.7")
|
|
||||||
depends_on("vtk-m@1.7:", when="@0.8:")
|
depends_on("vtk-m@1.7:", when="@0.8:")
|
||||||
|
|
||||||
|
# use vtk-m 1.6 or lower for vtk-h 0.7 or lower
|
||||||
|
depends_on("vtk-m@:1.6", when="@:0.7")
|
||||||
|
depends_on("vtk-m~tbb")
|
||||||
|
depends_on("vtk-m+openmp", when="+openmp")
|
||||||
|
depends_on("vtk-m~openmp", when="~openmp")
|
||||||
|
|
||||||
depends_on("vtk-m+openmp", when="+openmp")
|
depends_on("vtk-m+openmp", when="+openmp")
|
||||||
depends_on("vtk-m~openmp", when="~openmp")
|
depends_on("vtk-m~openmp", when="~openmp")
|
||||||
|
|
||||||
depends_on("vtk-m~cuda", when="~cuda")
|
depends_on("vtk-m~cuda", when="~cuda")
|
||||||
depends_on("vtk-m+cuda", when="+cuda")
|
depends_on("vtk-m+cuda", when="+cuda")
|
||||||
for _arch in CudaPackage.cuda_arch_values:
|
for _arch in CudaPackage.cuda_arch_values:
|
||||||
depends_on("vtk-m cuda_arch={0}".format(_arch), when="+cuda cuda_arch={0}".format(_arch))
|
depends_on("vtk-m+cuda cuda_arch={0}".format(_arch), when="+cuda+openmp cuda_arch={0}".format(_arch))
|
||||||
|
|
||||||
depends_on("vtk-m+shared", when="+shared")
|
|
||||||
depends_on("vtk-m~shared", when="~shared")
|
depends_on("vtk-m~shared", when="~shared")
|
||||||
|
|
||||||
patch('vtk-h-shared-cuda.patch', when='@0.8.0,0.8.1 +cuda')
|
# provide cmake args (pass host config as cmake cache file)
|
||||||
|
def cmake_args(self):
|
||||||
|
host_config = self._get_host_config_path(self.spec)
|
||||||
|
options = []
|
||||||
|
options.extend(['-C', host_config, "../spack-src/src/"])
|
||||||
|
return options
|
||||||
|
|
||||||
def install(self, spec, prefix):
|
def _get_host_config_path(self, spec):
|
||||||
with working_dir('spack-build', create=True):
|
sys_type = spec.architecture
|
||||||
cmake_args = ["../src",
|
# if on llnl systems, we can use the SYS_TYPE
|
||||||
"-DVTKM_DIR={0}".format(spec["vtk-m"].prefix),
|
if "SYS_TYPE" in env:
|
||||||
"-DENABLE_TESTS=OFF",
|
sys_type = env["SYS_TYPE"]
|
||||||
"-DBUILD_TESTING=OFF"]
|
host_config_path = "{0}-{1}-{2}-vtkh-{3}.cmake".format(socket.gethostname(),
|
||||||
|
sys_type,
|
||||||
|
spec.compiler,
|
||||||
|
spec.dag_hash())
|
||||||
|
dest_dir = spec.prefix
|
||||||
|
host_config_path = os.path.abspath(join_path(dest_dir,
|
||||||
|
host_config_path))
|
||||||
|
return host_config_path
|
||||||
|
|
||||||
# shared vs static libs logic
|
@run_before('cmake')
|
||||||
# force static when building with CUDA <= 1.6
|
def hostconfig(self):
|
||||||
if "+cuda" in spec and spec["vtk-m"].satisfies('@:1.6'):
|
spec = self.spec
|
||||||
cmake_args.append('-DBUILD_SHARED_LIBS=OFF')
|
|
||||||
else:
|
|
||||||
if "+shared" in spec:
|
|
||||||
cmake_args.append('-DBUILD_SHARED_LIBS=ON')
|
|
||||||
else:
|
|
||||||
cmake_args.append('-DBUILD_SHARED_LIBS=OFF')
|
|
||||||
|
|
||||||
# mpi support
|
|
||||||
if "+mpi" in spec:
|
|
||||||
mpicc = spec['mpi'].mpicc
|
|
||||||
mpicxx = spec['mpi'].mpicxx
|
|
||||||
cmake_args.extend(["-DMPI_C_COMPILER={0}".format(mpicc),
|
|
||||||
"-DMPI_CXX_COMPILER={0}".format(mpicxx)])
|
|
||||||
mpiexe_bin = join_path(spec['mpi'].prefix.bin, 'mpiexec')
|
|
||||||
if os.path.isfile(mpiexe_bin):
|
|
||||||
cmake_args.append("-DMPIEXEC={0}".format(mpiexe_bin))
|
|
||||||
|
|
||||||
# openmp support
|
|
||||||
if "+openmp" in spec:
|
|
||||||
cmake_args.append("-DENABLE_OPENMP=ON")
|
|
||||||
|
|
||||||
# build with logging
|
|
||||||
if "+logging" in spec:
|
|
||||||
cmake_args.append("-DENABLE_LOGGING=ON")
|
|
||||||
|
|
||||||
if "+contourtree" in spec:
|
|
||||||
cmake_args.append("-DENABLE_FILTER_CONTOUR_TREE=ON")
|
|
||||||
|
|
||||||
# cuda support
|
|
||||||
if "+cuda" in spec:
|
|
||||||
cmake_args.append("-DVTKm_ENABLE_CUDA:BOOL=ON")
|
|
||||||
cmake_args.append("-DENABLE_CUDA:BOOL=ON")
|
|
||||||
cmake_args.append("-DCMAKE_CUDA_HOST_COMPILER={0}".format(
|
|
||||||
env["SPACK_CXX"]))
|
|
||||||
else:
|
|
||||||
cmake_args.append("-DVTKm_ENABLE_CUDA:BOOL=OFF")
|
|
||||||
cmake_args.append("-DENABLE_CUDA:BOOL=OFF")
|
|
||||||
# use release, instead of release with debug symbols b/c vtkh libs
|
|
||||||
# can overwhelm compilers with too many symbols
|
|
||||||
for arg in std_cmake_args:
|
|
||||||
if arg.count("CMAKE_BUILD_TYPE") == 0:
|
|
||||||
cmake_args.extend(std_cmake_args)
|
|
||||||
cmake_args.append("-DCMAKE_BUILD_TYPE=Release")
|
|
||||||
cmake(*cmake_args)
|
|
||||||
make()
|
|
||||||
make("install")
|
|
||||||
|
|
||||||
host_cfg_fname = self.create_host_config(spec,
|
|
||||||
prefix)
|
|
||||||
|
|
||||||
install(host_cfg_fname, prefix)
|
|
||||||
|
|
||||||
def create_host_config(self, spec, prefix, py_site_pkgs_dir=None):
|
|
||||||
"""
|
"""
|
||||||
This method creates a 'host-config' file that specifies
|
This method creates a 'host-config' file that specifies
|
||||||
all of the options used to configure and build vtkh.
|
all of the options used to configure and build vtkh.
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
if not os.path.isdir(spec.prefix):
|
||||||
|
os.mkdir(spec.prefix)
|
||||||
|
|
||||||
#######################
|
#######################
|
||||||
# Compiler Info
|
# Compiler Info
|
||||||
#######################
|
#######################
|
||||||
@ -181,9 +151,8 @@ def create_host_config(self, spec, prefix, py_site_pkgs_dir=None):
|
|||||||
|
|
||||||
cmake_exe = spec['cmake'].command.path
|
cmake_exe = spec['cmake'].command.path
|
||||||
|
|
||||||
host_cfg_fname = "%s-%s-%s-vtkh.cmake" % (socket.gethostname(),
|
# get hostconfig name
|
||||||
sys_type,
|
host_cfg_fname = self._get_host_config_path(spec)
|
||||||
spec.compiler)
|
|
||||||
|
|
||||||
cfg = open(host_cfg_fname, "w")
|
cfg = open(host_cfg_fname, "w")
|
||||||
cfg.write("##################################\n")
|
cfg.write("##################################\n")
|
||||||
@ -214,43 +183,8 @@ def create_host_config(self, spec, prefix, py_site_pkgs_dir=None):
|
|||||||
else:
|
else:
|
||||||
cfg.write(cmake_cache_entry("BUILD_SHARED_LIBS", "OFF"))
|
cfg.write(cmake_cache_entry("BUILD_SHARED_LIBS", "OFF"))
|
||||||
|
|
||||||
#######################################################################
|
cfg.write(cmake_cache_entry("ENABLE_TESTS", "OFF"))
|
||||||
# Core Dependencies
|
cfg.write(cmake_cache_entry("BUILD_TESTING", "OFF"))
|
||||||
#######################################################################
|
|
||||||
|
|
||||||
#######################
|
|
||||||
# VTK-h (and deps)
|
|
||||||
#######################
|
|
||||||
|
|
||||||
cfg.write("# vtk-m support \n")
|
|
||||||
|
|
||||||
if "+openmp" in spec:
|
|
||||||
cfg.write("# enable openmp support\n")
|
|
||||||
cfg.write(cmake_cache_entry("ENABLE_OPENMP", "ON"))
|
|
||||||
|
|
||||||
cfg.write("# vtk-m from spack\n")
|
|
||||||
cfg.write(cmake_cache_entry("VTKM_DIR", spec['vtk-m'].prefix))
|
|
||||||
|
|
||||||
#######################################################################
|
|
||||||
# Optional Dependencies
|
|
||||||
#######################################################################
|
|
||||||
|
|
||||||
#######################
|
|
||||||
# Serial
|
|
||||||
#######################
|
|
||||||
|
|
||||||
if "+serial" in spec:
|
|
||||||
cfg.write(cmake_cache_entry("ENABLE_SERIAL", "ON"))
|
|
||||||
else:
|
|
||||||
cfg.write(cmake_cache_entry("ENABLE_SERIAL", "OFF"))
|
|
||||||
|
|
||||||
#######################
|
|
||||||
# Logging
|
|
||||||
#######################
|
|
||||||
if "+logging" in spec:
|
|
||||||
cfg.write(cmake_cache_entry("ENABLE_LOGGING", "ON"))
|
|
||||||
else:
|
|
||||||
cfg.write(cmake_cache_entry("ENABLE_LOGGING", "OFF"))
|
|
||||||
|
|
||||||
#######################
|
#######################
|
||||||
# MPI
|
# MPI
|
||||||
@ -284,19 +218,68 @@ def create_host_config(self, spec, prefix, py_site_pkgs_dir=None):
|
|||||||
else:
|
else:
|
||||||
cfg.write(cmake_cache_entry("MPIEXEC",
|
cfg.write(cmake_cache_entry("MPIEXEC",
|
||||||
mpiexe_bin))
|
mpiexe_bin))
|
||||||
|
if "+blt_find_mpi" in spec:
|
||||||
|
cfg.write(cmake_cache_entry("ENABLE_FIND_MPI", "ON"))
|
||||||
|
else:
|
||||||
|
cfg.write(cmake_cache_entry("ENABLE_FIND_MPI", "OFF"))
|
||||||
else:
|
else:
|
||||||
cfg.write(cmake_cache_entry("ENABLE_MPI", "OFF"))
|
cfg.write(cmake_cache_entry("ENABLE_MPI", "OFF"))
|
||||||
|
|
||||||
#######################
|
#######################
|
||||||
# CUDA
|
# CUDA
|
||||||
#######################
|
#######################
|
||||||
|
|
||||||
cfg.write("# CUDA Support\n")
|
cfg.write("# CUDA Support\n")
|
||||||
|
|
||||||
if "+cuda" in spec:
|
if "+cuda" in spec:
|
||||||
cfg.write(cmake_cache_entry("ENABLE_CUDA", "ON"))
|
cfg.write(cmake_cache_entry("ENABLE_CUDA", "ON"))
|
||||||
|
cfg.write(cmake_cache_entry("VTKm_ENABLE_CUDA", "ON"))
|
||||||
|
cfg.write(cmake_cache_entry("CMAKE_CUDA_HOST_COMPILER", env["SPACK_CXX"]))
|
||||||
else:
|
else:
|
||||||
cfg.write(cmake_cache_entry("ENABLE_CUDA", "OFF"))
|
cfg.write(cmake_cache_entry("ENABLE_CUDA", "OFF"))
|
||||||
|
cfg.write(cmake_cache_entry("VTKm_ENABLE_CUDA", "OFF"))
|
||||||
|
|
||||||
|
#######################################################################
|
||||||
|
# Core Dependencies
|
||||||
|
#######################################################################
|
||||||
|
|
||||||
|
#######################
|
||||||
|
# VTK-h (and deps)
|
||||||
|
#######################
|
||||||
|
|
||||||
|
cfg.write("# vtk-m support \n")
|
||||||
|
|
||||||
|
if "+openmp" in spec:
|
||||||
|
cfg.write("# enable openmp support\n")
|
||||||
|
cfg.write(cmake_cache_entry("ENABLE_OPENMP", "ON"))
|
||||||
|
|
||||||
|
cfg.write("# vtk-m from spack\n")
|
||||||
|
cfg.write(cmake_cache_entry("VTKM_DIR", spec['vtk-m'].prefix))
|
||||||
|
|
||||||
|
#######################################################################
|
||||||
|
# Optional Dependencies
|
||||||
|
#######################################################################
|
||||||
|
|
||||||
|
#######################
|
||||||
|
# Serial
|
||||||
|
#######################
|
||||||
|
if "+serial" in spec:
|
||||||
|
cfg.write(cmake_cache_entry("ENABLE_SERIAL", "ON"))
|
||||||
|
else:
|
||||||
|
cfg.write(cmake_cache_entry("ENABLE_SERIAL", "OFF"))
|
||||||
|
|
||||||
|
#######################
|
||||||
|
# Logging
|
||||||
|
#######################
|
||||||
|
if "+logging" in spec:
|
||||||
|
cfg.write(cmake_cache_entry("ENABLE_LOGGING", "ON"))
|
||||||
|
else:
|
||||||
|
cfg.write(cmake_cache_entry("ENABLE_LOGGING", "OFF"))
|
||||||
|
|
||||||
|
# contour tree
|
||||||
|
if "+contourtree" in spec:
|
||||||
|
cfg.write(cmake_cache_entry("ENABLE_FILTER_CONTOUR_TREE", "ON"))
|
||||||
|
else:
|
||||||
|
cfg.write(cmake_cache_entry("ENABLE_FILTER_CONTOUR_TREE", "ON"))
|
||||||
|
|
||||||
cfg.write("##################################\n")
|
cfg.write("##################################\n")
|
||||||
cfg.write("# end spack generated host-config\n")
|
cfg.write("# end spack generated host-config\n")
|
||||||
@ -304,5 +287,4 @@ def create_host_config(self, spec, prefix, py_site_pkgs_dir=None):
|
|||||||
cfg.close()
|
cfg.close()
|
||||||
|
|
||||||
host_cfg_fname = os.path.abspath(host_cfg_fname)
|
host_cfg_fname = os.path.abspath(host_cfg_fname)
|
||||||
tty.info("spack generated conduit host-config file: " + host_cfg_fname)
|
tty.info("spack generated host-config file: " + host_cfg_fname)
|
||||||
return host_cfg_fname
|
|
||||||
|
@ -58,6 +58,7 @@ class VtkM(CMakePackage, CudaPackage, ROCmPackage):
|
|||||||
variant("64bitids", default=False,
|
variant("64bitids", default=False,
|
||||||
description="enable 64 bits ids")
|
description="enable 64 bits ids")
|
||||||
variant("testlib", default=False, description="build test library")
|
variant("testlib", default=False, description="build test library")
|
||||||
|
variant("fpic", default=False, description="build fpic support")
|
||||||
|
|
||||||
# Device variants
|
# Device variants
|
||||||
# CudaPackage provides cuda variant
|
# CudaPackage provides cuda variant
|
||||||
@ -183,6 +184,10 @@ def cmake_args(self):
|
|||||||
if spec.variants["build_type"].value != 'Release':
|
if spec.variants["build_type"].value != 'Release':
|
||||||
options.append("-DVTKm_NO_ASSERT:BOOL=ON")
|
options.append("-DVTKm_NO_ASSERT:BOOL=ON")
|
||||||
|
|
||||||
|
# Support for relocatable code
|
||||||
|
if "~shared" in spec and "+fpic" in spec:
|
||||||
|
options.append("-DCMAKE_POSITION_INDEPENDENT_CODE:BOOL=ON")
|
||||||
|
|
||||||
# cuda support
|
# cuda support
|
||||||
if "+cuda_native" in spec:
|
if "+cuda_native" in spec:
|
||||||
options.append("-DVTKm_ENABLE_CUDA:BOOL=ON")
|
options.append("-DVTKm_ENABLE_CUDA:BOOL=ON")
|
||||||
|
Loading…
Reference in New Issue
Block a user