CMakeLists.txt 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129
  1. cmake_minimum_required(VERSION 3.21)
  2. project(Ollama C CXX)
  3. include(CheckLanguage)
  4. find_package(Threads REQUIRED)
  5. set(CMAKE_BUILD_TYPE Release)
  6. set(BUILD_SHARED_LIBS ON)
  7. set(CMAKE_CXX_STANDARD 17)
  8. set(CMAKE_CXX_STANDARD_REQUIRED ON)
  9. set(CMAKE_CXX_EXTENSIONS OFF)
  10. set(GGML_BUILD ON)
  11. set(GGML_SHARED ON)
  12. set(GGML_CCACHE ON)
  13. set(GGML_BACKEND_DL ON)
  14. set(GGML_BACKEND_SHARED ON)
  15. set(GGML_SCHED_MAX_COPIES 4)
  16. set(GGML_LLAMAFILE ON)
  17. set(GGML_CUDA_PEER_MAX_BATCH_SIZE 128)
  18. set(GGML_CUDA_GRAPHS ON)
  19. if((NOT CMAKE_OSX_ARCHITECTURES MATCHES "arm64")
  20. OR (NOT CMAKE_OSX_ARCHITECTURES AND NOT CMAKE_SYSTEM_PROCESSOR MATCHES "arm|aarch64|ARM64|ARMv[0-9]+"))
  21. set(GGML_CPU_ALL_VARIANTS ON)
  22. endif()
  23. if (CMAKE_OSX_ARCHITECTURES MATCHES "x86_64")
  24. set(CMAKE_BUILD_RPATH "@loader_path")
  25. set(CMAKE_INSTALL_RPATH "@loader_path")
  26. endif()
  27. set(OLLAMA_BUILD_DIR ${CMAKE_BINARY_DIR}/lib/ollama)
  28. set(OLLAMA_INSTALL_DIR ${CMAKE_INSTALL_PREFIX}/lib/ollama)
  29. set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${OLLAMA_BUILD_DIR})
  30. set(CMAKE_RUNTIME_OUTPUT_DIRECTORY_DEBUG ${OLLAMA_BUILD_DIR})
  31. set(CMAKE_RUNTIME_OUTPUT_DIRECTORY_RELEASE ${OLLAMA_BUILD_DIR})
  32. set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${OLLAMA_BUILD_DIR})
  33. set(CMAKE_LIBRARY_OUTPUT_DIRECTORY_DEBUG ${OLLAMA_BUILD_DIR})
  34. set(CMAKE_LIBRARY_OUTPUT_DIRECTORY_RELEASE ${OLLAMA_BUILD_DIR})
  35. include_directories(${CMAKE_CURRENT_SOURCE_DIR}/ml/backend/ggml/ggml/src)
  36. include_directories(${CMAKE_CURRENT_SOURCE_DIR}/ml/backend/ggml/ggml/src/include)
  37. include_directories(${CMAKE_CURRENT_SOURCE_DIR}/ml/backend/ggml/ggml/src/ggml-cpu)
  38. include_directories(${CMAKE_CURRENT_SOURCE_DIR}/ml/backend/ggml/ggml/src/ggml-cpu/amx)
  39. set(GGML_CPU ON)
  40. add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/ml/backend/ggml/ggml/src)
  41. set_property(TARGET ggml PROPERTY EXCLUDE_FROM_ALL TRUE)
  42. get_target_property(CPU_VARIANTS ggml-cpu MANUALLY_ADDED_DEPENDENCIES)
  43. if(NOT CPU_VARIANTS)
  44. set(CPU_VARIANTS "ggml-cpu")
  45. endif()
  46. install(TARGETS ggml-base ${CPU_VARIANTS}
  47. RUNTIME_DEPENDENCIES
  48. PRE_EXCLUDE_REGEXES ".*"
  49. RUNTIME DESTINATION ${OLLAMA_INSTALL_DIR} COMPONENT CPU
  50. LIBRARY DESTINATION ${OLLAMA_INSTALL_DIR} COMPONENT CPU
  51. FRAMEWORK DESTINATION ${OLLAMA_INSTALL_DIR} COMPONENT CPU
  52. )
  53. check_language(CUDA)
  54. if(CMAKE_CUDA_COMPILER)
  55. if(CMAKE_VERSION VERSION_GREATER_EQUAL "3.24" AND NOT CMAKE_CUDA_ARCHITECTURES)
  56. set(CMAKE_CUDA_ARCHITECTURES "native")
  57. endif()
  58. find_package(CUDAToolkit)
  59. add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/ml/backend/ggml/ggml/src/ggml-cuda)
  60. set(OLLAMA_CUDA_INSTALL_DIR ${OLLAMA_INSTALL_DIR}/cuda_v${CUDAToolkit_VERSION_MAJOR})
  61. install(TARGETS ggml-cuda
  62. RUNTIME_DEPENDENCIES
  63. DIRECTORIES ${CUDAToolkit_BIN_DIR} ${CUDAToolkit_LIBRARY_DIR}
  64. PRE_INCLUDE_REGEXES cublas cublasLt cudart
  65. PRE_EXCLUDE_REGEXES ".*"
  66. RUNTIME DESTINATION ${OLLAMA_CUDA_INSTALL_DIR} COMPONENT CUDA
  67. LIBRARY DESTINATION ${OLLAMA_CUDA_INSTALL_DIR} COMPONENT CUDA
  68. )
  69. endif()
  70. set(WINDOWS_AMDGPU_TARGETS_EXCLUDE_REGEX "^gfx(906|908|90a):xnack[+-]$"
  71. CACHE STRING
  72. "Regular expression describing AMDGPU_TARGETS not supported on Windows. Override to force building these targets. Default \"^gfx(906|908|90a):xnack[+-]$\"."
  73. )
  74. check_language(HIP)
  75. if(CMAKE_HIP_COMPILER)
  76. set(HIP_PLATFORM "amd")
  77. find_package(hip REQUIRED)
  78. if(NOT AMDGPU_TARGETS)
  79. list(FILTER AMDGPU_TARGETS INCLUDE REGEX "^gfx(900|94[012]|101[02]|1030|110[012])$")
  80. elseif(WIN32 AND WINDOWS_AMDGPU_TARGETS_EXCLUDE_REGEX)
  81. list(FILTER AMDGPU_TARGETS EXCLUDE REGEX ${WINDOWS_AMDGPU_TARGETS_EXCLUDE_REGEX})
  82. endif()
  83. if(AMDGPU_TARGETS)
  84. add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/ml/backend/ggml/ggml/src/ggml-hip)
  85. if (WIN32)
  86. target_compile_definitions(ggml-hip PRIVATE GGML_CUDA_NO_PEER_COPY=1)
  87. endif()
  88. set(OLLAMA_HIP_INSTALL_DIR ${OLLAMA_INSTALL_DIR}/rocm)
  89. install(TARGETS ggml-hip
  90. RUNTIME_DEPENDENCIES
  91. DIRECTORIES ${HIP_BIN_INSTALL_DIR} ${HIP_LIB_INSTALL_DIR}
  92. PRE_INCLUDE_REGEXES hipblas rocblas amdhip64 rocsolver amd_comgr hsa-runtime64 rocsparse tinfo rocprofiler-register drm drm_amdgpu numa elf
  93. PRE_EXCLUDE_REGEXES ".*"
  94. POST_EXCLUDE_REGEXES "system32"
  95. RUNTIME DESTINATION ${OLLAMA_HIP_INSTALL_DIR} COMPONENT HIP
  96. LIBRARY DESTINATION ${OLLAMA_HIP_INSTALL_DIR} COMPONENT HIP
  97. )
  98. foreach(HIP_LIB_BIN_INSTALL_DIR IN ITEMS ${HIP_BIN_INSTALL_DIR} ${HIP_LIB_INSTALL_DIR})
  99. if(EXISTS ${HIP_LIB_BIN_INSTALL_DIR}/rocblas)
  100. install(DIRECTORY ${HIP_LIB_BIN_INSTALL_DIR}/rocblas DESTINATION ${OLLAMA_HIP_INSTALL_DIR} COMPONENT HIP)
  101. break()
  102. endif()
  103. endforeach()
  104. endif()
  105. endif()