Commit bc64a03c authored by Vladislav Vaintroub's avatar Vladislav Vaintroub

Windows - Fix CMAKE_INTERPROCEDURAL_OPTIMIZATION build with MSVC

If IPO is enabled, MSVC compiles with /GL  which is not
compatible with cmake's WINDOWS_EXPORT_ALL_SYMBOLS.

Since server.dll can't autoexport symbols from /GL compiled objects,
IPO must be disabled for dbug, string,mysys, and sql targets (in case we
build "plugin" DLLs that need server.dll's symbols)
parent f33e8e4a
...@@ -368,7 +368,12 @@ ENDFUNCTION() ...@@ -368,7 +368,12 @@ ENDFUNCTION()
# for some static libraries. # for some static libraries.
FUNCTION (MAYBE_DISABLE_IPO target) FUNCTION (MAYBE_DISABLE_IPO target)
IF(MSVC AND NOT CLANG_CL) IF(MSVC AND (NOT CLANG_CL) AND (NOT WITHOUT_DYNAMIC_PLUGINS))
SET_TARGET_PROPERTIES(${target} PROPERTIES INTERPROCEDURAL_OPTIMIZATION OFF) SET_TARGET_PROPERTIES(${target} PROPERTIES
INTERPROCEDURAL_OPTIMIZATION OFF
INTERPROCEDURAL_OPTIMIZATION_DEBUG OFF
INTERPROCEDURAL_OPTIMIZATION_RELEASE OFF
INTERPROCEDURAL_OPTIMIZATION_RELWITHDEBINFO OFF
INTERPROCEDURAL_OPTIMIZATION_MINSIZEREL OFF)
ENDIF() ENDIF()
ENDFUNCTION() ENDFUNCTION()
...@@ -187,7 +187,7 @@ IF ((CMAKE_SYSTEM_NAME MATCHES "Linux" OR ...@@ -187,7 +187,7 @@ IF ((CMAKE_SYSTEM_NAME MATCHES "Linux" OR
ENDIF() ENDIF()
IF(WIN32) IF(WIN32)
SET(SQL_SOURCE ${SQL_SOURCE} handle_connections_win.cc) SET(SQL_SOURCE ${SQL_SOURCE} handle_connections_win.cc winmain.cc)
ENDIF() ENDIF()
MYSQL_ADD_PLUGIN(partition ha_partition.cc STORAGE_ENGINE DEFAULT STATIC_ONLY MYSQL_ADD_PLUGIN(partition ha_partition.cc STORAGE_ENGINE DEFAULT STATIC_ONLY
...@@ -217,7 +217,7 @@ FOREACH(se aria partition perfschema sql_sequence wsrep) ...@@ -217,7 +217,7 @@ FOREACH(se aria partition perfschema sql_sequence wsrep)
ENDFOREACH() ENDFOREACH()
IF(WIN32) IF(WIN32)
SET(MYSQLD_SOURCE winmain.cc message.rc) SET(MYSQLD_SOURCE main.cc message.rc)
ELSE() ELSE()
SET(MYSQLD_SOURCE main.cc ${DTRACE_PROBES_ALL}) SET(MYSQLD_SOURCE main.cc ${DTRACE_PROBES_ALL})
ENDIF() ENDIF()
...@@ -259,7 +259,9 @@ IF(MSVC OR CMAKE_SYSTEM_NAME MATCHES AIX) ...@@ -259,7 +259,9 @@ IF(MSVC OR CMAKE_SYSTEM_NAME MATCHES AIX)
sql_builtins sql_builtins
) )
IF(MSVC) IF(MSVC)
SET_TARGET_PROPERTIES(server PROPERTIES WINDOWS_EXPORT_ALL_SYMBOLS TRUE) IF(NOT WITHOUT_DYNAMIC_PLUGINS)
SET_TARGET_PROPERTIES(server PROPERTIES WINDOWS_EXPORT_ALL_SYMBOLS TRUE)
ENDIF()
ELSE() ELSE()
SET_TARGET_PROPERTIES(server PROPERTIES AIX_EXPORT_ALL_SYMBOLS TRUE) SET_TARGET_PROPERTIES(server PROPERTIES AIX_EXPORT_ALL_SYMBOLS TRUE)
ENDIF() ENDIF()
......
...@@ -17,10 +17,20 @@ ...@@ -17,10 +17,20 @@
/* /*
main() for mysqld. main() for mysqld.
Calls mysqld_main() entry point exported by sql library. Calls mysqld_main() entry point exported by sql library.
On Windows, might do some service handling.
*/ */
#ifdef _WIN32
/* Windows main function, service handling, calls mysqld_main */
extern int mysqld_win_main(int argc, char **argv);
#else
extern int mysqld_main(int argc, char **argv); extern int mysqld_main(int argc, char **argv);
#endif
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
#ifdef _WIN32
return mysqld_win_main(argc, argv);
#else
return mysqld_main(argc, argv); return mysqld_main(argc, argv);
#endif
} }
...@@ -60,8 +60,8 @@ static SERVICE_STATUS svc_status{SERVICE_WIN32_OWN_PROCESS}; ...@@ -60,8 +60,8 @@ static SERVICE_STATUS svc_status{SERVICE_WIN32_OWN_PROCESS};
static SERVICE_STATUS_HANDLE svc_status_handle; static SERVICE_STATUS_HANDLE svc_status_handle;
static char *svc_name; static char *svc_name;
static char **orig_argv; static char **save_argv;
static int orig_argc; static int save_argc;
static int install_service(int argc, char **argv, const char *name); static int install_service(int argc, char **argv, const char *name);
static int remove_service(const char *name); static int remove_service(const char *name);
...@@ -165,8 +165,8 @@ static void WINAPI svc_main(DWORD svc_argc, char **svc_argv) ...@@ -165,8 +165,8 @@ static void WINAPI svc_main(DWORD svc_argc, char **svc_argv)
Do not pass the service name parameter (last on the command line) Do not pass the service name parameter (last on the command line)
to mysqld_main(), it is unaware of it. to mysqld_main(), it is unaware of it.
*/ */
orig_argv[orig_argc - 1]= 0; save_argv[save_argc - 1]= 0;
mysqld_main(orig_argc - 1, orig_argv); mysqld_main(save_argc - 1, save_argv);
} }
/* /*
...@@ -224,10 +224,10 @@ static const char *get_svc_name(const char *arg) ...@@ -224,10 +224,10 @@ static const char *get_svc_name(const char *arg)
Plus, the obsolete functionality to register/remove services. Plus, the obsolete functionality to register/remove services.
*/ */
int main(int argc, char **argv) __declspec(dllexport) int mysqld_win_main(int argc, char **argv)
{ {
orig_argv= argv; save_argv= argv;
orig_argc= argc; save_argc= argc;
/* /*
If no special arguments are given, service name is nor present If no special arguments are given, service name is nor present
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment