aboutsummaryrefslogtreecommitdiffhomepage
path: root/third_party/gpus
diff options
context:
space:
mode:
authorGravatar A. Unique TensorFlower <gardener@tensorflow.org>2018-03-05 14:31:59 -0800
committerGravatar TensorFlower Gardener <gardener@tensorflow.org>2018-03-05 14:36:16 -0800
commitc79c9512486daa119d3cda9c00bb36acb3933a5b (patch)
treefc03da05e703829330cb7be3397f30b96f5d39f7 /third_party/gpus
parente139cbf91ab416822ce01f5515e9dc230e7294e6 (diff)
Add alternative paths for CUDA installation.
This detects negativo17's CUDA packages for Fedora. PiperOrigin-RevId: 187923472
Diffstat (limited to 'third_party/gpus')
-rw-r--r--third_party/gpus/cuda_configure.bzl177
1 files changed, 124 insertions, 53 deletions
diff --git a/third_party/gpus/cuda_configure.bzl b/third_party/gpus/cuda_configure.bzl
index b7c47a19dd..6c9c128db6 100644
--- a/third_party/gpus/cuda_configure.bzl
+++ b/third_party/gpus/cuda_configure.bzl
@@ -38,6 +38,64 @@ _DEFAULT_CUDA_TOOLKIT_PATH = "/usr/local/cuda"
_DEFAULT_CUDNN_INSTALL_PATH = "/usr/local/cuda"
_DEFAULT_CUDA_COMPUTE_CAPABILITIES = ["3.5", "5.2"]
+# Lookup paths for CUDA / cuDNN libraries, relative to the install directories.
+#
+# Paths will be tried out in the order listed below. The first successful path
+# will be used. For example, when looking for the cudart libraries, the first
+# attempt will be lib64/cudart inside the CUDA toolkit.
+CUDA_LIB_PATHS = [
+ "lib64/",
+ "lib64/stubs/",
+ "lib/x86_64-linux-gnu/",
+ "lib/x64/",
+ "lib/",
+ "",
+]
+
+# Lookup paths for cupti.h, relative to the CUDA toolkit directory.
+#
+# On most systems, the cupti library is not installed in the same directory as
+# the other CUDA libraries but rather in a special extras/CUPTI directory.
+CUPTI_HEADER_PATHS = [
+ "extras/CUPTI/include/",
+ "include/cuda/CUPTI/",
+]
+
+# Lookup paths for the cupti library, relative to the
+#
+# On most systems, the cupti library is not installed in the same directory as
+# the other CUDA libraries but rather in a special extras/CUPTI directory.
+CUPTI_LIB_PATHS = [
+ "extras/CUPTI/lib64/",
+ "lib/x86_64-linux-gnu",
+ "lib64/",
+ "extras/CUPTI/libx64/",
+ "extras/CUPTI/lib/",
+ "lib/",
+]
+
+# Lookup paths for CUDA headers (cuda.h) relative to the CUDA toolkit directory.
+CUDA_INCLUDE_PATHS = [
+ "include/",
+ "include/cuda/"
+]
+
+# Lookup paths for cudnn.h relative to the CUDNN install directory.
+CUDNN_INCLUDE_PATHS = [
+ "",
+ "include/",
+ "include/cuda/",
+]
+
+# Lookup paths for NVVM libdevice relative to the CUDA directory toolkit.
+#
+# libdevice implements mathematical functions for GPU kernels, and is provided
+# in NVVM bitcode (a subset of LLVM bitcode).
+NVVM_LIBDEVICE_PATHS = [
+ "nvvm/libdevice/",
+ "share/cuda/",
+]
+
load(":download_clang.bzl", "download_clang")
# TODO(dzc): Once these functions have been factored out of Bazel's
@@ -522,31 +580,31 @@ def _find_cuda_lib(lib, repository_ctx, cpu_value, basedir, version="",
path: The full path to the library.
"""
file_name = _lib_name(lib, cpu_value, version, static)
- if cpu_value == "Linux":
- path = repository_ctx.path("%s/lib64/%s" % (basedir, file_name))
- if path.exists:
- return struct(file_name=file_name, path=str(path.realpath))
- path = repository_ctx.path("%s/lib64/stubs/%s" % (basedir, file_name))
- if path.exists:
- return struct(file_name=file_name, path=str(path.realpath))
- path = repository_ctx.path(
- "%s/lib/x86_64-linux-gnu/%s" % (basedir, file_name))
+ for relative_path in CUDA_LIB_PATHS:
+ path = repository_ctx.path("%s/%s%s" % (basedir, relative_path, file_name))
if path.exists:
return struct(file_name=file_name, path=str(path.realpath))
+ auto_configure_fail("Cannot find cuda library %s" % file_name)
- elif cpu_value == "Windows":
- path = repository_ctx.path("%s/lib/x64/%s" % (basedir, file_name))
- if path.exists:
- return struct(file_name=file_name, path=str(path.realpath))
- path = repository_ctx.path("%s/lib/%s" % (basedir, file_name))
- if path.exists:
- return struct(file_name=file_name, path=str(path.realpath))
- path = repository_ctx.path("%s/%s" % (basedir, file_name))
- if path.exists:
- return struct(file_name=file_name, path=str(path.realpath))
+def _find_cupti_header_dir(repository_ctx, cuda_config):
+ """Returns the path to the directory containing cupti.h
- auto_configure_fail("Cannot find cuda library %s" % file_name)
+ On most systems, the cupti library is not installed in the same directory as
+ the other CUDA libraries but rather in a special extras/CUPTI directory.
+
+ Args:
+ repository_ctx: The repository context.
+ cuda_config: The CUDA config as returned by _get_cuda_config
+
+ Returns:
+ The path of the directory containing the cupti header.
+ """
+ cuda_toolkit_path = cuda_config.cuda_toolkit_path
+ for relative_path in CUPTI_HEADER_PATHS:
+ if repository_ctx.path("%s/%scupti.h" % (cuda_toolkit_path, relative_path)).exists:
+ return ("%s/%s" % (cuda_toolkit_path, relative_path))[:-1]
+ auto_configure_fail("Cannot find cupti.h under %s" % cuda_toolkit_path)
def _find_cupti_lib(repository_ctx, cuda_config):
@@ -566,35 +624,13 @@ def _find_cupti_lib(repository_ctx, cuda_config):
"""
file_name = _lib_name("cupti", cuda_config.cpu_value,
cuda_config.cuda_version)
- if cuda_config.cpu_value == "Linux":
- path = repository_ctx.path(
- "%s/extras/CUPTI/lib64/%s" % (cuda_config.cuda_toolkit_path, file_name))
- if path.exists:
- return struct(file_name=file_name, path=str(path.realpath))
-
- path = repository_ctx.path(
- "%s/lib/x86_64-linux-gnu/%s" % (cuda_config.cuda_toolkit_path,
- file_name))
- if path.exists:
- return struct(file_name=file_name, path=str(path.realpath))
-
- elif cuda_config.cpu_value == "Windows":
+ cuda_toolkit_path = cuda_config.cuda_toolkit_path
+ for relative_path in CUPTI_LIB_PATHS:
path = repository_ctx.path(
- "%s/extras/CUPTI/libx64/%s" %
- (cuda_config.cuda_toolkit_path, file_name))
+ "%s/%s%s" % (cuda_toolkit_path, relative_path, file_name))
if path.exists:
return struct(file_name=file_name, path=str(path.realpath))
- path = repository_ctx.path(
- "%s/extras/CUPTI/lib/%s" % (cuda_config.cuda_toolkit_path, file_name))
- if path.exists:
- return struct(file_name=file_name, path=str(path.realpath))
-
- path = repository_ctx.path(
- "%s/lib/%s" % (cuda_config.cuda_toolkit_path, file_name))
- if path.exists:
- return struct(file_name=file_name, path=str(path.realpath))
-
auto_configure_fail("Cannot find cupti library %s" % file_name)
def _find_libs(repository_ctx, cuda_config):
@@ -635,6 +671,23 @@ def _find_libs(repository_ctx, cuda_config):
}
+def _find_cuda_include_path(repository_ctx, cuda_config):
+ """Returns the path to the directory containing cuda.h
+
+ Args:
+ repository_ctx: The repository context.
+ cuda_config: The CUDA config as returned by _get_cuda_config
+
+ Returns:
+ The path of the directory containing the CUDA headers.
+ """
+ cuda_toolkit_path = cuda_config.cuda_toolkit_path
+ for relative_path in CUDA_INCLUDE_PATHS:
+ if repository_ctx.path("%s/%scuda.h" % (cuda_toolkit_path, relative_path)).exists:
+ return ("%s/%s" % (cuda_toolkit_path, relative_path))[:-1]
+ auto_configure_fail("Cannot find cuda.h under %s" % cuda_toolkit_path)
+
+
def _find_cudnn_header_dir(repository_ctx, cudnn_install_basedir):
"""Returns the path to the directory containing cudnn.h
@@ -646,15 +699,31 @@ def _find_cudnn_header_dir(repository_ctx, cudnn_install_basedir):
Returns:
The path of the directory containing the cudnn header.
"""
- if repository_ctx.path(cudnn_install_basedir + "/cudnn.h").exists:
- return cudnn_install_basedir
- if repository_ctx.path(cudnn_install_basedir + "/include/cudnn.h").exists:
- return cudnn_install_basedir + "/include"
+ for relative_path in CUDA_INCLUDE_PATHS:
+ if repository_ctx.path("%s/%scudnn.h" % (cudnn_install_basedir, relative_path)).exists:
+ return ("%s/%s" % (cudnn_install_basedir, relative_path))[:-1]
if repository_ctx.path("/usr/include/cudnn.h").exists:
return "/usr/include"
auto_configure_fail("Cannot find cudnn.h under %s" % cudnn_install_basedir)
+def _find_nvvm_libdevice_dir(repository_ctx, cuda_config):
+ """Returns the path to the directory containing libdevice in bitcode format.
+
+ Args:
+ repository_ctx: The repository context.
+ cuda_config: The CUDA config as returned by _get_cuda_config
+
+ Returns:
+ The path of the directory containing the CUDA headers.
+ """
+ cuda_toolkit_path = cuda_config.cuda_toolkit_path
+ for relative_path in NVVM_LIBDEVICE_PATHS:
+ if repository_ctx.path("%s/%slibdevice.10.bc" % (cuda_toolkit_path, relative_path)).exists:
+ return ("%s/%s" % (cuda_toolkit_path, relative_path))[:-1]
+ auto_configure_fail("Cannot find libdevice.10.bc under %s" % cuda_toolkit_path)
+
+
def _cudart_static_linkopt(cpu_value):
"""Returns additional platform-specific linkopts for cudart."""
return "" if cpu_value == "Darwin" else "\"-lrt\","
@@ -925,21 +994,22 @@ def _create_local_cuda_repository(repository_ctx):
"""Creates the repository containing files set up to build with CUDA."""
cuda_config = _get_cuda_config(repository_ctx)
+ cuda_include_path = _find_cuda_include_path(repository_ctx, cuda_config)
cudnn_header_dir = _find_cudnn_header_dir(repository_ctx,
cuda_config.cudnn_install_basedir)
+ cupti_header_dir = _find_cupti_header_dir(repository_ctx, cuda_config)
+ nvvm_libdevice_dir = _find_nvvm_libdevice_dir(repository_ctx, cuda_config)
# Set up symbolic links for the cuda toolkit by creating genrules to do
# symlinking. We create one genrule for each directory we want to track under
# cuda_toolkit_path
cuda_toolkit_path = cuda_config.cuda_toolkit_path
- cuda_include_path = cuda_toolkit_path + "/include"
genrules = [symlink_genrule_for_dir(repository_ctx,
cuda_include_path, "cuda/include", "cuda-include")]
genrules.append(symlink_genrule_for_dir(repository_ctx,
- cuda_toolkit_path + "/nvvm", "cuda/nvvm", "cuda-nvvm"))
+ nvvm_libdevice_dir, "cuda/nvvm/libdevice", "cuda-nvvm"))
genrules.append(symlink_genrule_for_dir(repository_ctx,
- cuda_toolkit_path + "/extras/CUPTI/include",
- "cuda/extras/CUPTI/include", "cuda-extras"))
+ cupti_header_dir, "cuda/extras/CUPTI/include", "cuda-extras"))
cuda_libs = _find_libs(repository_ctx, cuda_config)
cuda_lib_src = []
@@ -1086,6 +1156,7 @@ cuda_configure = repository_rule(
_TF_CUDNN_VERSION,
_TF_CUDA_COMPUTE_CAPABILITIES,
_TF_CUDA_CONFIG_REPO,
+ "NVVMIR_LIBRARY_DIR",
],
)