xmake.lua 13.5 KB
Newer Older
PanZezhongQY's avatar
PanZezhongQY committed
1
add_rules("mode.debug", "mode.release")
2
add_requires("boost", {configs = {stacktrace = true}})
3
4
add_requires("pybind11")

PanZezhongQY's avatar
PanZezhongQY committed
5
6
7
8
9
-- Define color codes
local GREEN = '\27[0;32m'
local YELLOW = '\27[1;33m'
local NC = '\27[0m'  -- No Color

10
set_encodings("utf-8")
PanZezhongQY's avatar
PanZezhongQY committed
11

12
add_includedirs("include")
13
add_includedirs("third_party/spdlog/include")
qinyiqun's avatar
qinyiqun committed
14
add_includedirs("third_party/nlohmann_json/single_include/")
15

PanZezhongQY's avatar
PanZezhongQY committed
16
17
18
19
if is_mode("debug") then
    add_defines("DEBUG_MODE")
end

20
21
if is_plat("windows") then
    set_runtimes("MD")
22
    add_ldflags("/utf-8", {force = true})
23
    add_cxxflags("/utf-8", {force = true})
24
25
end

PanZezhongQY's avatar
PanZezhongQY committed
26
27
28
29
-- CPU
option("cpu")
    set_default(true)
    set_showmenu(true)
YdrMaster's avatar
YdrMaster committed
30
    set_description("Whether to compile implementations for CPU")
PanZezhongQY's avatar
PanZezhongQY committed
31
32
33
option_end()

option("omp")
34
    set_default(true)
PanZezhongQY's avatar
PanZezhongQY committed
35
36
37
38
39
40
41
42
43
    set_showmenu(true)
    set_description("Enable or disable OpenMP support for cpu kernel")
option_end()

if has_config("cpu") then
    includes("xmake/cpu.lua")
    add_defines("ENABLE_CPU_API")
end

44
45
46
47
if has_config("omp") then
    add_defines("ENABLE_OMP")
end

PanZezhongQY's avatar
PanZezhongQY committed
48
49
50
51
-- 英伟达
option("nv-gpu")
    set_default(false)
    set_showmenu(true)
YdrMaster's avatar
YdrMaster committed
52
    set_description("Whether to compile implementations for Nvidia GPU")
PanZezhongQY's avatar
PanZezhongQY committed
53
54
55
option_end()

if has_config("nv-gpu") then
56
    add_defines("ENABLE_NVIDIA_API")
57
    includes("xmake/nvidia.lua")
PanZezhongQY's avatar
PanZezhongQY committed
58
59
end

60
61
option("cudnn")
    set_default(true)
YdrMaster's avatar
YdrMaster committed
62
    set_showmenu(true)
YdrMaster's avatar
YdrMaster committed
63
    set_description("Whether to compile cudnn for Nvidia GPU")
YdrMaster's avatar
YdrMaster committed
64
65
option_end()

66
67
if has_config("cudnn") then
    add_defines("ENABLE_CUDNN_API")
YdrMaster's avatar
YdrMaster committed
68
69
end

70
71
72
73
74
75
76
77
78
79
option("cutlass")
    set_default(false)
    set_showmenu(true)
    set_description("Whether to compile cutlass for Nvidia GPU")
option_end()

if has_config("cutlass") then 
    add_defines("ENABLE_CUTLASS_API")
end

80
81
82
83
84
85
86
option("cuda_arch")
    set_showmenu(true)
    set_description("Set CUDA GPU architecture (e.g. sm_90)")
    set_values("sm_50", "sm_60", "sm_70", "sm_75", "sm_80", "sm_86", "sm_89", "sm_90", "sm_90a")
    set_category("option")
option_end()

PanZezhongQY's avatar
PanZezhongQY committed
87
88
89
90
-- 寒武纪
option("cambricon-mlu")
    set_default(false)
    set_showmenu(true)
YdrMaster's avatar
YdrMaster committed
91
    set_description("Whether to compile implementations for Cambricon MLU")
PanZezhongQY's avatar
PanZezhongQY committed
92
93
94
95
option_end()

if has_config("cambricon-mlu") then
    add_defines("ENABLE_CAMBRICON_API")
PanZezhong's avatar
PanZezhong committed
96
    includes("xmake/bang.lua")
PanZezhongQY's avatar
PanZezhongQY committed
97
98
99
100
101
102
end

-- 华为昇腾
option("ascend-npu")
    set_default(false)
    set_showmenu(true)
YdrMaster's avatar
YdrMaster committed
103
    set_description("Whether to compile implementations for Huawei Ascend NPU")
PanZezhongQY's avatar
PanZezhongQY committed
104
105
106
107
option_end()

if has_config("ascend-npu") then
    add_defines("ENABLE_ASCEND_API")
Pan Zezhong's avatar
Pan Zezhong committed
108
    includes("xmake/ascend.lua")
PanZezhongQY's avatar
PanZezhongQY committed
109
110
end

111
112
113
114
-- 天数智芯
option("iluvatar-gpu")
    set_default(false)
    set_showmenu(true)
YdrMaster's avatar
YdrMaster committed
115
    set_description("Whether to compile implementations for Iluvatar GPU")
116
117
option_end()

118
119
120
121
122
123
option("ivcore-20")
    set_default(false)
    set_showmenu(true)
    set_description("Use ivcore20")
option_end()

124
if has_config("iluvatar-gpu") then
125
    add_defines("ENABLE_ILUVATAR_API")
126
127
128
    includes("xmake/iluvatar.lua")
end

wooway777's avatar
wooway777 committed
129
130
131
132
133
134
135
136
137
138
139
140
-- ali
option("ali-ppu")
    set_default(false)
    set_showmenu(true)
    set_description("Whether to compile implementations for Ali PPU")
option_end()

if has_config("ali-ppu") then
    add_defines("ENABLE_ALI_API")
    includes("xmake/ali.lua")
end

141
142
143
144
145
146
147
148
149
150
151
152
-- qy
option("qy-gpu")
    set_default(false)
    set_showmenu(true)
    set_description("Whether to compile implementations for Qy GPU")
option_end()

if has_config("qy-gpu") then
    add_defines("ENABLE_QY_API")
    includes("xmake/qy.lua")
end

PanZezhongQY's avatar
PanZezhongQY committed
153
154
155
156
-- 沐曦
option("metax-gpu")
    set_default(false)
    set_showmenu(true)
YdrMaster's avatar
YdrMaster committed
157
    set_description("Whether to compile implementations for MetaX GPU")
PanZezhongQY's avatar
PanZezhongQY committed
158
159
option_end()

160
161
162
163
164
165
option("use-mc")
    set_default(false)
    set_showmenu(true)
    set_description("Use MC version")
option_end()

PanZezhongQY's avatar
PanZezhongQY committed
166
if has_config("metax-gpu") then
167
    add_defines("ENABLE_METAX_API")
168
169
170
    if has_config("use-mc") then
        add_defines("ENABLE_METAX_MC_API")
    end
171
    includes("xmake/metax.lua")
PanZezhongQY's avatar
PanZezhongQY committed
172
173
174
175
176
177
end

-- 摩尔线程
option("moore-gpu")
    set_default(false)
    set_showmenu(true)
YdrMaster's avatar
YdrMaster committed
178
    set_description("Whether to compile implementations for Moore Threads GPU")
PanZezhongQY's avatar
PanZezhongQY committed
179
180
option_end()

181
if has_config("moore-gpu") then
182
    add_defines("ENABLE_MOORE_API")
183
    includes("xmake/moore.lua")
184
end
PanZezhongQY's avatar
PanZezhongQY committed
185

186
187
-- 海光DCU
option("hygon-dcu")
PanZezhongQY's avatar
PanZezhongQY committed
188
189
    set_default(false)
    set_showmenu(true)
190
    set_description("Whether to compile implementations for Hygon DCU")
PanZezhongQY's avatar
PanZezhongQY committed
191
192
option_end()

193
194
195
if has_config("hygon-dcu") then
    add_defines("ENABLE_HYGON_API")
    includes("xmake/hygon.lua")
PanZezhongQY's avatar
PanZezhongQY committed
196
197
end

198
199
200
201
202
203
204
205
206
207
208
-- 昆仑芯
option("kunlun-xpu")
    set_default(false)
    set_showmenu(true)
    set_description("Enable or disable Kunlun XPU kernel")
option_end()

if has_config("kunlun-xpu") then
    add_defines("ENABLE_KUNLUN_API")
    includes("xmake/kunlun.lua")
end
PanZezhongQY's avatar
PanZezhongQY committed
209

210
211
212
213
214
215
216
217
218
219
220
-- 九齿
option("ninetoothed")
    set_default(false)
    set_showmenu(true)
    set_description("Whether to complie NineToothed implementations")
option_end()

if has_config("ninetoothed") then
    add_defines("ENABLE_NINETOOTHED")
end

221
222
223
224
225
226
227
228
229
230
231
232
-- cuda graph
option("graph")
    set_default(false)
    set_showmenu(true)
    set_description("Whether to use device graph instantiating feature, such as cuda graph for nvidia")
option_end()

if has_config("graph") then
    add_defines("USE_INFINIRT_GRAPH")
end


233
234
235
236
-- InfiniCCL
option("ccl")
    set_default(false)
    set_showmenu(true)
YdrMaster's avatar
YdrMaster committed
237
    set_description("Wether to compile implementations for InfiniCCL")
238
239
240
241
242
243
option_end()

if has_config("ccl") then
    add_defines("ENABLE_CCL")
end

PanZezhong's avatar
PanZezhong committed
244
245
target("infini-utils")
    set_kind("static")
PanZezhong's avatar
PanZezhong committed
246
    on_install(function (target) end)
PanZezhong's avatar
PanZezhong committed
247
    set_languages("cxx17")
248
249
250
251

    set_warnings("all", "error")

    if is_plat("windows") then
252
        add_cxxflags("/wd4068")
253
        if has_config("omp") then
254
            add_cxxflags("/openmp")
255
256
257
        end
    else
        add_cxflags("-fPIC", "-Wno-unknown-pragmas")
258
        add_cxxflags("-fPIC", "-Wno-unknown-pragmas")
259
        if has_config("omp") then
260
            add_cxxflags("-fopenmp")
PanZezhong's avatar
PanZezhong committed
261
            add_ldflags("-fopenmp", {force = true})
262
263
264
        end
    end

PanZezhong's avatar
PanZezhong committed
265
266
267
    add_files("src/utils/*.cc")
target_end()

268
269
270
271
272
273
274
target("infinirt")
    set_kind("shared")

    if has_config("cpu") then
        add_deps("infinirt-cpu")
    end
    if has_config("nv-gpu") then
275
        add_deps("infinirt-nvidia")
276
    end
277
278
279
    if has_config("cambricon-mlu") then
        add_deps("infinirt-cambricon")
    end
280
281
282
    if has_config("ascend-npu") then
        add_deps("infinirt-ascend")
    end
283
284
285
    if has_config("metax-gpu") then
        add_deps("infinirt-metax")
    end
qinyiqun's avatar
qinyiqun committed
286
287
288
    if has_config("moore-gpu") then
        add_deps("infinirt-moore")
    end
YdrMaster's avatar
YdrMaster committed
289
290
291
    if has_config("iluvatar-gpu") then
        add_deps("infinirt-iluvatar")
    end
wooway777's avatar
wooway777 committed
292
293
294
    if has_config("ali-ppu") then
        add_deps("infinirt-ali")
    end
295
296
297
298
    if has_config("qy-gpu") then
        add_deps("infinirt-qy")
        add_files("build/.objs/infinirt-qy/rules/qy.cuda/src/infinirt/cuda/*.cu.o", {public = true})
    end
zhangyue's avatar
zhangyue committed
299
300
301
    if has_config("kunlun-xpu") then
        add_deps("infinirt-kunlun")
    end
302
303
304
    if has_config("hygon-dcu") then
        add_deps("infinirt-hygon")
    end
305
    set_languages("cxx17")
306
307
    if not is_plat("windows") then
        add_cxflags("-fPIC")
308
        add_cxxflags("-fPIC")
309
    end
310
311
    set_installdir(os.getenv("INFINI_ROOT") or (os.getenv(is_host("windows") and "HOMEPATH" or "HOME") .. "/.infini"))
    add_files("src/infinirt/*.cc")
312
    add_installfiles("include/infinirt.h", {prefixdir = "include"})
313
314
target_end()

PanZezhongQY's avatar
PanZezhongQY committed
315
316
target("infiniop")
    set_kind("shared")
317
318
    add_deps("infinirt")

PanZezhongQY's avatar
PanZezhongQY committed
319
320
321
322
    if has_config("cpu") then
        add_deps("infiniop-cpu")
    end
    if has_config("nv-gpu") then
323
        add_deps("infiniop-nvidia")
PanZezhongQY's avatar
PanZezhongQY committed
324
    end
YdrMaster's avatar
YdrMaster committed
325
326
327
    if has_config("iluvatar-gpu") then
        add_deps("infiniop-iluvatar")
    end
wooway777's avatar
wooway777 committed
328
329
330
    if has_config("ali-ppu") then
        add_deps("infiniop-ali")
    end
331
332
333
    if has_config("qy-gpu") then
        add_deps("infiniop-qy")
        add_files("build/.objs/infiniop-qy/rules/qy.cuda/src/infiniop/ops/*/nvidia/*.cu.o", {public = true})
qinyiqun's avatar
qinyiqun committed
334
        add_files("build/.objs/infiniop-qy/rules/qy.cuda/src/infiniop/ops/*/*/nvidia/*.cu.o", {public = true})
335
336
        add_files("build/.objs/infiniop-qy/rules/qy.cuda/src/infiniop/devices/nvidia/*.cu.o", {public = true})
    end
PanZezhongQY's avatar
PanZezhongQY committed
337
338

    if has_config("cambricon-mlu") then
PanZezhong's avatar
PanZezhong committed
339
        add_deps("infiniop-cambricon")
PanZezhongQY's avatar
PanZezhongQY committed
340
341
    end
    if has_config("ascend-npu") then
Pan Zezhong's avatar
Pan Zezhong committed
342
        add_deps("infiniop-ascend")
PanZezhongQY's avatar
PanZezhongQY committed
343
344
    end
    if has_config("metax-gpu") then
345
        add_deps("infiniop-metax")
PanZezhongQY's avatar
PanZezhongQY committed
346
    end
347
    if has_config("moore-gpu") then
348
        add_deps("infiniop-moore")
349
    end
350
351
352
    if has_config("kunlun-xpu") then
        add_deps("infiniop-kunlun")
    end
353
354
355
    if has_config("hygon-dcu") then
        add_deps("infiniop-hygon")
    end
PanZezhongQY's avatar
PanZezhongQY committed
356
357
    set_languages("cxx17")
    add_files("src/infiniop/devices/handle.cc")
qinyiqun's avatar
qinyiqun committed
358
    add_files("src/infiniop/ops/*/operator.cc", "src/infiniop/ops/*/*/operator.cc")
PanZezhongQY's avatar
PanZezhongQY committed
359
360
361
362
363
364
365
366
    add_files("src/infiniop/*.cc")

    set_installdir(os.getenv("INFINI_ROOT") or (os.getenv(is_host("windows") and "HOMEPATH" or "HOME") .. "/.infini"))
    add_installfiles("include/infiniop/(**/*.h)", {prefixdir = "include/infiniop"})
    add_installfiles("include/infiniop/*.h", {prefixdir = "include/infiniop"})
    add_installfiles("include/infiniop.h", {prefixdir = "include"})
    add_installfiles("include/infinicore.h", {prefixdir = "include"})
target_end()
367

368
369
370
371
372
target("infiniccl")
    set_kind("shared")
    add_deps("infinirt")

    if has_config("nv-gpu") then
373
        add_deps("infiniccl-nvidia")
374
    end
Pan Zezhong's avatar
Pan Zezhong committed
375
376
377
    if has_config("ascend-npu") then
        add_deps("infiniccl-ascend")
    end
wooway777's avatar
wooway777 committed
378
379
380
    if has_config("cambricon-mlu") then
        add_deps("infiniccl-cambricon")
    end
PanZezhong's avatar
PanZezhong committed
381
382
383
    if has_config("metax-gpu") then
        add_deps("infiniccl-metax")
    end
YdrMaster's avatar
YdrMaster committed
384
385
386
    if has_config("iluvatar-gpu") then
        add_deps("infiniccl-iluvatar")
    end
wooway777's avatar
wooway777 committed
387
388
389
    if has_config("ali-ppu") then
        add_deps("infiniccl-ali")
    end
390
391
    if has_config("qy-gpu") then
        add_deps("infiniccl-qy")
392
        add_files("build/.objs/infiniccl-qy/rules/qy.cuda/src/infiniccl/cuda/*.cu.o", {public = true})
393
    end
YdrMaster's avatar
YdrMaster committed
394

spike-zhu's avatar
spike-zhu committed
395
396
397
    if has_config("moore-gpu") then
        add_deps("infiniccl-moore")
    end
398

399
400
401
    if has_config("kunlun-xpu") then
        add_deps("infiniccl-kunlun")
    end
402
403
404
    if has_config("hygon-dcu") then
        add_deps("infiniccl-hygon")
    end
405

406
407
408
409
410
411
412
    set_languages("cxx17")

    add_files("src/infiniccl/*.cc")
    add_installfiles("include/infiniccl.h", {prefixdir = "include"})

    set_installdir(os.getenv("INFINI_ROOT") or (os.getenv(is_host("windows") and "HOMEPATH" or "HOME") .. "/.infini"))
target_end()
413

414
target("infinicore_c_api")
415
    set_kind("phony")
416
    add_deps("infiniop", "infinirt", "infiniccl")
417
418
    after_build(function (target) print(YELLOW .. "[Congratulations!] Now you can install the libraries with \"xmake install\"" .. NC) end)
target_end()
419

420
421
422
423
target("infinicore_cpp_api")
    set_kind("shared")
    add_deps("infiniop", "infinirt", "infiniccl")
    set_languages("cxx17")
424
    set_symbols("visibility")
425
426
427
428
429
430
431
432
433
434
435
436
437
438

    local INFINI_ROOT = os.getenv("INFINI_ROOT") or (os.getenv(is_host("windows") and "HOMEPATH" or "HOME") .. "/.infini")

    add_includedirs("include")
    add_includedirs(INFINI_ROOT.."/include", { public = true })

    add_linkdirs(INFINI_ROOT.."/lib")
    add_links("infiniop", "infinirt", "infiniccl")

    -- Add InfiniCore C++ source files (needed for RoPE and other nn modules)
    add_files("src/infinicore/*.cc")
    add_files("src/infinicore/context/*.cc")
    add_files("src/infinicore/context/*/*.cc")
    add_files("src/infinicore/tensor/*.cc")
439
    add_files("src/infinicore/graph/*.cc")
440
441
    add_files("src/infinicore/nn/*.cc")
    add_files("src/infinicore/ops/*/*.cc")
442
    add_files("src/utils/*.cc")
443
444
445
446
447
448
449
450
451
452
453

    set_installdir(INFINI_ROOT)
    add_installfiles("include/infinicore/(**.h)",    {prefixdir = "include/infinicore"})
    add_installfiles("include/infinicore/(**.hpp)",    {prefixdir = "include/infinicore"})
    add_installfiles("include/infinicore/(**/*.h)",  {prefixdir = "include/infinicore"})
    add_installfiles("include/infinicore/(**/*.hpp)",{prefixdir = "include/infinicore"})
    add_installfiles("include/infinicore.h",          {prefixdir = "include"})
    add_installfiles("include/infinicore.hpp",        {prefixdir = "include"})
    after_build(function (target) print(YELLOW .. "[Congratulations!] Now you can install the libraries with \"xmake install\"" .. NC) end)
target_end()

454
455
456
457
458
459
460
461
462
463
target("_infinicore")
    add_packages("boost")
    if is_mode("debug") then
        add_defines("BOOST_STACKTRACE_USE_BACKTRACE")
        add_links("backtrace")
    else
        add_defines("BOOST_STACKTRACE_USE_NOOP")
    end

    set_default(false)
464
465
    add_rules("python.library", {soabi = true})
    add_packages("pybind11")
466
    set_languages("cxx17")
467

468
469
    add_deps("infinicore_cpp_api")

470
    set_kind("shared")
471
472
473
474
475
    local INFINI_ROOT = os.getenv("INFINI_ROOT") or (os.getenv(is_host("windows") and "HOMEPATH" or "HOME") .. "/.infini")
    add_includedirs(INFINI_ROOT.."/include", { public = true })

    add_linkdirs(INFINI_ROOT.."/lib")
    add_links("infiniop", "infinirt", "infiniccl")
476

477
    add_files("src/infinicore/pybind11/**.cc")
478

479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
    set_installdir("python/infinicore")
target_end()

option("editable")
    set_default(false)
    set_showmenu(true)
    set_description("Install the `infinicore` Python package in editable mode")
option_end()

target("infinicore")
    set_kind("phony")

    set_default(false)

    add_deps("_infinicore")

    on_install(function (target)
        local pip_install_args = {}

        if has_config("editable") then
            table.insert(pip_install_args, "--editable")
        end

        os.execv("python", table.join({"-m", "pip", "install"}, pip_install_args, {"."}))
    end)
504
505
target_end()

506
507
-- Tests
includes("xmake/test.lua")