Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

CMake improvements and compiler warning fixes #810

Open
wants to merge 6 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
65 changes: 46 additions & 19 deletions host/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -14,17 +14,20 @@ cmake_minimum_required(VERSION 3.12)
if(POLICY CMP0048)
cmake_policy(SET CMP0048 NEW) # Suppress Version warnings
endif(POLICY CMP0048)

project(UHD CXX C)
enable_testing()

#make sure our local CMake Modules path comes first
# Make sure our local CMake Modules path comes first
list(INSERT CMAKE_MODULE_PATH 0 ${UHD_SOURCE_DIR}/cmake/Modules)


########################################################################
# UHD Dependency Minimum Versions are stored in a separate file
########################################################################
include(UHDMinDepVersions)


########################################################################
# Check Compiler Version
########################################################################
Expand All @@ -51,21 +54,22 @@ elseif(${CMAKE_CXX_COMPILER_ID} MATCHES "Clang")
RESULT_VARIABLE res ERROR_VARIABLE err
ERROR_STRIP_TRAILING_WHITESPACE)
if(${res} STREQUAL "0")
# output is in error stream
# Version output is in error stream
string(REGEX MATCH "^Apple.*" IS_APPLE ${err})

# Retrieve the compiler's version
if("${IS_APPLE}" STREQUAL "")
set(MIN_VERSION ${UHD_CLANG_MIN_VERSION})
set(APPLE_STR "")
# retrieve the compiler's version from it
string(REGEX MATCH "clang version [0-9.]+" CLANG_OTHER_VERSION ${err})
string(REGEX MATCH "[0-9.]+" CLANG_VERSION ${CLANG_OTHER_VERSION})
else()
set(MIN_VERSION ${UHD_APPLECLANG_MIN_VERSION})
set(APPLE_STR "Apple ")
# retrieve the compiler's version from it
string(REGEX MATCH "(clang-[0-9.]+)" CLANG_APPLE_VERSION ${err})
string(REGEX MATCH "[0-9.]+" CLANG_VERSION ${CLANG_APPLE_VERSION})
endif()

if(${CLANG_VERSION} VERSION_LESS "${MIN_VERSION}")
message(WARNING
"\nThe compiler selected to build UHD "
Expand Down Expand Up @@ -98,21 +102,22 @@ if(CMAKE_SYSTEM_NAME STREQUAL "FreeBSD" AND ${CMAKE_CXX_COMPILER_ID} STREQUAL "C
set(CMAKE_CXX_FLAGS "-stdlib=libc++ ${CMAKE_CXX_FLAGS}")
endif()


########################################################################
# Packaging Variables
########################################################################

option(UNDERSCORE_UHD_VERSION "Replace dashes in uhd version with underscores" OFF)
set(LIBUHD_PKG ${LIBUHD_PKG} CACHE BOOL "Build Debian libuhd003 package")
set(LIBUHDDEV_PKG ${LIBUHDDEV_PKG} CACHE BOOL "Build Debian libuhd-dev package")
set(UHDHOST_PKG ${UHDPOST_PKG} CACHE BOOL "Build Debian uhd-host package")
include(UHDComponent) #enable components
include(UHDPackage) #setup cpack


########################################################################
# Install Dirs
########################################################################
#when the library suffix should be 64 (applies to redhat linux family)
# Whether the library suffix should be 64 (applies to redhat linux family)
if(NOT DEFINED LIB_SUFFIX AND REDHAT AND CMAKE_SYSTEM_PROCESSOR MATCHES "64$")
set(LIB_SUFFIX 64)
endif()
Expand All @@ -133,6 +138,7 @@ if(NOT DEFINED PKG_DOC_DIR)
endif()
set(PKG_MAN_DIR share/man/man1)


########################################################################
# UHD config files
########################################################################
Expand All @@ -157,6 +163,7 @@ else()
message(WARNING "Not setting UHD_SYS_CONF_FILE!")
endif()


########################################################################
# UHD Image Directories
########################################################################
Expand All @@ -175,12 +182,14 @@ if(DEFINED UHD_IMAGES_DIR_WINREG_KEY)
add_definitions(-DUHD_IMAGES_DIR_WINREG_KEY=${UHD_IMAGES_DIR_WINREG_KEY})
endif(DEFINED UHD_IMAGES_DIR_WINREG_KEY)


########################################################################
# Local Include Dir
########################################################################
include_directories(${UHD_BINARY_DIR}/include)
include_directories(${UHD_SOURCE_DIR}/include)


########################################################################
# Static Lib Configuration
########################################################################
Expand All @@ -189,8 +198,9 @@ if(ENABLE_STATIC_LIBS)
message(STATUS "Building Static Libraries: ${ENABLE_STATIC_LIBS}")
endif(ENABLE_STATIC_LIBS)


########################################################################
# On Apple only, set install name and use rpath correctly, if not already set
# On Apple only, set install name and rpath correctly if not already set
########################################################################
if(APPLE)
if(NOT CMAKE_INSTALL_NAME_DIR)
Expand All @@ -206,9 +216,12 @@ if(APPLE)
if(NOT CMAKE_BUILD_WITH_INSTALL_RPATH)
set(CMAKE_BUILD_WITH_INSTALL_RPATH ON CACHE
BOOL "Do Build Using Library Install RPath" FORCE)
set(CMAKE_BUILD_WITH_INSTALL_NAME_DIR ON CACHE
BOOL "Set install name to install name dir during build" FORCE)
endif(NOT CMAKE_BUILD_WITH_INSTALL_RPATH)
endif(APPLE)


########################################################################
# Optional Compiler Flags
########################################################################
Expand All @@ -220,14 +233,14 @@ macro(UHD_ADD_OPTIONAL_CXX_COMPILER_FLAG flag have)
endif(${have})
endmacro(UHD_ADD_OPTIONAL_CXX_COMPILER_FLAG)

#select the release build type by default to get optimization flags
# Select the release build type by default to get optimization flags
if(NOT CMAKE_BUILD_TYPE)
set(CMAKE_BUILD_TYPE "Release")
message(STATUS "Build type not specified: defaulting to release.")
endif(NOT CMAKE_BUILD_TYPE)
set(CMAKE_BUILD_TYPE "${CMAKE_BUILD_TYPE}" CACHE STRING "")

#force UHD_RELEASE_MODE to be a string for cmake-gui
# Force UHD_RELEASE_MODE to be a string for cmake-gui
set(UHD_RELEASE_MODE "${UHD_RELEASE_MODE}" CACHE STRING "UHD Release Mode")

if(${CMAKE_CXX_COMPILER_ID} STREQUAL "GNU" OR
Expand All @@ -244,21 +257,23 @@ if(${CMAKE_CXX_COMPILER_ID} STREQUAL "GNU" OR
#add_definitions(-pedantic)
#add_definitions(-ansi)
if(NOT WIN32)
#only export symbols that are declared to be part of the uhd api (non dll platforms)
# Only export symbols that are declared to be part of the uhd api (non dll platforms)
UHD_ADD_OPTIONAL_CXX_COMPILER_FLAG(-fvisibility=hidden HAVE_VISIBILITY_HIDDEN)
UHD_ADD_OPTIONAL_CXX_COMPILER_FLAG(-fvisibility-inlines-hidden HAVE_VISIBILITY_INLINES_HIDDEN)
endif(NOT WIN32)
if(${CMAKE_BUILD_TYPE} STREQUAL "Coverage")
include(CodeCoverage)
setup_target_for_coverage(coverage "ctest || return 0" coverage) # never fail ctest, always generate coverage report
# Never fail ctest, always generate coverage report
setup_target_for_coverage(coverage "ctest || return 0" coverage)
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -pedantic -pthread -g -O0 -fprofile-arcs -ftest-coverage" CACHE STRING "Flags used by the C++ compiler during Coverage builds." FORCE)
set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Wall -pedantic -pthread -g -O0 -fprofile-arcs -ftest-coverage" CACHE STRING "Flags used by the C compiler during Coverage builds." FORCE)
endif()
endif()

if(MSVC)
include_directories(${UHD_SOURCE_DIR}/cmake/msvc)
add_definitions( #stop all kinds of compatibility warnings
# Stop all kinds of compatibility warnings
add_definitions(
-DWIN32_LEAN_AND_MEAN
-DVC_EXTRALEAN
-D_SCL_SECURE_NO_WARNINGS
Expand All @@ -269,19 +284,20 @@ if(MSVC)
-D_CRT_NONSTDC_NO_DEPRECATE
-D_WINSOCK_DEPRECATED_NO_WARNINGS
)
# multi-threaded build and increases the number of addressable sections in an .obj file.
# Enable multi-threaded build and increase the number of addressable sections in an .obj file.
add_compile_options(/MP /bigobj)
endif(MSVC)

if(CYGWIN)
add_definitions(-D__USE_W32_SOCKETS) #boost asio says we need this
add_definitions(-D__USE_W32_SOCKETS) # boost asio says we need this
endif(CYGWIN)

if(WIN32)
add_definitions(-D_WIN32_WINNT=0x0501) #minimum version required is windows xp
add_definitions(-DNOMINMAX) #disables stupidity and enables std::min and std::max
add_definitions(-D_WIN32_WINNT=0x0501) # minimum version required is windows xp
add_definitions(-DNOMINMAX) # disables stupidity and enables std::min and std::max
endif(WIN32)


########################################################################
# Setup Boost
########################################################################
Expand All @@ -302,15 +318,18 @@ set(UHD_BOOST_REQUIRED_COMPONENTS

include(UHDBoost)

include_directories(${Boost_INCLUDE_DIRS})
# Include boost headers as system headers to avoid compiler warnings from them.
include_directories(SYSTEM ${Boost_INCLUDE_DIRS})
link_directories(${Boost_LIBRARY_DIRS})


########################################################################
# Additional settings for build environment
########################################################################
include(UHDGlobalDefs)
include(UHDLog)


########################################################################
# Check Python Modules
########################################################################
Expand Down Expand Up @@ -356,6 +375,7 @@ UHD_PYTHON_CHECK_MODULE_VERSION(
HAVE_PYTHON_MODULE_YAML
)


########################################################################
# Option to use QEMU for running unittests
#
Expand Down Expand Up @@ -409,6 +429,7 @@ if(ENABLE_QEMU_UNITTESTS)
message(STATUS " QEMU sysroot: ${QEMU_SYSROOT}")
endif(ENABLE_QEMU_UNITTESTS)


########################################################################
# Create Uninstall Target
########################################################################
Expand All @@ -421,6 +442,7 @@ add_custom_target(uninstall
${CMAKE_COMMAND} -P ${CMAKE_CURRENT_BINARY_DIR}/cmake_uninstall.cmake
)


########################################################################
# Install Package Docs
########################################################################
Expand All @@ -431,6 +453,7 @@ UHD_INSTALL(FILES
COMPONENT readme
)


########################################################################
# Register top level components
########################################################################
Expand Down Expand Up @@ -462,6 +485,7 @@ LIBUHD_REGISTER_COMPONENT(
"HAVE_PYTHON_MODULE_NUMPY;HAVE_PYTHON_MODULE_MAKO;HAVE_PYTHON_MODULE_YAML"
OFF OFF)


########################################################################
# Add the subdirectories
########################################################################
Expand Down Expand Up @@ -489,6 +513,7 @@ if(ENABLE_PYTHON_API OR ENABLE_PYMOD_UTILS)
add_subdirectory(python)
endif()


########################################################################
# Create Pkg Config File
########################################################################
Expand All @@ -500,12 +525,12 @@ foreach(lib ${Boost_LIBRARY_DIRS})
list(APPEND UHD_PC_LIBS "-L${lib}")
endforeach(lib)

#use space-separation format for the pc file
# Use space-separation format for the pc file
string(REPLACE ";" " " UHD_PC_REQUIRES "${UHD_PC_REQUIRES}")
string(REPLACE ";" " " UHD_PC_CFLAGS "${UHD_PC_CFLAGS}")
string(REPLACE ";" " " UHD_PC_LIBS "${UHD_PC_LIBS}")

#unset these vars to avoid hard-coded paths to cross environment
# Unset these vars to avoid hard-coded paths to cross environment
if(CMAKE_CROSSCOMPILING)
set(UHD_PC_CFLAGS)
set(UHD_PC_LIBS)
Expand Down Expand Up @@ -567,6 +592,7 @@ UHD_INSTALL(
COMPONENT "devel"
)


########################################################################
# Handle pre-built UHD Images for packaging
########################################################################
Expand All @@ -580,6 +606,7 @@ if(DEFINED UHD_IMAGES_SRC_DIR AND EXISTS "${UHD_IMAGES_SRC_DIR}")
UHD_INSTALL(FILES ${_image_files} DESTINATION ${PKG_DATA_DIR}/images COMPONENT images)
endif(DEFINED UHD_IMAGES_SRC_DIR AND EXISTS "${UHD_IMAGES_SRC_DIR}")


########################################################################
# Print Summary
########################################################################
Expand Down
9 changes: 8 additions & 1 deletion host/cmake/Modules/FindDPDK.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -19,5 +19,12 @@ include(FindPackageHandleStandardArgs)
find_package(PkgConfig)
PKG_CHECK_MODULES(DPDK libdpdk>=18.11)

find_package_handle_standard_args(DPDK DEFAULT_MSG DPDK_INCLUDE_DIRS DPDK_CFLAGS DPDK_LDFLAGS DPDK_LIBRARIES)
find_package_handle_standard_args(
DPDK
DEFAULT_MSG
DPDK_INCLUDE_DIRS
DPDK_CFLAGS DPDK_LDFLAGS
DPDK_LIBRARIES
HANDLE_VERSION_RANGE
)
mark_as_advanced(DPDK_INCLUDE_DIRS DPDK_CFLAGS DPDK_LDFLAGS DPDK_LIBRARIES)
11 changes: 2 additions & 9 deletions host/cmake/Modules/UHDConfig.cmake.in
Original file line number Diff line number Diff line change
Expand Up @@ -21,13 +21,11 @@
# Allows us to use all .cmake files in this directory
list(INSERT CMAKE_MODULE_PATH 0 "${CMAKE_CURRENT_LIST_DIR}")

# set that this file was found, for use in GNU Radio's FindUHD.cmake.
# Set that this file was found, for use in GNU Radio's FindUHD.cmake.
# Have to use the ENV, since this file might not allow CACHE changes.

set(ENV{UHD_CONFIG_USED} TRUE)

# set default values

# Set default values
set(UHD_FOUND TRUE)
set(UHD_RFNOC_FOUND @UHD_RFNOC_FOUND@)
set(UHD_INCLUDE_HINTS)
Expand Down Expand Up @@ -69,7 +67,6 @@ endif()
# Verify that <uhd/config.hpp> and libuhd are available, and, if a
# version is provided, that UHD meets the version requirements -- no
# matter what pkg-config might think.

find_path(
UHD_INCLUDE_DIRS
NAMES uhd/config.hpp
Expand Down Expand Up @@ -104,13 +101,9 @@ if(UHD_USE_STATIC_LIBS)
endif(UHD_USE_STATIC_LIBS)

if(UHD_LIBRARIES AND UHD_INCLUDE_DIRS)

include(FindPackageHandleStandardArgs)
FIND_PACKAGE_HANDLE_STANDARD_ARGS(UHD DEFAULT_MSG UHD_LIBRARIES UHD_INCLUDE_DIRS)
mark_as_advanced(UHD_LIBRARIES UHD_INCLUDE_DIRS)

elseif(UHD_FIND_REQUIRED)

message(FATAL_ERROR "UHD is required, but was not found.")

endif()
3 changes: 3 additions & 0 deletions host/include/uhd/rfnoc/chdr_types.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -709,7 +709,10 @@ class UHD_API mgmt_op_t
: _op_code(op_code), _op_payload(op_payload), _ops_pending(ops_pending)
{
}

mgmt_op_t(const mgmt_op_t& rhs) = default;
mgmt_op_t& operator=(const mgmt_op_t& rhs) = default;


//! Get the ops pending for this transaction
// Note that ops_pending is not used by UHD, since it can infer this value
Expand Down
Loading
Loading