3 # We need 3.12 or later, so that we can set policy CMP0074; see
6 cmake_minimum_required(VERSION 3.12)
11 # if this is a version of CMake less than 3.5, require only
12 # 2.8.12, just in case somebody is configuring with CMake
13 # on a "long-term support" version # of some OS and that
14 # version supplies an older version of CMake;
16 # otherwise, require 3.5, so we don't get messages warning
17 # that support for versions of CMake lower than 3.5 is
20 if(CMAKE_VERSION VERSION_LESS "3.5")
21 cmake_minimum_required(VERSION 2.8.12)
23 cmake_minimum_required(VERSION 3.5)
28 # We want find_path() and find_library() to honor {packagename}_ROOT,
29 # as that appears to be the standard way to say "hey, look here for
30 # this package" from the command line.
33 cmake_policy(SET CMP0074 NEW)
39 # When building on NetBSD, with a libpcap installed from pkgsrc,
40 # a -Wl,-rpath,/usr/pkg/lib option is added to the options when
41 # linking tcpdump. This puts /usr/pkg/lib into the run-time path.
43 # However, by default, CMake adds a rule to the install CMake script
44 # a CMake command (using an undocumented subcommand of file()) that
45 # strips /usr/pkg/lib *out* of the run-time path; the message in the
46 # output for the "install" target is
48 # -- Set runtime path of "{target-directory}/tcpdump" to ""
50 # I am not certain what the rationale is for doing this, but a
51 # *consequence* of this is that, when you run the installed tcpdump,
52 # it fails to find libpcap.so:
54 # $ {target-directory}/tcpdump -h
55 # {target-directory}/tcpdump: Shared object "libpcap.so.0" not found
57 # It also appears to be the case that, on Ubuntu 22.04, FreeBSD 12,
58 # DragonFly BSD 5.8, OpenBSD 6.6, and Solaris 11.4,
60 # On Ubuntu and Solaris, even if you have a libpcap in /usr/local, you
61 # have to provide not only -I/usr/local/include and -L/usr/local/lib,
62 # you also must provide -Wl,-rpath,/usr/local/lib in order to have
63 # the run-time linker look in /usr/local/lib for libpcap. If it's not
64 # specified, then, if the shared library major version number of the
65 # libpcap in /usr/lib is the same as the shared major version number
66 # of the libpcap in /usr/local/lib, the run-time linker will find the
67 # libpcap in /usr/lib; if the versions are different, the run-time
68 # linker will fail to find the libpcap in /usr/lib, so the program will
71 # We suppress this by setting CMAKE_INSTALL_RPATH_USE_LINK_PATH to TRUE;
72 # as the documentation for that variable says:
74 # Add paths to linker search and installed rpath.
76 # CMAKE_INSTALL_RPATH_USE_LINK_PATH is a boolean that if set to True
77 # will append to the runtime search path (rpath) of installed
78 # binaries any directories outside the project that are in the linker
79 # search path or contain linked library files. The directories are
80 # appended after the value of the INSTALL_RPATH target property.
82 # If, for whatever reason, directories in which we search for external
83 # libraries, other than the standard system library directories, are
84 # added to the executable's rpath in the build process, we most
85 # definitely want them in the installed image's rpath if they are
86 # necessary in order to find the libraries at run time.
88 set(CMAKE_INSTALL_RPATH_USE_LINK_PATH TRUE)
90 set(CMAKE_MODULE_PATH ${CMAKE_SOURCE_DIR}/cmake/Modules)
93 # We explicitly indicate what languages are used in tcpdump to avoid
94 # checking for a C++ compiler.
96 # One reason to avoid that check is that there's no need to waste
97 # configuration time performing it.
99 # Another reason is that:
101 # CMake will try to determine the sizes of some data types, including
102 # void *, early in the process of configuration; apparently, it's done
103 # as part of processing the project() command.
105 # At least as of CMake 2.8.6, it does so by checking the size of
106 # "void *" in C, setting CMAKE_C_SIZEOF_DATA_PTR based on that,
107 # setting CMAKE_SIZEOF_VOID_P to that, and then checking the size
108 # of "void *" in C++, setting CMAKE_CXX_SIZEOF_DATA_PTR based on
109 # that, and then setting CMAKE_SIZEOF_VOID_P to *that*.
111 # The compile tests include whatever C flags may have been provided
112 # to CMake in the CFLAGS and CXXFLAGS environment variables.
114 # If you set an architecture flag such as -m32 or -m64 in CFLAGS
115 # but *not* in CXXFLAGS, the size for C++ will win, and hilarity
118 # Or if, at least on Solaris, you have a newer version of GCC
119 # installed, but *not* a newer version of G++, and you have Oracle
120 # Studio installed, it will find GCC, which will default to building
121 # 64-bit, and Oracle Studio's C++ compiler, which will default to
122 # building 32-bit, the size for C++ will win, and, again, hilarity
128 # Export the size of void * as SIZEOF_VOID_P so that it can be
131 set(SIZEOF_VOID_P "${CMAKE_SIZEOF_VOID_P}")
134 # For checking if a compiler flag works and adding it if it does.
136 include(CheckCCompilerFlag)
137 macro(check_and_add_compiler_option _option)
138 message(STATUS "Checking C compiler flag ${_option}")
139 string(REPLACE "=" "-" _temp_option_variable ${_option})
140 string(REGEX REPLACE "^-" "" _option_variable ${_temp_option_variable})
141 check_c_compiler_flag("${_option}" ${_option_variable})
142 if(${${_option_variable}})
143 set(C_ADDITIONAL_FLAGS "${C_ADDITIONAL_FLAGS} ${_option}")
148 # If we're building with Visual Studio, we require Visual Studio 2015,
149 # in order to get sufficient C99 compatibility. Check for that.
151 # If not, try the appropriate flag for the compiler to enable C99
154 set(C_ADDITIONAL_FLAGS "")
156 if(MSVC_VERSION LESS 1900)
157 message(FATAL_ERROR "Visual Studio 2015 or later is required")
161 # Treat source files as being in UTF-8 with MSVC if it's not using
162 # the Clang front end.
163 # We assume that UTF-8 source is OK with other compilers and with
164 # MSVC if it's using the Clang front end.
166 if(NOT ${CMAKE_C_COMPILER} MATCHES "clang*")
167 set(C_ADDITIONAL_FLAGS "${C_ADDITIONAL_FLAGS} /utf-8")
168 endif(NOT ${CMAKE_C_COMPILER} MATCHES "clang*")
171 # Try to enable as many C99 features as we can.
172 # At minimum, we want C++/C99-style // comments.
174 # Newer versions of compilers might default to supporting C99, but
175 # older versions may require a special flag.
177 # Prior to CMake 3.1, setting CMAKE_C_STANDARD will not have any effect,
178 # so, unless and until we require CMake 3.1 or later, we have to do it
179 # ourselves on pre-3.1 CMake, so we just do it ourselves on all versions
182 # Note: with CMake 3.1 through 3.5, the only compilers for which CMake
183 # handles CMAKE_C_STANDARD are GCC and Clang. 3.6 adds support only
184 # for Intel C; 3.9 adds support for PGI C, Sun C, and IBM XL C, and
185 # 3.10 adds support for Cray C and IAR C, but no version of CMake has
186 # support for HP C. Therefore, even if we use CMAKE_C_STANDARD with
187 # compilers for which CMake supports it, we may still have to do it
188 # ourselves on other compilers.
190 # See the CMake documentation for the CMAKE_<LANG>_COMPILER_ID variables
191 # for a list of compiler IDs.
193 # XXX - this just tests whether the option works and adds it if it does.
194 # We don't test whether it's necessary in order to get the C99 features
195 # that we use; if we ever have a user who tries to compile with a compiler
196 # that can't be made to support those features, we can add a test to make
197 # sure we actually *have* C99 support.
199 if(CMAKE_C_COMPILER_ID MATCHES "GNU" OR
200 CMAKE_C_COMPILER_ID MATCHES "Clang")
201 check_and_add_compiler_option("-std=gnu99")
202 elseif(CMAKE_C_COMPILER_ID MATCHES "XL")
204 # We want support for extensions picked up for GNU C compatibility,
205 # so we use -qlanglvl=extc99.
207 check_and_add_compiler_option("-qlanglvl=extc99")
208 elseif(CMAKE_C_COMPILER_ID MATCHES "HP")
209 check_and_add_compiler_option("-AC99")
210 elseif(CMAKE_C_COMPILER_ID MATCHES "Sun")
211 check_and_add_compiler_option("-xc99")
212 elseif(CMAKE_C_COMPILER_ID MATCHES "Intel")
213 check_and_add_compiler_option("-c99")
217 set(LIBRARY_NAME netdissect)
219 ###################################################################
221 ###################################################################
223 option(WITH_SMI "Build with libsmi, if available" ON)
224 option(WITH_CRYPTO "Build with OpenSSL/libressl libcrypto, if available" ON)
225 option(WITH_CAPSICUM "Build with Capsicum security functions, if available" ON)
226 option(WITH_CAP_NG "Use libcap-ng, if available" ON)
227 option(ENABLE_SMB "Build with the SMB dissector" OFF)
230 # String parameters. Neither of them are set, initially; only if the
231 # user explicitly configures them are they set.
233 # WITH_CHROOT is STRING, not PATH, as the directory need not exist
236 set(WITH_CHROOT CACHE STRING
237 "Directory to which to chroot when dropping privileges")
238 set(WITH_USER CACHE STRING
239 "User to whom to set the UID when dropping privileges")
242 # By default, build universal with the appropriate set of architectures
243 # for the OS on which we're doing the build.
245 if(APPLE AND "${CMAKE_OSX_ARCHITECTURES}" STREQUAL "")
247 # Get the major version of Darwin.
249 string(REGEX MATCH "^([0-9]+)" SYSTEM_VERSION_MAJOR "${CMAKE_SYSTEM_VERSION}")
251 if(SYSTEM_VERSION_MAJOR EQUAL 9)
253 # Leopard. Build for x86 and 32-bit PowerPC, with
254 # x86 first. (That's what Apple does.)
256 set(CMAKE_OSX_ARCHITECTURES "i386;ppc")
257 elseif(SYSTEM_VERSION_MAJOR EQUAL 10)
259 # Snow Leopard. Build for x86-64 and x86, with
260 # x86-64 first. (That's what Apple does.)
262 set(CMAKE_OSX_ARCHITECTURES "x86_64;i386")
266 ###################################################################
268 ###################################################################
270 # Get, parse, format and set tcpdump's version string from
271 # [tcpdump_root]/VERSION for later use.
273 # Get MAJOR, MINOR, PATCH & SUFFIX
274 file(STRINGS ${tcpdump_SOURCE_DIR}/VERSION
276 LIMIT_COUNT 1 # Read only the first line
279 ######################################
281 ######################################
283 add_definitions(-DHAVE_CONFIG_H)
286 ${CMAKE_CURRENT_BINARY_DIR}
287 ${tcpdump_SOURCE_DIR}
291 add_definitions(-D__STDC__)
292 add_definitions(-D_CRT_SECURE_NO_WARNINGS)
297 MESSAGE(STATUS "Use STATIC runtime")
299 set (CMAKE_CXX_FLAGS_MINSIZEREL "${CMAKE_CXX_FLAGS_MINSIZEREL} /MT")
300 set (CMAKE_CXX_FLAGS_RELWITHDEBINFO "${CMAKE_CXX_FLAGS_RELWITHDEBINFO} /MT")
301 set (CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} /MT")
302 set (CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /MTd")
304 set (CMAKE_C_FLAGS_MINSIZEREL "${CMAKE_C_FLAGS_MINSIZEREL} /MT")
305 set (CMAKE_C_FLAGS_RELWITHDEBINFO "${CMAKE_C_FLAGS_RELWITHDEBINFO} /MT")
306 set (CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} /MT")
307 set (CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} /MTd")
309 MESSAGE(STATUS "Use DYNAMIC runtime")
311 set (CMAKE_CXX_FLAGS_MINSIZEREL "${CMAKE_CXX_FLAGS_MINSIZEREL} /MD")
312 set (CMAKE_CXX_FLAGS_RELWITHDEBINFO "${CMAKE_CXX_FLAGS_RELWITHDEBINFO} /MD")
313 set (CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} /MD")
314 set (CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /MDd")
316 set (CMAKE_C_FLAGS_MINSIZEREL "${CMAKE_C_FLAGS_MINSIZEREL} /MD")
317 set (CMAKE_C_FLAGS_RELWITHDEBINFO "${CMAKE_C_FLAGS_RELWITHDEBINFO} /MD")
318 set (CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} /MD")
319 set (CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} /MDd")
320 endif (USE_STATIC_RT)
323 ###################################################################
324 # Detect available platform features
325 ###################################################################
327 include(CMakePushCheckState)
328 include(CheckIncludeFile)
329 include(CheckIncludeFiles)
330 include(CheckFunctionExists)
331 include(CheckLibraryExists)
332 include(CheckSymbolExists)
333 include(CheckStructHasMember)
334 include(CheckVariableExists)
335 include(CheckTypeSize)
338 # Get the size of a time_t, to know whether it's 32-bit or 64-bit.
340 cmake_push_check_state()
341 set(CMAKE_EXTRA_INCLUDE_FILES time.h)
342 check_type_size("time_t" SIZEOF_TIME_T)
343 cmake_pop_check_state()
348 check_include_file(fcntl.h HAVE_FCNTL_H)
349 check_include_file(rpc/rpc.h HAVE_RPC_RPC_H)
350 check_include_file(net/if.h HAVE_NET_IF_H)
352 check_include_files("rpc/rpc.h;rpc/rpcent.h" HAVE_RPC_RPCENT_H)
353 endif(HAVE_RPC_RPC_H)
358 check_function_exists(strlcat HAVE_STRLCAT)
359 check_function_exists(strlcpy HAVE_STRLCPY)
360 check_function_exists(strsep HAVE_STRSEP)
363 # Find library needed for gethostbyaddr.
364 # NOTE: if you hand check_library_exists as its last argument a variable
365 # that's been set, it skips the test, so we need different variables.
367 set(TCPDUMP_LINK_LIBRARIES "")
370 # We need winsock2.h and ws2tcpip.h.
372 cmake_push_check_state()
373 set(CMAKE_REQUIRED_LIBRARIES ws2_32)
374 check_symbol_exists(gethostbyaddr "winsock2.h;ws2tcpip.h" LIBWS2_32_HAS_GETHOSTBYADDR)
375 cmake_pop_check_state()
376 if(LIBWS2_32_HAS_GETHOSTBYADDR)
377 set(TCPDUMP_LINK_LIBRARIES ws2_32 ${TCPDUMP_LINK_LIBRARIES})
378 else(LIBWS2_32_HAS_GETHOSTBYADDR)
379 message(FATAL_ERROR "gethostbyaddr is required, but wasn't found")
380 endif(LIBWS2_32_HAS_GETHOSTBYADDR)
382 check_function_exists(gethostbyaddr STDLIBS_HAVE_GETHOSTBYADDR)
383 if(NOT STDLIBS_HAVE_GETHOSTBYADDR)
384 check_library_exists(socket gethostbyaddr "" LIBSOCKET_HAS_GETHOSTBYADDR)
385 if(LIBSOCKET_HAS_GETHOSTBYADDR)
386 set(TCPDUMP_LINK_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} socket)
387 else(LIBSOCKET_HAS_GETHOSTBYADDR)
388 check_library_exists(nsl gethostbyaddr "" LIBNSL_HAS_GETHOSTBYADDR)
389 if(LIBNSL_HAS_GETHOSTBYADDR)
390 set(TCPDUMP_LINK_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} nsl)
391 else(LIBNSL_HAS_GETHOSTBYADDR)
392 check_library_exists(network gethostbyaddr "" LIBNETWORK_HAS_GETHOSTBYADDR)
393 if(LIBNETWORK_HAS_GETHOSTBYADDR)
394 set(TCPDUMP_LINK_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} network)
395 else(LIBNETWORK_HAS_GETHOSTBYADDR)
396 message(FATAL_ERROR "gethostbyaddr is required, but wasn't found")
397 endif(LIBNETWORK_HAS_GETHOSTBYADDR)
398 endif(LIBNSL_HAS_GETHOSTBYADDR)
399 endif(LIBSOCKET_HAS_GETHOSTBYADDR)
400 endif(NOT STDLIBS_HAVE_GETHOSTBYADDR)
404 # This may require additional libraries.
406 cmake_push_check_state()
407 set(CMAKE_REQUIRED_LIBRARIES ${TCPDUMP_LINK_LIBRARIES})
408 check_function_exists(getservent STDLIBS_HAVE_GETSERVENT)
409 if(STDLIBS_HAVE_GETSERVENT)
410 set(HAVE_GETSERVENT TRUE)
411 else(STDLIBS_HAVE_GETSERVENT)
413 # Some platforms may need -lsocket for getservent.
415 set(CMAKE_REQUIRED_LIBRARIES socket ${TCPDUMP_LINK_LIBRARIES})
416 check_function_exists(getservent LIBSOCKET_HAS_GETSERVENT)
417 if(LIBSOCKET_HAS_GETSERVENT)
418 set(HAVE_GETSERVENT TRUE)
419 set(TCPDUMP_LINK_LIBRARIES socket ${TCPDUMP_LINK_LIBRARIES})
420 endif(LIBSOCKET_HAS_GETSERVENT)
421 endif(STDLIBS_HAVE_GETSERVENT)
422 cmake_pop_check_state()
425 # Make sure we have snprintf(); we require it.
426 # We use check_symbol_exists(), as it isn't necessarily an external
427 # function - in Visual Studio, for example, it is an inline function
428 # calling an external function.
430 check_symbol_exists(snprintf "stdio.h" HAVE_SNPRINTF)
431 if(NOT HAVE_SNPRINTF)
432 message(FATAL_ERROR "snprintf() is required but wasn't found")
436 # Require a proof of suitable snprintf(3), same as in Autoconf.
438 include(CheckCSourceRuns)
439 check_c_source_runs("
442 #include <inttypes.h>
443 #include <sys/types.h>
448 uint64_t t = (uint64_t)1 << 32;
450 snprintf(buf, sizeof(buf), \"%zu\", sizeof(buf));
451 if (strncmp(buf, \"100\", sizeof(buf)))
454 snprintf(buf, sizeof(buf), \"%zd\", -sizeof(buf));
455 if (strncmp(buf, \"-100\", sizeof(buf)))
458 snprintf(buf, sizeof(buf), \"%\" PRId64, -t);
459 if (strncmp(buf, \"-4294967296\", sizeof(buf)))
462 snprintf(buf, sizeof(buf), \"0o%\" PRIo64, t);
463 if (strncmp(buf, \"0o40000000000\", sizeof(buf)))
466 snprintf(buf, sizeof(buf), \"0x%\" PRIx64, t);
467 if (strncmp(buf, \"0x100000000\", sizeof(buf)))
470 snprintf(buf, sizeof(buf), \"%\" PRIu64, t);
471 if (strncmp(buf, \"4294967296\", sizeof(buf)))
480 if(NOT SUITABLE_SNPRINTF)
482 "The snprintf(3) implementation in this libc is not suitable,
483 tcpdump would not work correctly even if it managed to compile."
487 check_function_exists(getopt_long HAVE_GETOPT_LONG)
489 # For Windows, don't need to waste time checking for fork() or vfork().
492 check_function_exists(fork HAVE_FORK)
493 check_function_exists(vfork HAVE_VFORK)
497 # Some platforms may need -lnsl for getrpcbynumber.
499 cmake_push_check_state()
500 set(CMAKE_REQUIRED_LIBRARIES ${TCPDUMP_LINK_LIBRARIES})
501 check_function_exists(getrpcbynumber STDLIBS_HAVE_GETRPCBYNUMBER)
502 if(STDLIBS_HAVE_GETRPCBYNUMBER)
503 set(HAVE_GETRPCBYNUMBER TRUE)
504 else(STDLIBS_HAVE_GETRPCBYNUMBER)
505 set(CMAKE_REQUIRED_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} nsl)
506 check_function_exists(getrpcbynumber LIBNSL_HAS_GETRPCBYNUMBER)
507 if(LIBNSL_HAS_GETRPCBYNUMBER)
508 set(HAVE_GETRPCBYNUMBER TRUE)
509 set(TCPDUMP_LINK_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} nsl)
510 endif(LIBNSL_HAS_GETRPCBYNUMBER)
511 endif(STDLIBS_HAVE_GETRPCBYNUMBER)
512 cmake_pop_check_state()
515 # This requires the libraries we require, as ether_ntohost might be
516 # in one of those libraries. That means we have to do this after
517 # we check for those libraries.
519 # You are in a twisty little maze of UN*Xes, all different.
520 # Some might not have ether_ntohost().
521 # Some might have it and declare it in <net/ethernet.h>.
522 # Some might have it and declare it in <netinet/ether.h>
523 # Some might have it and declare it in <sys/ethernet.h>.
524 # Some might have it and declare it in <arpa/inet.h>.
525 # Some might have it and declare it in <netinet/if_ether.h>.
526 # Some might have it and not declare it in any header file.
528 # Before you is a C compiler.
530 cmake_push_check_state()
531 set(CMAKE_REQUIRED_LIBRARIES ${TCPDUMP_LINK_LIBRARIES})
532 check_function_exists(ether_ntohost HAVE_ETHER_NTOHOST)
533 if(HAVE_ETHER_NTOHOST)
535 # OK, we have ether_ntohost(). We don't check whether it's buggy,
536 # as we assume any system that has CMake is likely to be new enough
537 # that, if it has ether_ntohost(), whatever bug is checked for in
538 # autotools is fixed; we just decide to use it.
540 set(USE_ETHER_NTOHOST TRUE)
543 # Is it declared in <net/ethernet.h>?
545 # This test fails if we don't have <net/ethernet.h> or if we do
546 # but it doesn't declare ether_ntohost().
548 check_symbol_exists(ether_ntohost net/ethernet.h NET_ETHERNET_H_DECLARES_ETHER_NTOHOST)
549 if(NET_ETHERNET_H_DECLARES_ETHER_NTOHOST)
551 # Yes - we have it declared.
553 set(HAVE_DECL_ETHER_NTOHOST TRUE)
558 if(NOT HAVE_DECL_ETHER_NTOHOST)
560 # No - how about <netinet/ether.h>, as on Linux?
562 # This test fails if we don't have <netinet/ether.h>
563 # or if we do but it doesn't declare ether_ntohost().
565 check_symbol_exists(ether_ntohost netinet/ether.h NETINET_ETHER_H_DECLARES_ETHER_NTOHOST)
566 if(NETINET_ETHER_H_DECLARES_ETHER_NTOHOST)
568 # Yes - we have it declared.
570 set(HAVE_DECL_ETHER_NTOHOST TRUE)
576 if(NOT HAVE_DECL_ETHER_NTOHOST)
578 # No - how about <sys/ethernet.h>, as on Solaris 10 and later?
580 # This test fails if we don't have <sys/ethernet.h>
581 # or if we do but it doesn't declare ether_ntohost().
583 check_symbol_exists(ether_ntohost sys/ethernet.h SYS_ETHERNET_H_DECLARES_ETHER_NTOHOST)
584 if(SYS_ETHERNET_H_DECLARES_ETHER_NTOHOST)
586 # Yes - we have it declared.
588 set(HAVE_DECL_ETHER_NTOHOST TRUE)
594 if(NOT HAVE_DECL_ETHER_NTOHOST)
596 # No, how about <arpa/inet.h>, as on AIX?
598 # This test fails if we don't have <arpa/inet.h>
599 # or if we do but it doesn't declare ether_ntohost().
601 check_symbol_exists(ether_ntohost arpa/inet.h ARPA_INET_H_DECLARES_ETHER_NTOHOST)
602 if(ARPA_INET_H_DECLARES_ETHER_NTOHOST)
604 # Yes - we have it declared.
606 set(HAVE_DECL_ETHER_NTOHOST TRUE)
612 if(NOT HAVE_DECL_ETHER_NTOHOST)
614 # No, how about <netinet/if_ether.h>?
615 # On some platforms, it requires <net/if.h> and
616 # <netinet/in.h>, and we always include it with
617 # both of them, so test it with both of them.
619 # This test fails if we don't have <netinet/if_ether.h>
620 # and the headers we include before it, or if we do but
621 # <netinet/if_ether.h> doesn't declare ether_ntohost().
623 check_symbol_exists(ether_ntohost "sys/types.h;sys/socket.h;net/if.h;netinet/in.h;netinet/if_ether.h" NETINET_IF_ETHER_H_DECLARES_ETHER_NTOHOST)
624 if(NETINET_IF_ETHER_H_DECLARES_ETHER_NTOHOST)
626 # Yes - we have it declared.
628 set(HAVE_DECL_ETHER_NTOHOST TRUE)
632 # After all that, is ether_ntohost() declared?
634 if(NOT HAVE_DECL_ETHER_NTOHOST)
636 # No, we'll have to declare it ourselves.
637 # Do we have "struct ether_addr" if we include<netinet/if_ether.h>?
639 check_struct_has_member("struct ether_addr" octet "sys/types.h;sys/socket.h;net/if.h;netinet/in.h;netinet/if_ether.h" HAVE_STRUCT_ETHER_ADDR)
642 cmake_pop_check_state()
647 # XXX - there's no check_struct() macro that's like check_struct_has_member()
648 # except that it only checks for the existence of the structure type,
649 # so we use check_struct_has_member() and look for ss_family.
652 ######################################
653 # External dependencies
654 ######################################
657 # libpcap/WinPcap/Npcap.
660 find_package(PCAP REQUIRED)
661 include_directories(${PCAP_INCLUDE_DIRS})
663 cmake_push_check_state()
668 set(CMAKE_REQUIRED_INCLUDES ${PCAP_INCLUDE_DIRS})
671 # Check whether we have pcap/pcap-inttypes.h.
672 # If we do, we use that to get the C99 types defined.
674 check_include_file(pcap/pcap-inttypes.h HAVE_PCAP_PCAP_INTTYPES_H)
677 # At compile time HAVE_PCAP_FINDALLDEVS depends on HAVE_PCAP_IF_T.
679 cmake_push_check_state()
680 set(CMAKE_EXTRA_INCLUDE_FILES pcap.h)
681 check_type_size(pcap_if_t PCAP_IF_T)
682 cmake_pop_check_state()
685 # Check for various functions in libpcap/WinPcap/Npcap.
687 cmake_push_check_state()
688 set(CMAKE_REQUIRED_LIBRARIES ${PCAP_LIBRARIES})
691 # Check for "pcap_list_datalinks()" and use a substitute version if
692 # it's not present. If it is present, check for "pcap_free_datalinks()";
693 # if it's not present, we don't replace it for now. (We could do so
694 # on UN*X, but not on Windows, where hilarity ensues if a program
695 # built with one version of the MSVC support library tries to free
696 # something allocated by a library built with another version of
697 # the MSVC support library.)
699 check_function_exists(pcap_list_datalinks HAVE_PCAP_LIST_DATALINKS)
700 if(HAVE_PCAP_LIST_DATALINKS)
701 check_function_exists(pcap_free_datalinks HAVE_PCAP_FREE_DATALINKS)
702 endif(HAVE_PCAP_LIST_DATALINKS)
705 # Check for "pcap_datalink_name_to_val()", and use a substitute
706 # version if it's not present. If it is present, check for
707 # "pcap_datalink_val_to_description()", and if we don't have it,
708 # use a substitute version.
710 check_function_exists(pcap_datalink_name_to_val HAVE_PCAP_DATALINK_NAME_TO_VAL)
711 if(HAVE_PCAP_DATALINK_NAME_TO_VAL)
712 check_function_exists(pcap_datalink_val_to_description HAVE_PCAP_DATALINK_VAL_TO_DESCRIPTION)
713 endif(HAVE_PCAP_DATALINK_NAME_TO_VAL)
716 # Check for "pcap_set_datalink()"; you can't substitute for it if
717 # it's absent (it has hooks into libpcap), so just define the
718 # HAVE_ value if it's there.
720 check_function_exists(pcap_set_datalink HAVE_PCAP_SET_DATALINK)
723 # Check for "pcap_breakloop()"; you can't substitute for it if
724 # it's absent (it has hooks into the live capture routines),
725 # so just define the HAVE_ value if it's there.
727 check_function_exists(pcap_breakloop HAVE_PCAP_BREAKLOOP)
730 # Check for "pcap_dump_ftell()"; we use a substitute version
731 # if it's not present.
733 check_function_exists(pcap_dump_ftell HAVE_PCAP_DUMP_FTELL)
736 # Do we have the new open API? Check for pcap_create() and for
737 # pcap_statustostr(), and assume that, if we have both of them,
738 # we also have pcap_activate() and the other new routines
739 # introduced in libpcap 1.0.0. (We check for pcap_statustostr()
740 # as well, because WinPcap 4.1.3 screwed up and exported pcap_create()
741 # but not other routines such as pcap_statustostr(), even though it
742 # defined them and even though you really want pcap_statustostr() to
743 # get strings corresponding to some of the status returns from the
746 check_function_exists(pcap_statustostr HAVE_PCAP_STATUSTOSTR)
748 # If we don't have pcap_statustostr(), don't check for pcap_create(),
749 # so we pretend we don't have it.
751 if(HAVE_PCAP_STATUSTOSTR)
752 check_function_exists(pcap_create HAVE_PCAP_CREATE)
753 endif(HAVE_PCAP_STATUSTOSTR)
756 # OK, do we have pcap_set_tstamp_type? If so, assume we have
757 # pcap_list_tstamp_types and pcap_free_tstamp_types as well.
759 check_function_exists(pcap_set_tstamp_type HAVE_PCAP_SET_TSTAMP_TYPE)
762 # And do we have pcap_set_tstamp_precision? If so, we assume
763 # we also have pcap_open_offline_with_tstamp_precision.
765 check_function_exists(pcap_set_tstamp_precision HAVE_PCAP_SET_TSTAMP_PRECISION)
766 endif(HAVE_PCAP_CREATE)
769 # Check for a miscellaneous collection of functions which we use
772 check_function_exists(pcap_findalldevs HAVE_PCAP_FINDALLDEVS)
773 check_function_exists(pcap_dump_flush HAVE_PCAP_DUMP_FLUSH)
774 check_function_exists(pcap_lib_version HAVE_PCAP_LIB_VERSION)
775 if(NOT HAVE_PCAP_LIB_VERSION)
776 # Check for the pcap_version string variable and set HAVE_PCAP_VERSION
777 endif(NOT HAVE_PCAP_LIB_VERSION)
778 check_function_exists(pcap_setdirection HAVE_PCAP_SETDIRECTION)
779 check_function_exists(pcap_set_immediate_mode HAVE_PCAP_SET_IMMEDIATE_MODE)
780 check_function_exists(pcap_dump_ftell64 HAVE_PCAP_DUMP_FTELL64)
781 check_function_exists(pcap_open HAVE_PCAP_OPEN)
782 check_function_exists(pcap_findalldevs_ex HAVE_PCAP_FINDALLDEVS_EX)
785 # On Windows, check for pcap_wsockinit(); if we don't have it, check for
789 check_function_exists(pcap_wsockinit HAVE_PCAP_WSOCKINIT)
790 if(NOT HAVE_PCAP_WSOCKINIT)
791 check_function_exists(wsockinit HAVE_WSOCKINIT)
792 endif(NOT HAVE_PCAP_WSOCKINIT)
796 # Check for special debugging functions
798 check_function_exists(pcap_set_parser_debug HAVE_PCAP_SET_PARSER_DEBUG)
799 if(NOT HAVE_PCAP_SET_PARSER_DEBUG)
800 # Check whether libpcap defines pcap_debug or yydebug
801 check_variable_exists(pcap_debug HAVE_PCAP_DEBUG)
802 if(NOT HAVE_PCAP_DEBUG)
803 check_variable_exists(yydebug HAVE_YYDEBUG)
804 endif(NOT HAVE_PCAP_DEBUG)
805 endif(NOT HAVE_PCAP_SET_PARSER_DEBUG)
807 check_function_exists(pcap_set_optimizer_debug HAVE_PCAP_SET_OPTIMIZER_DEBUG)
808 check_function_exists(bpf_dump HAVE_BPF_DUMP)
810 cmake_pop_check_state()
811 cmake_pop_check_state()
816 include_directories(SYSTEM ${PCAP_INCLUDE_DIRS})
817 set(TCPDUMP_LINK_LIBRARIES ${PCAP_LIBRARIES} ${TCPDUMP_LINK_LIBRARIES})
820 # Optional libraries.
829 include_directories(SYSTEM ${SMI_INCLUDE_DIRS})
830 set(TCPDUMP_LINK_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} ${SMI_LIBRARIES})
836 # OpenSSL/libressl libcrypto.
842 # Check for some headers and functions.
844 check_include_file(openssl/evp.h HAVE_OPENSSL_EVP_H)
847 # 1) do we have EVP_CIPHER_CTX_new?
848 # If so, we use it to allocate an EVP_CIPHER_CTX, as
849 # EVP_CIPHER_CTX may be opaque; otherwise, we allocate
852 cmake_push_check_state()
853 set(CMAKE_REQUIRED_LIBRARIES "${CRYPTO_LIBRARIES}")
855 check_function_exists(EVP_CIPHER_CTX_new HAVE_EVP_CIPHER_CTX_NEW)
858 # 2) do we have EVP_DecryptInit_ex()?
859 # If so, we use it, because we need to be able to make two
860 # "initialize the cipher" calls, one with the cipher and key,
861 # and one with the IV, and, as of OpenSSL 1.1, You Can't Do That
862 # with EVP_DecryptInit(), because a call to EVP_DecryptInit() will
863 # unconditionally clear the context, and if you don't supply a
864 # cipher, it'll clear the cipher, rendering the context unusable
865 # and causing a crash.
867 check_function_exists(EVP_DecryptInit_ex HAVE_EVP_DECRYPTINIT_EX)
869 cmake_pop_check_state()
874 include_directories(SYSTEM ${CRYPTO_INCLUDE_DIRS})
875 set(TCPDUMP_LINK_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} ${CRYPTO_LIBRARIES})
876 set(HAVE_LIBCRYPTO ON)
881 # Capsicum sandboxing.
882 # Some of this is in the system library, some of it is in other libraries.
885 check_include_files("sys/capsicum.h" HAVE_SYS_CAPSICUM_H)
886 if(HAVE_SYS_CAPSICUM_H)
887 check_function_exists(cap_enter HAVE_CAP_ENTER)
888 check_function_exists(cap_rights_limit HAVE_CAP_RIGHTS_LIMIT)
889 check_function_exists(cap_ioctls_limit HAVE_CAP_IOCTLS_LIMIT)
890 check_function_exists(openat HAVE_OPENAT)
891 if(HAVE_CAP_ENTER AND HAVE_CAP_RIGHTS_LIMIT AND
892 HAVE_CAP_IOCTLS_LIMIT AND HAVE_OPENAT)
894 # OK, we have the functions we need to support Capsicum.
896 set(HAVE_CAPSICUM TRUE)
899 # OK, can we use Casper?
901 check_library_exists(casper cap_init "" HAVE_CAP_INIT)
903 cmake_push_check_state()
904 set(CMAKE_REQUIRED_LIBRARIES casper)
905 check_library_exists(cap_dns cap_gethostbyaddr "" HAVE_CAP_GETHOSTBYADDR)
906 cmake_pop_check_state()
907 if(HAVE_CAP_GETHOSTBYADDR)
908 set(HAVE_CASPER TRUE)
909 set(TCPDUMP_LINK_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} casper cap_dns)
910 endif(HAVE_CAP_GETHOSTBYADDR)
912 endif(HAVE_CAP_ENTER AND HAVE_CAP_RIGHTS_LIMIT AND
913 HAVE_CAP_IOCTLS_LIMIT AND HAVE_OPENAT)
914 endif(HAVE_SYS_CAPSICUM_H)
921 check_include_file(cap-ng.h HAVE_CAP_NG_H)
922 check_library_exists(cap-ng capng_change_id "" HAVE_LIBCAP_NG)
924 set(TCPDUMP_LINK_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} cap-ng)
925 endif(HAVE_LIBCAP_NG)
928 ###################################################################
930 ###################################################################
933 # Check and add warning options if we have a .devel file.
935 if(EXISTS ${CMAKE_SOURCE_DIR}/.devel OR EXISTS ${CMAKE_BINARY_DIR}/.devel)
939 if(MSVC AND NOT ${CMAKE_C_COMPILER} MATCHES "clang*")
941 # MSVC, with Microsoft's front end and code generator.
942 # "MSVC" is also set for Microsoft's compiler with a Clang
943 # front end and their code generator ("Clang/C2"), so we
944 # check for clang.exe and treat that differently.
946 check_and_add_compiler_option(-Wall)
948 # Disable some pointless warnings that /Wall turns on.
950 # Unfortunately, MSVC does not appear to have an equivalent
951 # to "__attribute__((unused))" to mark a particular function
952 # parameter as being known to be unused, so that the compiler
953 # won't warn about it (for example, the function might have
954 # that parameter because a pointer to it is being used, and
955 # the signature of that function includes that parameter).
956 # C++ lets you give a parameter a type but no name, but C
959 check_and_add_compiler_option(-wd4100)
961 # In theory, we care whether somebody uses f() rather than
962 # f(void) to declare a function with no arguments, but, in
963 # practice, there are places in the Windows header files
964 # that appear to do that, so we squelch that warning.
966 check_and_add_compiler_option(-wd4255)
968 # Windows FD_SET() generates this, so we suppress it.
970 check_and_add_compiler_option(-wd4548)
972 # Perhaps testing something #defined to be 0 with #ifdef is an
973 # error, and it should be tested with #if, but perhaps it's
974 # not, and Microsoft does that in its headers, so we squelch
977 check_and_add_compiler_option(-wd4574)
979 # The Windows headers also test not-defined values in #if, so
980 # we don't want warnings about that, either.
982 check_and_add_compiler_option(-wd4668)
984 # We do *not* care whether some function is, or isn't, going to be
987 check_and_add_compiler_option(-wd4710)
988 check_and_add_compiler_option(-wd4711)
990 # We do *not* care whether we're adding padding bytes after
993 check_and_add_compiler_option(-wd4820)
995 # We do *not* care about every single place the compiler would
996 # have inserted Spectre mitigation if only we had told it to
997 # do so with /Qspectre. I guess the theory is that it's seeing
998 # bounds checks that would prevent out-of-bounds loads and that
999 # those out-of-bounds loads could be done speculatively and that
1000 # the Spectre attack could detect the value of the out-of-bounds
1001 # data *if* it's within our address space, but unless I'm
1002 # missing something I don't see that as being any form of
1005 # XXX - add /Qspectre if that is really worth doing.
1007 check_and_add_compiler_option(-wd5045)
1009 # We do *not* care whether a structure had padding added at
1010 # the end because of __declspec(align) - *we* don't use
1011 # __declspec(align), because the only structures whose layout
1012 # we precisely specify are those that get overlaid on packet
1013 # data, and in those every element is an array of octets so
1014 # that we have full control over the size and alignment, and,
1015 # apparently, jmp_buf has such a declaration on x86, meaning
1016 # that everything that includes netdissect.h, i.e. almost every
1017 # file in tcpdump, gets a warning.
1019 check_and_add_compiler_option(-wd4324)
1022 # Other compilers, including MSVC with a Clang front end and
1023 # Microsoft's code generator. We currently treat them as if
1024 # they might support GCC-style -W options.
1026 check_and_add_compiler_option(-W)
1027 check_and_add_compiler_option(-Wall)
1028 check_and_add_compiler_option(-Wassign-enum)
1029 check_and_add_compiler_option(-Wcast-qual)
1030 check_and_add_compiler_option(-Wmissing-prototypes)
1031 check_and_add_compiler_option(-Wmissing-variable-declarations)
1032 check_and_add_compiler_option(-Wold-style-definition)
1033 if(NOT CMAKE_C_COMPILER_ID MATCHES "Sun")
1034 # In Sun C versions that implement GCC compatibility "-Wpedantic"
1035 # means the same as "-pedantic". The latter is mutually exclusive
1036 # with several other options. One of those is "-xc99", which has
1037 # already been set for Sun C above.
1038 check_and_add_compiler_option(-Wpedantic)
1040 check_and_add_compiler_option(-Wpointer-arith)
1041 check_and_add_compiler_option(-Wpointer-sign)
1042 check_and_add_compiler_option(-Wshadow)
1043 check_and_add_compiler_option(-Wsign-compare)
1044 check_and_add_compiler_option(-Wstrict-prototypes)
1045 check_and_add_compiler_option(-Wundef)
1046 check_and_add_compiler_option(-Wunreachable-code-return)
1047 check_and_add_compiler_option(-Wused-but-marked-unused)
1048 check_and_add_compiler_option(-Wwrite-strings)
1053 # Extra compiler options for the build matrix scripts to request -Werror or
1054 # its equivalent if required. The CMake variable name cannot be CFLAGS
1055 # because that is already used for a different purpose in CMake. Example
1056 # usage: cmake -DEXTRA_CFLAGS='-Wall -Wextra -Werror' ...
1058 if(NOT "${EXTRA_CFLAGS}" STREQUAL "")
1059 # The meaning of EXTRA_CFLAGS is "use the exact specified options, or the
1060 # build risks failing to fail", not "try every specified option, omit those
1061 # that do not work and use the rest". Thus use add_compile_options(), not
1062 # foreach()/check_and_add_compiler_option(). Another reason to do that is
1063 # that the effect lasts in testprogs/ and testprogs/fuzz/.
1064 string(REPLACE " " ";" _extra_cflags_list ${EXTRA_CFLAGS})
1065 add_compile_options(${_extra_cflags_list})
1066 message(STATUS "Added extra compile options (${EXTRA_CFLAGS})")
1069 ######################################
1071 ######################################
1075 # We allow the SMB dissector to be omitted.
1077 set(LOCALSRC ${LOCALSRC}
1082 set(NETDISSECT_SOURCE_LIST_C
1197 print-openflow-1.0.c
1198 print-openflow-1.3.c
1268 # Replace missing functions
1270 foreach(FUNC strlcat strlcpy strsep getservent getopt_long)
1271 string(TOUPPER ${FUNC} FUNC_UPPERCASE)
1272 set(HAVE_FUNC_UPPERCASE HAVE_${FUNC_UPPERCASE})
1273 if(NOT ${HAVE_FUNC_UPPERCASE})
1274 set(NETDISSECT_SOURCE_LIST_C ${NETDISSECT_SOURCE_LIST_C} missing/${FUNC}.c)
1278 add_library(netdissect STATIC
1279 ${NETDISSECT_SOURCE_LIST_C}
1281 if(NOT C_ADDITIONAL_FLAGS STREQUAL "")
1282 set_target_properties(netdissect PROPERTIES COMPILE_FLAGS ${C_ADDITIONAL_FLAGS})
1285 set(TCPDUMP_SOURCE_LIST_C fptype.c tcpdump.c)
1287 if(NOT HAVE_BPF_DUMP)
1288 set(TCPDUMP_SOURCE_LIST_C ${TCPDUMP_SOURCE_LIST_C} bpf_dump.c)
1289 endif(NOT HAVE_BPF_DUMP)
1290 if(NOT HAVE_PCAP_DUMP_FTELL)
1291 set(TCPDUMP_SOURCE_LIST_C ${TCPDUMP_SOURCE_LIST_C} missing/pcap_dump_ftell.c)
1292 endif(NOT HAVE_PCAP_DUMP_FTELL)
1294 if(NOT HAVE_PCAP_LIST_DATALINKS)
1295 set(TCPDUMP_SOURCE_LIST_C ${TCPDUMP_SOURCE_LIST_C} missing/datalinks.c)
1296 endif(NOT HAVE_PCAP_LIST_DATALINKS)
1298 if((NOT HAVE_PCAP_DATALINK_NAME_TO_VAL) OR (NOT HAVE_PCAP_DATALINK_VAL_TO_DESCRIPTION))
1299 set(TCPDUMP_SOURCE_LIST_C ${TCPDUMP_SOURCE_LIST_C} missing/dlnames.c)
1300 endif((NOT HAVE_PCAP_DATALINK_NAME_TO_VAL) OR (NOT HAVE_PCAP_DATALINK_VAL_TO_DESCRIPTION))
1302 set(PROJECT_SOURCE_LIST_C ${NETDISSECT_SOURCE_LIST_C} ${TCPDUMP_SOURCE_LIST_C})
1304 file(GLOB PROJECT_SOURCE_LIST_H
1309 # Assume, by default, no support for shared libraries and V7/BSD
1310 # convention for man pages (devices in section 4, file formats in
1311 # section 5, miscellaneous info in section 7, administrative commands
1312 # and daemons in section 8). Individual cases can override this.
1313 # Individual cases can override this.
1315 set(MAN_FILE_FORMATS 5)
1316 set(MAN_MISC_INFO 7)
1317 if(CMAKE_SYSTEM_NAME STREQUAL "AIX")
1318 # Workaround to enable certain features
1320 elseif(CMAKE_SYSTEM_NAME STREQUAL "HP-UX")
1322 # Use System V conventions for man pages.
1324 set(MAN_FILE_FORMATS 4)
1325 set(MAN_MISC_INFO 5)
1326 elseif(CMAKE_SYSTEM_NAME STREQUAL "SunOS" AND CMAKE_SYSTEM_VERSION MATCHES "5[.][0-9.]*")
1330 if(CMAKE_SYSTEM_VERSION STREQUAL "5.12")
1333 # Use System V conventions for man pages.
1335 set(MAN_FILE_FORMATS 4)
1336 set(MAN_MISC_INFO 5)
1340 source_group("Source Files" FILES ${PROJECT_SOURCE_LIST_C})
1341 source_group("Header Files" FILES ${PROJECT_SOURCE_LIST_H})
1343 ######################################
1345 ######################################
1347 add_executable(tcpdump ${TCPDUMP_SOURCE_LIST_C})
1348 if(NOT C_ADDITIONAL_FLAGS STREQUAL "")
1349 set_target_properties(tcpdump PROPERTIES COMPILE_FLAGS ${C_ADDITIONAL_FLAGS})
1351 target_link_libraries(tcpdump netdissect ${TCPDUMP_LINK_LIBRARIES})
1353 ######################################
1354 # Write out the config.h file
1355 ######################################
1357 configure_file(${CMAKE_CURRENT_SOURCE_DIR}/cmakeconfig.h.in ${CMAKE_CURRENT_BINARY_DIR}/config.h)
1359 ######################################
1360 # Install tcpdump and man pages
1361 ######################################
1364 # "Define GNU standard installation directories", which actually
1365 # are also defined, to some degree, by autotools, and at least
1366 # some of which are general UN*X conventions.
1368 include(GNUInstallDirs)
1370 set(MAN1_EXPAND tcpdump.1.in)
1373 # XXX TODO where to install on Windows?
1375 install(TARGETS tcpdump DESTINATION bin)
1378 # On UN*X, and on Windows when not using MSVC, process man pages and
1379 # arrange that they be installed.
1384 # For each section of the manual for which we have man pages
1385 # that require macro expansion, do the expansion.
1388 foreach(TEMPLATE_MANPAGE ${MAN1_EXPAND})
1389 string(REPLACE ".in" "" MANPAGE ${TEMPLATE_MANPAGE})
1390 configure_file(${CMAKE_SOURCE_DIR}/${TEMPLATE_MANPAGE} ${CMAKE_CURRENT_BINARY_DIR}/${MANPAGE} @ONLY)
1391 set(MAN1 ${MAN1} ${CMAKE_CURRENT_BINARY_DIR}/${MANPAGE})
1392 endforeach(TEMPLATE_MANPAGE)
1393 install(FILES ${MAN1} DESTINATION ${CMAKE_INSTALL_MANDIR}/man1)
1398 "${CMAKE_CURRENT_SOURCE_DIR}/cmake_uninstall.cmake.in"
1399 "${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake"
1402 add_custom_target(uninstall
1403 COMMAND ${CMAKE_COMMAND} -P ${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake)
1407 # We try to find the Perl interpreter and, if we do, we have the check
1408 # rule run tests/TESTrun with it, because just trying to run the TESTrun
1409 # script as a command won't work on Windows.
1411 find_program(PERL perl)
1413 message(STATUS "Found perl at ${PERL}")
1414 add_custom_target(check
1415 COMMAND ${PERL} ${CMAKE_SOURCE_DIR}/tests/TESTrun)
1417 message(STATUS "Didn't find perl")