1======================== 2Building LLVM with CMake 3======================== 4 5.. contents:: 6 :local: 7 8Introduction 9============ 10 11`CMake <http://www.cmake.org/>`_ is a cross-platform build-generator tool. CMake 12does not build the project, it generates the files needed by your build tool 13(GNU make, Visual Studio, etc.) for building LLVM. 14 15If **you are a new contributor**, please start with the :doc:`GettingStarted` 16page. This page is geared for existing contributors moving from the 17legacy configure/make system. 18 19If you are really anxious about getting a functional LLVM build, go to the 20`Quick start`_ section. If you are a CMake novice, start with `Basic CMake usage`_ 21and then go back to the `Quick start`_ section once you know what you are doing. The 22`Options and variables`_ section is a reference for customizing your build. If 23you already have experience with CMake, this is the recommended starting point. 24 25This page is geared towards users of the LLVM CMake build. If you're looking for 26information about modifying the LLVM CMake build system you may want to see the 27:doc:`CMakePrimer` page. It has a basic overview of the CMake language. 28 29.. _Quick start: 30 31Quick start 32=========== 33 34We use here the command-line, non-interactive CMake interface. 35 36#. `Download <http://www.cmake.org/cmake/resources/software.html>`_ and install 37 CMake. Version 3.4.3 is the minimum required. 38 39#. Open a shell. Your development tools must be reachable from this shell 40 through the PATH environment variable. 41 42#. Create a build directory. Building LLVM in the source 43 directory is not supported. cd to this directory: 44 45 .. code-block:: console 46 47 $ mkdir mybuilddir 48 $ cd mybuilddir 49 50#. Execute this command in the shell replacing `path/to/llvm/source/root` with 51 the path to the root of your LLVM source tree: 52 53 .. code-block:: console 54 55 $ cmake path/to/llvm/source/root 56 57 CMake will detect your development environment, perform a series of tests, and 58 generate the files required for building LLVM. CMake will use default values 59 for all build parameters. See the `Options and variables`_ section for 60 a list of build parameters that you can modify. 61 62 This can fail if CMake can't detect your toolset, or if it thinks that the 63 environment is not sane enough. In this case, make sure that the toolset that 64 you intend to use is the only one reachable from the shell, and that the shell 65 itself is the correct one for your development environment. CMake will refuse 66 to build MinGW makefiles if you have a POSIX shell reachable through the PATH 67 environment variable, for instance. You can force CMake to use a given build 68 tool; for instructions, see the `Usage`_ section, below. 69 70#. After CMake has finished running, proceed to use IDE project files, or start 71 the build from the build directory: 72 73 .. code-block:: console 74 75 $ cmake --build . 76 77 The ``--build`` option tells ``cmake`` to invoke the underlying build 78 tool (``make``, ``ninja``, ``xcodebuild``, ``msbuild``, etc.) 79 80 The underlying build tool can be invoked directly, of course, but 81 the ``--build`` option is portable. 82 83#. After LLVM has finished building, install it from the build directory: 84 85 .. code-block:: console 86 87 $ cmake --build . --target install 88 89 The ``--target`` option with ``install`` parameter in addition to 90 the ``--build`` option tells ``cmake`` to build the ``install`` target. 91 92 It is possible to set a different install prefix at installation time 93 by invoking the ``cmake_install.cmake`` script generated in the 94 build directory: 95 96 .. code-block:: console 97 98 $ cmake -DCMAKE_INSTALL_PREFIX=/tmp/llvm -P cmake_install.cmake 99 100.. _Basic CMake usage: 101.. _Usage: 102 103Basic CMake usage 104================= 105 106This section explains basic aspects of CMake 107which you may need in your day-to-day usage. 108 109CMake comes with extensive documentation, in the form of html files, and as 110online help accessible via the ``cmake`` executable itself. Execute ``cmake 111--help`` for further help options. 112 113CMake allows you to specify a build tool (e.g., GNU make, Visual Studio, 114or Xcode). If not specified on the command line, CMake tries to guess which 115build tool to use, based on your environment. Once it has identified your 116build tool, CMake uses the corresponding *Generator* to create files for your 117build tool (e.g., Makefiles or Visual Studio or Xcode project files). You can 118explicitly specify the generator with the command line option ``-G "Name of the 119generator"``. To see a list of the available generators on your system, execute 120 121.. code-block:: console 122 123 $ cmake --help 124 125This will list the generator names at the end of the help text. 126 127Generators' names are case-sensitive, and may contain spaces. For this reason, 128you should enter them exactly as they are listed in the ``cmake --help`` 129output, in quotes. For example, to generate project files specifically for 130Visual Studio 12, you can execute: 131 132.. code-block:: console 133 134 $ cmake -G "Visual Studio 12" path/to/llvm/source/root 135 136For a given development platform there can be more than one adequate 137generator. If you use Visual Studio, "NMake Makefiles" is a generator you can use 138for building with NMake. By default, CMake chooses the most specific generator 139supported by your development environment. If you want an alternative generator, 140you must tell this to CMake with the ``-G`` option. 141 142.. todo:: 143 144 Explain variables and cache. Move explanation here from #options section. 145 146.. _Options and variables: 147 148Options and variables 149===================== 150 151Variables customize how the build will be generated. Options are boolean 152variables, with possible values ON/OFF. Options and variables are defined on the 153CMake command line like this: 154 155.. code-block:: console 156 157 $ cmake -DVARIABLE=value path/to/llvm/source 158 159You can set a variable after the initial CMake invocation to change its 160value. You can also undefine a variable: 161 162.. code-block:: console 163 164 $ cmake -UVARIABLE path/to/llvm/source 165 166Variables are stored in the CMake cache. This is a file named ``CMakeCache.txt`` 167stored at the root of your build directory that is generated by ``cmake``. 168Editing it yourself is not recommended. 169 170Variables are listed in the CMake cache and later in this document with 171the variable name and type separated by a colon. You can also specify the 172variable and type on the CMake command line: 173 174.. code-block:: console 175 176 $ cmake -DVARIABLE:TYPE=value path/to/llvm/source 177 178Frequently-used CMake variables 179------------------------------- 180 181Here are some of the CMake variables that are used often, along with a 182brief explanation and LLVM-specific notes. For full documentation, consult the 183CMake manual, or execute ``cmake --help-variable VARIABLE_NAME``. 184 185**CMAKE_BUILD_TYPE**:STRING 186 Sets the build type for ``make``-based generators. Possible values are 187 Release, Debug, RelWithDebInfo and MinSizeRel. If you are using an IDE such as 188 Visual Studio, you should use the IDE settings to set the build type. 189 190**CMAKE_INSTALL_PREFIX**:PATH 191 Path where LLVM will be installed if "make install" is invoked or the 192 "install" target is built. 193 194**LLVM_LIBDIR_SUFFIX**:STRING 195 Extra suffix to append to the directory where libraries are to be 196 installed. On a 64-bit architecture, one could use ``-DLLVM_LIBDIR_SUFFIX=64`` 197 to install libraries to ``/usr/lib64``. 198 199**CMAKE_C_FLAGS**:STRING 200 Extra flags to use when compiling C source files. 201 202**CMAKE_CXX_FLAGS**:STRING 203 Extra flags to use when compiling C++ source files. 204 205.. _LLVM-specific variables: 206 207LLVM-specific variables 208----------------------- 209 210**LLVM_TARGETS_TO_BUILD**:STRING 211 Semicolon-separated list of targets to build, or *all* for building all 212 targets. Case-sensitive. Defaults to *all*. Example: 213 ``-DLLVM_TARGETS_TO_BUILD="X86;PowerPC"``. 214 215**LLVM_BUILD_TOOLS**:BOOL 216 Build LLVM tools. Defaults to ON. Targets for building each tool are generated 217 in any case. You can build a tool separately by invoking its target. For 218 example, you can build *llvm-as* with a Makefile-based system by executing *make 219 llvm-as* at the root of your build directory. 220 221**LLVM_INCLUDE_TOOLS**:BOOL 222 Generate build targets for the LLVM tools. Defaults to ON. You can use this 223 option to disable the generation of build targets for the LLVM tools. 224 225**LLVM_BUILD_EXAMPLES**:BOOL 226 Build LLVM examples. Defaults to OFF. Targets for building each example are 227 generated in any case. See documentation for *LLVM_BUILD_TOOLS* above for more 228 details. 229 230**LLVM_INCLUDE_EXAMPLES**:BOOL 231 Generate build targets for the LLVM examples. Defaults to ON. You can use this 232 option to disable the generation of build targets for the LLVM examples. 233 234**LLVM_BUILD_TESTS**:BOOL 235 Build LLVM unit tests. Defaults to OFF. Targets for building each unit test 236 are generated in any case. You can build a specific unit test using the 237 targets defined under *unittests*, such as ADTTests, IRTests, SupportTests, 238 etc. (Search for ``add_llvm_unittest`` in the subdirectories of *unittests* 239 for a complete list of unit tests.) It is possible to build all unit tests 240 with the target *UnitTests*. 241 242**LLVM_INCLUDE_TESTS**:BOOL 243 Generate build targets for the LLVM unit tests. Defaults to ON. You can use 244 this option to disable the generation of build targets for the LLVM unit 245 tests. 246 247**LLVM_APPEND_VC_REV**:BOOL 248 Append version control revision info (svn revision number or Git revision id) 249 to LLVM version string (stored in the PACKAGE_VERSION macro). For this to work 250 cmake must be invoked before the build. Defaults to OFF. 251 252**LLVM_ENABLE_THREADS**:BOOL 253 Build with threads support, if available. Defaults to ON. 254 255**LLVM_ENABLE_CXX1Y**:BOOL 256 Build in C++1y mode, if available. Defaults to OFF. 257 258**LLVM_ENABLE_ASSERTIONS**:BOOL 259 Enables code assertions. Defaults to ON if and only if ``CMAKE_BUILD_TYPE`` 260 is *Debug*. 261 262**LLVM_ENABLE_EH**:BOOL 263 Build LLVM with exception-handling support. This is necessary if you wish to 264 link against LLVM libraries and make use of C++ exceptions in your own code 265 that need to propagate through LLVM code. Defaults to OFF. 266 267**LLVM_ENABLE_EXPENSIVE_CHECKS**:BOOL 268 Enable additional time/memory expensive checking. Defaults to OFF. 269 270**LLVM_ENABLE_PIC**:BOOL 271 Add the ``-fPIC`` flag to the compiler command-line, if the compiler supports 272 this flag. Some systems, like Windows, do not need this flag. Defaults to ON. 273 274**LLVM_ENABLE_RTTI**:BOOL 275 Build LLVM with run-time type information. Defaults to OFF. 276 277**LLVM_ENABLE_WARNINGS**:BOOL 278 Enable all compiler warnings. Defaults to ON. 279 280**LLVM_ENABLE_PEDANTIC**:BOOL 281 Enable pedantic mode. This disables compiler-specific extensions, if 282 possible. Defaults to ON. 283 284**LLVM_ENABLE_WERROR**:BOOL 285 Stop and fail the build, if a compiler warning is triggered. Defaults to OFF. 286 287**LLVM_ABI_BREAKING_CHECKS**:STRING 288 Used to decide if LLVM should be built with ABI breaking checks or 289 not. Allowed values are `WITH_ASSERTS` (default), `FORCE_ON` and 290 `FORCE_OFF`. `WITH_ASSERTS` turns on ABI breaking checks in an 291 assertion enabled build. `FORCE_ON` (`FORCE_OFF`) turns them on 292 (off) irrespective of whether normal (`NDEBUG`-based) assertions are 293 enabled or not. A version of LLVM built with ABI breaking checks 294 is not ABI compatible with a version built without it. 295 296**LLVM_BUILD_32_BITS**:BOOL 297 Build 32-bit executables and libraries on 64-bit systems. This option is 298 available only on some 64-bit Unix systems. Defaults to OFF. 299 300**LLVM_TARGET_ARCH**:STRING 301 LLVM target to use for native code generation. This is required for JIT 302 generation. It defaults to "host", meaning that it shall pick the architecture 303 of the machine where LLVM is being built. If you are cross-compiling, set it 304 to the target architecture name. 305 306**LLVM_TABLEGEN**:STRING 307 Full path to a native TableGen executable (usually named ``llvm-tblgen``). This is 308 intended for cross-compiling: if the user sets this variable, no native 309 TableGen will be created. 310 311**LLVM_LIT_ARGS**:STRING 312 Arguments given to lit. ``make check`` and ``make clang-test`` are affected. 313 By default, ``'-sv --no-progress-bar'`` on Visual C++ and Xcode, ``'-sv'`` on 314 others. 315 316**LLVM_LIT_TOOLS_DIR**:PATH 317 The path to GnuWin32 tools for tests. Valid on Windows host. Defaults to 318 the empty string, in which case lit will look for tools needed for tests 319 (e.g. ``grep``, ``sort``, etc.) in your %PATH%. If GnuWin32 is not in your 320 %PATH%, then you can set this variable to the GnuWin32 directory so that 321 lit can find tools needed for tests in that directory. 322 323**LLVM_ENABLE_FFI**:BOOL 324 Indicates whether the LLVM Interpreter will be linked with the Foreign Function 325 Interface library (libffi) in order to enable calling external functions. 326 If the library or its headers are installed in a custom 327 location, you can also set the variables FFI_INCLUDE_DIR and 328 FFI_LIBRARY_DIR to the directories where ffi.h and libffi.so can be found, 329 respectively. Defaults to OFF. 330 331**LLVM_EXTERNAL_{CLANG,LLD,POLLY}_SOURCE_DIR**:PATH 332 These variables specify the path to the source directory for the external 333 LLVM projects Clang, lld, and Polly, respectively, relative to the top-level 334 source directory. If the in-tree subdirectory for an external project 335 exists (e.g., llvm/tools/clang for Clang), then the corresponding variable 336 will not be used. If the variable for an external project does not point 337 to a valid path, then that project will not be built. 338 339**LLVM_EXTERNAL_PROJECTS**:STRING 340 Semicolon-separated list of additional external projects to build as part of 341 llvm. For each project LLVM_EXTERNAL_<NAME>_SOURCE_DIR have to be specified 342 with the path for the source code of the project. Example: 343 ``-DLLVM_EXTERNAL_PROJECTS="Foo;Bar" 344 -DLLVM_EXTERNAL_FOO_SOURCE_DIR=/src/foo 345 -DLLVM_EXTERNAL_BAR_SOURCE_DIR=/src/bar``. 346 347**LLVM_USE_OPROFILE**:BOOL 348 Enable building OProfile JIT support. Defaults to OFF. 349 350**LLVM_PROFDATA_FILE**:PATH 351 Path to a profdata file to pass into clang's -fprofile-instr-use flag. This 352 can only be specified if you're building with clang. 353 354**LLVM_USE_INTEL_JITEVENTS**:BOOL 355 Enable building support for Intel JIT Events API. Defaults to OFF. 356 357**LLVM_ENABLE_ZLIB**:BOOL 358 Enable building with zlib to support compression/uncompression in LLVM tools. 359 Defaults to ON. 360 361**LLVM_USE_SANITIZER**:STRING 362 Define the sanitizer used to build LLVM binaries and tests. Possible values 363 are ``Address``, ``Memory``, ``MemoryWithOrigins``, ``Undefined``, ``Thread``, 364 and ``Address;Undefined``. Defaults to empty string. 365 366**LLVM_ENABLE_LTO**:STRING 367 Add ``-flto`` or ``-flto=`` flags to the compile and link command 368 lines, enabling link-time optimization. Possible values are ``Off``, 369 ``On``, ``Thin`` and ``Full``. Defaults to OFF. 370 371**LLVM_PARALLEL_COMPILE_JOBS**:STRING 372 Define the maximum number of concurrent compilation jobs. 373 374**LLVM_PARALLEL_LINK_JOBS**:STRING 375 Define the maximum number of concurrent link jobs. 376 377**LLVM_BUILD_DOCS**:BOOL 378 Adds all *enabled* documentation targets (i.e. Doxgyen and Sphinx targets) as 379 dependencies of the default build targets. This results in all of the (enabled) 380 documentation targets being as part of a normal build. If the ``install`` 381 target is run then this also enables all built documentation targets to be 382 installed. Defaults to OFF. To enable a particular documentation target, see 383 see LLVM_ENABLE_SPHINX and LLVM_ENABLE_DOXYGEN. 384 385**LLVM_ENABLE_DOXYGEN**:BOOL 386 Enables the generation of browsable HTML documentation using doxygen. 387 Defaults to OFF. 388 389**LLVM_ENABLE_DOXYGEN_QT_HELP**:BOOL 390 Enables the generation of a Qt Compressed Help file. Defaults to OFF. 391 This affects the make target ``doxygen-llvm``. When enabled, apart from 392 the normal HTML output generated by doxygen, this will produce a QCH file 393 named ``org.llvm.qch``. You can then load this file into Qt Creator. 394 This option is only useful in combination with ``-DLLVM_ENABLE_DOXYGEN=ON``; 395 otherwise this has no effect. 396 397**LLVM_DOXYGEN_QCH_FILENAME**:STRING 398 The filename of the Qt Compressed Help file that will be generated when 399 ``-DLLVM_ENABLE_DOXYGEN=ON`` and 400 ``-DLLVM_ENABLE_DOXYGEN_QT_HELP=ON`` are given. Defaults to 401 ``org.llvm.qch``. 402 This option is only useful in combination with 403 ``-DLLVM_ENABLE_DOXYGEN_QT_HELP=ON``; 404 otherwise it has no effect. 405 406**LLVM_DOXYGEN_QHP_NAMESPACE**:STRING 407 Namespace under which the intermediate Qt Help Project file lives. See `Qt 408 Help Project`_ 409 for more information. Defaults to "org.llvm". This option is only useful in 410 combination with ``-DLLVM_ENABLE_DOXYGEN_QT_HELP=ON``; otherwise 411 it has no effect. 412 413**LLVM_DOXYGEN_QHP_CUST_FILTER_NAME**:STRING 414 See `Qt Help Project`_ for 415 more information. Defaults to the CMake variable ``${PACKAGE_STRING}`` which 416 is a combination of the package name and version string. This filter can then 417 be used in Qt Creator to select only documentation from LLVM when browsing 418 through all the help files that you might have loaded. This option is only 419 useful in combination with ``-DLLVM_ENABLE_DOXYGEN_QT_HELP=ON``; 420 otherwise it has no effect. 421 422.. _Qt Help Project: http://qt-project.org/doc/qt-4.8/qthelpproject.html#custom-filters 423 424**LLVM_DOXYGEN_QHELPGENERATOR_PATH**:STRING 425 The path to the ``qhelpgenerator`` executable. Defaults to whatever CMake's 426 ``find_program()`` can find. This option is only useful in combination with 427 ``-DLLVM_ENABLE_DOXYGEN_QT_HELP=ON``; otherwise it has no 428 effect. 429 430**LLVM_DOXYGEN_SVG**:BOOL 431 Uses .svg files instead of .png files for graphs in the Doxygen output. 432 Defaults to OFF. 433 434**LLVM_ENABLE_SPHINX**:BOOL 435 If specified, CMake will search for the ``sphinx-build`` executable and will make 436 the ``SPHINX_OUTPUT_HTML`` and ``SPHINX_OUTPUT_MAN`` CMake options available. 437 Defaults to OFF. 438 439**SPHINX_EXECUTABLE**:STRING 440 The path to the ``sphinx-build`` executable detected by CMake. 441 442**SPHINX_OUTPUT_HTML**:BOOL 443 If enabled (and ``LLVM_ENABLE_SPHINX`` is enabled) then the targets for 444 building the documentation as html are added (but not built by default unless 445 ``LLVM_BUILD_DOCS`` is enabled). There is a target for each project in the 446 source tree that uses sphinx (e.g. ``docs-llvm-html``, ``docs-clang-html`` 447 and ``docs-lld-html``). Defaults to ON. 448 449**SPHINX_OUTPUT_MAN**:BOOL 450 If enabled (and ``LLVM_ENABLE_SPHINX`` is enabled) the targets for building 451 the man pages are added (but not built by default unless ``LLVM_BUILD_DOCS`` 452 is enabled). Currently the only target added is ``docs-llvm-man``. Defaults 453 to ON. 454 455**SPHINX_WARNINGS_AS_ERRORS**:BOOL 456 If enabled then sphinx documentation warnings will be treated as 457 errors. Defaults to ON. 458 459**LLVM_CREATE_XCODE_TOOLCHAIN**:BOOL 460 OS X Only: If enabled CMake will generate a target named 461 'install-xcode-toolchain'. This target will create a directory at 462 $CMAKE_INSTALL_PREFIX/Toolchains containing an xctoolchain directory which can 463 be used to override the default system tools. 464 465**LLVM_BUILD_LLVM_DYLIB**:BOOL 466 If enabled, the target for building the libLLVM shared library is added. 467 This library contains all of LLVM's components in a single shared library. 468 Defaults to OFF. This cannot be used in conjunction with BUILD_SHARED_LIBS. 469 Tools will only be linked to the libLLVM shared library if LLVM_LINK_LLVM_DYLIB 470 is also ON. 471 The components in the library can be customised by setting LLVM_DYLIB_COMPONENTS 472 to a list of the desired components. 473 474**LLVM_LINK_LLVM_DYLIB**:BOOL 475 If enabled, tools will be linked with the libLLVM shared library. Defaults 476 to OFF. Setting LLVM_LINK_LLVM_DYLIB to ON also sets LLVM_BUILD_LLVM_DYLIB 477 to ON. 478 479**BUILD_SHARED_LIBS**:BOOL 480 Flag indicating if each LLVM component (e.g. Support) is built as a shared 481 library (ON) or as a static library (OFF). Its default value is OFF. On 482 Windows, shared libraries may be used when building with MinGW, including 483 mingw-w64, but not when building with the Microsoft toolchain. 484 485 .. note:: BUILD_SHARED_LIBS is only recommended for use by LLVM developers. 486 If you want to build LLVM as a shared library, you should use the 487 ``LLVM_BUILD_LLVM_DYLIB`` option. 488 489**LLVM_OPTIMIZED_TABLEGEN**:BOOL 490 If enabled and building a debug or asserts build the CMake build system will 491 generate a Release build tree to build a fully optimized tablegen for use 492 during the build. Enabling this option can significantly speed up build times 493 especially when building LLVM in Debug configurations. 494 495CMake Caches 496============ 497 498Recently LLVM and Clang have been adding some more complicated build system 499features. Utilizing these new features often involves a complicated chain of 500CMake variables passed on the command line. Clang provides a collection of CMake 501cache scripts to make these features more approachable. 502 503CMake cache files are utilized using CMake's -C flag: 504 505.. code-block:: console 506 507 $ cmake -C <path to cache file> <path to sources> 508 509CMake cache scripts are processed in an isolated scope, only cached variables 510remain set when the main configuration runs. CMake cached variables do not reset 511variables that are already set unless the FORCE option is specified. 512 513A few notes about CMake Caches: 514 515- Order of command line arguments is important 516 517 - -D arguments specified before -C are set before the cache is processed and 518 can be read inside the cache file 519 - -D arguments specified after -C are set after the cache is processed and 520 are unset inside the cache file 521 522- All -D arguments will override cache file settings 523- CMAKE_TOOLCHAIN_FILE is evaluated after both the cache file and the command 524 line arguments 525- It is recommended that all -D options should be specified *before* -C 526 527For more information about some of the advanced build configurations supported 528via Cache files see :doc:`AdvancedBuilds`. 529 530Executing the test suite 531======================== 532 533Testing is performed when the *check-all* target is built. For instance, if you are 534using Makefiles, execute this command in the root of your build directory: 535 536.. code-block:: console 537 538 $ make check-all 539 540On Visual Studio, you may run tests by building the project "check-all". 541For more information about testing, see the :doc:`TestingGuide`. 542 543Cross compiling 544=============== 545 546See `this wiki page <http://www.vtk.org/Wiki/CMake_Cross_Compiling>`_ for 547generic instructions on how to cross-compile with CMake. It goes into detailed 548explanations and may seem daunting, but it is not. On the wiki page there are 549several examples including toolchain files. Go directly to `this section 550<http://www.vtk.org/Wiki/CMake_Cross_Compiling#Information_how_to_set_up_various_cross_compiling_toolchains>`_ 551for a quick solution. 552 553Also see the `LLVM-specific variables`_ section for variables used when 554cross-compiling. 555 556Embedding LLVM in your project 557============================== 558 559From LLVM 3.5 onwards both the CMake and autoconf/Makefile build systems export 560LLVM libraries as importable CMake targets. This means that clients of LLVM can 561now reliably use CMake to develop their own LLVM-based projects against an 562installed version of LLVM regardless of how it was built. 563 564Here is a simple example of a CMakeLists.txt file that imports the LLVM libraries 565and uses them to build a simple application ``simple-tool``. 566 567.. code-block:: cmake 568 569 cmake_minimum_required(VERSION 3.4.3) 570 project(SimpleProject) 571 572 find_package(LLVM REQUIRED CONFIG) 573 574 message(STATUS "Found LLVM ${LLVM_PACKAGE_VERSION}") 575 message(STATUS "Using LLVMConfig.cmake in: ${LLVM_DIR}") 576 577 # Set your project compile flags. 578 # E.g. if using the C++ header files 579 # you will need to enable C++11 support 580 # for your compiler. 581 582 include_directories(${LLVM_INCLUDE_DIRS}) 583 add_definitions(${LLVM_DEFINITIONS}) 584 585 # Now build our tools 586 add_executable(simple-tool tool.cpp) 587 588 # Find the libraries that correspond to the LLVM components 589 # that we wish to use 590 llvm_map_components_to_libnames(llvm_libs support core irreader) 591 592 # Link against LLVM libraries 593 target_link_libraries(simple-tool ${llvm_libs}) 594 595The ``find_package(...)`` directive when used in CONFIG mode (as in the above 596example) will look for the ``LLVMConfig.cmake`` file in various locations (see 597cmake manual for details). It creates a ``LLVM_DIR`` cache entry to save the 598directory where ``LLVMConfig.cmake`` is found or allows the user to specify the 599directory (e.g. by passing ``-DLLVM_DIR=/usr/lib/cmake/llvm`` to 600the ``cmake`` command or by setting it directly in ``ccmake`` or ``cmake-gui``). 601 602This file is available in two different locations. 603 604* ``<INSTALL_PREFIX>/lib/cmake/llvm/LLVMConfig.cmake`` where 605 ``<INSTALL_PREFIX>`` is the install prefix of an installed version of LLVM. 606 On Linux typically this is ``/usr/lib/cmake/llvm/LLVMConfig.cmake``. 607 608* ``<LLVM_BUILD_ROOT>/lib/cmake/llvm/LLVMConfig.cmake`` where 609 ``<LLVM_BUILD_ROOT>`` is the root of the LLVM build tree. **Note: this is only 610 available when building LLVM with CMake.** 611 612If LLVM is installed in your operating system's normal installation prefix (e.g. 613on Linux this is usually ``/usr/``) ``find_package(LLVM ...)`` will 614automatically find LLVM if it is installed correctly. If LLVM is not installed 615or you wish to build directly against the LLVM build tree you can use 616``LLVM_DIR`` as previously mentioned. 617 618The ``LLVMConfig.cmake`` file sets various useful variables. Notable variables 619include 620 621``LLVM_CMAKE_DIR`` 622 The path to the LLVM CMake directory (i.e. the directory containing 623 LLVMConfig.cmake). 624 625``LLVM_DEFINITIONS`` 626 A list of preprocessor defines that should be used when building against LLVM. 627 628``LLVM_ENABLE_ASSERTIONS`` 629 This is set to ON if LLVM was built with assertions, otherwise OFF. 630 631``LLVM_ENABLE_EH`` 632 This is set to ON if LLVM was built with exception handling (EH) enabled, 633 otherwise OFF. 634 635``LLVM_ENABLE_RTTI`` 636 This is set to ON if LLVM was built with run time type information (RTTI), 637 otherwise OFF. 638 639``LLVM_INCLUDE_DIRS`` 640 A list of include paths to directories containing LLVM header files. 641 642``LLVM_PACKAGE_VERSION`` 643 The LLVM version. This string can be used with CMake conditionals, e.g., ``if 644 (${LLVM_PACKAGE_VERSION} VERSION_LESS "3.5")``. 645 646``LLVM_TOOLS_BINARY_DIR`` 647 The path to the directory containing the LLVM tools (e.g. ``llvm-as``). 648 649Notice that in the above example we link ``simple-tool`` against several LLVM 650libraries. The list of libraries is determined by using the 651``llvm_map_components_to_libnames()`` CMake function. For a list of available 652components look at the output of running ``llvm-config --components``. 653 654Note that for LLVM < 3.5 ``llvm_map_components_to_libraries()`` was 655used instead of ``llvm_map_components_to_libnames()``. This is now deprecated 656and will be removed in a future version of LLVM. 657 658.. _cmake-out-of-source-pass: 659 660Developing LLVM passes out of source 661------------------------------------ 662 663It is possible to develop LLVM passes out of LLVM's source tree (i.e. against an 664installed or built LLVM). An example of a project layout is provided below. 665 666.. code-block:: none 667 668 <project dir>/ 669 | 670 CMakeLists.txt 671 <pass name>/ 672 | 673 CMakeLists.txt 674 Pass.cpp 675 ... 676 677Contents of ``<project dir>/CMakeLists.txt``: 678 679.. code-block:: cmake 680 681 find_package(LLVM REQUIRED CONFIG) 682 683 add_definitions(${LLVM_DEFINITIONS}) 684 include_directories(${LLVM_INCLUDE_DIRS}) 685 686 add_subdirectory(<pass name>) 687 688Contents of ``<project dir>/<pass name>/CMakeLists.txt``: 689 690.. code-block:: cmake 691 692 add_library(LLVMPassname MODULE Pass.cpp) 693 694Note if you intend for this pass to be merged into the LLVM source tree at some 695point in the future it might make more sense to use LLVM's internal 696``add_llvm_loadable_module`` function instead by... 697 698 699Adding the following to ``<project dir>/CMakeLists.txt`` (after 700``find_package(LLVM ...)``) 701 702.. code-block:: cmake 703 704 list(APPEND CMAKE_MODULE_PATH "${LLVM_CMAKE_DIR}") 705 include(AddLLVM) 706 707And then changing ``<project dir>/<pass name>/CMakeLists.txt`` to 708 709.. code-block:: cmake 710 711 add_llvm_loadable_module(LLVMPassname 712 Pass.cpp 713 ) 714 715When you are done developing your pass, you may wish to integrate it 716into the LLVM source tree. You can achieve it in two easy steps: 717 718#. Copying ``<pass name>`` folder into ``<LLVM root>/lib/Transform`` directory. 719 720#. Adding ``add_subdirectory(<pass name>)`` line into 721 ``<LLVM root>/lib/Transform/CMakeLists.txt``. 722 723Compiler/Platform-specific topics 724================================= 725 726Notes for specific compilers and/or platforms. 727 728Microsoft Visual C++ 729-------------------- 730 731**LLVM_COMPILER_JOBS**:STRING 732 Specifies the maximum number of parallel compiler jobs to use per project 733 when building with msbuild or Visual Studio. Only supported for the Visual 734 Studio 2010 CMake generator. 0 means use all processors. Default is 0. 735