-
Notifications
You must be signed in to change notification settings - Fork 86
/
CMakeLists.txt
152 lines (131 loc) · 5.18 KB
/
CMakeLists.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
cmake_minimum_required(VERSION 3.15.2)
set(CMAKE_EXPORT_COMPILE_COMMANDS
ON
CACHE INTERNAL "")
project(InferLLM LANGUAGES C CXX ASM)
option(ENABLE_ASAN "Build with asan." OFF)
option(ENABLE_PROFILE "Build with profile information." OFF)
option(ENABLE_GPROF "Build with gprof enabled." OFF)
option(ENABLE_DOT "Build with Arm dotprod." OFF)
option(ENABLE_FP16 "Build with Arm FP16." OFF)
option(ENABLE_GPU "Build with GPU." OFF)
option(ENABLE_TEST "Build with TEST." OFF)
set(INFER_ARCH "auto" CACHE STRING "Build with specific ISA (x86/arm/rvvXpX).")
if(${INFER_ARCH} STREQUAL "auto")
if (${CMAKE_SYSTEM_PROCESSOR} STREQUAL "x86_64" OR ${CMAKE_SYSTEM_PROCESSOR} STREQUAL "AMD64")
set(INFER_ARCH "x86")
elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "aarch64" OR ${CMAKE_SYSTEM_PROCESSOR} STREQUAL "arm64")
set(INFER_ARCH "arm")
elseif(${CMAKE_SYSTEM_PROCESSOR} STREQUAL "riscv64" OR ${CMAKE_SYSTEM_PROCESSOR} STREQUAL "riscv32")
set(INFER_ARCH "rvv1p0")
endif()
endif()
if(${INFER_ARCH} MATCHES "rvv.p.")
string(SUBSTRING ${INFER_ARCH} 3 -1 RVV_VER)
string(REPLACE "p" "" RVV_VER ${RVV_VER})
string(PREPEND RVV_VER "1")
message(STATUS "current platform: ${INFER_ARCH} with ${RVV_VER}")
set(INFER_ARCH "rvv")
add_definitions(-DINFER_RVV=${RVV_VER})
elseif(${INFER_ARCH} STREQUAL "x86")
message(STATUS "current platform: x86")
set(INFER_ARCH "x86")
add_definitions(-DINFER_X86=1)
elseif(${INFER_ARCH} STREQUAL "arm")
message(STATUS "current platform: arm")
set(INFER_ARCH "arm")
add_definitions(-DINFER_ARM=1)
if(ENABLE_DOT)
message(STATUS "Enable dotprod feature in armv8.2-a")
set(CMAKE_CXX_FLAGS " -march=armv8.2-a+dotprod ${CMAKE_CXX_FLAGS}")
endif()
if(ENABLE_FP16)
message(STATUS "Enable fp16 feature in armv8.2-a")
set(CMAKE_CXX_FLAGS " -march=armv8.2-a+fp16 ${CMAKE_CXX_FLAGS}")
endif()
else()
message(STATUS "current platform: NONE")
set(INFER_ARCH "")
endif()
if(ENABLE_PROFILE)
message(STATUS "Enable profile information.")
add_definitions(-DINFER_PROFILE)
endif()
file(GLOB_RECURSE SRC src/*.cpp src/*.h)
list(FILTER SRC EXCLUDE REGEX "src/kern/optimized/.*")
list(FILTER SRC EXCLUDE REGEX "src/kern/gpu/.*")
if (NOT ${INFER_ARCH} STREQUAL "")
file(GLOB_RECURSE PLTSRC src/kern/optimized/${INFER_ARCH}/*)
endif()
set(CMAKE_CXX_FLAGS " -std=c++11 -pthread -Wno-multichar -fPIC ${CMAKE_CXX_FLAGS}")
if(ENABLE_GPU)
message(STATUS "Build with GPU.")
add_definitions(-DENABLE_GPU=1)
find_package(CUDA)
include_directories(${CUDA_INCLUDE_DIRS})
file(GLOB_RECURSE GPU_SRC src/kern/gpu/*.cu src/kern/gpu/*.h)
cuda_add_library(InferLLMGPU STATIC ${GPU_SRC})
target_include_directories(InferLLMGPU PUBLIC include src)
target_include_directories(InferLLMGPU PUBLIC ${CUDA_CUBLAS_INCLUDE_DIRS}})
target_link_libraries(InferLLMGPU ${CUDA_LIBRARIES} ${CUDA_CUBLAS_LIBRARIES})
endif()
add_library(InferLLM STATIC ${SRC} ${PLTSRC})
add_library(InferLLMShared SHARED ${SRC} ${PLTSRC})
set_target_properties(InferLLMShared PROPERTIES PUBLIC_HEADER ${CMAKE_SOURCE_DIR}/include/model.h)
target_include_directories(InferLLM PUBLIC include src)
target_include_directories(InferLLMShared PUBLIC include src)
if(CMAKE_BUILD_TYPE MATCHES "Debug")
set(CMAKE_CXX_FLAGS " -g -O0 ${CMAKE_CXX_FLAGS}")
else()
set(CMAKE_CXX_FLAGS " -O3 -g ${CMAKE_CXX_FLAGS}")
endif()
if(ENABLE_GPROF)
include(CheckCXXCompilerFlag)
CHECK_CXX_COMPILER_FLAG("-pg" HAS_GPROF)
message(WARNING "Build with gprof: ${HAS_GPROF}. Gprof may not work on darwin.")
if(HAS_GPROF)
set(CMAKE_CXX_FLAGS " -pg ${CMAKE_CXX_FLAGS}")
endif()
endif()
if(ENABLE_ASAN)
if(${CMAKE_CXX_COMPILER_ID} STREQUAL "Clang")
set(CMAKE_CXX_FLAGS
" -fsanitize=address -g -O0 -static-libsan ${CMAKE_CXX_FLAGS}"
)
set(CMAKE_LINK_FLAGS "-fsanitize=address -static-libsan ${CMAKE_LINK_FLAGS}")
else()
set(CMAKE_CXX_FLAGS
" -fsanitize=address -g -O0 -static-libasan ${CMAKE_CXX_FLAGS}"
)
set(CMAKE_LINK_FLAGS "-fsanitize=address -static-libasan ${CMAKE_LINK_FLAGS}")
endif()
add_definitions(-DENABLE_ASAN)
endif()
add_executable(llama application/llama/llama.cpp)
target_link_libraries(llama InferLLM)
add_executable(chatglm application/chatglm/chatglm.cpp)
target_link_libraries(chatglm InferLLM)
add_executable(chat application/chat.cpp)
target_link_libraries(chat InferLLM)
add_executable(quantizer application/quantizer.cpp)
target_link_libraries(quantizer InferLLM)
if(ENABLE_GPU)
target_link_libraries(InferLLM InferLLMGPU)
target_link_libraries(InferLLMShared InferLLMGPU)
target_link_libraries(llama InferLLMGPU)
target_link_libraries(chatglm InferLLMGPU)
target_link_libraries(quantizer InferLLMGPU)
target_link_libraries(chat InferLLMGPU)
endif()
if(ENABLE_TEST)
message(STATUS "Build with TEST.")
add_subdirectory(third-party/googletest ${CMAKE_CURRENT_BINARY_DIR}/googletest EXCLUDE_FROM_ALL)
file(GLOB TEST_SRC test/*.cpp test/CPU/*.cpp test/CPU/*.h)
if(ENABLE_GPU)
file(GLOB_RECURSE GPU_TEST_SRC test/GPU/*.cpp test/GPU/*.h)
list(APPEND TEST_SRC ${GPU_TEST_SRC})
endif()
add_executable(InferLLMTest ${TEST_SRC})
target_include_directories(InferLLMTest PUBLIC test inlude src)
target_link_libraries(InferLLMTest InferLLM gtest)
endif()