2020-03-23 21:44:29 +08:00
|
|
|
#***************************************************************************
|
|
|
|
# _ _ ____ _
|
|
|
|
# Project ___| | | | _ \| |
|
|
|
|
# / __| | | | |_) | |
|
|
|
|
# | (__| |_| | _ <| |___
|
|
|
|
# \___|\___/|_| \_\_____|
|
|
|
|
#
|
2023-01-02 20:51:48 +08:00
|
|
|
# Copyright (C) Daniel Stenberg, <daniel@haxx.se>, et al.
|
2020-03-23 21:44:29 +08:00
|
|
|
#
|
|
|
|
# This software is licensed as described in the file COPYING, which
|
|
|
|
# you should have received as part of this distribution. The terms
|
2020-11-04 21:02:01 +08:00
|
|
|
# are also available at https://curl.se/docs/copyright.html.
|
2020-03-23 21:44:29 +08:00
|
|
|
#
|
|
|
|
# You may opt to use, copy, modify, merge, publish, distribute and/or sell
|
|
|
|
# copies of the Software, and permit persons to whom the Software is
|
|
|
|
# furnished to do so, under the terms of the COPYING file.
|
|
|
|
#
|
|
|
|
# This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
|
|
|
|
# KIND, either express or implied.
|
|
|
|
#
|
|
|
|
# SPDX-License-Identifier: curl
|
2022-05-17 17:16:50 +08:00
|
|
|
#
|
2020-03-23 21:44:29 +08:00
|
|
|
###########################################################################
|
cmake: clean OtherTests, fixing -Werror
There were several -Wunused warnings and one duplicate macro definition.
The EXTRA_DEFINES variable of the CurlCheckCSources macro was being
abused ("__unused1\n#undef inline\n#define __unused2", seriously?) to
insert extra C code. Avoid this broken abstraction and use cmake's
check_c_source_compiles directly (works fine with CMake 2.8, maybe
even cmake 2.6).
After cleaning up all related variables (EXTRA_DEFINES,
HEADER_INCLUDES, auxiliary headers_hack), also remove a duplicate
add_headers_include macro and remove duplicate header additions before
the struct timeval check.
Oh, and now the code is converted to use CheckCSourceRuns and
CheckCSourceCompiles, the two curl-specific helpers can be removed.
Unfortunately, the cmake output is now slightly more verbose. Before:
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test)
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test) - Failed
Since check_c_source_compiles prints the varname, now you see:
Performing Test curl_cv_func_send_test
Performing Test curl_cv_func_send_test - Failed
Tested: int send(int, const void *, size_t, int)
Compared cmake output with each other using vimdiff, no functional
differences were found. Tested with GCC 4.9.1 and Clang 3.5.0.
Signed-off-by: Peter Wu <peter@lekensteyn.nl>
2014-10-31 19:32:40 +08:00
|
|
|
include(CheckCSourceCompiles)
|
2023-09-29 08:38:06 +08:00
|
|
|
include(CheckCSourceRuns)
|
2023-12-13 06:00:59 +08:00
|
|
|
include(CheckTypeSize)
|
2023-09-29 08:38:06 +08:00
|
|
|
|
2009-06-10 01:29:16 +08:00
|
|
|
macro(add_header_include check header)
|
|
|
|
if(${check})
|
2023-12-10 04:37:11 +08:00
|
|
|
set(_source_epilogue "${_source_epilogue}
|
|
|
|
#include <${header}>")
|
2018-07-05 18:55:47 +08:00
|
|
|
endif()
|
|
|
|
endmacro()
|
2009-04-02 21:14:53 +08:00
|
|
|
|
2019-04-07 18:43:38 +08:00
|
|
|
set(CMAKE_TRY_COMPILE_TARGET_TYPE STATIC_LIBRARY)
|
|
|
|
|
2023-12-18 23:40:33 +08:00
|
|
|
if(NOT DEFINED HAVE_STRUCT_SOCKADDR_STORAGE)
|
|
|
|
set(CMAKE_EXTRA_INCLUDE_FILES)
|
|
|
|
if(WIN32)
|
|
|
|
set(CMAKE_EXTRA_INCLUDE_FILES "winsock2.h")
|
|
|
|
set(CMAKE_REQUIRED_DEFINITIONS "-DWIN32_LEAN_AND_MEAN")
|
|
|
|
set(CMAKE_REQUIRED_LIBRARIES "ws2_32")
|
|
|
|
elseif(HAVE_SYS_SOCKET_H)
|
|
|
|
set(CMAKE_EXTRA_INCLUDE_FILES "sys/socket.h")
|
|
|
|
endif()
|
|
|
|
check_type_size("struct sockaddr_storage" SIZEOF_STRUCT_SOCKADDR_STORAGE)
|
|
|
|
set(HAVE_STRUCT_SOCKADDR_STORAGE ${HAVE_SIZEOF_STRUCT_SOCKADDR_STORAGE})
|
|
|
|
endif()
|
2009-04-02 21:14:53 +08:00
|
|
|
|
2023-12-10 04:37:11 +08:00
|
|
|
if(NOT WIN32)
|
2023-12-18 23:40:33 +08:00
|
|
|
set(_source_epilogue "#undef inline")
|
|
|
|
add_header_include(HAVE_SYS_TYPES_H "sys/types.h")
|
|
|
|
add_header_include(HAVE_SYS_SOCKET_H "sys/socket.h")
|
|
|
|
check_c_source_compiles("${_source_epilogue}
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
int flag = MSG_NOSIGNAL;
|
|
|
|
(void)flag;
|
|
|
|
return 0;
|
|
|
|
}" HAVE_MSG_NOSIGNAL)
|
cmake: clean OtherTests, fixing -Werror
There were several -Wunused warnings and one duplicate macro definition.
The EXTRA_DEFINES variable of the CurlCheckCSources macro was being
abused ("__unused1\n#undef inline\n#define __unused2", seriously?) to
insert extra C code. Avoid this broken abstraction and use cmake's
check_c_source_compiles directly (works fine with CMake 2.8, maybe
even cmake 2.6).
After cleaning up all related variables (EXTRA_DEFINES,
HEADER_INCLUDES, auxiliary headers_hack), also remove a duplicate
add_headers_include macro and remove duplicate header additions before
the struct timeval check.
Oh, and now the code is converted to use CheckCSourceRuns and
CheckCSourceCompiles, the two curl-specific helpers can be removed.
Unfortunately, the cmake output is now slightly more verbose. Before:
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test)
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test) - Failed
Since check_c_source_compiles prints the varname, now you see:
Performing Test curl_cv_func_send_test
Performing Test curl_cv_func_send_test - Failed
Tested: int send(int, const void *, size_t, int)
Compared cmake output with each other using vimdiff, no functional
differences were found. Tested with GCC 4.9.1 and Clang 3.5.0.
Signed-off-by: Peter Wu <peter@lekensteyn.nl>
2014-10-31 19:32:40 +08:00
|
|
|
endif()
|
2023-12-18 23:40:33 +08:00
|
|
|
|
|
|
|
set(_source_epilogue "#undef inline")
|
|
|
|
add_header_include(HAVE_SYS_TIME_H "sys/time.h")
|
cmake: clean OtherTests, fixing -Werror
There were several -Wunused warnings and one duplicate macro definition.
The EXTRA_DEFINES variable of the CurlCheckCSources macro was being
abused ("__unused1\n#undef inline\n#define __unused2", seriously?) to
insert extra C code. Avoid this broken abstraction and use cmake's
check_c_source_compiles directly (works fine with CMake 2.8, maybe
even cmake 2.6).
After cleaning up all related variables (EXTRA_DEFINES,
HEADER_INCLUDES, auxiliary headers_hack), also remove a duplicate
add_headers_include macro and remove duplicate header additions before
the struct timeval check.
Oh, and now the code is converted to use CheckCSourceRuns and
CheckCSourceCompiles, the two curl-specific helpers can be removed.
Unfortunately, the cmake output is now slightly more verbose. Before:
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test)
Performing Test int send(int, const void *, size_t, int) (curl_cv_func_send_test) - Failed
Since check_c_source_compiles prints the varname, now you see:
Performing Test curl_cv_func_send_test
Performing Test curl_cv_func_send_test - Failed
Tested: int send(int, const void *, size_t, int)
Compared cmake output with each other using vimdiff, no functional
differences were found. Tested with GCC 4.9.1 and Clang 3.5.0.
Signed-off-by: Peter Wu <peter@lekensteyn.nl>
2014-10-31 19:32:40 +08:00
|
|
|
check_c_source_compiles("${_source_epilogue}
|
2023-12-13 05:46:58 +08:00
|
|
|
#include <time.h>
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
struct timeval ts;
|
|
|
|
ts.tv_sec = 0;
|
|
|
|
ts.tv_usec = 0;
|
|
|
|
(void)ts;
|
|
|
|
return 0;
|
|
|
|
}" HAVE_STRUCT_TIMEVAL)
|
2009-04-02 21:14:53 +08:00
|
|
|
|
2019-04-07 18:43:38 +08:00
|
|
|
unset(CMAKE_TRY_COMPILE_TARGET_TYPE)
|
|
|
|
|
2023-12-18 23:40:33 +08:00
|
|
|
if(NOT CMAKE_CROSSCOMPILING AND NOT APPLE)
|
|
|
|
set(_source_epilogue "#undef inline")
|
|
|
|
add_header_include(HAVE_SYS_POLL_H "sys/poll.h")
|
|
|
|
add_header_include(HAVE_POLL_H "poll.h")
|
|
|
|
check_c_source_runs("${_source_epilogue}
|
|
|
|
#include <stdlib.h>
|
|
|
|
#include <sys/time.h>
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
if(0 != poll(0, 0, 10)) {
|
|
|
|
return 1; /* fail */
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
/* detect the 10.12 poll() breakage */
|
|
|
|
struct timeval before, after;
|
|
|
|
int rc;
|
|
|
|
size_t us;
|
|
|
|
|
|
|
|
gettimeofday(&before, NULL);
|
|
|
|
rc = poll(NULL, 0, 500);
|
|
|
|
gettimeofday(&after, NULL);
|
|
|
|
|
|
|
|
us = (after.tv_sec - before.tv_sec) * 1000000 +
|
|
|
|
(after.tv_usec - before.tv_usec);
|
|
|
|
|
|
|
|
if(us < 400000) {
|
|
|
|
return 1;
|
2023-12-13 05:46:58 +08:00
|
|
|
}
|
2023-12-18 23:40:33 +08:00
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}" HAVE_POLL_FINE)
|
2016-10-31 07:45:17 +08:00
|
|
|
endif()
|
2023-09-29 08:38:06 +08:00
|
|
|
|
|
|
|
# Detect HAVE_GETADDRINFO_THREADSAFE
|
|
|
|
|
|
|
|
if(WIN32)
|
|
|
|
set(HAVE_GETADDRINFO_THREADSAFE ${HAVE_GETADDRINFO})
|
|
|
|
elseif(NOT HAVE_GETADDRINFO)
|
|
|
|
set(HAVE_GETADDRINFO_THREADSAFE FALSE)
|
2023-12-14 08:49:55 +08:00
|
|
|
elseif(APPLE OR
|
|
|
|
CMAKE_SYSTEM_NAME STREQUAL "AIX" OR
|
2023-09-29 08:38:06 +08:00
|
|
|
CMAKE_SYSTEM_NAME STREQUAL "FreeBSD" OR
|
|
|
|
CMAKE_SYSTEM_NAME STREQUAL "HP-UX" OR
|
|
|
|
CMAKE_SYSTEM_NAME STREQUAL "MidnightBSD" OR
|
|
|
|
CMAKE_SYSTEM_NAME STREQUAL "NetBSD" OR
|
|
|
|
CMAKE_SYSTEM_NAME STREQUAL "SunOS")
|
|
|
|
set(HAVE_GETADDRINFO_THREADSAFE TRUE)
|
|
|
|
elseif(CMAKE_SYSTEM_NAME MATCHES "BSD")
|
|
|
|
set(HAVE_GETADDRINFO_THREADSAFE FALSE)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(NOT DEFINED HAVE_GETADDRINFO_THREADSAFE)
|
|
|
|
set(_source_epilogue "#undef inline")
|
|
|
|
add_header_include(HAVE_SYS_SOCKET_H "sys/socket.h")
|
|
|
|
add_header_include(HAVE_SYS_TIME_H "sys/time.h")
|
|
|
|
add_header_include(HAVE_NETDB_H "netdb.h")
|
|
|
|
check_c_source_compiles("${_source_epilogue}
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
#ifdef h_errno
|
|
|
|
return 0;
|
|
|
|
#else
|
|
|
|
force compilation error
|
|
|
|
#endif
|
|
|
|
}" HAVE_H_ERRNO)
|
|
|
|
|
|
|
|
if(NOT HAVE_H_ERRNO)
|
2023-10-12 00:06:12 +08:00
|
|
|
check_c_source_compiles("${_source_epilogue}
|
2023-09-29 08:38:06 +08:00
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
h_errno = 2;
|
|
|
|
return h_errno != 0 ? 1 : 0;
|
|
|
|
}" HAVE_H_ERRNO_ASSIGNABLE)
|
|
|
|
|
|
|
|
if(NOT HAVE_H_ERRNO_ASSIGNABLE)
|
|
|
|
check_c_source_compiles("${_source_epilogue}
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
#if defined(_POSIX_C_SOURCE) && (_POSIX_C_SOURCE >= 200809L)
|
|
|
|
return 0;
|
|
|
|
#elif defined(_XOPEN_SOURCE) && (_XOPEN_SOURCE >= 700)
|
|
|
|
return 0;
|
|
|
|
#else
|
|
|
|
force compilation error
|
|
|
|
#endif
|
|
|
|
}" HAVE_H_ERRNO_SBS_ISSUE_7)
|
|
|
|
endif()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(HAVE_H_ERRNO OR HAVE_H_ERRNO_ASSIGNABLE OR HAVE_H_ERRNO_SBS_ISSUE_7)
|
|
|
|
set(HAVE_GETADDRINFO_THREADSAFE TRUE)
|
|
|
|
endif()
|
|
|
|
endif()
|
2023-09-29 10:20:44 +08:00
|
|
|
|
cmake: pre-fill rest of detection values for Windows
The goal of this patch is to avoid unnecessary feature detection work
when doing Windows builds with CMake. Do this by pre-filling well-known
detection results for Windows and specifically for mingw-w64 and MSVC
compilers. Also limit feature checks to platforms where the results are
actually used. Drop a few redundant ones. And some tidying up.
- pre-fill remaining detection values in Windows CMake builds.
Based on actual detection results observed in CI runs, preceding
similar work over libssh2 and matching up values with
`lib/config-win32.h`.
This brings down CMake configuration time from 58 to 14 seconds on the
same local machine.
On AppVeyor CI this translates to:
- 128 seconds -> 50 seconds VS2022 MSVC with OpenSSL (per CMake job):
https://ci.appveyor.com/project/curlorg/curl/builds/48208419/job/4gw66ecrjpy7necb#L296
https://ci.appveyor.com/project/curlorg/curl/builds/48217440/job/8m4fwrr2fe249uo8#L186
- 62 seconds -> 16 seconds VS2017 MINGW (per CMake job):
https://ci.appveyor.com/project/curlorg/curl/builds/48208419/job/s1y8q5ivlcs7ub29?fullLog=true#L290
https://ci.appveyor.com/project/curlorg/curl/builds/48217440/job/pchpxyjsyc9kl13a?fullLog=true#L194
The formula is about 1-3 seconds delay for each detection. Almost all
of these trigger a full compile-link cycle behind the scenes, slow
even today, both cross and native, mingw-w64 and apparently MSVC too.
Enabling .map files or other custom build features slows it down
further. (Similar is expected for autotools configure.)
- stop detecting `idn2.h` if idn2 was deselected.
autotools does this.
- stop detecting `idn2.h` if idn2 was not found.
This deviates from autotools. Source code requires both header and
lib, so this is still correct, but faster.
- limit `ADDRESS_FAMILY` detection to Windows.
- normalize `HAVE_WIN32_WINNT` value to lowercase `0x0a12` format.
- pre-fill `HAVE_WIN32_WINNT`-dependent detection results.
Saving 4 (slow) feature-detections in most builds: `getaddrinfo`,
`freeaddrinfo`, `inet_ntop`, `inet_pton`
- fix pre-filled `HAVE_SYS_TIME_H`, `HAVE_SYS_PARAM_H`,
`HAVE_GETTIMEOFDAY` for mingw-w64.
Luckily this do not change build results, as `WIN32` took
priority over `HAVE_GETTIMEOFDAY` with the current source
code.
- limit `HAVE_CLOCK_GETTIME_MONOTONIC_RAW` and
`HAVE_CLOCK_GETTIME_MONOTONIC` detections to non-Windows.
We're not using these in the source code for Windows.
- reduce compiler warning noise in CMake internal logs:
- fix to include `winsock2.h` before `windows.h`.
Apply it to autotools test snippets too.
- delete previous `-D_WINSOCKAPI_=` hack that aimed to fix the above.
- cleanup `CMake/CurlTests.c` to emit less warnings.
- delete redundant `HAVE_MACRO_SIGSETJMP` feature check.
It was the same check as `HAVE_SIGSETJMP`.
- delete 'experimental' marking from `CURL_USE_OPENSSL`.
- show CMake version via `CMakeLists.txt`.
Credit to the `zlib-ng` project for the idea:
https://github.com/zlib-ng/zlib-ng/blob/61e181c8ae93dbf56040336179c9954078bd1399/CMakeLists.txt#L7
- make `CMake/CurlTests.c` pass `checksrc`.
- `CMake/WindowsCache.cmake` tidy-ups.
- replace `WIN32` guard with `_WIN32` in `CMake/CurlTests.c`.
Closes #12044
2023-10-06 07:38:59 +08:00
|
|
|
if(NOT WIN32 AND NOT DEFINED HAVE_CLOCK_GETTIME_MONOTONIC_RAW)
|
2023-09-29 10:20:44 +08:00
|
|
|
set(_source_epilogue "#undef inline")
|
|
|
|
add_header_include(HAVE_SYS_TYPES_H "sys/types.h")
|
|
|
|
add_header_include(HAVE_SYS_TIME_H "sys/time.h")
|
|
|
|
check_c_source_compiles("${_source_epilogue}
|
|
|
|
#include <time.h>
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
struct timespec ts;
|
|
|
|
(void)clock_gettime(CLOCK_MONOTONIC_RAW, &ts);
|
|
|
|
return 0;
|
|
|
|
}" HAVE_CLOCK_GETTIME_MONOTONIC_RAW)
|
|
|
|
endif()
|