-
Notifications
You must be signed in to change notification settings - Fork 16
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Overhaul cmake interface to DPDK SDE (#305)
- Replace the dpdk-driver.cmake include file with FindDpdkDriver.cmake, a find-module that allows us to use `find_package(DpdkDriver)` to define namespaced cmake targets for the DPDK SDE. - Define an `add_dpdk_target_libraries()` function that provides an abstract interface to set the properties a target needs to compile and link with the DPDK SDE. - Update krnlmon submodule reference. Signed-off-by: Derek G Foster <[email protected]>
- Loading branch information
Showing
5 changed files
with
149 additions
and
86 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,146 @@ | ||
# FindDpdkDriver.cmake - import DPDK P4 Driver (SDE). | ||
# | ||
# Copyright 2023 Intel Corporation | ||
# SPDX-License-Identifier: Apache 2.0 | ||
# | ||
|
||
# This module requires that SDE_INSTALL_DIR be defined. | ||
# It needs additional work to make it a proper CMake find-module. | ||
|
||
#----------------------------------------------------------------------- | ||
# Use pkg-config to find DPDK module | ||
#----------------------------------------------------------------------- | ||
include(FindPkgConfig) | ||
pkg_check_modules(DPDK REQUIRED libdpdk) | ||
|
||
#----------------------------------------------------------------------- | ||
# Define SDE_INCLUDE_DIR | ||
#----------------------------------------------------------------------- | ||
find_path(SDE_INCLUDE_DIR | ||
NAMES "bf_switchd/bf_switchd.h" | ||
PATHS ${SDE_INSTALL_DIR}/include | ||
) | ||
if(NOT SDE_INCLUDE_DIR) | ||
message(FATAL_ERROR "bf_switchd.h not found") | ||
endif() | ||
mark_as_advanced(SDE_INCLUDE_DIR) | ||
|
||
#----------------------------------------------------------------------- | ||
# Find libraries | ||
#----------------------------------------------------------------------- | ||
find_library(LIBBF_SWITCHD bf_switchd_lib) | ||
if(NOT LIBBF_SWITCHD) | ||
message(FATAL_ERROR "sde::bf_switchd_lib library not found") | ||
endif() | ||
mark_as_advanced(LIBBF_SWITCHD) | ||
|
||
find_library(LIBDRIVER driver) | ||
if(NOT LIBDRIVER) | ||
message(FATAL_ERROR "sde::driver library not found") | ||
endif() | ||
mark_as_advanced(LIBDRIVER) | ||
|
||
find_library(LIBTDI tdi) | ||
if(NOT LIBTDI) | ||
message(FATAL_ERROR "sde::tdi library not found") | ||
endif() | ||
mark_as_advanced(LIBTDI) | ||
|
||
find_library(LIBTDI_JSON_PARSER tdi_json_parser) | ||
if(NOT LIBTDI_JSON_PARSER) | ||
message(FATAL_ERROR "sde::tdi_json_parser library not found") | ||
endif() | ||
mark_as_advanced(LIBTDI_JSON_PARSER) | ||
|
||
find_library(LIBTARGET_SYS target_sys) | ||
if(NOT LIBTARGET_SYS) | ||
message(FATAL_ERROR "sde::target_sys library not found") | ||
endif() | ||
mark_as_advanced(LIBTARGET_SYS) | ||
|
||
find_library(LIBTARGET_UTILS target_utils) | ||
if(NOT LIBTARGET_UTILS) | ||
message(FATAL_ERROR "sde::target_utils library not found") | ||
endif() | ||
mark_as_advanced(LIBTARGET_UTILS) | ||
|
||
#----------------------------------------------------------------------- | ||
# Get version number | ||
#----------------------------------------------------------------------- | ||
if(EXISTS ${SDE_INSTALL_DIR}/share/VERSION) | ||
file(READ ${SDE_INSTALL_DIR}/share/VERSION _sde_version) | ||
string(STRIP "${_sde_version}" _sde_version) | ||
if(NOT _sde_version STREQUAL "") | ||
set(SDE_VERSION "${_sde_version}" CACHE STRING "DPDK SDE version") | ||
mark_as_advanced(SDE_VERSION) | ||
endif() | ||
unset(_sde_version) | ||
endif() | ||
|
||
#----------------------------------------------------------------------- | ||
# Define library targets | ||
#----------------------------------------------------------------------- | ||
add_library(sde::bf_switchd UNKNOWN IMPORTED) | ||
set_target_properties(sde::bf_switchd PROPERTIES | ||
IMPORTED_LOCATION ${LIBBF_SWITCHD} | ||
INTERFACE_INCLUDE_DIRECTORIES ${SDE_INCLUDE_DIR} | ||
IMPORTED_LINK_INTERFACE_LANGUAGES C) | ||
|
||
add_library(sde::driver UNKNOWN IMPORTED) | ||
set_target_properties(sde::driver PROPERTIES | ||
IMPORTED_LOCATION ${LIBDRIVER} | ||
INTERFACE_INCLUDE_DIRECTORIES ${SDE_INCLUDE_DIR} | ||
IMPORTED_LINK_INTERFACE_LANGUAGES C) | ||
|
||
add_library(sde::tdi UNKNOWN IMPORTED) | ||
set_target_properties(sde::tdi PROPERTIES | ||
IMPORTED_LOCATION ${LIBTDI} | ||
INTERFACE_INCLUDE_DIRECTORIES ${SDE_INCLUDE_DIR} | ||
IMPORTED_LINK_INTERFACE_LANGUAGES CXX) | ||
|
||
add_library(sde::tdi_json_parser UNKNOWN IMPORTED) | ||
set_target_properties(sde::tdi_json_parser PROPERTIES | ||
IMPORTED_LOCATION ${LIBTDI_JSON_PARSER} | ||
INTERFACE_INCLUDE_DIRECTORIES ${SDE_INCLUDE_DIR} | ||
IMPORTED_LINK_INTERFACE_LANGUAGES CXX) | ||
|
||
add_library(sde::target_sys UNKNOWN IMPORTED) | ||
set_target_properties(sde::target_sys PROPERTIES | ||
IMPORTED_LOCATION ${LIBTARGET_SYS} | ||
INTERFACE_INCLUDE_DIRECTORIES ${SDE_INCLUDE_DIR} | ||
IMPORTED_LINK_INTERFACE_LANGUAGES C) | ||
|
||
add_library(sde::target_utils UNKNOWN IMPORTED) | ||
set_target_properties(sde::target_utils PROPERTIES | ||
IMPORTED_LOCATION ${LIBTARGET_UTILS} | ||
INTERFACE_INCLUDE_DIRECTORIES ${SDE_INCLUDE_DIR} | ||
IMPORTED_LINK_INTERFACE_LANGUAGES C) | ||
|
||
#----------------------------------------------------------------------- | ||
# Define SDE_LIBRARY_DIRS | ||
#----------------------------------------------------------------------- | ||
set(SDE_LIBRARY_DIRS | ||
${SDE_INSTALL_DIR}/lib | ||
${DPDK_LIBRARY_DIRS} | ||
) | ||
|
||
#----------------------------------------------------------------------- | ||
# Apply SDE properties to target | ||
#----------------------------------------------------------------------- | ||
function(add_dpdk_target_libraries TGT) | ||
target_link_libraries(${TGT} PUBLIC | ||
sde::bf_switchd | ||
sde::driver | ||
sde::target_sys | ||
sde::target_utils | ||
sde::tdi | ||
sde::tdi_json_parser | ||
) | ||
|
||
target_link_directories(${TGT} PUBLIC ${SDE_LIBRARY_DIRS}) | ||
|
||
target_link_options(${TGT} PUBLIC | ||
${DPDK_LD_FLAGS} | ||
${DPDK_LDFLAGS_OTHER} | ||
) | ||
endfunction() |
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Submodule krnlmon
updated
3 files
+3 −4 | switchapi/dpdk/CMakeLists.txt | |
+3 −4 | switchapi/es2k/CMakeLists.txt | |
+1 −1 | switchlink/testing.cmake |