diff options
author | Sander Vrijders <sander.vrijders@ugent.be> | 2017-04-07 10:18:46 +0000 |
---|---|---|
committer | dimitri staessens <dimitri.staessens@ugent.be> | 2017-04-07 10:18:46 +0000 |
commit | 97dd492cb7c6d88fbd9f95fe2469a637e445b762 (patch) | |
tree | 580153354f3018d08cd25d46b624bc3b4ff42300 | |
parent | a520f53970e59b4663b2baa70dd458175154622b (diff) | |
parent | 20d0532a4b1fd7568adf63654d023d782373873e (diff) | |
download | ouroboros-97dd492cb7c6d88fbd9f95fe2469a637e445b762.tar.gz ouroboros-97dd492cb7c6d88fbd9f95fe2469a637e445b762.zip |
Merged in sandervrijders/ouroboros/be-netmap-cmake (pull request #470)
ipcpd: shim-eth-llc: Add check for netmap headers
-rw-r--r-- | cmake/CompilerUtils.cmake | 3 | ||||
-rw-r--r-- | include/ouroboros/wrap/CMakeLists.txt | 2 | ||||
-rw-r--r-- | src/ipcpd/shim-eth-llc/CMakeLists.txt | 14 |
3 files changed, 15 insertions, 4 deletions
diff --git a/cmake/CompilerUtils.cmake b/cmake/CompilerUtils.cmake index fb81b7e7..b9fd391c 100644 --- a/cmake/CompilerUtils.cmake +++ b/cmake/CompilerUtils.cmake @@ -6,10 +6,7 @@ function(test_and_set_c_compiler_flag_global _flag) check_c_compiler_flag(${_flag} COMPILER_SUPPORTS_FLAG_${_sflag}) if(COMPILER_SUPPORTS_FLAG_${_sflag}) - message(STATUS "Compiler supports flag ${_flag}, added globally") set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${_flag}" PARENT_SCOPE) - else(${_retval}) - message(STATUS "Compiler does not support flag ${_flag}, discarded") endif() endfunction(test_and_set_c_compiler_flag_global) diff --git a/include/ouroboros/wrap/CMakeLists.txt b/include/ouroboros/wrap/CMakeLists.txt index 7753ca02..fd9368e8 100644 --- a/include/ouroboros/wrap/CMakeLists.txt +++ b/include/ouroboros/wrap/CMakeLists.txt @@ -17,7 +17,7 @@ else () include_directories(${PYTHON_INCLUDE_PATH}) # Python assumes C99 since Python 3.6 - set(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -std=c99") + test_and_set_c_compiler_flag_global(-std=c99) swig_add_module(ouroboros python ouroboros.i) swig_link_libraries(ouroboros ${PYTHON_LIBRARIES} ouroboros) diff --git a/src/ipcpd/shim-eth-llc/CMakeLists.txt b/src/ipcpd/shim-eth-llc/CMakeLists.txt index bd3049a2..b3abc052 100644 --- a/src/ipcpd/shim-eth-llc/CMakeLists.txt +++ b/src/ipcpd/shim-eth-llc/CMakeLists.txt @@ -12,6 +12,11 @@ include_directories(${CURRENT_BINARY_PARENT_DIR}) include_directories(${CMAKE_SOURCE_DIR}/include) include_directories(${CMAKE_BINARY_DIR}/include) +find_path(NETMAP_C_INCLUDE_DIR + net/netmap_user.h + HINTS /usr/include /usr/local/include + ) + protobuf_generate_c(SHIM_ETH_LLC_PROTO_SRCS SHIM_ETH_LLC_PROTO_HDRS shim_eth_llc_messages.proto) @@ -27,6 +32,15 @@ add_executable(ipcpd-shim-eth-llc ${SHIM_ETH_LLC_SOURCES} ${IPCP_SOURCES} target_link_libraries(ipcpd-shim-eth-llc LINK_PUBLIC ouroboros ${PROTOBUF_C_LIBRARY}) +if (${NETMAP_C_INCLUDE_DIR} STREQUAL "NETMAP_C_INCLUDE_DIR-NOTFOUND") + message("-- Could not find netmap. Install for better performance.") +else () + message("-- Found netmap headers in ${NETMAP_C_INCLUDE_DIR}") + include_directories(${NETMAP_C_INCLUDE_DIR}) + add_compile_flags(ipcpd-shim-eth-llc -DHAVE_NETMAP) + test_and_set_c_compiler_flag_global(-std=c99) +endif () + include(AddCompileFlags) if (CMAKE_BUILD_TYPE MATCHES Debug) add_compile_flags(ipcpd-shim-eth-llc -DCONFIG_OUROBOROS_DEBUG) |