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
option("iluvatar_arch")
    set_default("ivcore20")
120
    set_showmenu(true)
121
122
123
    set_description("Set Iluvatar GPU architecture (e.g. ivcore20)")
    set_values("ivcore20")
    set_category("option")
124
125
option_end()

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

wooway777's avatar
wooway777 committed
131
132
133
134
135
136
137
138
139
140
141
142
-- 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

143
144
145
146
147
148
149
150
151
152
153
154
-- 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
155
156
157
158
-- 沐曦
option("metax-gpu")
    set_default(false)
    set_showmenu(true)
YdrMaster's avatar
YdrMaster committed
159
    set_description("Whether to compile implementations for MetaX GPU")
PanZezhongQY's avatar
PanZezhongQY committed
160
161
option_end()

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

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

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

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

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

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

200
201
202
203
204
205
206
207
208
209
210
-- 昆仑芯
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
211

212
213
214
215
216
217
218
219
220
221
222
-- 九齿
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

223
224
225
226
227
228
229
230
231
232
233
234
-- 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


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

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

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

    set_warnings("all", "error")

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

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

270
271
272
273
274
275
276
target("infinirt")
    set_kind("shared")

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

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

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

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

370
371
372
373
374
target("infiniccl")
    set_kind("shared")
    add_deps("infinirt")

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

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

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

408
409
410
411
412
413
414
    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()
415

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

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

    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")
441
    add_files("src/infinicore/graph/*.cc")
442
443
    add_files("src/infinicore/nn/*.cc")
    add_files("src/infinicore/ops/*/*.cc")
444
    add_files("src/utils/*.cc")
445
446
447
448
449
450
451
452
453
454
455

    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()

456
457
458
459
460
461
462
463
464
465
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)
466
467
    add_rules("python.library", {soabi = true})
    add_packages("pybind11")
468
    set_languages("cxx17")
469

470
471
    add_deps("infinicore_cpp_api")

472
    set_kind("shared")
473
474
475
476
477
    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")
478

479
    add_files("src/infinicore/pybind11/**.cc")
480

481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
    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)
506
507
target_end()

508
509
-- Tests
includes("xmake/test.lua")