Skip to content

Commit a1ebd42

Browse files
author
Vladislav Vaintroub
committed
On Linux, support -Wl,--no-undefined (only client shared library)
and --Wl,--as-needed (all shared modules). The later will remove unused dependencies (also from gcc and C++ runtime)
1 parent 555c99c commit a1ebd42

File tree

8 files changed

+96
-60
lines changed

8 files changed

+96
-60
lines changed

cmake/libutils.cmake

+24-7
Original file line numberDiff line numberDiff line change
@@ -132,25 +132,31 @@ MACRO(MERGE_STATIC_LIBS TARGET OUTPUT_NAME LIBS_TO_MERGE)
132132
ADD_LIBRARY(${TARGET} STATIC ${SOURCE_FILE})
133133
SET_TARGET_PROPERTIES(${TARGET} PROPERTIES OUTPUT_NAME ${OUTPUT_NAME})
134134

135+
SET(OSLIBS)
135136
FOREACH(LIB ${LIBS_TO_MERGE})
136137
GET_TARGET_PROPERTY(LIB_LOCATION ${LIB} LOCATION)
137138
GET_TARGET_PROPERTY(LIB_TYPE ${LIB} TYPE)
138139
IF(NOT LIB_LOCATION)
139140
# 3rd party library like libz.so. Make sure that everything
140141
# that links to our library links to this one as well.
141-
TARGET_LINK_LIBRARIES(${TARGET} ${LIB})
142+
LIST(APPEND OSLIBS ${LIB})
142143
ELSE()
143144
# This is a target in current project
144145
# (can be a static or shared lib)
145146
IF(LIB_TYPE STREQUAL "STATIC_LIBRARY")
146147
SET(STATIC_LIBS ${STATIC_LIBS} ${LIB_LOCATION})
147148
ADD_DEPENDENCIES(${TARGET} ${LIB})
149+
# Extract dependend OS libraries
150+
GET_DEPENDEND_OS_LIBS(${LIB} LIB_OSLIBS)
151+
LIST(APPEND OSLIBS ${LIB_OSLIBS})
148152
ELSE()
149153
# This is a shared library our static lib depends on.
150-
TARGET_LINK_LIBRARIES(${TARGET} ${LIB})
154+
LIST(APPEND OSLIBS ${LIB})
151155
ENDIF()
152156
ENDIF()
153157
ENDFOREACH()
158+
LIST(REMOVE_DUPLICATES OSLIBS)
159+
TARGET_LINK_LIBRARIES(${TARGET} ${OSLIBS})
154160

155161
# Make the generated dummy source file depended on all static input
156162
# libs. If input lib changes,the source file is touched
@@ -249,16 +255,27 @@ MACRO(MERGE_LIBRARIES)
249255
IF(ARG_OUTPUT_NAME)
250256
SET_TARGET_PROPERTIES(${TARGET} PROPERTIES OUTPUT_NAME "${ARG_OUTPUT_NAME}")
251257
ENDIF()
252-
# Disallow undefined symbols in shared libraries, but allow for modules
253-
# (they export from loading executable)
254-
IF(LIBTYPE MATCHES "SHARED" AND CMAKE_SYSTEM_TYPE MATCHES "Linux")
255-
SET_TARGET_PROPERTIES(${TARGET} PROPERTIES LINK_FLAGS "-Wl,--no-undefined")
256-
ENDIF()
257258
ELSE()
258259
MESSAGE(FATAL_ERROR "Unknown library type")
259260
ENDIF()
260261
ENDMACRO()
261262

263+
FUNCTION(GET_DEPENDEND_OS_LIBS target result)
264+
SET(deps ${${target}_LIB_DEPENDS})
265+
IF(deps)
266+
FOREACH(lib ${deps})
267+
# Filter out keywords for used for debug vs optimized builds
268+
IF(NOT lib MATCHES "general" AND NOT lib MATCHES "debug" AND NOT lib MATCHES "optimized")
269+
GET_TARGET_PROPERTY(lib_location ${lib} LOCATION)
270+
IF(NOT lib_location)
271+
SET(ret ${ret} ${lib})
272+
ENDIF()
273+
ENDIF()
274+
ENDFOREACH()
275+
ENDIF()
276+
SET(${result} ${ret} PARENT_SCOPE)
277+
ENDFUNCTION()
278+
262279
MACRO(RESTRICT_SYMBOL_EXPORTS target)
263280
IF(CMAKE_COMPILER_IS_GNUCXX AND UNIX)
264281
GET_TARGET_PROPERTY(COMPILE_FLAGS ${target} COMPILE_FLAGS)

cmake/plugin.cmake

+4
Original file line numberDiff line numberDiff line change
@@ -125,7 +125,11 @@ MACRO(MYSQL_ADD_PLUGIN)
125125
DTRACE_INSTRUMENT(${target})
126126
SET_TARGET_PROPERTIES (${target} PROPERTIES PREFIX ""
127127
COMPILE_DEFINITIONS "MYSQL_DYNAMIC_PLUGIN")
128+
IF(ARG_LINK_LIBRARIES)
129+
TARGET_LINK_LIBRARIES (${target} ${ARG_LINK_LIBRARIES})
130+
ENDIF()
128131
TARGET_LINK_LIBRARIES (${target} mysqlservices)
132+
129133
# Plugin uses symbols defined in mysqld executable.
130134
# Some operating systems like Windows and OSX and are pretty strict about
131135
# unresolved symbols. Others are less strict and allow unresolved symbols

configure.cmake

+53-49
Original file line numberDiff line numberDiff line change
@@ -94,9 +94,6 @@ IF(CMAKE_COMPILER_IS_GNUCXX)
9494
ENDIF()
9595
ENDIF(CMAKE_COMPILER_IS_GNUCXX)
9696

97-
IF(WIN32)
98-
SET(CAN_CONVERT_STATIC_TO_SHARED_LIB 1)
99-
ENDIF()
10097

10198
# Large files
10299
SET(_LARGEFILE_SOURCE 1)
@@ -134,21 +131,17 @@ IF(CMAKE_GENERATOR MATCHES "Visual Studio 7")
134131

135132
# VS2003 needs the /Op compiler option to disable floating point
136133
# optimizations
137-
SET(CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /Op")
138-
SET(CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} /Op")
139-
SET(CMAKE_CXX_FLAGS_RELWITHDEBINFO "${CMAKE_CXX_FLAGS_RELWITHDEBINFO} /Op")
140-
SET(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} /Op")
141-
SET(CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} /Op")
142-
SET(CMAKE_C_FLAGS_RELWITHDEBINFO "${CMAKE_C_FLAGS_RELWITHDEBINFO} /Op")
143-
ENDIF(CMAKE_GENERATOR MATCHES "Visual Studio 7")
134+
SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} /Op")
135+
SET(CMAKE_C_FLAGS "${CMAKE_CXX_FLAGS} /Op")
136+
ENDIF()
144137

145138

146139
IF(CMAKE_SYSTEM_NAME STREQUAL "HP-UX" )
147140
IF(CMAKE_SIZEOF_VOID_P EQUAL 4)
148141
# HPUX linker crashes building plugins
149142
SET(WITHOUT_DYNAMIC_PLUGINS TRUE)
150143
ENDIF()
151-
# If not PA-RISC make shared library suffix .so
144+
# If Itanium make shared library suffix .so
152145
# OS understands both .sl and .so. CMake would
153146
# use .sl, however MySQL prefers .so
154147
IF(NOT CMAKE_SYSTEM_PROCESSOR MATCHES "9000")
@@ -157,6 +150,24 @@ IF(CMAKE_SYSTEM_NAME STREQUAL "HP-UX" )
157150
ENDIF()
158151
ENDIF()
159152

153+
IF(CMAKE_SYSTEM_NAME STREQUAL "Linux")
154+
# Ensure we have clean build for shared libraries
155+
# without extra dependencies and without unresolved symbols
156+
FOREACH(LANG C CXX)
157+
STRING(REPLACE "-rdynamic" ""
158+
CMAKE_SHARED_LIBRARY_LINK_${LANG}_FLAGS
159+
${CMAKE_SHARED_LIBRARY_LINK_${LANG}_FLAGS}
160+
)
161+
ENDFOREACH()
162+
SET(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -Wl,--as-needed")
163+
SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -Wl,--as-needed")
164+
SET(LINK_FLAG_NO_UNDEFINED "--Wl,--no-undefined")
165+
ENDIF()
166+
167+
IF(CMAKE_SYSTEM_NAME MATCHES "SunOS")
168+
SET(LINK_FLAG_NO_UNDEFINED "-z defs")
169+
ENDIF()
170+
160171
#Some OS specific hacks
161172
IF(CMAKE_SYSTEM_NAME MATCHES "FreeBSD")
162173
ADD_DEFINITIONS(-DNET_RETRY_COUNT=1000000)
@@ -244,48 +255,41 @@ IF(WIN32)
244255
LINK_LIBRARIES(ws2_32)
245256
ENDIF()
246257

247-
248-
249-
MACRO(MY_CHECK_LIB func lib found)
250-
SET(${found} 0)
258+
# Searches function in libraries
259+
# if function is found, sets output parameter result to the name of the library
260+
# if function is found in libc, result will be empty
261+
FUNCTION(MY_SEARCH_LIBS func libs result)
251262
CHECK_FUNCTION_EXISTS(${func} HAVE_${func}_IN_LIBC)
252-
CHECK_LIBRARY_EXISTS(${lib} ${func} "" HAVE_${func}_IN_${lib})
253-
IF (HAVE_${func}_IN_${lib})
254-
SET(CMAKE_REQUIRED_LIBRARIES ${CMAKE_REQUIRED_LIBRARIES} ${lib})
255-
LINK_LIBRARIES(${lib})
256-
STRING(TOUPPER ${lib} upper_lib)
257-
SET(HAVE_LIB${upper_lib} 1 CACHE INTERNAL "Library check")
258-
SET(${found} 1)
263+
IF(HAVE_${func}_IN_LIBC)
264+
SET(${result} "" PARENT_SCOPE)
265+
RETURN()
259266
ENDIF()
260-
ENDMACRO()
261-
262-
MACRO(MY_SEARCH_LIBS func lib found)
263-
SET(${found} 0)
264-
CHECK_FUNCTION_EXISTS(${func} HAVE_${func}_IN_LIBC)
265-
IF(NOT HAVE_${func}_IN_LIBC)
266-
MY_CHECK_LIB(${func} ${lib} ${found})
267-
ELSE()
268-
SET(${found} 1)
269-
ENDIF()
270-
ENDMACRO()
267+
FOREACH(lib ${libs})
268+
CHECK_LIBRARY_EXISTS(${lib} ${func} "" HAVE_${func}_IN_${lib})
269+
IF(HAVE_${func}_IN_${lib})
270+
SET(${result} ${lib} PARENT_SCOPE)
271+
ENDIF()
272+
RETURN()
273+
ENDFOREACH()
274+
ENDFUNCTION()
271275

272276
IF(UNIX)
273-
MY_CHECK_LIB(floor m found)
274-
IF(NOT found)
275-
MY_CHECK_LIB( __infinity m found)
276-
ENDIF()
277-
MY_CHECK_LIB(gethostbyname_r nsl_r found)
278-
IF (NOT found)
279-
MY_CHECK_LIB(gethostbyname_r nsl found)
277+
MY_SEARCH_LIBS(floor m LIBM)
278+
IF(NOT LIBM)
279+
MY_SEARCH_LIBS(__infinity m LIBM)
280280
ENDIF()
281-
MY_SEARCH_LIBS(bind bind found)
282-
MY_SEARCH_LIBS(crypt crypt found)
283-
MY_SEARCH_LIBS(setsockopt socket found)
284-
MY_SEARCH_LIBS(aio_read rt found)
285-
MY_SEARCH_LIBS(sched_yield posix4 found)
286-
MY_CHECK_LIB(pthread_create pthread found)
287-
MY_SEARCH_LIBS(dlopen dl found)
288-
281+
MY_SEARCH_LIBS(gethostbyname_r "nsl_r;nsl" LIBNLS)
282+
MY_SEARCH_LIBS(bind bind LIBBIND)
283+
MY_SEARCH_LIBS(crypt crypt LIBCRYPT)
284+
MY_SEARCH_LIBS(setsockopt socket LIBSOCKET)
285+
MY_SEARCH_LIBS(dlopen dl LIBDL)
286+
FIND_PACKAGE(Threads)
287+
288+
SET(CMAKE_REQUIRED_LIBRARIES
289+
${LIBNLS} ${LIBBIND} ${LIBCRYPT} ${LIBSOCKET} ${LIBDL} ${CMAKE_THREAD_LIBS_INIT})
290+
291+
LINK_LIBRARIES(${CMAKE_THREAD_LIBS_INIT})
292+
289293
OPTION(WITH_LIBWRAP "Compile with tcp wrappers support" OFF)
290294
IF(WITH_LIBWRAP)
291295
SET(SAVE_CMAKE_REQUIRED_LIBRARIES ${CMAKE_REQUIRED_LIBRARIES})
@@ -303,7 +307,7 @@ IF(UNIX)
303307
SET(CMAKE_REQUIRED_LIBRARIES ${SAVE_CMAKE_REQUIRED_LIBRARIES})
304308
IF(HAVE_LIBWRAP)
305309
SET(MYSYS_LIBWRAP_SOURCE ${CMAKE_SOURCE_DIR}/mysys/my_libwrap.c)
306-
SET(LIBWRAP_LIBRARY "wrap")
310+
SET(LIBWRAP "wrap")
307311
ENDIF()
308312
ENDIF()
309313
ENDIF()

libmysql/CMakeLists.txt

+8-1
Original file line numberDiff line numberDiff line change
@@ -167,7 +167,14 @@ IF(NOT DISABLE_SHARED)
167167
OUTPUT_NAME mysqlclient
168168
VERSION "${SHARED_LIB_MAJOR_VERSION}.0.0"
169169
SOVERSION "${SHARED_LIB_MAJOR_VERSION}")
170-
170+
IF(LINK_FLAG_NO_UNDEFINED)
171+
GET_TARGET_PROPERTY(libmysql_link_flags libmysql LINK_FLAGS)
172+
IF(NOT libmysql_link_flag)
173+
SET(libmysql_link_flags)
174+
ENDIF()
175+
SET_TARGET_PROPERTIES(libmysql PROPERTIES LINK_FLAGS
176+
"${libmysql_link_flags} ${LINK_FLAG_NO_UNDEFINED}")
177+
ENDIF()
171178
# clean direct output needs to be set several targets have the same name
172179
#(mysqlclient in this case)
173180
SET_TARGET_PROPERTIES(mysqlclient PROPERTIES CLEAN_DIRECT_OUTPUT 1)

libmysqld/CMakeLists.txt

+2-1
Original file line numberDiff line numberDiff line change
@@ -100,7 +100,8 @@ ENDIF()
100100

101101
SET(LIBS
102102
dbug strings regex mysys vio
103-
${ZLIB_LIBRARY} ${SSL_LIBRARIES} ${LIBWRAP_LIBRARY}
103+
${ZLIB_LIBRARY} ${SSL_LIBRARIES}
104+
${LIBWRAP} ${LIBCRYPT} ${LIBDL}
104105
${MYSQLD_STATIC_PLUGIN_LIBS} ${NDB_CLIENT_LIBS}
105106
sql_embedded
106107
)

mysys/CMakeLists.txt

+2-1
Original file line numberDiff line numberDiff line change
@@ -63,5 +63,6 @@ IF(UNIX)
6363
SET(MYSYS_SOURCES ${MYSYS_SOURCES} my_port.c)
6464
ENDIF()
6565
ADD_CONVENIENCE_LIBRARY(mysys ${MYSYS_SOURCES})
66-
TARGET_LINK_LIBRARIES(mysys dbug strings ${ZLIB_LIBRARY})
66+
TARGET_LINK_LIBRARIES(mysys dbug strings ${ZLIB_LIBRARY}
67+
${LIBNLS} ${LIBM})
6768
DTRACE_INSTRUMENT(mysys)

sql/CMakeLists.txt

+2-1
Original file line numberDiff line numberDiff line change
@@ -130,7 +130,8 @@ SET_TARGET_PROPERTIES(mysqld PROPERTIES ENABLE_EXPORTS TRUE)
130130
SET_TARGET_PROPERTIES(mysqld PROPERTIES OUTPUT_NAME mysqld${MYSQLD_EXE_SUFFIX})
131131
TARGET_LINK_LIBRARIES(mysqld ${MYSQLD_STATIC_PLUGIN_LIBS}
132132
mysys dbug strings vio regex ${SQL_LIB}
133-
${LIBWRAP_LIBRARY} ${ZLIB_LIBRARY} ${SSL_LIBRARIES})
133+
${LIBWRAP} ${LIBCRYPT} ${LIBDL}
134+
${ZLIB_LIBRARY} ${SSL_LIBRARIES})
134135
INSTALL(TARGETS mysqld DESTINATION bin)
135136
INSTALL_DEBUG_SYMBOLS(mysqld)
136137

vio/CMakeLists.txt

+1
Original file line numberDiff line numberDiff line change
@@ -20,3 +20,4 @@ ADD_DEFINITIONS(${SSL_DEFINES})
2020

2121
SET(VIO_SOURCES vio.c viosocket.c viossl.c viosslfactories.c)
2222
ADD_CONVENIENCE_LIBRARY(vio ${VIO_SOURCES})
23+
TARGET_LINK_LIBRARIES(vio ${LIBSOCKET})

0 commit comments

Comments
 (0)