diff options
| author | Brad King <brad.king@kitware.com> | 2019-07-12 16:55:55 (GMT) | 
|---|---|---|
| committer | Brad King <brad.king@kitware.com> | 2019-07-15 17:27:16 (GMT) | 
| commit | 9f5c2040bfd41a2c87624cec3d9504cf477c9fc3 (patch) | |
| tree | 9c3b008604781f25b8a43938c584d6a5627e8f90 /Help/guide/tutorial/Step8 | |
| parent | 0f150b69d3a01c3c5b4a96d10334eb2703ba237f (diff) | |
| download | CMake-9f5c2040bfd41a2c87624cec3d9504cf477c9fc3.zip CMake-9f5c2040bfd41a2c87624cec3d9504cf477c9fc3.tar.gz CMake-9f5c2040bfd41a2c87624cec3d9504cf477c9fc3.tar.bz2 | |
AIX: Explicitly compute executable exports for both XL and GNU
On AIX, symbols in executables must be exported in order to be visible
to modules (plugins) they load via `dlopen`.  Prior to policy `CMP0065`,
CMake linked all executables with flags to export symbols, but the NEW
behavior for that policy is to do so only for executables that have the
`ENABLE_EXPORTS` target property set.  In both cases, CMake has always
used the AIX linker option `-bexpall` option to export symbols from
executables.
This has worked fairly well with the XL compiler, but with the GNU
compiler it works only for C ABI symbols.  The reason is that `-bexpall`
does not export symbols starting in `_` but the GNU C++ ABI mangles all
symbols with a leading `_`.  Therefore we have only supported C ABI
plugins with the GNU compiler on AIX.  Some projects have tried to work
around this by replacing `-bexpall` with `-bexpfull`, but the latter
often exports symbols that we do not want exported.
Avoid using `-bexpall` for executables by instead using by our own
internal `ExportImportList` script to compute symbol export lists from
the object files to be linked into an executable.  Pass the explicitly
computed export list to the AIX linker's `-bE:...` option.  We already
do this for shared object exports.
Issue: #19163
Diffstat (limited to 'Help/guide/tutorial/Step8')
0 files changed, 0 insertions, 0 deletions
