mirror of
https://github.com/Kitware/CMake.git
synced 2026-01-03 20:29:56 -06:00
We've long created shared objects on AIX using the linker's `-G` option (also offered by the XL front-end). The `-G` option implies `-brtl` and enables runtime linking. This has been largely unnecessary because we provide all dependencies on the link line and both XL and GNU compilers offer builtin behavior to export symbols. Since commit0f150b69d3(AIX: Explicitly compute shared object exports for both XL and GNU, 2019-07-11) we compute exports explicitly and consistently. Therefore runtime linking is no longer necessary for shared objects. We've also long created executables on AIX using the linker's `-brtl` option to enable runtime linking in case they load plugins at runtime. Since commit9f5c2040bf(AIX: Explicitly compute executable exports for both XL and GNU, 2019-07-12) and commit2fa920c0cd(AIX: Create import library for executables with exports, 2019-07-16) we now provide the linker enough information to fully resolve symbols in plugins up front. Therefore runtime linking is no longer necessary for executables. Drop use of `-G` for creating shared objects and use the XL `-qmkshrobj` and GCC `-shared` options instead. Both invoke the linker with the `-bM:SRE -bnoentry` options to create a shared object without runtime linking enabled. Also drop use of `-brtl` for creating executables. Issue: #19163
21 lines
1.0 KiB
ReStructuredText
21 lines
1.0 KiB
ReStructuredText
aix
|
|
---
|
|
|
|
* On AIX, executables using the :prop_tgt:`ENABLE_EXPORTS` target property
|
|
now produce a linker import file with a ``.imp`` extension in addition
|
|
to the executable file. Plugins (created via :command:`add_library` with
|
|
the ``MODULE`` option) that use :command:`target_link_libraries` to link
|
|
to the executable for its symbols are now linked using the import file.
|
|
The :command:`install(TARGETS)` command now installs the import file as
|
|
an ``ARCHIVE`` artifact.
|
|
|
|
* On AIX, runtime linking is no longer enabled by default. CMake provides
|
|
the linker enough information to resolve all symbols up front.
|
|
One may manually enable runtime linking for shared libraries and/or
|
|
loadable modules by adding ``-Wl,-G`` to their link flags
|
|
(e.g. in the :variable:`CMAKE_SHARED_LINKER_FLAGS` or
|
|
:variable:`CMAKE_MODULE_LINKER_FLAGS` variable).
|
|
One may manually enable runtime linking for executables by adding
|
|
``-Wl,-brtl`` to their link flags (e.g. in the
|
|
:variable:`CMAKE_EXE_LINKER_FLAGS` variable).
|