AIX,HP-UX: Fix RPATH handling when CMP0065 is set to NEW
The CMAKE_SHARED_LIBRARY_LINK_<LANG>_FLAGS setting has always been meant for flags needed to export symbols from executables for use by shared library plugins. Since commit v3.4.0-rc1~58^2~1 (CMP0065: Restrict the use of CMAKE_SHARED_LIBRARY_LINK_<LANG>_FLAGS, 2015-08-24) this is made explicit by using the flags only for executables with ENABLE_EXPORTS, guarded by CMP0065 for compatibility. On some platforms we were accidentally using this setting to pass other flags to the linker: * AIX: -bnoipath, -brtl * HP-UX: +s, +nodefaultrpath These flags are incorrectly dropped when CMP0065 is set to NEW. Fix this by moving the flags to more appropriate places for linking executables.
This commit is contained in:
parent
fd7180f0c0
commit
f254276fc1
|
@ -18,10 +18,20 @@ if(__AIX_COMPILER_GNU)
|
||||||
endif()
|
endif()
|
||||||
set(__AIX_COMPILER_GNU 1)
|
set(__AIX_COMPILER_GNU 1)
|
||||||
|
|
||||||
|
#
|
||||||
|
# By default, runtime linking is enabled. All shared objects specified on the command line
|
||||||
|
# will be listed, even if there are no symbols referenced, in the output file.
|
||||||
|
set (CMAKE_SHARED_LINKER_FLAGS_INIT "-Wl,-brtl")
|
||||||
|
set (CMAKE_MODULE_LINKER_FLAGS_INIT "-Wl,-brtl")
|
||||||
|
set (CMAKE_EXE_LINKER_FLAGS_INIT "-Wl,-brtl")
|
||||||
|
|
||||||
|
|
||||||
macro(__aix_compiler_gnu lang)
|
macro(__aix_compiler_gnu lang)
|
||||||
set(CMAKE_SHARED_LIBRARY_RUNTIME_${lang}_FLAG "-Wl,-blibpath:")
|
set(CMAKE_SHARED_LIBRARY_RUNTIME_${lang}_FLAG "-Wl,-blibpath:")
|
||||||
set(CMAKE_SHARED_LIBRARY_RUNTIME_${lang}_FLAG_SEP ":")
|
set(CMAKE_SHARED_LIBRARY_RUNTIME_${lang}_FLAG_SEP ":")
|
||||||
set(CMAKE_SHARED_LIBRARY_CREATE_${lang}_FLAGS "${CMAKE_SHARED_LIBRARY_CREATE_${lang}_FLAGS} -Wl,-G,-bnoipath")
|
set(CMAKE_SHARED_LIBRARY_CREATE_${lang}_FLAGS "${CMAKE_SHARED_LIBRARY_CREATE_${lang}_FLAGS} -Wl,-G,-bnoipath")
|
||||||
set(CMAKE_SHARED_LIBRARY_LINK_${lang}_FLAGS "-Wl,-brtl,-bnoipath,-bexpall") # +s, flag for exe link to use shared lib
|
set(CMAKE_SHARED_LIBRARY_LINK_${lang}_FLAGS "-Wl,-bexpall")
|
||||||
set(CMAKE_${lang}_USE_IMPLICIT_LINK_DIRECTORIES_IN_RUNTIME_PATH 1)
|
set(CMAKE_${lang}_USE_IMPLICIT_LINK_DIRECTORIES_IN_RUNTIME_PATH 1)
|
||||||
|
|
||||||
|
set(CMAKE_${lang}_LINK_FLAGS "-Wl,-bnoipath")
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
|
@ -18,11 +18,21 @@ if(__AIX_COMPILER_XL)
|
||||||
endif()
|
endif()
|
||||||
set(__AIX_COMPILER_XL 1)
|
set(__AIX_COMPILER_XL 1)
|
||||||
|
|
||||||
|
#
|
||||||
|
# By default, runtime linking is enabled. All shared objects specified on the command line
|
||||||
|
# will be listed, even if there are no symbols referenced, in the output file.
|
||||||
|
set(CMAKE_SHARED_LINKER_FLAGS_INIT "-Wl,-brtl")
|
||||||
|
set(CMAKE_MODULE_LINKER_FLAGS_INIT "-Wl,-brtl")
|
||||||
|
set(CMAKE_EXE_LINKER_FLAGS_INIT "-Wl,-brtl")
|
||||||
|
|
||||||
|
|
||||||
macro(__aix_compiler_xl lang)
|
macro(__aix_compiler_xl lang)
|
||||||
set(CMAKE_SHARED_LIBRARY_RUNTIME_${lang}_FLAG "-Wl,-blibpath:")
|
set(CMAKE_SHARED_LIBRARY_RUNTIME_${lang}_FLAG "-Wl,-blibpath:")
|
||||||
set(CMAKE_SHARED_LIBRARY_RUNTIME_${lang}_FLAG_SEP ":")
|
set(CMAKE_SHARED_LIBRARY_RUNTIME_${lang}_FLAG_SEP ":")
|
||||||
set(CMAKE_SHARED_LIBRARY_CREATE_${lang}_FLAGS "-G -Wl,-bnoipath") # -shared
|
set(CMAKE_SHARED_LIBRARY_CREATE_${lang}_FLAGS "-G -Wl,-bnoipath") # -shared
|
||||||
set(CMAKE_SHARED_LIBRARY_LINK_${lang}_FLAGS "-Wl,-brtl,-bnoipath,-bexpall") # +s, flag for exe link to use shared lib
|
set(CMAKE_SHARED_LIBRARY_LINK_${lang}_FLAGS "-Wl,-bexpall")
|
||||||
set(CMAKE_SHARED_LIBRARY_${lang}_FLAGS " ")
|
set(CMAKE_SHARED_LIBRARY_${lang}_FLAGS " ")
|
||||||
set(CMAKE_SHARED_MODULE_${lang}_FLAGS " ")
|
set(CMAKE_SHARED_MODULE_${lang}_FLAGS " ")
|
||||||
|
|
||||||
|
set(CMAKE_${lang}_LINK_FLAGS "-Wl,-bnoipath")
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
|
@ -20,8 +20,10 @@ set(__HPUX_COMPILER_GNU 1)
|
||||||
|
|
||||||
macro(__hpux_compiler_gnu lang)
|
macro(__hpux_compiler_gnu lang)
|
||||||
set(CMAKE_SHARED_LIBRARY_CREATE_${lang}_FLAGS "${CMAKE_SHARED_LIBRARY_CREATE_${lang}_FLAGS} -Wl,-E,-b,+nodefaultrpath")
|
set(CMAKE_SHARED_LIBRARY_CREATE_${lang}_FLAGS "${CMAKE_SHARED_LIBRARY_CREATE_${lang}_FLAGS} -Wl,-E,-b,+nodefaultrpath")
|
||||||
set(CMAKE_SHARED_LIBRARY_LINK_${lang}_FLAGS "-Wl,+s,-E,+nodefaultrpath")
|
set(CMAKE_SHARED_LIBRARY_LINK_${lang}_FLAGS "-Wl,-E")
|
||||||
set(CMAKE_SHARED_LIBRARY_RUNTIME_${lang}_FLAG "-Wl,+b")
|
set(CMAKE_SHARED_LIBRARY_RUNTIME_${lang}_FLAG "-Wl,+b")
|
||||||
set(CMAKE_SHARED_LIBRARY_RUNTIME_${lang}_FLAG_SEP ":")
|
set(CMAKE_SHARED_LIBRARY_RUNTIME_${lang}_FLAG_SEP ":")
|
||||||
set(CMAKE_SHARED_LIBRARY_SONAME_${lang}_FLAG "-Wl,+h")
|
set(CMAKE_SHARED_LIBRARY_SONAME_${lang}_FLAG "-Wl,+h")
|
||||||
|
|
||||||
|
set(CMAKE_${lang}_LINK_FLAGS "-Wl,+s,+nodefaultrpath")
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
|
@ -22,10 +22,12 @@ macro(__hpux_compiler_hp lang)
|
||||||
set(CMAKE_${lang}_COMPILE_OPTIONS_PIC "+Z")
|
set(CMAKE_${lang}_COMPILE_OPTIONS_PIC "+Z")
|
||||||
set(CMAKE_SHARED_LIBRARY_${lang}_FLAGS "+Z")
|
set(CMAKE_SHARED_LIBRARY_${lang}_FLAGS "+Z")
|
||||||
set(CMAKE_SHARED_LIBRARY_CREATE_${lang}_FLAGS "-Wl,-E,+nodefaultrpath -b -L/usr/lib")
|
set(CMAKE_SHARED_LIBRARY_CREATE_${lang}_FLAGS "-Wl,-E,+nodefaultrpath -b -L/usr/lib")
|
||||||
set(CMAKE_SHARED_LIBRARY_LINK_${lang}_FLAGS "-Wl,+s,-E,+nodefaultrpath")
|
set(CMAKE_SHARED_LIBRARY_LINK_${lang}_FLAGS "-Wl,-E")
|
||||||
set(CMAKE_SHARED_LIBRARY_RUNTIME_${lang}_FLAG "-Wl,+b")
|
set(CMAKE_SHARED_LIBRARY_RUNTIME_${lang}_FLAG "-Wl,+b")
|
||||||
set(CMAKE_SHARED_LIBRARY_RUNTIME_${lang}_FLAG_SEP ":")
|
set(CMAKE_SHARED_LIBRARY_RUNTIME_${lang}_FLAG_SEP ":")
|
||||||
set(CMAKE_SHARED_LIBRARY_SONAME_${lang}_FLAG "-Wl,+h")
|
set(CMAKE_SHARED_LIBRARY_SONAME_${lang}_FLAG "-Wl,+h")
|
||||||
|
|
||||||
set(CMAKE_${lang}_FLAGS_INIT "")
|
set(CMAKE_${lang}_FLAGS_INIT "")
|
||||||
|
|
||||||
|
set(CMAKE_${lang}_LINK_FLAGS "-Wl,+s,+nodefaultrpath")
|
||||||
endmacro()
|
endmacro()
|
||||||
|
|
Loading…
Reference in New Issue