CMakeLists.txt 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  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. set(OLLAMA_BUILD_DIR ${CMAKE_BINARY_DIR}/lib/ollama)
  24. set(OLLAMA_INSTALL_DIR ${CMAKE_INSTALL_PREFIX}/lib/ollama)
  25. set(CMAKE_RUNTIME_OUTPUT_DIRECTORY ${OLLAMA_BUILD_DIR})
  26. set(CMAKE_RUNTIME_OUTPUT_DIRECTORY_DEBUG ${OLLAMA_BUILD_DIR})
  27. set(CMAKE_RUNTIME_OUTPUT_DIRECTORY_RELEASE ${OLLAMA_BUILD_DIR})
  28. set(CMAKE_LIBRARY_OUTPUT_DIRECTORY ${OLLAMA_BUILD_DIR})
  29. set(CMAKE_LIBRARY_OUTPUT_DIRECTORY_DEBUG ${OLLAMA_BUILD_DIR})
  30. set(CMAKE_LIBRARY_OUTPUT_DIRECTORY_RELEASE ${OLLAMA_BUILD_DIR})
  31. include_directories(${CMAKE_CURRENT_SOURCE_DIR}/ml/backend/ggml/ggml/src)
  32. include_directories(${CMAKE_CURRENT_SOURCE_DIR}/ml/backend/ggml/ggml/src/include)
  33. include_directories(${CMAKE_CURRENT_SOURCE_DIR}/ml/backend/ggml/ggml/src/ggml-cpu)
  34. include_directories(${CMAKE_CURRENT_SOURCE_DIR}/ml/backend/ggml/ggml/src/ggml-cpu/amx)
  35. set(GGML_CPU ON)
  36. add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/ml/backend/ggml/ggml/src)
  37. set_property(TARGET ggml PROPERTY EXCLUDE_FROM_ALL TRUE)
  38. get_target_property(CPU_VARIANTS ggml-cpu MANUALLY_ADDED_DEPENDENCIES)
  39. if(NOT CPU_VARIANTS)
  40. set(CPU_VARIANTS "ggml-cpu")
  41. endif()
  42. install(TARGETS ggml-base ${CPU_VARIANTS}
  43. RUNTIME_DEPENDENCIES
  44. PRE_EXCLUDE_REGEXES ".*"
  45. RUNTIME DESTINATION ${OLLAMA_INSTALL_DIR} COMPONENT CPU
  46. LIBRARY DESTINATION ${OLLAMA_INSTALL_DIR} COMPONENT CPU
  47. FRAMEWORK DESTINATION ${OLLAMA_INSTALL_DIR} COMPONENT CPU
  48. )
  49. check_language(CUDA)
  50. if(CMAKE_CUDA_COMPILER)
  51. if(CMAKE_VERSION VERSION_GREATER_EQUAL "3.24" AND NOT CMAKE_CUDA_ARCHITECTURES)
  52. set(CMAKE_CUDA_ARCHITECTURES "native")
  53. endif()
  54. find_package(CUDAToolkit)
  55. add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/ml/backend/ggml/ggml/src/ggml-cuda)
  56. set(OLLAMA_CUDA_INSTALL_DIR ${OLLAMA_INSTALL_DIR}/cuda_v${CUDAToolkit_VERSION_MAJOR})
  57. install(TARGETS ggml-cuda
  58. RUNTIME_DEPENDENCIES
  59. DIRECTORIES ${CUDAToolkit_BIN_DIR} ${CUDAToolkit_LIBRARY_DIR}
  60. PRE_INCLUDE_REGEXES cublas cublasLt cudart
  61. PRE_EXCLUDE_REGEXES ".*"
  62. RUNTIME DESTINATION ${OLLAMA_CUDA_INSTALL_DIR} COMPONENT CUDA
  63. LIBRARY DESTINATION ${OLLAMA_CUDA_INSTALL_DIR} COMPONENT CUDA
  64. )
  65. endif()
  66. check_language(HIP)
  67. if(CMAKE_HIP_COMPILER)
  68. set(HIP_PLATFORM "amd")
  69. find_package(hip REQUIRED)
  70. if(NOT AMDGPU_TARGETS)
  71. list(FILTER AMDGPU_TARGETS INCLUDE REGEX "^gfx(900|94[012]|101[02]|1030|110[012])$")
  72. endif()
  73. if(AMDGPU_TARGETS)
  74. add_subdirectory(${CMAKE_CURRENT_SOURCE_DIR}/ml/backend/ggml/ggml/src/ggml-hip)
  75. set(OLLAMA_HIP_INSTALL_DIR ${OLLAMA_INSTALL_DIR}/rocm)
  76. install(TARGETS ggml-hip
  77. RUNTIME_DEPENDENCIES
  78. DIRECTORIES ${HIP_BIN_INSTALL_DIR} ${HIP_LIB_INSTALL_DIR}
  79. PRE_INCLUDE_REGEXES amdhip64 hipblas rocblas amd_comgr hsa_runtime64 rocprofiler-register drm_amdgpu drm numa
  80. PRE_EXCLUDE_REGEXES ".*"
  81. POST_EXCLUDE_REGEXES "system32"
  82. RUNTIME DESTINATION ${OLLAMA_HIP_INSTALL_DIR} COMPONENT HIP
  83. LIBRARY DESTINATION ${OLLAMA_HIP_INSTALL_DIR} COMPONENT HIP
  84. )
  85. foreach(HIP_LIB_BIN_INSTALL_DIR IN ITEMS ${HIP_BIN_INSTALL_DIR} ${HIP_LIB_INSTALL_DIR})
  86. if(EXISTS ${HIP_LIB_BIN_INSTALL_DIR}/rocblas)
  87. install(DIRECTORY ${HIP_LIB_BIN_INSTALL_DIR}/rocblas DESTINATION ${OLLAMA_HIP_INSTALL_DIR} COMPONENT HIP)
  88. break()
  89. endif()
  90. endforeach()
  91. endif()
  92. endif()