| | --- |
| | parent: Setup |
| | nav_order: 1 |
| | --- |
| | |
| | # CMake Options |
| |
|
| | A Thrust build is configured using CMake options. These may be passed to CMake |
| | using |
| |
|
| | ``` |
| | cmake -D<option_name>=<value> /path/to/thrust/sources |
| | ``` |
| |
|
| | or configured interactively with the `ccmake` or `cmake-gui` interfaces. |
| |
|
| | Thrust supports two build modes. By default, a single configuration is built |
| | that targets a specific host system, device system, and C++ dialect. |
| | When `THRUST_ENABLE_MULTICONFIG` is `ON`, multiple configurations |
| | targeting a variety of systems and dialects are generated. |
| |
|
| | The CMake options are divided into these categories: |
| |
|
| | 1. [Generic CMake Options](#generic-cmake-options): Options applicable to all |
| | Thrust builds. |
| | 1. [Single Config CMake Options](#single-config-cmake-options) Options |
| | applicable only when `THRUST_ENABLE_MULTICONFIG` is disabled. |
| | 1. [Multi Config CMake Options](#multi-config-cmake-options) Options applicable |
| | only when `THRUST_ENABLE_MULTICONFIG` is enabled. |
| | 1. [CUDA Specific CMake Options](#cuda-specific-cmake-options) Options that |
| | control CUDA compilation. Only available when one or more configurations |
| | targets the CUDA system. |
| | 1. [TBB Specific CMake Options](#tbb-specific-cmake-options) Options that |
| | control TBB compilation. Only available when one or more configurations |
| | targets the TBB system. |
| |
|
| | ## Generic CMake Options |
| |
|
| | - `CMAKE_BUILD_TYPE={Release, Debug, RelWithDebInfo, MinSizeRel}` |
| | - Standard CMake build option. Default: `RelWithDebInfo` |
| | - `THRUST_ENABLE_HEADER_TESTING={ON, OFF}` |
| | - Whether to test compile public headers. Default is `ON`. |
| | - `THRUST_ENABLE_TESTING={ON, OFF}` |
| | - Whether to build unit tests. Default is `ON`. |
| | - `THRUST_ENABLE_EXAMPLES={ON, OFF}` |
| | - Whether to build examples. Default is `ON`. |
| | - `THRUST_ENABLE_MULTICONFIG={ON, OFF}` |
| | - Toggles single-config and multi-config modes. Default is `OFF` (single config). |
| | - `THRUST_ENABLE_EXAMPLE_FILECHECK={ON, OFF}` |
| | - Enable validation of example outputs using the LLVM FileCheck utility. |
| | Default is `OFF`. |
| | - `THRUST_ENABLE_INSTALL_RULES={ON, OFF}` |
| | - If true, installation rules will be generated for thrust. Default is `ON`. |
| | |
| | ## Single Config CMake Options |
| |
|
| | - `THRUST_HOST_SYSTEM={CPP, TBB, OMP}` |
| | - Selects the host system. Default: `CPP` |
| | - `THRUST_DEVICE_SYSTEM={CUDA, TBB, OMP, CPP}` |
| | - Selects the device system. Default: `CUDA` |
| | - `THRUST_CPP_DIALECT={11, 14, 17}` |
| | - Selects the C++ standard dialect to use. Default is `14` (C++14). |
| |
|
| | ## Multi Config CMake Options |
| |
|
| | - `THRUST_MULTICONFIG_ENABLE_DIALECT_CPPXX={ON, OFF}` |
| | - Toggle whether a specific C++ dialect will be targeted. |
| | - Possible values of `XX` are `{11, 14, 17}`. |
| | - By default, only C++14 is enabled. |
| | - `THRUST_MULTICONFIG_ENABLE_SYSTEM_XXXX={ON, OFF}` |
| | - Toggle whether a specific system will be targeted. |
| | - Possible values of `XXXX` are `{CPP, CUDA, TBB, OMP}` |
| | - By default, only `CPP` and `CUDA` are enabled. |
| | - `THRUST_MULTICONFIG_WORKLOAD={SMALL, MEDIUM, LARGE, FULL}` |
| | - Restricts the host/device combinations that will be targeted. |
| | - By default, the `SMALL` workload is used. |
| | - The full cross product of `host x device` systems results in 12 |
| | configurations, some of which are more important than others. |
| | This option can be used to prune some of the less important ones. |
| | - `SMALL`: (3 configs) Minimal coverage and validation of each device system against the `CPP` host. |
| | - `MEDIUM`: (6 configs) Cheap extended coverage. |
| | - `LARGE`: (8 configs) Expensive extended coverage. Includes all useful build configurations. |
| | - `FULL`: (12 configs) The complete cross product of all possible build configurations. |
| | |
| | | Config | Workloads | Value | Expense | Note | |
| | |----------|-----------|------------|-----------|------------------------------| |
| | | CPP/CUDA | `F L M S` | Essential | Expensive | Validates CUDA against CPP | |
| | | CPP/OMP | `F L M S` | Essential | Cheap | Validates OMP against CPP | |
| | | CPP/TBB | `F L M S` | Essential | Cheap | Validates TBB against CPP | |
| | | CPP/CPP | `F L M ` | Important | Cheap | Tests CPP as device | |
| | | OMP/OMP | `F L M ` | Important | Cheap | Tests OMP as host | |
| | | TBB/TBB | `F L M ` | Important | Cheap | Tests TBB as host | |
| | | TBB/CUDA | `F L ` | Important | Expensive | Validates TBB/CUDA interop | |
| | | OMP/CUDA | `F L ` | Important | Expensive | Validates OMP/CUDA interop | |
| | | TBB/OMP | `F ` | Not useful | Cheap | Mixes CPU-parallel systems | |
| | | OMP/TBB | `F ` | Not useful | Cheap | Mixes CPU-parallel systems | |
| | | TBB/CPP | `F ` | Not Useful | Cheap | Parallel host, serial device | |
| | | OMP/CPP | `F ` | Not Useful | Cheap | Parallel host, serial device | |
| |
|
| | ## CUDA Specific CMake Options |
| |
|
| | - `THRUST_INCLUDE_CUB_CMAKE={ON, OFF}` |
| | - If enabled, the CUB project will be built as part of Thrust. Default is |
| | `OFF`. |
| | - This adds CUB tests, etc. Useful for working on both CUB and Thrust |
| | simultaneously. |
| | - CUB configurations will be generated for each C++ dialect targeted by |
| | the current Thrust build. |
| | - `THRUST_INSTALL_CUB_HEADERS={ON, OFF}` |
| | - If enabled, the CUB project's headers will be installed through Thrust's |
| | installation rules. Default is `ON`. |
| | - This option depends on `THRUST_ENABLE_INSTALL_RULES`. |
| | - `THRUST_ENABLE_COMPUTE_XX={ON, OFF}` |
| | - Controls the targeted CUDA architecture(s) |
| | - Multiple options may be selected when using NVCC as the CUDA compiler. |
| | - Valid values of `XX` are: |
| | `{35, 37, 50, 52, 53, 60, 61, 62, 70, 72, 75, 80}` |
| | - Default value depends on `THRUST_DISABLE_ARCH_BY_DEFAULT`: |
| | - `THRUST_ENABLE_COMPUTE_FUTURE={ON, OFF}` |
| | - If enabled, CUDA objects will target the most recent virtual architecture |
| | in addition to the real architectures specified by the |
| | `THRUST_ENABLE_COMPUTE_XX` options. |
| | - Default value depends on `THRUST_DISABLE_ARCH_BY_DEFAULT`: |
| | - `THRUST_DISABLE_ARCH_BY_DEFAULT={ON, OFF}` |
| | - When `ON`, all `THRUST_ENABLE_COMPUTE_*` options are initially `OFF`. |
| | - Default: `OFF` (meaning all architectures are enabled by default) |
| | - `THRUST_ENABLE_TESTS_WITH_RDC={ON, OFF}` |
| | - Whether to enable Relocatable Device Code when building tests. |
| | Default is `OFF`. |
| | - `THRUST_ENABLE_EXAMPLES_WITH_RDC={ON, OFF}` |
| | - Whether to enable Relocatable Device Code when building examples. |
| | Default is `OFF`. |
| | |
| | ## TBB Specific CMake Options |
| |
|
| | - `THRUST_TBB_ROOT=<path to tbb root>` |
| | - When the TBB system is requested, set this to the root of the TBB installation |
| | (e.g. the location of `lib/`, `bin/` and `include/` for the TBB libraries). |
| | |
| |
|