-
Notifications
You must be signed in to change notification settings - Fork 99
Building
KokkosKernels is a stand-alone library in the Kokkos Ecosystem, as well as a package within the Trilinos Project
Building KokkosKernels as a stand-alone library requires CMake. Using KokkosKernels as a package within Trilinos additionally requires the TriBITS build system.
- Compatible versions of Kokkos and Kokkos Kernels cloned or downloaded from https://github.com
- Supported compiler and computing hardware - see Kokkos' README for what is currently tested.
- CUDA builds require use of the
nvcc_wrapper
script provided by Kokkos, unless using Clang-CUDA
- Create a build directory
<BUILD_DIR>
(different from source and install locations).
> mkdir <BUILD_DIR>
cd <BUILD_DIR>
- Run
cmake ${SOURCE_DIR} <...>
whereSOURCE_DIR
is the location of the Kokkos Kernels source.<...>
is a list of CMake options given as `-D{OPTION}={VALUE}' - Build and install the library, depending on the generator (make is default):
> make install
or
> ninja install
To use the Ninja build system add -G Ninja
.
A full listing of CMake options is given below. Another way to get a list of options and documentation is to the use ccmake
utility.
ccmake <SOURCE_DIR>
which brings up a user interface listing all the options, their default values, and associated documentation.
Below is a list of example CMake configurations. Kokkos Kernels requires first building Kokkos (or including it as a subproject). To see a full list of options for building Kokkos, see BUILD
First install Kokkos:
> cmake \
-DCMAKE_CXX_COMPILER=g++ \
-DCMAKE_INSTALL_PREFIX=${HOME}/kokkos-install \
-DKokkos_ENABLE_OPENMP=ON \
-DKokkos_ARCH_SKX=ON \
<KOKKOS_SOURCE>
> make install
Then build Kokkos Kernels, pointing to Kokkos:
> cmake \
-DKokkos_ROOT=${HOME}/kokkos-install \
-DCMAKE_CXX_COMPILER=g++
<KOKKOS_KERNELS_SOURCE>
> make
Cuda and Serial backends, nvcc_wrapper compiler, Power8 and Volta sm_70 architectures, various compilation flags
First install Kokkos:
> cmake \
-DCMAKE_CXX_COMPILER=<KOKKOS_SOURCE>/bin/nvcc_wrapper \
-DCMAKE_INSTALL_PREFIX=${HOME}/kokkos-install \
-DKokkos_ENABLE_CUDA=ON \
-DKokkos_ENABLE_SERIAL=ON \
-DKokkos_ARCH_VOLTA70=ON \
-DKokkos_ARCH_POWER8=ON \
<KOKKOS_SOURCE>
> make install
Then build Kokkos Kernels, pointing to Kokkos:
> cmake \
-DKokkos_ROOT=${HOME}/kokkos-install \
-DCMAKE_CXX_COMPILER=${HOME}/kokkos-install/bin/nvcc_wrapper \
<KOKKOS_KERNELS_SOURCE>
> make
If you wish to enable certain CUDA third-party libraries (TPLs), you can also configure with
> cmake \
-DKokkos_ROOT=${HOME}/kokkos-install \
-DCMAKE_CXX_COMPILER=${HOME}/kokkos-install/bin/nvcc_wrapper \
-DKokkosKernels_ENABLE_TPL_CUSPARSE=ON \
<KOKKOS_KERNELS_SOURCE>
- CMake >= 3.10
- Compatible compiler and hardware
If building with Trilinos, the same set of CMake options apply. The only difference is you must enable KokkosKernels:
cmake \
-D Trilinos_ENABLE_KokkosKernels:BOOL=ON \
...
Note, no tests will be available unless -DKokkosKernels_ENABLE_TESTS=ON
is in your cmake command.
To run the tests, simply execute a CMake build and then run:
> make test
To limit the tests, one can cd
into either unit_test
or perf_test
and also run make test
. To show full detail of all tests, you can run ctest --extra-verbose
.
You can filter exactly which tests are run based on regular expressions with
ctest -R <match_string>
Tests are grouped into individual executables. You can run the executable for one of the enabled backends based on your configuration, for example if OpenMP is enabled:
>./KokkosKernels_UnitTest_OpenMP
To run a specific test in the executable use the --gtest_filter
flag:
>./KokkosKernels_UnitTest_OpenMP --gtest_filter=openmp.dot_double`
-
KokkosKernels_ENABLE_TESTS
: BOOL- Whether to build tests.
- Default: OFF
-
KokkosKernels_TEST_ETI_ONLY
: BOOL- Whether to restrict testing to ETI types.
- Default: ON
-
KokkosKernels_ENABLE_PERFTESTS
: STRING- Whether to build performance tests
- Default: OFF
-
KokkosKernels_ENABLE_TESTS_AND_PERFSUITE
: BOOL- Whether to build performance tests and suite.
- Default: OFF
-
KokkosKernels_ENABLE_EXAMPLES
: BOOL- Whether to build examples.
- Default: OFF
-
KokkosKernels_ENABLED_COMPONENTS
: BOOL- A list of components to enable in testing and building
- Default: ALL
- Valid: BATCHED BLAS LAPACK GRAPH SPARSE ALL
-
KokkosKernels_ENABLE_ALL_COMPONENTS
: BOOL -
KokkosKernels_ENABLE_COMPONENT_BATCHED
: BOOL -
KokkosKernels_ENABLE_COMPONENT_BLAS
: BOOL -
KokkosKernels_ENABLE_COMPONENT_LAPACK
: BOOL -
KokkosKernels_ENABLE_COMPONENT_SPARSE
: BOOL -
KokkosKernels_ENABLE_COMPONENT_GRAPH
: BOOL -
KokkosKernels_ENABLE_COMPONENT_ODE
: BOOL
-
KokkosKernels_INST_HALF
: BOOL- Whether to pre instantiate kernels for the scalar type Kokkos::Experimental::half_t. Disabling this may increase build times
- Default: OFF
-
KokkosKernels_INST_BHALF
: BOOL- Whether to pre instantiate kernels for the scalar type Kokkos::Experimental::bhalf_t. Disabling this may increase build times
- Default: OFF
-
KokkosKernels_ETI_ONLY
: BOOL- Whether to restrict availability of kernels to ETI types only. Turning this on guarantees that kernels are never built inside of object files which simply call KokkosKernels functions.
- Default: OFF
-
KokkosKernels_INST_COMPLEX_DOUBLE
: BOOL- Whether to pre instantiate kernels for the scalar type complex. Disabling this may increase build times.
- Default: OFF or unless enabled during a Trilinos build with Trilinos_ENABLE_COMPLEX_DOUBLE.
-
KokkosKernels_INST_COMPLEX_FLOAT
: BOOL- Whether to pre instantiate kernels for the scalar type complex. Disabling this may increase build times.
- Default: OFF or unless enabled during a Trilinos build with Trilinos_ENABLE_COMPLEX_FLOAT.
-
KokkosKernels_INST_DOUBLE
: BOOL- Whether to pre instantiate kernels for the scalar type double. This option is KokkosKernels_INST_DOUBLE=ON by default. Disabling this may increase build times.
- Default: ON
-
KokkosKernels_INST_EXECSPACE_OPENMP
: BOOL- Whether to pre instantiate kernels for the execution space Kokkos::OpenMP. Disabling this when Kokkos_ENABLE_OpenMP is enabled may increase build times.
- Default: ON if Kokkos is OpenMP-enabled, OFF otherwise.
-
KokkosKernels_INST_EXECSPACE_SERIAL
: BOOL- Whether to build kernels for the execution space Kokkos::Serial. If explicit template instantiation (ETI) is enabled in Trilinos, disabling this when Kokkos_ENABLE_SERIAL is enabled may increase build times.
- Default: ON when Kokkos is Serial-enabled, OFF otherwise.
-
KokkosKernels_INST_EXECSPACE_THREADS
: BOOL- Whether to build kernels for the execution space Kokkos::Threads. If explicit template instantiation (ETI) is enabled in Trilinos, disabling this when Kokkos_ENABLE_PTHREAD is enabled may increase build times.
- Default: ON if Kokkos is Threads-enabled, OFF otherwise.
-
KokkosKernels_INST_FLOAT
: BOOL- Whether to pre instantiate kernels for the scalar type float. Disabling this may increase build times.
- Default: OFF or unless enabled during a Trilinos build with Trilinos_ENABLE_FLOAT.
-
KokkosKernels_INST_LAYOUTLEFT
: BOOL- Whether to pre instantiate kernels for the view layout LayoutLeft. This option is KokkosKernels_INST_LAYOUTLEFT=ON by default. Disabling this may increase build times.
- Default: ON
-
KokkosKernels_INST_LAYOUTRIGHT
: BOOL- Whether to pre instantiate kernels for the view layout LayoutRight. This option is KokkosKernels_INST_LAYOUTRIGHT=OFF by default. Disabling this may increase build times.
- Default: OFF
-
KokkosKernels_INST_MEMSPACE_HOSTSPACE
: BOOL- Whether to pre instantiate kernels for the memory space Kokkos::HostSpace. Disabling this when one of the Host execution spaces is enabled may increase build times.
- Default: ON
-
KokkosKernels_INST_OFFSET_INT
: BOOL- Whether to pre instantiate kernels for the offset type int. This option is KokkosKernels_INST_OFFSET_INT=ON by default.
- Default: ON
-
KokkosKernels_INST_OFFSET_SIZE_T
: BOOL- Whether to pre instantiate kernels for the offset type size_t. This option is KokkosKernels_INST_OFFSET_SIZE_T=OFF by default.
- Default: ON
-
KokkosKernels_INST_ORDINAL_INT
: BOOL- Whether to pre instantiate kernels for the ordinal type int. This option is KokkosKernels_INST_ORDINAL_INT=ON by default.
- Default: ON
-
KokkosKernels_INST_ORDINAL_INT64_T
: BOOL- Whether to pre instantiate kernels for the ordinal type int64_t. This option is KokkosKernels_INST_ORDINAL_INT64_T=OFF by default.
- Default: OFF
-
KokkosKernels_ADD_DEFAULT_ETI
: BOOL- Whether to include a set of default ETI instantiations (otherwise only those explicitly requested will be included
- Default: OFF
-
KokkosKernels_INST_EXECSPACE_CUDA
: BOOL- Whether to pre instantiate kernels for the execution space Kokkos::Cuda. Disabling this when Kokkos_ENABLE_CU DA is enabled may increase build times.
- Default: ON if Kokkos is CUDA-enabled, OFF otherwise
-
KokkosKernels_INST_MEMSPACE_CUDAUVMSPACE
: BOOL- Whether to pre instantiate kernels for the memory space Kokkos::CudaUVMSpace. Disabling this when Kokkos_ENA BLE_CUDA is enabled may increase build times.
- Default: OFF.
-
KokkosKernels_INST_EXECSPACE_HIP
: BOOL -
KokkosKernels_INST_MEMSPACE_HIPSPACE
: BOOL -
KokkosKernels_INST_EXECSPACE_SYCL
: BOOL -
KokkosKernels_INST_MEMSPACE_SYCLSPACE
: BOOL -
KokkosKernels_INST_EXECSPACE_OPENMPTARGET
: BOOL -
KokkosKernels_INST_MEMSPACE_OPENMPTARGETSPACE
: BOOL -
KokkosKernels_INST_MEMSPACE_HBWSPACE
: BOOL
-
KokkosKernels_ENABLE_DOCS
: BOOL- Whether to build documentation
- Default: OFF
-
KokkosKernels_NO_DEFAULT_CUDA_TPLS
: BOOL- Whether CUDA TPLs should be enabled by default.
- Default: OFF
-
KokkosKernels_NO_DEFAULT_ROCM_TPLS
: BOOL -
ARMPL
- CMake Options
-
KokkosKernels_ENABLE_TPL_ARMPL
: BOOL- Whether to enable ARMPL
- Default: OFF
-
ARMPL_LIBRARIES
: STRING- the name of the armpl library files to look for (possibly combined with above)
-
ARMPL_LIBRARY_DIRS
: STRING- which directories to look for
armpl
/armpl_mp
(optionally combined with below)
- which directories to look for
-
- Environment Variables
- under construction...
- CMake Options
-
BLAS
- CMake Options
-
KokkosKernels_ENABLE_TPL_BLAS
: BOOL- Whether to enable BLAS
- Default: OFF
-
BLAS_LIBRARIES
: STRING- Optional override for the libraries that comprise TPL BLAS.
- Default: None. Default common library names will be searched
-
BLAS_LIBRARY_DIRS
: STRING- Optional override for the library directories that comprise TPL BLAS.
- Default: None. Default common library locations will be searched
-
- Environment Variables
- under construction...
- CMake Options
-
CBLAS
- CMake Options
-
KokkosKernels_ENABLE_TPL_CBLAS
: BOOL- Whether to enable CBLAS
- Default: OFF
CBLAS_ROOT
CBLAS_LIBRARIES
CBLAS_LIBRARY_DIRS
CBLAS_INCLUDE_DIRS
-
- Environment Variables
- under construction...
- CMake Options
-
CHOLMOD
- CMake Options
-
KokkosKernels_ENABLE_TPL_CHOLMOD
: BOOL- Whether to enable CHOLMOD
- Default: OFF
CHOLMOD_ROOT
CHOLMOD_LIBRARIES
CHOLMOD_LIBRARY_DIRS
CHOLMOD_INCLUDE_DIRS
-
- Environment Variables
- under construction...
- CMake Options
-
CUBLAS
- CMake Options
-
KokkosKernels_ENABLE_TPL_CUBLAS
: BOOL- Whether to enable CUBLAS
- Default: ON if CUDA-enabled Kokkos, otherwise OFF
-
TPLCUBLAS_ROOT
- Optional override for the library directories that comprise TPL CUSOLVER. As a side-effect of
find_library
being called from withinfind_package(CUDA)
which we use to find the CUDA libraries
- Optional override for the library directories that comprise TPL CUSOLVER. As a side-effect of
-
CUBLAS_ROOT
: Optional override for the root directory of CUBLAS install (contains e.g.include
,lib64
) -
KokkosKernels_CUBLAS_ROOT
: Optional override for the root directory of CUBLAS install (contains e.g.include
,lib64
) -
CUBLAS_LIBRARIES
: paths to CUBLAS libraries -
CUBLAS_INCLUDE_DIRS
: paths to CUBLAS include dirs -
CUBLAS_LIBRARY_DIRS
: paths directories containing CUBLAS libraries
-
- Environment Variables
- under construction...
- CMake Options
-
CUSOLVER
- CMake Options
-
KokkosKernels_ENABLE_TPL_CUSOLVER
: BOOL- Whether to enable CUSOLVER
- Default: ON if CUDA-enabled Kokkos, otherwise OFF
-
TPLCUSOLVER_ROOT
- Optional override for the library directories that comprise TPL CUSOLVER. (As a side-effect of
find_library
being called from withinfind_package(CUDA)
which we use to find the CUDA libraries). - Default: None
- Optional override for the library directories that comprise TPL CUSOLVER. (As a side-effect of
-
CUSOLVER_ROOT
: Optional override for the root directory of CUSOLVER install (contains e.g.include
,lib64
) -
KokkosKernels_CUSOLVER_ROOT
: Optional override for the root directory of CUSOLVER install (contains e.g.include
,lib64
) -
CUSOLVER_LIBRARIES
: paths to CUSOLVER libraries -
CUSOLVER_INCLUDE_DIRS
: paths to CUSOLVER include dirs -
CUSOLVER_LIBRARY_DIRS
: paths directories containing CUSOLVER libraries
-
- Environment Variables
- under construction...
- CMake Options
-
CUSPARSE
- CMake Options
-
KokkosKernels_ENABLE_TPL_CUSPARSE
: BOOL- Whether to enable CUSPARSE
- Default: ON if CUDA-enabled Kokkos, otherwise OFF
-
TPLCUSPARSE_ROOT
: STRING- Optional override for the library directories that comprise TPL CUSPARSE. (As a side-effect of
find_library
being called from withinfind_package(CUDA)
which we use to find the CUDA libraries). - Default: None
- Optional override for the library directories that comprise TPL CUSPARSE. (As a side-effect of
-
CUSPARSE_ROOT
: Optional override for the root directory of CUSPARSE install (contains e.g.include
,lib64
) -
KokkosKernels_CUSOLVER_ROOT
: Optional override for the root directory of CUSPARSE install (contains e.g.include
,lib64
) -
CUSPARSE_LIBRARIES
: paths to CUSPARSE libraries -
CUSPARSE_INCLUDE_DIRS
: paths to CUSPARSE include dirs -
CUSPARSE_LIBRARY_DIRS
: paths directories containing CUSPARSE libraries
-
- Environment Variables
- under construction...
- CMake Options
-
MAGMA
- CMake Options
-
KokkosKernels_ENABLE_TPL_MAGMA
: BOOL- Whether to enable MAGMA
- Default: OFF
-
KokkosKernels_MAGMA_ROOT
: PATH- Location of MAGMA install root.
- Default: None or the value of the environment variable MAGMA_ROOT if set
MAGMA_LIBRARY_DIRS
MAGMA_LIBRARIES
-
- Environment Variables
MAGMA_DIR
- CMake Options
-
MKL
- supported versions:
- CMake Options
-
KokkosKernels_ENABLE_TPL_MKL
: BOOL- Whether to enable MKL
- Default: OFF
-
MKL_LIBRARIES
: STRING- Optional override for the libraries that comprise TPL MKL.
- Default: None. Default common library names will be searched
-
MKL_LIBRARY_DIRS
: STRING- Optional override for the library directories that comprise TPL MKL.
- Default: None. Default common library locations will be searched
-
KokkosKernels_MKL_ROOT
: PATH- Location of MKL install root.
- Default: None or the value of the environment variable MKL_ROOT if set
-
- Environment Variables
MKLROOT
-
LAPACK
- CMake Options
-
KokkosKernels_ENABLE_TPL_LAPACK
: BOOL- Whether to enable LAPACK
- Default: ON if BLAS is enabled, otherwise OFF
-
LAPACK_LIBRARIES
: STRING- Optional override for the libraries that comprise TPL LAPACK.
- Default: None. Default common library names will be searched
-
LAPACK_LIBRARY_DIRS
: STRING- Optional override for the library directories that comprise TPL LAPACK.
- Default: None. Default common library locations will be searched
-
KokkosKernels_LAPACK_ROOT
: PATH- Location of LAPACK install root.
- Default: None or the value of the environment variable LAPACK_ROOT if set
-
- Environment Variables
- under construction...
- CMake Options
-
LAPACKE
- CMake Options
LAPACKE_LIBRARIES
LAPACKE_LIBRARY_DIRS
LAPACKE_INCLUDE_DIRS
- Environment Variables
LAPACKE_ROOT
KokkosKernels_LAPACKE_ROOT
OPENBLAS_ROOT
- CMake Options
-
METIS
- CMake Options
METIS_LIBRARY_DIRS
METIS_INCLUDE_DIRS
- Environment Variables
METIS_ROOT
KokkosKernels_METIS_ROOT
- CMake Options
-
ROCBLAS
- deferred to
find_package(ROCBLAS)
- deferred to
-
ROCSOLVER
- deferred to
find_package(ROCSOLVER)
- deferred to
-
ROCSPARSE
- deferred to
find_package(ROCSPARSE)
- deferred to
-
SUPERLU
- CMake Options
SUPERLU_LIBRARIES
SUPERLU_LIBRARY_DIRS
SUPERLU_INCLUDE_DIRS
- Environment Variables
SUPERLU_ROOT
KokkosKernels_SUPERLU_ROOT
- CMake Options
- KokkosKernels_ENABLE_EXPERIMENTAL: BOOL
- Enable building and installation of experimental KokkosKernels features.
- Default: OFF
- KokkosKernels_LINALG_OPT_LEVEL: BOOL
- Optimization level for KokkosKernels computational kernels: a nonnegative integer. Higher levels result in better performance that is more uniform for corner cases, but increase build time and library size. The default value is 1, which should give performance within ten percent of optimal on most platforms, for most problems.
- Default: 1
-
KokkosKernels_ENABLE_SUPERNODAL_SPTRSV
: BOOL- Whether to build supernodal SPTRSV support
- Default: ON
Generated using grep -r KOKKOSKERNELS_ADD_TPL_OPTION