Skip to content

Commit

Permalink
#2302: Add papi as dependency
Browse files Browse the repository at this point in the history
  • Loading branch information
pierrepebay committed Aug 15, 2024
1 parent 96689a3 commit 33d6cd1
Show file tree
Hide file tree
Showing 5 changed files with 48 additions and 0 deletions.
11 changes: 11 additions & 0 deletions ci/build_cpp.sh
Original file line number Diff line number Diff line change
Expand Up @@ -96,6 +96,17 @@ else
fi
fi

if test -d "${source_dir}/lib/papi"
then
{ echo "papi already in lib... not downloading, building, and installing"; } 2>/dev/null
else
cd "${source_dir}/lib"
git clone https://github.com/icl-utk-edu/papi.git
cd papi/src
./configure --prefix=${source_dir}/lib/papi/install
make && make install
fi

if test "${VT_ZOLTAN_ENABLED:-0}" -eq 1
then
export Zoltan_DIR=${ZOLTAN_DIR:-""}
Expand Down
21 changes: 21 additions & 0 deletions cmake/FindPAPI.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,21 @@
# Set minimum CMake version
cmake_minimum_required(VERSION 3.23 FATAL_ERROR)

set(PAPI_ROOT "${CMAKE_SOURCE_DIR}/lib/papi/install")

# Find the PAPI include directory and library
find_path(PAPI_INCLUDE_DIR NAMES papi.h HINTS ${PAPI_ROOT}/include)
find_library(PAPI_LIBRARY NAMES papi HINTS ${PAPI_ROOT}/lib)

include(FindPackageHandleStandardArgs)
find_package_handle_standard_args(PAPI DEFAULT_MSG PAPI_LIBRARY PAPI_INCLUDE_DIR)

if(PAPI_FOUND AND NOT TARGET PAPI::PAPI)
add_library(PAPI::PAPI UNKNOWN IMPORTED)
set_target_properties(PAPI::PAPI PROPERTIES
IMPORTED_LOCATION "{PAPI_LIBRARY}"
INTERFACE_INCLUDE_DIRECTORIES "${PAPI_INCLUDE_DIR}"
)
endif()

mark_as_advanced(PAPI_INCLUDE_DIR PAPI_LIBRARY)
10 changes: 10 additions & 0 deletions cmake/link_vt.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@ function(link_target_with_vt)
LINK_FORT
LINK_JSON
LINK_BROTLI
LINK_PAPI
)
set(
multiValueArg
Expand Down Expand Up @@ -221,6 +222,15 @@ function(link_target_with_vt)
)
endif()

if (NOT DEFINED ARG_LINK_PAPI AND ${ARG_DEFAULT_LINK_SET} OR ARG_LINK_PAPI)
if (${ARG_DEBUG_LINK})
message(STATUS "link_target_with_vt: papi=${ARG_LINK_PAPI}")
endif()
target_link_libraries(
${ARG_TARGET} PUBLIC ${ARG_BUILD_TYPE} ${PAPI_LIBRARY}
)
endif()

if (${vt_mimalloc_enabled})
if (${ARG_DEBUG_LINK})
message(STATUS "link_target_with_vt: mimalloc=${vt_mimalloc_enabled}")
Expand Down
3 changes: 3 additions & 0 deletions cmake/load_packages.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -21,5 +21,8 @@ include(cmake/load_libunwind.cmake)
# Optionally link with Zoltan
include(cmake/load_zoltan_package.cmake)

# Link with PAPI
include(cmake/load_papi.cmake)

# Tests
include(cmake/test_vt.cmake)
3 changes: 3 additions & 0 deletions cmake/load_papi.cmake
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
find_package(PAPI REQUIRED)
message(STATUS: "FOUND PAPI: PAPI LIBRARY: ${PAPI_LIBRARY}\n PAPI INCLUDE DIR: ${PAPI_INCLUDE_DIR}")
set(vt_papi_found "1")

0 comments on commit 33d6cd1

Please sign in to comment.