Rule Authoring
actions.compile
load("@rules_cuda_docs//:developer_docs.bzl", "actions") actions.compile(ctx, cuda_toolchain, cc_toolchain, srcs, common, pic, rdc, _prefix)
Perform CUDA compilation, return compiled object files.
Notes:
- If
rdc
is set toTrue
, then an additional step of device link must be performed. - The rules should call this action only once in case srcs have non-unique basenames,
say
foo/kernel.cu
andbar/kernel.cu
.
PARAMETERS
Name | Description | Default Value |
---|---|---|
ctx | A context object. | none |
cuda_toolchain | A platform_common.ToolchainInfo of a cuda toolchain, Can be obtained with find_cuda_toolchain(ctx) . |
none |
cc_toolchain | A CcToolchainInfo . Can be obtained with find_cpp_toolchain(ctx) . |
none |
srcs | A list of File s to be compiled. |
none |
common | A cuda common object. Can be obtained with cuda_helper.create_common(ctx) |
none |
pic | Whether the srcs are compiled for position independent code. |
False |
rdc | Whether the srcs are compiled for relocatable device code. |
False |
_prefix | DON'T USE IT! Prefix of the output dir. Exposed for device link to redirect the output. | "_objs" |
RETURNS
An compiled object File
.
actions.device_link
load("@rules_cuda_docs//:developer_docs.bzl", "actions") actions.device_link(ctx, cuda_toolchain, cc_toolchain, objects, common, pic, rdc, dlto)
Perform device link, return a dlink-ed object file.
Notes:
Compilation is carried out during device linking, which involves the embeeding of the fatbin into the resulting object File
.
PARAMETERS
Name | Description | Default Value |
---|---|---|
ctx | A context object. | none |
cuda_toolchain | A platform_common.ToolchainInfo of a cuda toolchain, Can be obtained with find_cuda_toolchain(ctx) . |
none |
cc_toolchain | A CcToolchainInfo . Can be obtained with find_cpp_toolchain(ctx) . |
none |
objects | A depset of File s to be device linked. |
none |
common | A cuda common object. Can be obtained with cuda_helper.create_common(ctx) |
none |
pic | Whether the objects are compiled for position independent code. |
False |
rdc | Whether the objects are device linked for relocatable device code. |
False |
dlto | Whether the device link time optimization is enabled. | False |
RETURNS
An deviced linked object File
.
config_helper.action_is_enabled
load("@rules_cuda_docs//:developer_docs.bzl", "config_helper") config_helper.action_is_enabled(info, name)
Returns whether a selectable is enable or not.
PARAMETERS
Name | Description | Default Value |
---|---|---|
info | A _FeatureConfigurationInfo , returned by configure_features , to be queried. |
none |
name | Name of the selectable, that is, an action_config or a feature . |
none |
config_helper.collect_selectables_info
load("@rules_cuda_docs//:developer_docs.bzl", "config_helper") config_helper.collect_selectables_info(selectables)
Constructor of _SelectablesInfo
.
PARAMETERS
Name | Description | Default Value |
---|---|---|
selectables | List of action_config s and/or feature s. |
none |
config_helper.configure_features
load("@rules_cuda_docs//:developer_docs.bzl", "config_helper") config_helper.configure_features(selectables, selectables_info, requested_features, unsupported_features, _debug)
Constructor of _FeatureConfigurationInfo
.
PARAMETERS
config_helper.get_artifact_name
load("@rules_cuda_docs//:developer_docs.bzl", "config_helper") config_helper.get_artifact_name(artifact_name_patterns, category_name, basename)
Returns artifact_name in form of prefix + basename + extension
.
PARAMETERS
Name | Description | Default Value |
---|---|---|
artifact_name_patterns | A list of artifact_name_pattern . |
none |
category_name | A string match the category_name field in artifact_name_pattern . |
none |
basename | A string. | none |
config_helper.get_command_line
load("@rules_cuda_docs//:developer_docs.bzl", "config_helper") config_helper.get_command_line(info, action, value)
Returns flattened command line flags for given action, using given variables for expansion.
PARAMETERS
config_helper.get_default_features_and_action_configs
load("@rules_cuda_docs//:developer_docs.bzl", "config_helper") config_helper.get_default_features_and_action_configs(info)
Get all default enabled features and action configs.
Notes: For testing purpose. Default enabled maybe disabled after configuration.
PARAMETERS
Name | Description | Default Value |
---|---|---|
info | A _FeatureConfigurationInfo , returned by configure_features , to be queried. |
none |
config_helper.get_enabled_feature
load("@rules_cuda_docs//:developer_docs.bzl", "config_helper") config_helper.get_enabled_feature(info)
Get all enabled features.
Notes: For testing purpose.
PARAMETERS
Name | Description | Default Value |
---|---|---|
info | A _FeatureConfigurationInfo , returned by configure_features , to be queried. |
none |
config_helper.get_environment_variables
load("@rules_cuda_docs//:developer_docs.bzl", "config_helper") config_helper.get_environment_variables(info, action, value)
Returns environment variables to be set for the given action.
PARAMETERS
config_helper.get_tool_for_action
load("@rules_cuda_docs//:developer_docs.bzl", "config_helper") config_helper.get_tool_for_action(info, action_name)
Returns tool path for given action.
PARAMETERS
Name | Description | Default Value |
---|---|---|
info | A _FeatureConfigurationInfo , returned by configure_features , to be queried. |
none |
action_name | Name of the action. | none |
config_helper.is_configured
load("@rules_cuda_docs//:developer_docs.bzl", "config_helper") config_helper.is_configured(selectables_info, name)
Whether an action or a feature exists
PARAMETERS
Name | Description | Default Value |
---|---|---|
selectables_info | The _SelectablesInfo returned from _collect_selectables_info |
none |
name | Name of the selectable, that is, an action_config or a feature . |
none |
config_helper.is_enabled
Returns whether a selectable is enable or not.
PARAMETERS
Name | Description | Default Value |
---|---|---|
info | A _FeatureConfigurationInfo , returned by configure_features , to be queried. |
none |
name | Name of the selectable, that is, an action_config or a feature . |
none |
cuda_helper.action_is_enabled
load("@rules_cuda_docs//:developer_docs.bzl", "cuda_helper") cuda_helper.action_is_enabled(info, name)
Returns whether a selectable is enable or not.
PARAMETERS
Name | Description | Default Value |
---|---|---|
info | A _FeatureConfigurationInfo , returned by configure_features , to be queried. |
none |
name | Name of the selectable, that is, an action_config or a feature . |
none |
cuda_helper.check_must_enforce_rdc
load("@rules_cuda_docs//:developer_docs.bzl", "cuda_helper") cuda_helper.check_must_enforce_rdc(arch_specs, cuda_archs_info)
Force enable rdc if dlto is enabled.
PARAMETERS
Name | Description | Default Value |
---|---|---|
arch_specs | - |
None |
cuda_archs_info | - |
None |
cuda_helper.check_srcs_extensions
load("@rules_cuda_docs//:developer_docs.bzl", "cuda_helper") cuda_helper.check_srcs_extensions(ctx, allowed_src_files, rule_name)
Ensure ctx.attr.srcs is valid.
PARAMETERS
Name | Description | Default Value |
---|---|---|
ctx | - |
none |
allowed_src_files | - |
none |
rule_name | - |
none |
cuda_helper.configure_features
load("@rules_cuda_docs//:developer_docs.bzl", "cuda_helper") cuda_helper.configure_features(ctx, cuda_toolchain, requested_features, unsupported_features, _debug)
Creates a feature_configuration instance.
PARAMETERS
cuda_helper.create_common
load("@rules_cuda_docs//:developer_docs.bzl", "cuda_helper") cuda_helper.create_common(ctx)
Helper to gather and process various information from ctx
object to ease the parameter passing for internal macros.
See cuda_helper.create_common_info
what information a common object encapsulates.
PARAMETERS
Name | Description | Default Value |
---|---|---|
ctx | - |
none |
cuda_helper.create_common_info
load("@rules_cuda_docs//:developer_docs.bzl", "cuda_helper") cuda_helper.create_common_info(cuda_archs_info, includes, quote_includes, system_includes, headers, transitive_headers, defines, local_defines, compile_flags, link_flags, host_defines, host_local_defines, host_compile_flags, host_link_flags, ptxas_flags, transitive_cc_info, transitive_linking_contexts)
Constructor of the common object.
PARAMETERS
cuda_helper.create_compile_variables
load("@rules_cuda_docs//:developer_docs.bzl", "cuda_helper") cuda_helper.create_compile_variables(cuda_toolchain, feature_configuration, cuda_archs_info, source_file, output_file, host_compiler, compile_flags, host_compile_flags, include_paths, quote_include_paths, system_include_paths, defines, host_defines, ptxas_flags, use_pic, use_rdc)
Returns variables used for compile
actions.
PARAMETERS
cuda_helper.create_cuda_info
load("@rules_cuda_docs//:developer_docs.bzl", "cuda_helper") cuda_helper.create_cuda_info(defines, objects, rdc_objects, pic_objects, rdc_pic_objects, archive_objects, archive_rdc_objects, archive_pic_objects, archive_rdc_pic_objects, dlink_rdc_objects, dlink_rdc_pic_objects)
Constructor for CudaInfo
. See the providers documentation for detail.
PARAMETERS
cuda_helper.create_device_link_variables
load("@rules_cuda_docs//:developer_docs.bzl", "cuda_helper") cuda_helper.create_device_link_variables(cuda_toolchain, feature_configuration, cuda_archs_info, output_file, host_compiler, host_compile_flags, user_link_flags, use_pic)
Returns variables used for device_link
actions.
PARAMETERS
cuda_helper.get_arch_specs
load("@rules_cuda_docs//:developer_docs.bzl", "cuda_helper") cuda_helper.get_arch_specs(specs_str)
Convert string into a list of ArchSpecInfo.
PARAMETERS
Name | Description | Default Value |
---|---|---|
specs_str | a string to be parsed, e.g., "compute_70:sm_70;compute_80:sm_80,sm_86". | none |
RETURNS
A list of ArchSpecInfo
s
cuda_helper.get_artifact_category_from_action
load("@rules_cuda_docs//:developer_docs.bzl", "cuda_helper") cuda_helper.get_artifact_category_from_action(action_name, use_pic, use_rdc)
Query the canonical artifact category name.
PARAMETERS
Name | Description | Default Value |
---|---|---|
action_name | - |
none |
use_pic | - |
None |
use_rdc | - |
None |
cuda_helper.get_artifact_name
load("@rules_cuda_docs//:developer_docs.bzl", "cuda_helper") cuda_helper.get_artifact_name(cuda_toolchain, category_name, output_basename)
Create the artifact name that follow the toolchain configuration.
PARAMETERS
cuda_helper.get_basename_without_ext
load("@rules_cuda_docs//:developer_docs.bzl", "cuda_helper") cuda_helper.get_basename_without_ext(basename, allow_exts, fail_if_not_match)
PARAMETERS
Name | Description | Default Value |
---|---|---|
basename | - |
none |
allow_exts | - |
none |
fail_if_not_match | - |
True |
cuda_helper.get_command_line
load("@rules_cuda_docs//:developer_docs.bzl", "cuda_helper") cuda_helper.get_command_line(info, action, value)
Returns flattened command line flags for given action, using given variables for expansion.
PARAMETERS
cuda_helper.get_environment_variables
load("@rules_cuda_docs//:developer_docs.bzl", "cuda_helper") cuda_helper.get_environment_variables(info, action, value)
Returns environment variables to be set for the given action.
PARAMETERS
cuda_helper.get_tool_for_action
load("@rules_cuda_docs//:developer_docs.bzl", "cuda_helper") cuda_helper.get_tool_for_action(info, action_name)
Returns tool path for given action.
PARAMETERS
Name | Description | Default Value |
---|---|---|
info | A _FeatureConfigurationInfo , returned by configure_features , to be queried. |
none |
action_name | Name of the action. | none |
cuda_helper.is_enabled
Returns whether a selectable is enable or not.
PARAMETERS
Name | Description | Default Value |
---|---|---|
info | A _FeatureConfigurationInfo , returned by configure_features , to be queried. |
none |
name | Name of the selectable, that is, an action_config or a feature . |
none |
repositories.config_clang
load("@rules_cuda_docs//:developer_docs.bzl", "repositories") repositories.config_clang(repository_ctx, cuda, clang_path)
Generate @local_cuda//toolchain/clang/BUILD
PARAMETERS
Name | Description | Default Value |
---|---|---|
repository_ctx | repository_ctx | none |
cuda | The struct returned from detect_cuda_toolkit |
none |
clang_path | Path to clang executable returned from detect_clang |
none |
repositories.config_cuda_toolkit_and_nvcc
load("@rules_cuda_docs//:developer_docs.bzl", "repositories") repositories.config_cuda_toolkit_and_nvcc(repository_ctx, cuda)
Generate @local_cuda//BUILD
and @local_cuda//defs.bzl
and @local_cuda//toolchain/BUILD
PARAMETERS
Name | Description | Default Value |
---|---|---|
repository_ctx | repository_ctx | none |
cuda | The struct returned from detect_cuda_toolkit | none |
repositories.detect_clang
load("@rules_cuda_docs//:developer_docs.bzl", "repositories") repositories.detect_clang(repository_ctx)
Detect local clang installation.
The path to clang is determined by:
- taken from
CUDA_CLANG_PATH
environment variable or - taken from
BAZEL_LLVM
environment variable as$BAZEL_LLVM/bin/clang
or - determined through
which clang
or - treated as being not detected and not configured
PARAMETERS
Name | Description | Default Value |
---|---|---|
repository_ctx | repository_ctx | none |
RETURNS
clang_path (str | None): Optionally return a string of path to clang executable if detected.
repositories.detect_cuda_toolkit
load("@rules_cuda_docs//:developer_docs.bzl", "repositories") repositories.detect_cuda_toolkit(repository_ctx)
Detect CUDA Toolkit.
The path to CUDA Toolkit is determined as:
- the value of toolkit_path
passed to local_cuda as an attribute
- taken from CUDA_PATH
environment variable or
- determined through 'which ptxas' or
- defaults to '/usr/local/cuda'
PARAMETERS
Name | Description | Default Value |
---|---|---|
repository_ctx | repository_ctx | none |
RETURNS
A struct contains the information of CUDA Toolkit.
toolchain.find_cuda_toolchain
load("@rules_cuda_docs//:developer_docs.bzl", "toolchain") toolchain.find_cuda_toolchain(ctx)
Helper to get the cuda toolchain from context object.
PARAMETERS
Name | Description | Default Value |
---|---|---|
ctx | The rule context for which to find a toolchain. | none |
RETURNS
A platform_common.ToolchainInfo
that wraps around the necessary information of a cuda toolchain.
toolchain.find_cuda_toolkit
load("@rules_cuda_docs//:developer_docs.bzl", "toolchain") toolchain.find_cuda_toolkit(ctx)
Finds the CUDA toolchain.
PARAMETERS
Name | Description | Default Value |
---|---|---|
ctx | The rule context for which to find a toolchain. | none |
RETURNS
A CudaToolkitInfo.
toolchain.use_cpp_toolchain
load("@rules_cuda_docs//:developer_docs.bzl", "toolchain") toolchain.use_cpp_toolchain(mandatory)
Helper to depend on the C++ toolchain.
Notes: Copied from toolchain_utils.bzl
PARAMETERS
Name | Description | Default Value |
---|---|---|
mandatory | - |
True |
toolchain.use_cuda_toolchain
load("@rules_cuda_docs//:developer_docs.bzl", "toolchain") toolchain.use_cuda_toolchain()
Helper to depend on the CUDA toolchain.