3 # We need 3.12 or later, so that we can set policy CMP0074; see
5 cmake_minimum_required(VERSION 3.12)
8 # For now, require only 2.8.6, just in case somebody is
9 # configuring with CMake on a "long-term support" version
10 # of some OS and that version supplies an older version of
13 # If this is ever updated to CMake 3.1 or later, remove the
14 # stuff in cmake/Modules/FindPCAP.cmake that appends subdirectories
15 # of directories from CMAKE_PREFIX_PATH to the PKG_CONFIG_PATH
16 # environment variable when running pkg-config, to make sure
17 # it finds any .pc file from there.
19 cmake_minimum_required(VERSION 2.8.12)
23 # We want find_path() and find_library() to honor {packagename}_ROOT,
24 # as that appears to be the standard way to say "hey, look here for
25 # this package" from the command line.
28 cmake_policy(SET CMP0074 NEW)
34 # When building on NetBSD, with a libpcap installed from pkgsrc,
35 # a -Wl,-rpath,/usr/pkg/lib option is added to the options when
36 # linking tcpdump. This puts /usr/pkg/lib into the run-time path.
38 # However, by default, CMake adds a rule to the install CMake script
39 # a CMake command (using an undocumented subcommand of file()) that
40 # strips /usr/pkg/lib *out* of the run-time path; the message in the
41 # output for the "install" target is
43 # -- Set runtime path of "{target-directory}/tcpdump" to ""
45 # I am not certain what the rationale is for doing this, but a
46 # *consequence* of this is that, when you run the installed tcpdump,
47 # it fails to find libpcap.so:
49 # $ {target-directory}/tcpdump -h
50 # {target-directory}/tcpdump: Shared object "libpcap.so.0" not found
52 # It also appears to be the case that, on Ubuntu 22.04, FreeBSD 12,
53 # DragonFly BSD 5.8, OpenBSD 6.6, and Solaris 11.4,
55 # On Ubuntu and Solaris, even if you have a libpcap in /usr/local, you
56 # have to provide not only -I/usr/local/include and -L/usr/local/lib,
57 # you also must provide -Wl,-rpath,/usr/local/lib in order to have
58 # the run-time linker look in /usr/local/lib for libpcap. If it's not
59 # specified, then, if the shared library major version number of the
60 # libpcap in /usr/lib is the same as the shared major version number
61 # of the libpcap in /usr/local/lib, the run-time linker will find the
62 # libpcap in /usr/lib; if the versions are different, the run-time
63 # linker will fail to find the libpcap in /usr/lib, so the program will
66 # We suppress this by setting CMAKE_INSTALL_RPATH_USE_LINK_PATH to TRUE;
67 # as the documentation for that variable says:
69 # Add paths to linker search and installed rpath.
71 # CMAKE_INSTALL_RPATH_USE_LINK_PATH is a boolean that if set to True
72 # will append to the runtime search path (rpath) of installed
73 # binaries any directories outside the project that are in the linker
74 # search path or contain linked library files. The directories are
75 # appended after the value of the INSTALL_RPATH target property.
77 # If, for whatever reason, directories in which we search for external
78 # libraries, other than the standard system library directories, are
79 # added to the executable's rpath in the build process, we most
80 # defintely want them in the installed image's rpath if they are
81 # necessary in order to find the libraries at run time.
83 set(CMAKE_INSTALL_RPATH_USE_LINK_PATH TRUE)
85 set(CMAKE_MODULE_PATH ${CMAKE_SOURCE_DIR}/cmake/Modules)
88 # OK, this is a royal pain.
90 # CMake will try to determine the sizes of some data types, including
91 # void *, early in the process of configuration; apparently, it's done
92 # as part of processing the project() command.
94 # At least as of CMake 2.8.6, it does so by checking the size of
95 # "void *" in C, setting CMAKE_C_SIZEOF_DATA_PTR based on that,
96 # setting CMAKE_SIZEOF_VOID_P to that, and then checking the size
97 # of "void *" in C++, setting CMAKE_CXX_SIZEOF_DATA_PTR based on
98 # that, and then setting CMAKE_SIZEOF_VOID_P to *that*.
100 # The compile tests include whatever C flags may have been provided
101 # to CMake in the CFLAGS and CXXFLAGS environment variables.
103 # If you set an architecture flag such as -m32 or -m64 in CFLAGS
104 # but *not* in CXXFLAGS, the size for C++ will win, and hilarity
107 # Or if, at least on Solaris, you have a newer version of GCC
108 # installed, but *not* a newer version of G++, and you have Oracle
109 # Studio installed, it will find GCC, which will default to building
110 # 64-bit, and Oracle Studio's C++ compiler, which will default to
111 # building 32-bit, the size for C++ will win, and, again, hilarity
114 # So we *explicitly* state that only C is used; there is currently no
115 # C++ code in tcpdump.
120 # For checking if a compiler flag works and adding it if it does.
122 include(CheckCCompilerFlag)
123 macro(check_and_add_compiler_option _option)
124 message(STATUS "Checking C compiler flag ${_option}")
125 string(REPLACE "=" "-" _temp_option_variable ${_option})
126 string(REGEX REPLACE "^-" "" _option_variable ${_temp_option_variable})
127 check_c_compiler_flag("${_option}" ${_option_variable})
128 if(${${_option_variable}})
129 set(C_ADDITIONAL_FLAGS "${C_ADDITIONAL_FLAGS} ${_option}")
134 # If we're building with Visual Studio, we require Visual Studio 2015,
135 # in order to get sufficient C99 compatibility. Check for that.
137 # If not, try the appropriate flag for the compiler to enable C99
140 set(C_ADDITIONAL_FLAGS "")
142 if(MSVC_VERSION LESS 1900)
143 message(FATAL_ERROR "Visual Studio 2015 or later is required")
147 # Treat source files as being in UTF-8 with MSVC if it's not using
148 # the Clang front end.
149 # We assume that UTF-8 source is OK with other compilers and with
150 # MSVC if it's using the Clang front end.
152 if(NOT ${CMAKE_C_COMPILER} MATCHES "clang*")
153 set(C_ADDITIONAL_FLAGS "${C_ADDITIONAL_FLAGS} /utf-8")
154 endif(NOT ${CMAKE_C_COMPILER} MATCHES "clang*")
157 # Try to enable as many C99 features as we can.
158 # At minimum, we want C++/C99-style // comments.
160 # Newer versions of compilers might default to supporting C99, but
161 # older versions may require a special flag.
163 # Prior to CMake 3.1, setting CMAKE_C_STANDARD will not have any effect,
164 # so, unless and until we require CMake 3.1 or later, we have to do it
165 # ourselves on pre-3.1 CMake, so we just do it ourselves on all versions
168 # Note: with CMake 3.1 through 3.5, the only compilers for which CMake
169 # handles CMAKE_C_STANDARD are GCC and Clang. 3.6 adds support only
170 # for Intel C; 3.9 adds support for PGI C, Sun C, and IBM XL C, and
171 # 3.10 adds support for Cray C and IAR C, but no version of CMake has
172 # support for HP C. Therefore, even if we use CMAKE_C_STANDARD with
173 # compilers for which CMake supports it, we may still have to do it
174 # ourselves on other compilers.
176 # See the CMake documentation for the CMAKE_<LANG>_COMPILER_ID variables
177 # for a list of compiler IDs.
179 # XXX - this just tests whether the option works and adds it if it does.
180 # We don't test whether it's necessary in order to get the C99 features
181 # that we use; if we ever have a user who tries to compile with a compiler
182 # that can't be made to support those features, we can add a test to make
183 # sure we actually *have* C99 support.
185 if(CMAKE_C_COMPILER_ID MATCHES "GNU" OR
186 CMAKE_C_COMPILER_ID MATCHES "Clang")
187 check_and_add_compiler_option("-std=gnu99")
188 elseif(CMAKE_C_COMPILER_ID MATCHES "XL")
190 # We want support for extensions picked up for GNU C compatibility,
191 # so we use -qlanglvl=extc99.
193 check_and_add_compiler_option("-qlanglvl=extc99")
194 elseif(CMAKE_C_COMPILER_ID MATCHES "HP")
195 check_and_add_compiler_option("-AC99")
196 elseif(CMAKE_C_COMPILER_ID MATCHES "Sun")
197 check_and_add_compiler_option("-xc99")
198 elseif(CMAKE_C_COMPILER_ID MATCHES "Intel")
199 check_and_add_compiler_option("-c99")
203 set(LIBRARY_NAME netdissect)
205 ###################################################################
207 ###################################################################
209 option(WITH_SMI "Build with libsmi, if available" ON)
210 option(WITH_CRYPTO "Build with OpenSSL/libressl libcrypto, if available" ON)
211 option(WITH_CAPSICUM "Build with Capsicum security functions, if available" ON)
212 option(WITH_CAP_NG "Use libcap-ng, if available" ON)
213 option(ENABLE_SMB "Build with the SMB dissector" OFF)
216 # String parameters. Neither of them are set, initially; only if the
217 # user explicitly configures them are they set.
219 # WITH_CHROOT is STRING, not PATH, as the directory need not exist
222 set(WITH_CHROOT CACHE STRING
223 "Directory to which to chroot when dropping privileges")
224 set(WITH_USER CACHE STRING
225 "User to whom to set the UID when dropping privileges")
228 # By default, build universal with the appropriate set of architectures
229 # for the OS on which we're doing the build.
231 if(APPLE AND "${CMAKE_OSX_ARCHITECTURES}" STREQUAL "")
233 # Get the major version of Darwin.
235 string(REGEX MATCH "^([0-9]+)" SYSTEM_VERSION_MAJOR "${CMAKE_SYSTEM_VERSION}")
237 if(SYSTEM_VERSION_MAJOR EQUAL 9)
239 # Leopard. Build for x86 and 32-bit PowerPC, with
240 # x86 first. (That's what Apple does.)
242 set(CMAKE_OSX_ARCHITECTURES "i386;ppc")
243 elseif(SYSTEM_VERSION_MAJOR EQUAL 10)
245 # Snow Leopard. Build for x86-64 and x86, with
246 # x86-64 first. (That's what Apple does.)
248 set(CMAKE_OSX_ARCHITECTURES "x86_64;i386")
252 ###################################################################
254 ###################################################################
256 # Get, parse, format and set tcpdump's version string from
257 # [tcpdump_root]/VERSION for later use.
259 # Get MAJOR, MINOR, PATCH & SUFFIX
260 file(STRINGS ${tcpdump_SOURCE_DIR}/VERSION
262 LIMIT_COUNT 1 # Read only the first line
265 ######################################
267 ######################################
269 add_definitions(-DHAVE_CONFIG_H)
272 ${CMAKE_CURRENT_BINARY_DIR}
273 ${tcpdump_SOURCE_DIR}
277 add_definitions(-D__STDC__)
278 add_definitions(-D_CRT_SECURE_NO_WARNINGS)
283 MESSAGE(STATUS "Use STATIC runtime")
285 set (CMAKE_CXX_FLAGS_MINSIZEREL "${CMAKE_CXX_FLAGS_MINSIZEREL} /MT")
286 set (CMAKE_CXX_FLAGS_RELWITHDEBINFO "${CMAKE_CXX_FLAGS_RELWITHDEBINFO} /MT")
287 set (CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} /MT")
288 set (CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /MTd")
290 set (CMAKE_C_FLAGS_MINSIZEREL "${CMAKE_C_FLAGS_MINSIZEREL} /MT")
291 set (CMAKE_C_FLAGS_RELWITHDEBINFO "${CMAKE_C_FLAGS_RELWITHDEBINFO} /MT")
292 set (CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} /MT")
293 set (CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} /MTd")
295 MESSAGE(STATUS "Use DYNAMIC runtime")
297 set (CMAKE_CXX_FLAGS_MINSIZEREL "${CMAKE_CXX_FLAGS_MINSIZEREL} /MD")
298 set (CMAKE_CXX_FLAGS_RELWITHDEBINFO "${CMAKE_CXX_FLAGS_RELWITHDEBINFO} /MD")
299 set (CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS_RELEASE} /MD")
300 set (CMAKE_CXX_FLAGS_DEBUG "${CMAKE_CXX_FLAGS_DEBUG} /MDd")
302 set (CMAKE_C_FLAGS_MINSIZEREL "${CMAKE_C_FLAGS_MINSIZEREL} /MD")
303 set (CMAKE_C_FLAGS_RELWITHDEBINFO "${CMAKE_C_FLAGS_RELWITHDEBINFO} /MD")
304 set (CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} /MD")
305 set (CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} /MDd")
306 endif (USE_STATIC_RT)
309 ###################################################################
310 # Detect available platform features
311 ###################################################################
313 include(CMakePushCheckState)
314 include(CheckIncludeFile)
315 include(CheckIncludeFiles)
316 include(CheckFunctionExists)
317 include(CheckLibraryExists)
318 include(CheckSymbolExists)
319 include(CheckStructHasMember)
320 include(CheckVariableExists)
321 include(CheckTypeSize)
326 check_include_file(fcntl.h HAVE_FCNTL_H)
327 check_include_file(rpc/rpc.h HAVE_RPC_RPC_H)
328 check_include_file(net/if.h HAVE_NET_IF_H)
330 check_include_files("rpc/rpc.h;rpc/rpcent.h" HAVE_RPC_RPCENT_H)
331 endif(HAVE_RPC_RPC_H)
336 check_function_exists(strlcat HAVE_STRLCAT)
337 check_function_exists(strlcpy HAVE_STRLCPY)
338 check_function_exists(strdup HAVE_STRDUP)
339 check_function_exists(strsep HAVE_STRSEP)
342 # Find library needed for gethostbyaddr.
343 # NOTE: if you hand check_library_exists as its last argument a variable
344 # that's been set, it skips the test, so we need different variables.
346 set(TCPDUMP_LINK_LIBRARIES "")
349 # We need winsock2.h and ws2tcpip.h.
351 cmake_push_check_state()
352 set(CMAKE_REQUIRED_LIBRARIES ws2_32)
353 check_symbol_exists(gethostbyaddr "winsock2.h;ws2tcpip.h" LIBWS2_32_HAS_GETHOSTBYADDR)
354 cmake_pop_check_state()
355 if(LIBWS2_32_HAS_GETHOSTBYADDR)
356 set(TCPDUMP_LINK_LIBRARIES ws2_32 ${TCPDUMP_LINK_LIBRARIES})
357 else(LIBWS2_32_HAS_GETHOSTBYADDR)
358 message(FATAL_ERROR "gethostbyaddr is required, but wasn't found")
359 endif(LIBWS2_32_HAS_GETHOSTBYADDR)
361 check_function_exists(gethostbyaddr STDLIBS_HAVE_GETHOSTBYADDR)
362 if(NOT STDLIBS_HAVE_GETHOSTBYADDR)
363 check_library_exists(socket gethostbyaddr "" LIBSOCKET_HAS_GETHOSTBYADDR)
364 if(LIBSOCKET_HAS_GETHOSTBYADDR)
365 set(TCPDUMP_LINK_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} socket)
366 else(LIBSOCKET_HAS_GETHOSTBYADDR)
367 check_library_exists(nsl gethostbyaddr "" LIBNSL_HAS_GETHOSTBYADDR)
368 if(LIBNSL_HAS_GETHOSTBYADDR)
369 set(TCPDUMP_LINK_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} nsl)
370 else(LIBNSL_HAS_GETHOSTBYADDR)
371 message(FATAL_ERROR "gethostbyaddr is required, but wasn't found")
372 endif(LIBNSL_HAS_GETHOSTBYADDR)
373 endif(LIBSOCKET_HAS_GETHOSTBYADDR)
374 endif(NOT STDLIBS_HAVE_GETHOSTBYADDR)
378 # This may require additional libraries.
380 cmake_push_check_state()
381 set(CMAKE_REQUIRED_LIBRARIES ${TCPDUMP_LINK_LIBRARIES})
382 check_function_exists(getservent STDLIBS_HAVE_GETSERVENT)
383 if(STDLIBS_HAVE_GETSERVENT)
384 set(HAVE_GETSERVENT TRUE)
385 else(STDLIBS_HAVE_GETSERVENT)
387 # Some platforms may need -lsocket for getservent.
389 set(CMAKE_REQUIRED_LIBRARIES socket ${TCPDUMP_LINK_LIBRARIES})
390 check_function_exists(getservent LIBSOCKET_HAS_GETSERVENT)
391 if(LIBSOCKET_HAS_GETSERVENT)
392 set(HAVE_GETSERVENT TRUE)
393 set(TCPDUMP_LINK_LIBRARIES socket ${TCPDUMP_LINK_LIBRARIES})
394 endif(LIBSOCKET_HAS_GETSERVENT)
395 endif(STDLIBS_HAVE_GETSERVENT)
396 cmake_pop_check_state()
399 # Make sure we have vsnprintf() and snprintf(); we require them.
400 # We use check_symbol_exists(), as they aren't necessarily external
401 # functions - in Visual Studio, for example, they're inline functions
402 # calling a common external function.
404 check_symbol_exists(vsnprintf "stdio.h" HAVE_VSNPRINTF)
405 if(NOT HAVE_VSNPRINTF)
406 message(FATAL_ERROR "vsnprintf() is required but wasn't found")
407 endif(NOT HAVE_VSNPRINTF)
408 check_symbol_exists(snprintf "stdio.h" HAVE_SNPRINTF)
409 if(NOT HAVE_SNPRINTF)
410 message(FATAL_ERROR "snprintf() is required but wasn't found")
413 check_function_exists(getopt_long HAVE_GETOPT_LONG)
414 check_function_exists(strftime HAVE_STRFTIME)
415 check_function_exists(setlinebuf HAVE_SETLINEBUF)
417 # For Windows, don't need to waste time checking for fork() or vfork().
420 check_function_exists(fork HAVE_FORK)
421 check_function_exists(vfork HAVE_VFORK)
425 # Some platforms may need -lnsl for getrpcbynumber.
427 cmake_push_check_state()
428 set(CMAKE_REQUIRED_LIBRARIES ${TCPDUMP_LINK_LIBRARIES})
429 check_function_exists(getrpcbynumber STDLIBS_HAVE_GETRPCBYNUMBER)
430 if(STDLIBS_HAVE_GETRPCBYNUMBER)
431 set(HAVE_GETRPCBYNUMBER TRUE)
432 else(STDLIBS_HAVE_GETRPCBYNUMBER)
433 set(CMAKE_REQUIRED_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} nsl)
434 check_function_exists(getrpcbynumber LIBNSL_HAS_GETRPCBYNUMBER)
435 if(LIBNSL_HAS_GETRPCBYNUMBER)
436 set(HAVE_GETRPCBYNUMBER TRUE)
437 set(TCPDUMP_LINK_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} nsl)
438 endif(LIBNSL_HAS_GETRPCBYNUMBER)
439 endif(STDLIBS_HAVE_GETRPCBYNUMBER)
440 cmake_pop_check_state()
443 # This requires the libraries we require, as ether_ntohost might be
444 # in one of those libraries. That means we have to do this after
445 # we check for those libraries.
447 # You are in a twisty little maze of UN*Xes, all different.
448 # Some might not have ether_ntohost().
449 # Some might have it and declare it in <net/ethernet.h>.
450 # Some might have it and declare it in <netinet/ether.h>
451 # Some might have it and declare it in <sys/ethernet.h>.
452 # Some might have it and declare it in <arpa/inet.h>.
453 # Some might have it and declare it in <netinet/if_ether.h>.
454 # Some might have it and not declare it in any header file.
456 # Before you is a C compiler.
458 cmake_push_check_state()
459 set(CMAKE_REQUIRED_LIBRARIES ${TCPDUMP_LINK_LIBRARIES})
460 check_function_exists(ether_ntohost HAVE_ETHER_NTOHOST)
461 if(HAVE_ETHER_NTOHOST)
463 # OK, we have ether_ntohost(). We don't check whether it's buggy,
464 # as we assume any system that has CMake is likely to be new enough
465 # that, if it has ether_ntohost(), whatever bug is checked for in
466 # autotools is fixed; we just decide to use it.
468 set(USE_ETHER_NTOHOST TRUE)
471 # Is it declared in <net/ethernet.h>?
473 # This test fails if we don't have <net/ethernet.h> or if we do
474 # but it doesn't declare ether_ntohost().
476 check_symbol_exists(ether_ntohost net/ethernet.h NET_ETHERNET_H_DECLARES_ETHER_NTOHOST)
477 if(NET_ETHERNET_H_DECLARES_ETHER_NTOHOST)
479 # Yes - we have it declared.
481 set(HAVE_DECL_ETHER_NTOHOST TRUE)
486 if(NOT HAVE_DECL_ETHER_NTOHOST)
488 # No - how about <netinet/ether.h>, as on Linux?
490 # This test fails if we don't have <netinet/ether.h>
491 # or if we do but it doesn't declare ether_ntohost().
493 check_symbol_exists(ether_ntohost netinet/ether.h NETINET_ETHER_H_DECLARES_ETHER_NTOHOST)
494 if(NETINET_ETHER_H_DECLARES_ETHER_NTOHOST)
496 # Yes - we have it declared.
498 set(HAVE_DECL_ETHER_NTOHOST TRUE)
504 if(NOT HAVE_DECL_ETHER_NTOHOST)
506 # No - how about <sys/ethernet.h>, as on Solaris 10 and later?
508 # This test fails if we don't have <sys/ethernet.h>
509 # or if we do but it doesn't declare ether_ntohost().
511 check_symbol_exists(ether_ntohost sys/ethernet.h SYS_ETHERNET_H_DECLARES_ETHER_NTOHOST)
512 if(SYS_ETHERNET_H_DECLARES_ETHER_NTOHOST)
514 # Yes - we have it declared.
516 set(HAVE_DECL_ETHER_NTOHOST TRUE)
522 if(NOT HAVE_DECL_ETHER_NTOHOST)
524 # No, how about <arpa/inet.h>, as on AIX?
526 # This test fails if we don't have <arpa/inet.h>
527 # or if we do but it doesn't declare ether_ntohost().
529 check_symbol_exists(ether_ntohost arpa/inet.h ARPA_INET_H_DECLARES_ETHER_NTOHOST)
530 if(ARPA_INET_H_DECLARES_ETHER_NTOHOST)
532 # Yes - we have it declared.
534 set(HAVE_DECL_ETHER_NTOHOST TRUE)
540 if(NOT HAVE_DECL_ETHER_NTOHOST)
542 # No, how about <netinet/if_ether.h>?
543 # On some platforms, it requires <net/if.h> and
544 # <netinet/in.h>, and we always include it with
545 # both of them, so test it with both of them.
547 # This test fails if we don't have <netinet/if_ether.h>
548 # and the headers we include before it, or if we do but
549 # <netinet/if_ether.h> doesn't declare ether_ntohost().
551 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)
552 if(NETINET_IF_ETHER_H_DECLARES_ETHER_NTOHOST)
554 # Yes - we have it declared.
556 set(HAVE_DECL_ETHER_NTOHOST TRUE)
560 # After all that, is ether_ntohost() declared?
562 if(NOT HAVE_DECL_ETHER_NTOHOST)
564 # No, we'll have to declare it ourselves.
565 # Do we have "struct ether_addr" if we include<netinet/if_ether.h>?
567 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)
570 cmake_pop_check_state()
575 # XXX - there's no check_struct() macro that's like check_struct_has_member()
576 # except that it only checks for the existence of the structure type,
577 # so we use check_struct_has_member() and look for ss_family.
581 # Check for IPv6 support.
582 # We just check for AF_INET6 and struct in6_addr.
584 cmake_push_check_state()
586 set(CMAKE_EXTRA_INCLUDE_FILES sys/types.h ws2tcpip.h)
587 check_symbol_exists(AF_INET6 "sys/types.h;ws2tcpip.h" HAVE_AF_INET6)
589 set(CMAKE_EXTRA_INCLUDE_FILES sys/types.h sys/socket.h netinet/in.h)
590 check_symbol_exists(AF_INET6 "sys/types.h;sys/socket.h;netinet/in.h" HAVE_AF_INET6)
592 check_type_size("struct in6_addr" HAVE_STRUCT_IN6_ADDR)
593 cmake_pop_check_state()
594 if(HAVE_AF_INET6 AND HAVE_STRUCT_IN6_ADDR)
595 set(HAVE_OS_IPV6_SUPPORT TRUE)
596 endif(HAVE_AF_INET6 AND HAVE_STRUCT_IN6_ADDR)
598 ######################################
599 # External dependencies
600 ######################################
603 # libpcap/WinPcap/Npcap.
606 find_package(PCAP REQUIRED)
607 include_directories(${PCAP_INCLUDE_DIRS})
609 cmake_push_check_state()
614 set(CMAKE_REQUIRED_INCLUDES ${PCAP_INCLUDE_DIRS})
617 # Check whether we have pcap/pcap-inttypes.h.
618 # If we do, we use that to get the C99 types defined.
620 check_include_file(pcap/pcap-inttypes.h HAVE_PCAP_PCAP_INTTYPES_H)
623 # Check for various functions in libpcap/WinPcap/Npcap.
625 cmake_push_check_state()
626 set(CMAKE_REQUIRED_LIBRARIES ${PCAP_LIBRARIES})
629 # Check for "pcap_list_datalinks()" and use a substitute version if
630 # it's not present. If it is present, check for "pcap_free_datalinks()";
631 # if it's not present, we don't replace it for now. (We could do so
632 # on UN*X, but not on Windows, where hilarity ensues if a program
633 # built with one version of the MSVC support library tries to free
634 # something allocated by a library built with another version of
635 # the MSVC support library.)
637 check_function_exists(pcap_list_datalinks HAVE_PCAP_LIST_DATALINKS)
638 if(HAVE_PCAP_LIST_DATALINKS)
639 check_function_exists(pcap_free_datalinks HAVE_PCAP_FREE_DATALINKS)
640 endif(HAVE_PCAP_LIST_DATALINKS)
643 # Check for "pcap_datalink_name_to_val()", and use a substitute
644 # version if it's not present. If it is present, check for
645 # "pcap_datalink_val_to_description()", and if we don't have it,
646 # use a substitute version.
648 check_function_exists(pcap_datalink_name_to_val HAVE_PCAP_DATALINK_NAME_TO_VAL)
649 if(HAVE_PCAP_DATALINK_NAME_TO_VAL)
650 check_function_exists(pcap_datalink_val_to_description HAVE_PCAP_DATALINK_VAL_TO_DESCRIPTION)
651 endif(HAVE_PCAP_DATALINK_NAME_TO_VAL)
654 # Check for "pcap_set_datalink()"; you can't substitute for it if
655 # it's absent (it has hooks into libpcap), so just define the
656 # HAVE_ value if it's there.
658 check_function_exists(pcap_set_datalink HAVE_PCAP_SET_DATALINK)
661 # Check for "pcap_breakloop()"; you can't substitute for it if
662 # it's absent (it has hooks into the live capture routines),
663 # so just define the HAVE_ value if it's there.
665 check_function_exists(pcap_breakloop HAVE_PCAP_BREAKLOOP)
668 # Check for "pcap_dump_ftell()"; we use a substitute version
669 # if it's not present.
671 check_function_exists(pcap_dump_ftell HAVE_PCAP_DUMP_FTELL)
674 # Do we have the new open API? Check for pcap_create() and for
675 # pcap_statustostr(), and assume that, if we have both of them,
676 # we also have pcap_activate() and the other new routines
677 # introduced in libpcap 1.0.0. (We check for pcap_statustostr()
678 # as well, because WinPcap 4.1.3 screwed up and exported pcap_create()
679 # but not other routines such as pcap_statustostr(), even though it
680 # defined them and even though you really want pcap_statustostr() to
681 # get strings corresponding to some of the status returns from the
684 check_function_exists(pcap_statustostr HAVE_PCAP_STATUSTOSTR)
686 # If we don't have pcap_statustostr(), don't check for pcap_create(),
687 # so we pretend we don't have it.
689 if(HAVE_PCAP_STATUSTOSTR)
690 check_function_exists(pcap_create HAVE_PCAP_CREATE)
691 endif(HAVE_PCAP_STATUSTOSTR)
694 # OK, do we have pcap_set_tstamp_type? If so, assume we have
695 # pcap_list_tstamp_types and pcap_free_tstamp_types as well.
697 check_function_exists(pcap_set_tstamp_type HAVE_PCAP_SET_TSTAMP_TYPE)
700 # And do we have pcap_set_tstamp_precision? If so, we assume
701 # we also have pcap_open_offline_with_tstamp_precision.
703 check_function_exists(pcap_set_tstamp_precision HAVE_PCAP_SET_TSTAMP_PRECISION)
704 endif(HAVE_PCAP_CREATE)
707 # Check for a miscellaneous collection of functions which we use
710 check_function_exists(pcap_findalldevs HAVE_PCAP_FINDALLDEVS)
711 if(HAVE_PCAP_FINDALLDEVS)
713 # Check for libpcap having pcap_findalldevs() but the pcap.h header
714 # not having pcap_if_t; some versions of Mac OS X shipped with pcap.h
715 # from 0.6 and libpcap 0.8, so that libpcap had pcap_findalldevs but
716 # pcap.h didn't have pcap_if_t.
718 cmake_push_check_state()
719 set(CMAKE_REQUIRED_INCLUDES ${PCAP_INCLUDE_DIRS})
720 set(CMAKE_EXTRA_INCLUDE_FILES pcap.h)
721 check_type_size(pcap_if_t PCAP_IF_T)
722 cmake_pop_check_state()
723 endif(HAVE_PCAP_FINDALLDEVS)
724 check_function_exists(pcap_dump_flush HAVE_PCAP_DUMP_FLUSH)
725 check_function_exists(pcap_lib_version HAVE_PCAP_LIB_VERSION)
726 if(NOT HAVE_PCAP_LIB_VERSION)
727 # Check for the pcap_version string variable and set HAVE_PCAP_VERSION
728 endif(NOT HAVE_PCAP_LIB_VERSION)
729 check_function_exists(pcap_setdirection HAVE_PCAP_SETDIRECTION)
730 check_function_exists(pcap_set_immediate_mode HAVE_PCAP_SET_IMMEDIATE_MODE)
731 check_function_exists(pcap_dump_ftell64 HAVE_PCAP_DUMP_FTELL64)
732 check_function_exists(pcap_open HAVE_PCAP_OPEN)
733 check_function_exists(pcap_findalldevs_ex HAVE_PCAP_FINDALLDEVS_EX)
736 # On Windows, check for pcap_wsockinit(); if we don't have it, check for
740 check_function_exists(pcap_wsockinit HAVE_PCAP_WSOCKINIT)
741 if(NOT HAVE_PCAP_WSOCKINIT)
742 check_function_exists(wsockinit HAVE_WSOCKINIT)
743 endif(NOT HAVE_PCAP_WSOCKINIT)
747 # Check for special debugging functions
749 check_function_exists(pcap_set_parser_debug HAVE_PCAP_SET_PARSER_DEBUG)
750 if(NOT HAVE_PCAP_SET_PARSER_DEBUG)
751 # Check whether libpcap defines pcap_debug or yydebug
752 check_variable_exists(pcap_debug HAVE_PCAP_DEBUG)
753 if(NOT HAVE_PCAP_DEBUG)
754 check_variable_exists(yydebug HAVE_YYDEBUG)
755 endif(NOT HAVE_PCAP_DEBUG)
756 endif(NOT HAVE_PCAP_SET_PARSER_DEBUG)
758 check_function_exists(pcap_set_optimizer_debug HAVE_PCAP_SET_OPTIMIZER_DEBUG)
759 check_function_exists(bpf_dump HAVE_BPF_DUMP)
761 cmake_pop_check_state()
766 include_directories(SYSTEM ${PCAP_INCLUDE_DIRS})
767 set(TCPDUMP_LINK_LIBRARIES ${PCAP_LIBRARIES} ${TCPDUMP_LINK_LIBRARIES})
770 # Optional libraries.
779 include_directories(SYSTEM ${SMI_INCLUDE_DIRS})
780 set(TCPDUMP_LINK_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} ${SMI_LIBRARIES})
786 # OpenSSL/libressl libcrypto.
792 # Check for some headers and functions.
794 check_include_file(openssl/evp.h HAVE_OPENSSL_EVP_H)
797 # 1) do we have EVP_CIPHER_CTX_new?
798 # If so, we use it to allocate an EVP_CIPHER_CTX, as
799 # EVP_CIPHER_CTX may be opaque; otherwise, we allocate
802 cmake_push_check_state()
803 set(CMAKE_REQUIRED_LIBRARIES "${CRYPTO_LIBRARIES}")
805 check_function_exists(EVP_CIPHER_CTX_new HAVE_EVP_CIPHER_CTX_NEW)
808 # 2) do we have EVP_DecryptInit_ex()?
809 # If so, we use it, because we need to be able to make two
810 # "initialize the cipher" calls, one with the cipher and key,
811 # and one with the IV, and, as of OpenSSL 1.1, You Can't Do That
812 # with EVP_DecryptInit(), because a call to EVP_DecryptInit() will
813 # unconditionally clear the context, and if you don't supply a
814 # cipher, it'll clear the cipher, rendering the context unusable
815 # and causing a crash.
817 check_function_exists(EVP_DecryptInit_ex HAVE_EVP_DECRYPTINIT_EX)
819 cmake_pop_check_state()
824 include_directories(SYSTEM ${CRYPTO_INCLUDE_DIRS})
825 set(TCPDUMP_LINK_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} ${CRYPTO_LIBRARIES})
826 set(HAVE_LIBCRYPTO ON)
831 # Capsicum sandboxing.
832 # Some of this is in the system library, some of it is in other libraries.
835 check_include_files("sys/capsicum.h" HAVE_SYS_CAPSICUM_H)
836 if(HAVE_SYS_CAPSICUM_H)
837 check_function_exists(cap_enter HAVE_CAP_ENTER)
838 check_function_exists(cap_rights_limit HAVE_CAP_RIGHTS_LIMIT)
839 check_function_exists(cap_ioctls_limit HAVE_CAP_IOCTLS_LIMIT)
840 check_function_exists(openat HAVE_OPENAT)
841 if(HAVE_CAP_ENTER AND HAVE_CAP_RIGHTS_LIMIT AND
842 HAVE_CAP_IOCTLS_LIMIT AND HAVE_OPENAT)
844 # OK, we have the functions we need to support Capsicum.
846 set(HAVE_CAPSICUM TRUE)
849 # OK, can we use Casper?
851 check_library_exists(casper cap_init "" HAVE_CAP_INIT)
853 cmake_push_check_state()
854 set(CMAKE_REQUIRED_LIBRARIES casper)
855 check_library_exists(cap_dns cap_gethostbyaddr "" HAVE_CAP_GETHOSTBYADDR)
856 cmake_pop_check_state()
857 if(HAVE_CAP_GETHOSTBYADDR)
858 set(HAVE_CASPER TRUE)
859 set(TCPDUMP_LINK_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} casper cap_dns)
860 endif(HAVE_CAP_GETHOSTBYADDR)
862 endif(HAVE_CAP_ENTER AND HAVE_CAP_RIGHTS_LIMIT AND
863 HAVE_CAP_IOCTLS_LIMIT AND HAVE_OPENAT)
864 endif(HAVE_SYS_CAPSICUM_H)
871 check_include_file(cap-ng.h HAVE_CAP_NG_H)
872 check_library_exists(cap-ng capng_change_id "" HAVE_LIBCAP_NG)
874 set(TCPDUMP_LINK_LIBRARIES ${TCPDUMP_LINK_LIBRARIES} cap-ng)
875 endif(HAVE_LIBCAP_NG)
878 ###################################################################
880 ###################################################################
883 # Check and add warning options if we have a .devel file.
885 if(EXISTS ${CMAKE_SOURCE_DIR}/.devel OR EXISTS ${CMAKE_BINARY_DIR}/.devel)
889 if(MSVC AND NOT ${CMAKE_C_COMPILER} MATCHES "clang*")
891 # MSVC, with Microsoft's front end and code generator.
892 # "MSVC" is also set for Microsoft's compiler with a Clang
893 # front end and their code generator ("Clang/C2"), so we
894 # check for clang.exe and treat that differently.
896 check_and_add_compiler_option(-Wall)
898 # Disable some pointless warnings that /Wall turns on.
900 # Unfortunately, MSVC does not appear to have an equivalent
901 # to "__attribute__((unused))" to mark a particular function
902 # parameter as being known to be unused, so that the compiler
903 # won't warn about it (for example, the function might have
904 # that parameter because a pointer to it is being used, and
905 # the signature of that function includes that parameter).
906 # C++ lets you give a parameter a type but no name, but C
909 check_and_add_compiler_option(-wd4100)
911 # In theory, we care whether somebody uses f() rather than
912 # f(void) to declare a function with no arguments, but, in
913 # practice, there are places in the Windows header files
914 # that appear to do that, so we squelch that warning.
916 check_and_add_compiler_option(-wd4255)
918 # Windows FD_SET() generates this, so we suppress it.
920 check_and_add_compiler_option(-wd4548)
922 # Perhaps testing something #defined to be 0 with #ifdef is an
923 # error, and it should be tested with #if, but perhaps it's
924 # not, and Microsoft does that in its headers, so we squelch
927 check_and_add_compiler_option(-wd4574)
929 # The Windows headers also test not-defined values in #if, so
930 # we don't want warnings about that, either.
932 check_and_add_compiler_option(-wd4668)
934 # We do *not* care whether some function is, or isn't, going to be
937 check_and_add_compiler_option(-wd4710)
938 check_and_add_compiler_option(-wd4711)
940 # We do *not* care whether we're adding padding bytes after
943 check_and_add_compiler_option(-wd4820)
945 # We do *not* care about every single place the compiler would
946 # have inserted Spectre mitigation if only we had told it to
947 # do so with /Qspectre. I guess the theory is that it's seeing
948 # bounds checks that would prevent out-of-bounds loads and that
949 # those out-of-bounds loads could be done speculatively and that
950 # the Spectre attack could detect the value of the out-of-bounds
951 # data *if* it's within our address space, but unless I'm
952 # missing something I don't see that as being any form of
955 # XXX - add /Qspectre if that is really worth doing.
957 check_and_add_compiler_option(-wd5045)
959 # We do *not* care whether a structure had padding added at
960 # the end because of __declspec(align) - *we* don't use
961 # __declspec(align), because the only structures whose layout
962 # we precisely specify are those that get overlayed on packet
963 # data, and in those every element is an array of octets so
964 # that we have full control over the size and aligmnet, and,
965 # apparently, jmp_buf has such a declaration on x86, meaning
966 # that everything that includes netdissect.h, i.e. almost every
967 # file in tcpdump, gets a warning.
969 check_and_add_compiler_option(-wd4324)
972 # Other compilers, including MSVC with a Clang front end and
973 # Microsoft's code generator. We currently treat them as if
974 # they might support GCC-style -W options.
976 check_and_add_compiler_option(-W)
977 check_and_add_compiler_option(-Wall)
978 check_and_add_compiler_option(-Wassign-enum)
979 check_and_add_compiler_option(-Wcast-qual)
980 check_and_add_compiler_option(-Wmissing-prototypes)
981 check_and_add_compiler_option(-Wmissing-variable-declarations)
982 check_and_add_compiler_option(-Wold-style-definition)
983 check_and_add_compiler_option(-Wpedantic)
984 check_and_add_compiler_option(-Wpointer-arith)
985 check_and_add_compiler_option(-Wpointer-sign)
986 check_and_add_compiler_option(-Wshadow)
987 check_and_add_compiler_option(-Wsign-compare)
988 check_and_add_compiler_option(-Wstrict-prototypes)
989 check_and_add_compiler_option(-Wunreachable-code-return)
990 check_and_add_compiler_option(-Wused-but-marked-unused)
991 check_and_add_compiler_option(-Wwrite-strings)
996 # Extra compiler options for the build matrix scripts to request -Werror or
997 # its equivalent if required. The CMake variable name cannot be CFLAGS
998 # because that is already used for a different purpose in CMake. Example
999 # usage: cmake -DEXTRA_CFLAGS='-Wall -Wextra -Werror' ...
1001 if(NOT "${EXTRA_CFLAGS}" STREQUAL "")
1002 foreach(_extra_cflag ${EXTRA_CFLAGS})
1003 check_and_add_compiler_option("${_extra_cflag}")
1004 endforeach(_extra_cflag)
1005 message(STATUS "Added extra compile options (${EXTRA_CFLAGS})")
1008 ######################################
1010 ######################################
1014 # We allow the SMB dissector to be omitted.
1016 set(LOCALSRC ${LOCALSRC}
1021 set(NETDISSECT_SOURCE_LIST_C
1135 print-openflow-1.0.c
1136 print-openflow-1.3.c
1206 # Replace missing functions
1208 foreach(FUNC strlcat strlcpy strdup strsep getservent getopt_long)
1209 string(TOUPPER ${FUNC} FUNC_UPPERCASE)
1210 set(HAVE_FUNC_UPPERCASE HAVE_${FUNC_UPPERCASE})
1211 if(NOT ${HAVE_FUNC_UPPERCASE})
1212 set(NETDISSECT_SOURCE_LIST_C ${NETDISSECT_SOURCE_LIST_C} missing/${FUNC}.c)
1216 add_library(netdissect STATIC
1217 ${NETDISSECT_SOURCE_LIST_C}
1219 if(NOT C_ADDITIONAL_FLAGS STREQUAL "")
1220 set_target_properties(netdissect PROPERTIES COMPILE_FLAGS ${C_ADDITIONAL_FLAGS})
1223 set(TCPDUMP_SOURCE_LIST_C fptype.c tcpdump.c)
1225 if(NOT HAVE_BPF_DUMP)
1226 set(TCPDUMP_SOURCE_LIST_C ${TCPDUMP_SOURCE_LIST_C} bpf_dump.c)
1227 endif(NOT HAVE_BPF_DUMP)
1228 if(NOT HAVE_PCAP_DUMP_FTELL)
1229 set(TCPDUMP_SOURCE_LIST_C ${TCPDUMP_SOURCE_LIST_C} missing/pcap_dump_ftell.c)
1230 endif(NOT HAVE_PCAP_DUMP_FTELL)
1232 if(NOT HAVE_PCAP_LIST_DATALINKS)
1233 set(TCPDUMP_SOURCE_LIST_C ${TCPDUMP_SOURCE_LIST_C} missing/datalinks.c)
1234 endif(NOT HAVE_PCAP_LIST_DATALINKS)
1236 if((NOT HAVE_PCAP_DATALINK_NAME_TO_VAL) OR (NOT HAVE_PCAP_DATALINK_VAL_TO_DESCRIPTION))
1237 set(TCPDUMP_SOURCE_LIST_C ${TCPDUMP_SOURCE_LIST_C} missing/dlnames.c)
1238 endif((NOT HAVE_PCAP_DATALINK_NAME_TO_VAL) OR (NOT HAVE_PCAP_DATALINK_VAL_TO_DESCRIPTION))
1240 set(PROJECT_SOURCE_LIST_C ${NETDISSECT_SOURCE_LIST_C} ${TCPDUMP_SOURCE_LIST_C})
1242 file(GLOB PROJECT_SOURCE_LIST_H
1247 # Assume, by default, no support for shared libraries and V7/BSD
1248 # convention for man pages (devices in section 4, file formats in
1249 # section 5, miscellaneous info in section 7, administrative commands
1250 # and daemons in section 8). Individual cases can override this.
1251 # Individual cases can override this.
1253 set(MAN_FILE_FORMATS 5)
1254 set(MAN_MISC_INFO 7)
1255 if(CMAKE_SYSTEM_NAME STREQUAL "AIX")
1256 # Workaround to enable certain features
1258 elseif(CMAKE_SYSTEM_NAME STREQUAL "HP-UX")
1260 # Use System V conventions for man pages.
1262 set(MAN_FILE_FORMATS 4)
1263 set(MAN_MISC_INFO 5)
1264 elseif(CMAKE_SYSTEM_NAME STREQUAL "IRIX" OR CMAKE_SYSTEM_NAME STREQUAL "IRIX64")
1266 # Use IRIX conventions for man pages; they're the same as the
1267 # System V conventions, except that they use section 8 for
1268 # administrative commands and daemons.
1270 set(MAN_FILE_FORMATS 4)
1271 set(MAN_MISC_INFO 5)
1272 elseif(CMAKE_SYSTEM_NAME STREQUAL "OSF1")
1274 # DEC OSF/1, a/k/a Digital UNIX, a/k/a Tru64 UNIX.
1275 # Use Tru64 UNIX conventions for man pages; they're the same as the
1276 # System V conventions except that they use section 8 for
1277 # administrative commands and daemons.
1279 set(MAN_FILE_FORMATS 4)
1280 set(MAN_MISC_INFO 5)
1281 elseif(CMAKE_SYSTEM_NAME STREQUAL "SunOS" AND CMAKE_SYSTEM_VERSION MATCHES "5[.][0-9.]*")
1285 if(CMAKE_SYSTEM_VERSION STREQUAL "5.12")
1288 # Use System V conventions for man pages.
1290 set(MAN_FILE_FORMATS 4)
1291 set(MAN_MISC_INFO 5)
1295 source_group("Source Files" FILES ${PROJECT_SOURCE_LIST_C})
1296 source_group("Header Files" FILES ${PROJECT_SOURCE_LIST_H})
1298 ######################################
1300 ######################################
1302 add_executable(tcpdump ${TCPDUMP_SOURCE_LIST_C})
1303 if(NOT C_ADDITIONAL_FLAGS STREQUAL "")
1304 set_target_properties(tcpdump PROPERTIES COMPILE_FLAGS ${C_ADDITIONAL_FLAGS})
1306 target_link_libraries(tcpdump netdissect ${TCPDUMP_LINK_LIBRARIES})
1308 ######################################
1309 # Write out the config.h file
1310 ######################################
1312 configure_file(${CMAKE_CURRENT_SOURCE_DIR}/cmakeconfig.h.in ${CMAKE_CURRENT_BINARY_DIR}/config.h)
1314 ######################################
1315 # Install tcpdump and man pages
1316 ######################################
1319 # "Define GNU standard installation directories", which actually
1320 # are also defined, to some degree, by autotools, and at least
1321 # some of which are general UN*X conventions.
1323 include(GNUInstallDirs)
1325 set(MAN1_EXPAND tcpdump.1.in)
1328 # XXX TODO where to install on Windows?
1330 install(TARGETS tcpdump DESTINATION bin)
1333 # On UN*X, and on Windows when not using MSVC, process man pages and
1334 # arrange that they be installed.
1339 # For each section of the manual for which we have man pages
1340 # that require macro expansion, do the expansion.
1343 foreach(TEMPLATE_MANPAGE ${MAN1_EXPAND})
1344 string(REPLACE ".in" "" MANPAGE ${TEMPLATE_MANPAGE})
1345 configure_file(${CMAKE_SOURCE_DIR}/${TEMPLATE_MANPAGE} ${CMAKE_CURRENT_BINARY_DIR}/${MANPAGE} @ONLY)
1346 set(MAN1 ${MAN1} ${CMAKE_CURRENT_BINARY_DIR}/${MANPAGE})
1347 endforeach(TEMPLATE_MANPAGE)
1348 install(FILES ${MAN1} DESTINATION ${CMAKE_INSTALL_MANDIR}/man1)
1353 "${CMAKE_CURRENT_SOURCE_DIR}/cmake_uninstall.cmake.in"
1354 "${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake"
1357 add_custom_target(uninstall
1358 COMMAND ${CMAKE_COMMAND} -P ${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake)
1362 # We try to find the Perl interpreter and, if we do, we have the check
1363 # rule run tests/TESTrun with it, because just trying to run the TESTrun
1364 # script as a command won't work on Windows.
1366 find_program(PERL perl)
1368 message(STATUS "Found perl at ${PERL}")
1369 add_custom_target(check
1370 COMMAND ${PERL} ${CMAKE_SOURCE_DIR}/tests/TESTrun)
1372 message(STATUS "Didn't find perl")