-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathxmake.lua
More file actions
177 lines (137 loc) · 4.74 KB
/
xmake.lua
File metadata and controls
177 lines (137 loc) · 4.74 KB
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
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
add_rules("mode.debug", "mode.release")
set_encodings("utf-8")
add_includedirs("src/common")
add_includedirs("src")
add_requires("openmp")
add_requires("pybind11")
if is_mode("release") then
set_optimize("fastest")
end
add_vectorexts("avx2", "fma")
-- ============ Compiler Flags ============
local function add_compiler_flags()
if is_plat("linux", "macosx") then
add_cxflags("-mavx2", "-mfma", "-fopenmp", "-march=native", "-fPIC")
if is_mode("release") then
add_cxflags("-flto", "-funroll-loops", "-finline-functions", "-ffast-math")
else
add_cxflags("-O0", "-g")
end
elseif is_plat("windows") then
if is_mode("release") then
add_cxflags("/arch:AVX2", "/fp:fast", "/Ot")
else
add_cxflags("/Od", "/Zi")
end
end
end
-- ============ Static Library: tensor ============
target("tensor")
set_kind("static")
set_languages("c++20")
add_files("src/common/*.cpp")
add_files("src/tensor/*.cpp")
add_files("src/utils/*.cpp")
add_files("src/log/*.cpp")
add_files("src/kernel/allocator/*.cpp")
add_packages("openmp")
add_compiler_flags()
set_targetdir("$(builddir)/lib")
set_objectdir("$(builddir)/obj")
-- ============ Static Library: model_runner ============
target("model_runner")
set_kind("static")
set_languages("c++20")
add_files("src/model_runner/layer/*.cpp")
add_files("src/model_runner/layer/kernel/*/*.cpp")
add_files("src/model_runner/attention/*.cpp")
add_files("src/model_runner/attention/*/*.cpp")
add_files("src/model_runner/models/*.cpp")
add_deps("tensor")
add_packages("openmp")
add_packages("pybind11")
add_compiler_flags()
set_targetdir("$(builddir)/lib")
set_objectdir("$(builddir)/obj")
-- ============ Static Library: worker ============
target("worker")
set_kind("static")
set_languages("c++20")
add_files("src/executor/worker/*.cpp")
add_files("src/sampling/*.cpp")
add_files("src/sampling/kernel/cpu/*.cpp")
add_files("src/kv_cache_manager/kv_cache/*.cpp")
add_deps("tensor", "model_runner")
add_packages("openmp")
add_packages("pybind11")
add_compiler_flags()
set_targetdir("$(builddir)/lib")
set_objectdir("$(builddir)/obj")
-- ============ Static Library: executor ============
target("executor")
set_kind("static")
set_languages("c++20")
add_files("src/executor/*.cpp")
add_deps("tensor", "model_runner", "worker")
add_packages("openmp")
add_compiler_flags()
set_targetdir("$(builddir)/lib")
set_objectdir("$(builddir)/obj")
-- ============ Static Library: scheduler ============
target("scheduler")
set_kind("static")
set_languages("c++20")
add_files("src/scheduler/*.cpp")
add_files("src/kv_cache_manager/block_manager/*.cpp")
add_deps("tensor", "model_runner", "executor")
add_packages("openmp")
add_compiler_flags()
set_targetdir("$(builddir)/lib")
set_objectdir("$(builddir)/obj")
-- ============ Shared Library: jllm_engine (Python Binding) ============
target("jllm_engine")
set_kind("shared")
set_languages("c++20")
add_files("src/engine/engine.cpp")
-- Python binding source file (to be created)
add_files("src/engine/python_binding.cpp")
-- Link all static libraries
add_deps("executor", "scheduler")
add_packages("openmp")
add_packages("pybind11")
add_compiler_flags()
set_targetdir("$(builddir)/lib")
set_objectdir("$(builddir)/obj")
-- Set output name for Python
if is_plat("linux") then
set_filename("jllm_engine.so")
elseif is_plat("macosx") then
set_filename("jllm_engine.dylib")
elseif is_plat("windows") then
set_filename("jllm_engine.pyd")
end
after_build(function (target)
import("core.project.project")
-- 自动将生成的二进制拷贝到 python/ 目录下
os.cp(target:targetfile(), "$(projectdir)/python/jllm/")
end)
-- ============ BF16 Benchmark ============
target("benchmark_bf16_swiglu")
set_kind("binary")
set_languages("c++20")
set_default(false) -- Not built by default
add_files("tests/benchmark_gate_up_swiglu_bf16.cpp")
add_deps("tensor", "model_runner")
add_packages("openmp")
add_compiler_flags()
set_targetdir("$(builddir)/bin")
set_objectdir("$(builddir)/obj")
target("debug_main")
set_kind("binary")
set_languages("c++20")
set_default(false) -- Not built by default
set_rundir("$(projectdir)")
add_files("tests/debug_main.cpp")
add_deps("jllm_engine")
set_targetdir("$(builddir)/bin")
set_objectdir("$(builddir)/obj")