xmake.lua 14.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
184
185
186
187
188
option("moore-gpu-arch")
    set_default("mp_31")
    set_showmenu(true)
    set_description("Set Moore GPU architecture (e.g. mp_31)")
option_end()

189
if has_config("moore-gpu") then
190
    add_defines("ENABLE_MOORE_API")
191
    includes("xmake/moore.lua")
192
end
PanZezhongQY's avatar
PanZezhongQY committed
193

194
195
-- 海光DCU
option("hygon-dcu")
PanZezhongQY's avatar
PanZezhongQY committed
196
197
    set_default(false)
    set_showmenu(true)
198
    set_description("Whether to compile implementations for Hygon DCU")
PanZezhongQY's avatar
PanZezhongQY committed
199
200
option_end()

201
202
203
if has_config("hygon-dcu") then
    add_defines("ENABLE_HYGON_API")
    includes("xmake/hygon.lua")
PanZezhongQY's avatar
PanZezhongQY committed
204
205
end

206
207
208
209
210
211
212
213
214
215
216
-- 昆仑芯
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
217

218
219
220
221
222
223
224
225
226
227
228
-- 九齿
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

229
230
231
232
233
234
235
236
237
238
239
240
-- 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


241
242
243
244
-- InfiniCCL
option("ccl")
    set_default(false)
    set_showmenu(true)
YdrMaster's avatar
YdrMaster committed
245
    set_description("Wether to compile implementations for InfiniCCL")
246
247
248
249
250
251
option_end()

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

PanZezhong's avatar
PanZezhong committed
252
253
target("infini-utils")
    set_kind("static")
PanZezhong's avatar
PanZezhong committed
254
    on_install(function (target) end)
PanZezhong's avatar
PanZezhong committed
255
    set_languages("cxx17")
256
257
258
259

    set_warnings("all", "error")

    if is_plat("windows") then
260
        add_cxxflags("/wd4068")
261
        if has_config("omp") then
262
            add_cxxflags("/openmp")
263
264
265
        end
    else
        add_cxflags("-fPIC", "-Wno-unknown-pragmas")
266
        add_cxxflags("-fPIC", "-Wno-unknown-pragmas")
267
        if has_config("omp") then
268
            add_cxxflags("-fopenmp")
PanZezhong's avatar
PanZezhong committed
269
            add_ldflags("-fopenmp", {force = true})
270
271
272
        end
    end

PanZezhong's avatar
PanZezhong committed
273
274
275
    add_files("src/utils/*.cc")
target_end()

276
277
278
279
280
281
282
target("infinirt")
    set_kind("shared")

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

PanZezhongQY's avatar
PanZezhongQY committed
323
324
target("infiniop")
    set_kind("shared")
325
326
    add_deps("infinirt")

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

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

376
377
378
379
380
target("infiniccl")
    set_kind("shared")
    add_deps("infinirt")

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

spike-zhu's avatar
spike-zhu committed
403
404
405
    if has_config("moore-gpu") then
        add_deps("infiniccl-moore")
    end
406

407
408
409
    if has_config("kunlun-xpu") then
        add_deps("infiniccl-kunlun")
    end
410
411
412
    if has_config("hygon-dcu") then
        add_deps("infiniccl-hygon")
    end
413

414
415
416
417
418
419
420
    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()
421

422
target("infinicore_c_api")
423
    set_kind("phony")
424
    add_deps("infiniop", "infinirt", "infiniccl")
425
426
    after_build(function (target) print(YELLOW .. "[Congratulations!] Now you can install the libraries with \"xmake install\"" .. NC) end)
target_end()
427

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

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

442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
    -- ==============================
    -- LibTorch integration
    -- ==============================
    local LIBTORCH_ROOT = ("/home/panzezhong/.conda/envs/myenv/lib/python3.13/site-packages/torch")

    -- headers
    add_includedirs(
        path.join(LIBTORCH_ROOT, "include"),
        path.join(LIBTORCH_ROOT, "include/torch/csrc/api/include"),
        { public = true }
    )

    -- libraries
    add_linkdirs(path.join(LIBTORCH_ROOT, "lib"))

    -- core ATen / Torch libs
    add_links(
        "torch",
        "c10",
        "torch_cuda",
        "c10_cuda"
    )
    -- Flash attention lib
    add_linkdirs("/home/panzezhong/Projects/InfiniCore/third_party/flash-attention/csrc/build")
    add_links("flash_attn")

468
469
    -- Add InfiniCore C++ source files (needed for RoPE and other nn modules)
    add_files("src/infinicore/*.cc")
470
    add_files("src/infinicore/adaptor/*.cc")
471
472
473
    add_files("src/infinicore/context/*.cc")
    add_files("src/infinicore/context/*/*.cc")
    add_files("src/infinicore/tensor/*.cc")
474
    add_files("src/infinicore/graph/*.cc")
475
476
    add_files("src/infinicore/nn/*.cc")
    add_files("src/infinicore/ops/*/*.cc")
477
    add_files("src/utils/*.cc")
478
479
480
481
482
483
484
485
486
487
488

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

489
490
491
492
493
494
495
496
497
498
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)
499
500
    add_rules("python.library", {soabi = true})
    add_packages("pybind11")
501
    set_languages("cxx17")
502

503
504
    add_deps("infinicore_cpp_api")

505
    set_kind("shared")
506
507
508
509
510
    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")
511

512
    add_files("src/infinicore/pybind11/**.cc")
513

514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
    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)
539
540
target_end()

541
542
-- Tests
includes("xmake/test.lua")