"qa/L0_jax_distributed_unittest/test.sh" did not exist on "b48403861b651572bdd39e4a17c24f5c0930370a"
setup.py 2.46 KB
Newer Older
1
# Copyright (c) 2022-2025, NVIDIA CORPORATION & AFFILIATES. All rights reserved.
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
#
# See LICENSE for license information.

"""Installation script for TE pytorch extensions."""

# pylint: disable=wrong-import-position,wrong-import-order

import sys
import os
import shutil
from pathlib import Path

import setuptools

try:
17
    from torch.utils.cpp_extension import BuildExtension
18
19
20
21
22
23
24
except ImportError as e:
    raise RuntimeError("This package needs Torch to build.") from e


current_file_path = Path(__file__).parent.resolve()
build_tools_dir = current_file_path.parent.parent / "build_tools"
if bool(int(os.getenv("NVTE_RELEASE_BUILD", "0"))) or os.path.isdir(build_tools_dir):
25
26
27
28
    build_tools_copy = current_file_path / "build_tools"
    if build_tools_copy.exists():
        shutil.rmtree(build_tools_copy)
    shutil.copytree(build_tools_dir, build_tools_copy)
29
30
31


from build_tools.build_ext import get_build_ext
32
from build_tools.utils import copy_common_headers, cuda_toolkit_include_path
33
34
35
36
from build_tools.te_version import te_version
from build_tools.pytorch import setup_pytorch_extension


37
os.environ["NVTE_PROJECT_BUILDING"] = "1"
38
CMakeBuildExtension = get_build_ext(BuildExtension, True)
39
40
41
42
43


if __name__ == "__main__":
    # Extensions
    common_headers_dir = "common_headers"
44
    copy_common_headers(current_file_path.parent, str(current_file_path / common_headers_dir))
45
46
    ext_modules = [
        setup_pytorch_extension(
47
48
49
            "csrc", current_file_path / "csrc", current_file_path / common_headers_dir
        )
    ]
50

51
52
53
54
55
56
57
58
59
60
61
62
63
64
    setup_requires = ["torch>=2.1"]
    if cuda_toolkit_include_path() is None:
        setup_requires.extend(
            [
                "nvidia-cuda-runtime-cu12",
                "nvidia-cublas-cu12",
                "nvidia-cudnn-cu12",
                "nvidia-cuda-cccl-cu12",
                "nvidia-cuda-nvcc-cu12",
                "nvidia-nvtx-cu12",
                "nvidia-cuda-nvrtc-cu12",
            ]
        )

65
66
67
68
69
70
71
    # Configure package
    setuptools.setup(
        name="transformer_engine_torch",
        version=te_version(),
        description="Transformer acceleration library - Torch Lib",
        ext_modules=ext_modules,
        cmdclass={"build_ext": CMakeBuildExtension},
72
        setup_requires=setup_requires,
73
        install_requires=["torch>=2.1"],
74
        tests_require=["numpy", "torchvision"],
75
76
77
    )
    if any(x in sys.argv for x in (".", "sdist", "bdist_wheel")):
        shutil.rmtree(common_headers_dir)
78
        shutil.rmtree("build_tools")