2023-09-16 14:57:49 -04:00
|
|
|
cmake_minimum_required(VERSION 3.21)
|
2023-03-23 13:54:14 -04:00
|
|
|
|
|
|
|
project(llama_cpp)
|
|
|
|
|
2023-09-12 18:29:18 -04:00
|
|
|
option(LLAMA_BUILD "Build llama.cpp shared library and install alongside python package" ON)
|
2023-11-28 04:55:21 -05:00
|
|
|
option(LLAVA_BUILD "Build llava shared library and install alongside python package" ON)
|
2023-04-25 01:36:37 -04:00
|
|
|
|
2023-09-12 18:29:18 -04:00
|
|
|
if (LLAMA_BUILD)
|
2023-04-08 02:39:17 -04:00
|
|
|
set(BUILD_SHARED_LIBS "On")
|
2023-11-10 16:32:36 -05:00
|
|
|
|
|
|
|
# Building llama
|
2023-09-14 18:25:44 -04:00
|
|
|
if (APPLE AND NOT CMAKE_SYSTEM_PROCESSOR MATCHES "arm64")
|
|
|
|
# Need to disable these llama.cpp flags on Apple x86_64,
|
2023-09-12 18:41:00 -04:00
|
|
|
# otherwise users may encounter invalid instruction errors
|
2023-09-12 18:37:32 -04:00
|
|
|
set(LLAMA_AVX "Off" CACHE BOOL "llama: enable AVX" FORCE)
|
|
|
|
set(LLAMA_AVX2 "Off" CACHE BOOL "llama: enable AVX2" FORCE)
|
|
|
|
set(LLAMA_FMA "Off" CACHE BOOL "llama: enable FMA" FORCE)
|
|
|
|
set(LLAMA_F16C "Off" CACHE BOOL "llama: enable F16C" FORCE)
|
2023-09-12 18:25:31 -04:00
|
|
|
endif()
|
2024-03-20 17:46:09 +01:00
|
|
|
|
2024-04-06 01:36:53 -04:00
|
|
|
if (APPLE)
|
2024-03-20 17:46:09 +01:00
|
|
|
set(LLAMA_METAL_EMBED_LIBRARY "On" CACHE BOOL "llama: embed metal library" FORCE)
|
|
|
|
endif()
|
|
|
|
|
2023-09-12 18:29:18 -04:00
|
|
|
add_subdirectory(vendor/llama.cpp)
|
2023-04-08 02:39:17 -04:00
|
|
|
install(
|
|
|
|
TARGETS llama
|
2023-07-18 18:52:29 -04:00
|
|
|
LIBRARY DESTINATION ${SKBUILD_PLATLIB_DIR}/llama_cpp
|
|
|
|
RUNTIME DESTINATION ${SKBUILD_PLATLIB_DIR}/llama_cpp
|
|
|
|
ARCHIVE DESTINATION ${SKBUILD_PLATLIB_DIR}/llama_cpp
|
|
|
|
FRAMEWORK DESTINATION ${SKBUILD_PLATLIB_DIR}/llama_cpp
|
|
|
|
RESOURCE DESTINATION ${SKBUILD_PLATLIB_DIR}/llama_cpp
|
|
|
|
)
|
|
|
|
# Temporary fix for https://github.com/scikit-build/scikit-build-core/issues/374
|
|
|
|
install(
|
|
|
|
TARGETS llama
|
|
|
|
LIBRARY DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/llama_cpp
|
|
|
|
RUNTIME DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/llama_cpp
|
|
|
|
ARCHIVE DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/llama_cpp
|
|
|
|
FRAMEWORK DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/llama_cpp
|
|
|
|
RESOURCE DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/llama_cpp
|
2023-04-08 02:39:17 -04:00
|
|
|
)
|
2023-09-16 14:57:49 -04:00
|
|
|
# Workaround for Windows + CUDA https://github.com/abetlen/llama-cpp-python/issues/563
|
|
|
|
install(
|
|
|
|
FILES $<TARGET_RUNTIME_DLLS:llama>
|
|
|
|
DESTINATION ${SKBUILD_PLATLIB_DIR}/llama_cpp
|
|
|
|
)
|
|
|
|
install(
|
|
|
|
FILES $<TARGET_RUNTIME_DLLS:llama>
|
|
|
|
DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/llama_cpp
|
|
|
|
)
|
2023-11-10 16:32:36 -05:00
|
|
|
|
2023-11-28 04:55:21 -05:00
|
|
|
if (LLAVA_BUILD)
|
2024-02-11 12:53:59 -06:00
|
|
|
if (LLAMA_CUBLAS)
|
|
|
|
add_compile_definitions(GGML_USE_CUBLAS)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if (LLAMA_METAL)
|
|
|
|
add_compile_definitions(GGML_USE_METAL)
|
|
|
|
endif()
|
|
|
|
|
2023-11-28 04:55:21 -05:00
|
|
|
# Building llava
|
|
|
|
add_subdirectory(vendor/llama.cpp/examples/llava)
|
|
|
|
set_target_properties(llava_shared PROPERTIES OUTPUT_NAME "llava")
|
|
|
|
# Set CUDA_ARCHITECTURES to OFF on windows
|
|
|
|
if (WIN32)
|
|
|
|
set_target_properties(llava_shared PROPERTIES CUDA_ARCHITECTURES OFF)
|
|
|
|
endif()
|
|
|
|
install(
|
|
|
|
TARGETS llava_shared
|
|
|
|
LIBRARY DESTINATION ${SKBUILD_PLATLIB_DIR}/llama_cpp
|
|
|
|
RUNTIME DESTINATION ${SKBUILD_PLATLIB_DIR}/llama_cpp
|
|
|
|
ARCHIVE DESTINATION ${SKBUILD_PLATLIB_DIR}/llama_cpp
|
|
|
|
FRAMEWORK DESTINATION ${SKBUILD_PLATLIB_DIR}/llama_cpp
|
|
|
|
RESOURCE DESTINATION ${SKBUILD_PLATLIB_DIR}/llama_cpp
|
|
|
|
)
|
|
|
|
# Temporary fix for https://github.com/scikit-build/scikit-build-core/issues/374
|
|
|
|
install(
|
|
|
|
TARGETS llava_shared
|
|
|
|
LIBRARY DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/llama_cpp
|
|
|
|
RUNTIME DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/llama_cpp
|
|
|
|
ARCHIVE DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/llama_cpp
|
|
|
|
FRAMEWORK DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/llama_cpp
|
|
|
|
RESOURCE DESTINATION ${CMAKE_CURRENT_SOURCE_DIR}/llama_cpp
|
|
|
|
)
|
2023-11-10 16:32:36 -05:00
|
|
|
endif()
|
2023-05-16 09:07:14 -04:00
|
|
|
endif()
|