pyproject.toml 7.48 KB
Newer Older
1
2
3
[project]
name = "tilelang"
description = "A tile level programming language to generate high performance code."
4
readme = "README.md"
5
requires-python = ">=3.9"
6
7
authors = [{ name = "TileLang Contributors" }, { name = "Tile-AI" }]
maintainers = [{ name = "Lei Wang", email = "leiwang1999@outlook.com" }]
8
9
10
license = "MIT"
keywords = ["BLAS", "CUDA", "HIP", "Code Generation", "TVM"]
classifiers = [
11
    "Development Status :: 4 - Beta",
12
13
14
    "Environment :: GPU",
    "Operating System :: POSIX :: Linux",
    "Operating System :: MacOS",
15
16
    "Programming Language :: C++",
    "Programming Language :: Python :: 3",
17
18
19
20
    "Programming Language :: Python :: 3.9",
    "Programming Language :: Python :: 3.10",
    "Programming Language :: Python :: 3.11",
    "Programming Language :: Python :: 3.12",
21
22
23
    "Programming Language :: Python :: 3.13",
    "Programming Language :: Python :: 3.14",
    "Programming Language :: Python :: Implementation :: CPython",
24
25
    "Intended Audience :: Developers",
    "Intended Audience :: Science/Research",
26
    "Topic :: Scientific/Engineering :: Artificial Intelligence",
27
28
29
]
dynamic = ["version"]
dependencies = [
30
31
32
33
    "apache-tvm-ffi~=0.1.0",
    # Extra constraint to tvm-ffi for abi issue,
    # should be removed after our tvm's update.
    # See discussion in tilelang#1373 and apache/tvm-ffi#307
34
    "apache-tvm-ffi>=0.1.2",
35
36
37
    # torch-c-dlpack-ext provides prebuilt torch extensions.
    # Without it, TVM FFI may require JIT compilation on first import.
    "torch-c-dlpack-ext",
38
    "cloudpickle",
39
40
    "ml-dtypes",
    "numpy>=1.23.5",
41
42
    "psutil",
    "torch",
43
44
45
    "torch>=2.7; platform_system == 'Darwin'",
    "tqdm>=4.62.3",
    "typing-extensions>=4.10.0",
46
47
48
49
50
]

[project.optional-dependencies]
# mldtypes should be greater than 0.5.1
# if you want to enable fp4
51
fp4 = ["ml-dtypes>=0.5.1"]
52
53
# if you want to enable layout inference visualization
vis = ["matplotlib"]
54

55
[build-system]
56
requires = ["cython>=3.0.0", "scikit-build-core"]
57
58
59
60
61
62
63
64
65
66
67
68
69
70
build-backend = "scikit_build_core.build"

[tool.scikit-build]
wheel.py-api = "cp38"
cmake.version = ">=3.26.1"
build-dir = "build"

# editable.rebuild = true

# Include backend and git info in version
metadata.version.provider = "version_provider"
metadata.version.provider-path = "."
experimental = true

71
72
73
# build.verbose = true
# logging.level = "DEBUG"

74
75
[tool.scikit-build.sdist]
include = [
76
77
78
    "./VERSION",
    ".git_commit.txt",
    "./LICENSE",
79
80
81
82
83
84
85
    "THIRDPARTYNOTICES.txt",
    "version_provider.py",
    "requirements*.txt",
    "tilelang/jit/adapter/cython/cython_wrapper.pyx",
    "CMakeLists.txt",
    "src/**",
    "cmake/**",
86
87
88
89
90
91
92
93
94
    # The vendored 3rdparty contents in sdist should be same as wheel.
    # Need full TVM to build from source.
    "3rdparty/tvm",
    # CUTLASS
    "3rdparty/cutlass/include",
    "3rdparty/cutlass/tools",
    # Composable Kernel
    "3rdparty/composable_kernel/include",
    "3rdparty/composable_kernel/library",
95
96
97
98
99
100
101
102
    "testing/**",
    "examples/**",
]
exclude = [
    ".git",
    ".github",
    "**/.git",
    "**/.github",
103
    "3rdparty/**",
104
105
106
    "build",
]

107
108
109
[tool.scikit-build.wheel.packages]
tilelang = "tilelang"
"tilelang/src" = "src"
110
111
# NOTE: The mapping below places the contents of '3rdparty' inside 'tilelang/3rdparty' in the wheel.
# This is necessary to find TVM shared libraries at runtime.
112
# The vendored 3rdparty contents in wheel should be same as sdist.
113
114
115
# TVM
"tilelang/3rdparty/tvm/src" = "3rdparty/tvm/src"
"tilelang/3rdparty/tvm/python" = "3rdparty/tvm/python"
116
"tilelang/3rdparty/tvm/include" = "3rdparty/tvm/include"
117
118
119
120
121
122
123
"tilelang/3rdparty/tvm/version.py" = "3rdparty/tvm/version.py"
# CUTLASS
"tilelang/3rdparty/cutlass/include" = "3rdparty/cutlass/include"
"tilelang/3rdparty/cutlass/tools" = "3rdparty/cutlass/tools"
# Composable Kernel
"tilelang/3rdparty/composable_kernel/include" = "3rdparty/composable_kernel/include"
"tilelang/3rdparty/composable_kernel/library" = "3rdparty/composable_kernel/library"
124

125
126
127
128
129
130
[tool.yapf]
based_on_style = "yapf"
column_limit = 100
indent_width = 4

[tool.codespell]
131
ignore-words = "docs/spelling_wordlist.txt"
132
133
134
135
136
137
138
skip = [
    "build",
    "3rdparty",
    "dist",
    ".venv"
]

139
[tool.ruff]
140
target-version = "py39"
141
142
143
line-length = 100
output-format = "full"

144
145
146
147
148
149
150
151
152
153
154
exclude = [
    "3rdparty",
    "examples/deepseek_v32/inference",
]

[tool.ruff.lint.per-file-ignores]
# Do not upgrade type hint in testing and examples.
# See https://github.com/tile-ai/tilelang/issues/1079 for more information.
"testing/**.py" = ["UP", "FA"]
"examples/**.py" = ["UP", "FA"]

155
156
157
[tool.ruff.lint]
select = [
    # pycodestyle
158
    "E", "W",
159
160
161
    # Pyflakes
    "F",
    # pyupgrade
162
    "UP", "FA",
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
    # flake8-bugbear
    "B",
    # flake8-simplify
    "SIM",
    # isort
    # "I",
]
ignore = [
    # Module level import not at top of file
    "E402",
    # star imports
    "F405", "F403",
    # ambiguous name
    "E741",
    # line too long
    "E501",
179
180
    # if-else-block instead of ternary
    "SIM108",
181
182
    # key in dict.keys()
    "SIM118",
183
184
    # open file w.o. ctx manager
    "SIM115",
185
186
    # memory leaks
    "B019",
187
188
    # zip without explicit strict
    "B905",
189
190
191
    # No such file or directory
    "E902",
]
192

193
194
195
196
[tool.pytest.ini_options]
verbosity_assertions = 3
filterwarnings = ["always"]

197
198
[tool.cibuildwheel]
archs = ["auto64"]
199
200
201
202
203
skip = "*musllinux*"
build-frontend = "build"
environment = { PYTHONDEVMODE = "1", PYTHONUNBUFFERED = "1" }
environment-pass = [
    "CUDA_VERSION",
204
205
206
    "NO_VERSION_LABEL",
    "NO_TOOLCHAIN_VERSION",
    "NO_GIT_VERSION",
207
    "COLUMNS",
208
209
    "CMAKE_GENERATOR",
    "CMAKE_BUILD_PARALLEL_LEVEL",
210
211
212
213
214
    "FORCE_COLOR",
    "CLICOLOR_FORCE",
]
before-build = "env -0 | sort -z | tr '\\0' '\\n'"
windows.before-build = "set"
215
216
217
test-command = [
    "python -c 'import tilelang; print(tilelang.__version__)'",
]
218
219

[tool.cibuildwheel.linux]
220
221
222
223
environment.PYTHONDEVMODE = "1"
environment.PYTHONUNBUFFERED = "1"
environment.PATH = "/usr/local/cuda/bin:$PATH"
environment.LD_LIBRARY_PATH = "/usr/local/cuda/lib64:/usr/local/cuda/lib64/stubs:$LD_LIBRARY_PATH"
224
225
manylinux-x86_64-image  = "manylinux_2_28"  # AlmaLinux 8
manylinux-aarch64-image = "manylinux_2_28"  # AlmaLinux 8
226
# Install CUDA runtime and stub driver library
227
# manylinux_2_28 uses gcc 14, which needs CUDA >=12.8
228
229
230
before-all = """
set -eux

231
232
233
cat /etc/*-release
uname -a

234
case "$(uname -m)" in
235
    "x86_64")
236
237
        DEFAULT_CUDA_VERSION="12.8"
        dnf config-manager --add-repo https://developer.download.nvidia.cn/compute/cuda/repos/rhel8/x86_64/cuda-rhel8.repo
238
239
        ;;
    "aarch64")
240
        DEFAULT_CUDA_VERSION="12.8"
241
242
243
244
245
        dnf config-manager --add-repo https://developer.download.nvidia.com/compute/cuda/repos/rhel8/sbsa/cuda-rhel8.repo
        ;;
    *)
        exit 1
        ;;
246
247
esac

248
cudaver="$(echo "${CUDA_VERSION:-$DEFAULT_CUDA_VERSION}" | cut -d '.' -f-2)"
249
v="${cudaver//./-}"
250
yum install -y "cuda-minimal-build-${v}" "cuda-driver-devel-${v}" "cuda-nvrtc-devel-${v}" nvidia-driver-cuda-libs
251
yum clean all
252
"""
253
254
255
256
257
258
259
260
261
262
263
264
265
repair-wheel-command = [
    "auditwheel -v repair --exclude libtvm_ffi.so --exclude libcuda.so.1 --exclude '/usr/local/cuda*' -w {dest_dir} {wheel}",
    "pipx run abi3audit --verbose --strict {wheel}",
]

[tool.cibuildwheel.macos]
repair-wheel-command = [
    "delocate-wheel --verbose --ignore-missing-dependencies --no-sanitize-rpaths --require-archs {delocate_archs} -w {dest_dir} -v {wheel}",
    "pipx run abi3audit --verbose --strict {wheel}",
]

[[tool.cibuildwheel.overrides]]
select = "*linux*x86_64*"
266
267
268
269
# x86_64 runners in GitHub Actions have limited storage,
# pre-install torch without caching to reduce disk usage during install tilelang.
before-test = [
    "pip install torch --no-cache-dir",
270
]