diff options
author | Craig Scott <craig.scott@crascit.com> | 2018-12-23 22:22:59 (GMT) |
---|---|---|
committer | Kitware Robot <kwrobot@kitware.com> | 2018-12-23 22:23:11 (GMT) |
commit | d480ede35b82c540e9d93b7bb4280014875f6444 (patch) | |
tree | ad2a4fe6eb8525e9ff47e889727cebd1e7c4b9ba /Help/policy | |
parent | 170fcebf2e866ce5266067716025a57c7e7e6ec4 (diff) | |
parent | f255280fd908e4ef1af5eba6230e81b74d339855 (diff) | |
download | CMake-d480ede35b82c540e9d93b7bb4280014875f6444.zip CMake-d480ede35b82c540e9d93b7bb4280014875f6444.tar.gz CMake-d480ede35b82c540e9d93b7bb4280014875f6444.tar.bz2 |
Merge topic 'link-options'
f255280fd9 PIE link options: Update strategy to fix performance regression
Acked-by: Kitware Robot <kwrobot@kitware.com>
Merge-request: !2739
Diffstat (limited to 'Help/policy')
-rw-r--r-- | Help/policy/CMP0083.rst | 38 |
1 files changed, 38 insertions, 0 deletions
diff --git a/Help/policy/CMP0083.rst b/Help/policy/CMP0083.rst index 7b467b0..b26d6c8 100644 --- a/Help/policy/CMP0083.rst +++ b/Help/policy/CMP0083.rst @@ -17,8 +17,46 @@ is set: passed to the linker step. For example ``-no-pie`` for ``GCC``. * Not set: no flags are passed to the linker step. +Since a given linker may not support ``PIE`` flags in all environments in +which it is used, it is the project's responsibility to use the +:module:`CheckPIESupported` module to check for support to ensure that the +:prop_tgt:`POSITION_INDEPENDENT_CODE` target property for executables will be +honored at link time. + This policy was introduced in CMake version 3.14. CMake version |release| warns when the policy is not set and uses ``OLD`` behavior. Use the :command:`cmake_policy` command to set it to ``OLD`` or ``NEW`` explicitly. .. include:: DEPRECATED.txt + +Examples +^^^^^^^^ + +Behave like CMake 3.13 and do not apply any ``PIE`` flags at link stage. + +.. code-block:: cmake + + cmake_minimum_required(VERSION 3.13) + project(foo) + + # ... + + add_executable(foo ...) + set_property(TARGET foo PROPERTY POSITION_INDEPENDENT_CODE TRUE) + +Use the :module:`CheckPIESupported` module to detect whether ``PIE`` is +supported by the current linker and environment. Apply ``PIE`` flags only +if the linker supports them. + +.. code-block:: cmake + + cmake_minimum_required(VERSION 3.14) # CMP0083 NEW + project(foo) + + include(CheckPIESupported) + check_pie_supported() + + # ... + + add_executable(foo ...) + set_property(TARGET foo PROPERTY POSITION_INDEPENDENT_CODE TRUE) |