Files
pytorch/tools/setup_helpers/cuda.py
Hong Xu 081069e8ca Remove CUDA_VERSION from Python script (which has already been detected in CMake) (#27316)
Summary:
(Intentionally left blank)
Pull Request resolved: https://github.com/pytorch/pytorch/pull/27316

Differential Revision: D17762715

Pulled By: ezyang

fbshipit-source-id: 044c0ea6e8c2d12912c946a9a50b934b5253d8c8
2019-10-04 07:49:57 -07:00

45 lines
1.3 KiB
Python

import os
import glob
import ctypes.util
from . import which
from .env import IS_WINDOWS, IS_LINUX, IS_DARWIN, check_negative_env_flag
LINUX_HOME = '/usr/local/cuda'
WINDOWS_HOME = glob.glob('C:/Program Files/NVIDIA GPU Computing Toolkit/CUDA/v*.*')
def find_nvcc():
nvcc = which('nvcc')
if nvcc is not None:
return os.path.dirname(nvcc)
else:
return None
if check_negative_env_flag('USE_CUDA'):
USE_CUDA = False
CUDA_HOME = None
else:
if IS_LINUX or IS_DARWIN:
CUDA_HOME = os.getenv('CUDA_HOME', LINUX_HOME)
else:
CUDA_HOME = os.getenv('CUDA_PATH', '').replace('\\', '/')
if CUDA_HOME == '' and len(WINDOWS_HOME) > 0:
CUDA_HOME = WINDOWS_HOME[0].replace('\\', '/')
if not os.path.exists(CUDA_HOME):
# We use nvcc path on Linux and cudart path on macOS
if IS_LINUX or IS_WINDOWS:
cuda_path = find_nvcc()
else:
cudart_path = ctypes.util.find_library('cudart')
if cudart_path is not None:
cuda_path = os.path.dirname(cudart_path)
else:
cuda_path = None
if cuda_path is not None:
CUDA_HOME = os.path.dirname(cuda_path)
else:
CUDA_HOME = None
USE_CUDA = CUDA_HOME is not None