| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106 |
- set(LLAMA_VERSION @LLAMA_INSTALL_VERSION@)
- set(LLAMA_BUILD_COMMIT @LLAMA_BUILD_COMMIT@)
- set(LLAMA_BUILD_NUMBER @LLAMA_BUILD_NUMBER@)
- set(LLAMA_SHARED_LIB @BUILD_SHARED_LIBS@)
- set(GGML_ACCELERATE @GGML_ACCELERATE@)
- set(GGML_VULKAN_CHECK_RESULTS @GGML_VULKAN_CHECK_RESULTS@)
- set(GGML_VULKAN_DEBUG @GGML_VULKAN_DEBUG@)
- set(GGML_VULKAN_MEMORY_DEBUG @GGML_VULKAN_MEMORY_DEBUG@)
- set(GGML_VULKAN_VALIDATE @GGML_VULKAN_VALIDATE@)
- set(GGML_OPENMP @GGML_OPENMP@)
- @PACKAGE_INIT@
- set_and_check(LLAMA_INCLUDE_DIR "@PACKAGE_LLAMA_INCLUDE_INSTALL_DIR@")
- set_and_check(LLAMA_LIB_DIR "@PACKAGE_LLAMA_LIB_INSTALL_DIR@")
- set_and_check(LLAMA_BIN_DIR "@PACKAGE_LLAMA_BIN_INSTALL_DIR@")
- find_package(Threads REQUIRED)
- set(_llama_transient_defines "@GGML_TRANSIENT_DEFINES@")
- set(_llama_link_deps "")
- foreach(_ggml_lib ggml ggml-base)
- string(REPLACE "-" "_" _ggml_lib_var "${_ggml_lib}_LIBRARY")
- find_library(${_ggml_lib_var} ${_ggml_lib}
- REQUIRED
- HINTS ${LLAMA_LIB_DIR}
- NO_CMAKE_FIND_ROOT_PATH
- )
- list(APPEND _llama_link_deps "${${_ggml_lib_var}}")
- message(STATUS "Found ${${_ggml_lib_var}}")
- endforeach()
- foreach(backend amx blas cann cpu cuda hip kompute metal musa rpc sycl vulkan)
- string(TOUPPER "GGML_${backend}" backend_id)
- set(_ggml_lib "ggml-${backend}")
- string(REPLACE "-" "_" _ggml_lib_var "${_ggml_lib}_LIBRARY")
- find_library(${_ggml_lib_var} ${_ggml_lib}
- HINTS ${LLAMA_LIB_DIR}
- NO_CMAKE_FIND_ROOT_PATH
- )
- if(${_ggml_lib_var})
- list(APPEND _llama_link_deps "${${_ggml_lib_var}}")
- set(${backend_id} ON)
- message(STATUS "Found backend ${${_ggml_lib_var}}")
- else()
- set(${backend_id} OFF)
- endif()
- endforeach()
- if (APPLE AND GGML_ACCELERATE)
- find_library(ACCELERATE_FRAMEWORK Accelerate REQUIRED)
- endif()
- if (GGML_BLAS)
- find_package(BLAS REQUIRED)
- endif()
- if (GGML_CUDA)
- find_package(CUDAToolkit REQUIRED)
- endif()
- if (GGML_METAL)
- find_library(FOUNDATION_LIBRARY Foundation REQUIRED)
- find_library(METAL_FRAMEWORK Metal REQUIRED)
- find_library(METALKIT_FRAMEWORK MetalKit REQUIRED)
- endif()
- if (GGML_VULKAN)
- find_package(Vulkan REQUIRED)
- endif()
- if (GGML_HIP)
- find_package(hip REQUIRED)
- find_package(hipblas REQUIRED)
- find_package(rocblas REQUIRED)
- endif()
- if (GGML_SYCL)
- find_package(IntelSYCL REQUIRED)
- find_package(MKL REQUIRED)
- endif()
- if (GGML_OPENMP)
- find_package(OpenMP REQUIRED)
- endif()
- find_library(llama_LIBRARY llama
- REQUIRED
- HINTS ${LLAMA_LIB_DIR}
- NO_CMAKE_FIND_ROOT_PATH
- )
- add_library(llama UNKNOWN IMPORTED)
- set_target_properties(llama
- PROPERTIES
- INTERFACE_INCLUDE_DIRECTORIES "${LLAMA_INCLUDE_DIR}"
- INTERFACE_LINK_LIBRARIES "${_llama_link_deps}"
- INTERFACE_COMPILE_DEFINITIONS "${_llama_transient_defines}"
- IMPORTED_LINK_INTERFACE_LANGUAGES "CXX"
- IMPORTED_LOCATION "${llama_LIBRARY}"
- INTERFACE_COMPILE_FEATURES cxx_std_11
- POSITION_INDEPENDENT_CODE ON )
- check_required_components(Llama)
|