CMakeLists.txt 4.8 KB

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