| # This file keeps a list of PyTorch source files that are used for templated selective build. |
| # NB: as this is PyTorch Edge selective build, we assume only CPU targets are |
| # being built |
| |
| load("@bazel_skylib//lib:paths.bzl", "paths") |
| load("//tools/build_defs:fbsource_utils.bzl", "is_arvr_mode") |
| load(":build_variables.bzl", "aten_native_source_list") |
| load( |
| ":ufunc_defs.bzl", |
| "aten_ufunc_generated_cpu_kernel_sources", |
| "aten_ufunc_generated_cpu_sources", |
| ) |
| |
| # Files in this list are supposed to be built separately for each app, |
| # for different operator allow lists. |
| TEMPLATE_SOURCE_LIST = [ |
| "torch/csrc/jit/runtime/register_prim_ops.cpp", |
| "torch/csrc/jit/runtime/register_special_ops.cpp", |
| ] + aten_native_source_list |
| |
| # For selective build, we can lump the CPU and CPU kernel sources altogether |
| # because there is only ever one vectorization variant that is compiled |
| def aten_ufunc_generated_all_cpu_sources(gencode_pattern = "{}"): |
| return ( |
| aten_ufunc_generated_cpu_sources(gencode_pattern) + |
| aten_ufunc_generated_cpu_kernel_sources(gencode_pattern) |
| ) |
| |
| TEMPLATE_MASKRCNN_SOURCE_LIST = [ |
| "register_maskrcnn_ops.cpp", |
| ] |
| |
| TEMPLATE_BATCH_BOX_COX_SOURCE_LIST = [ |
| "register_batch_box_cox_ops.cpp", |
| ] |
| |
| METAL_SOURCE_LIST = [ |
| "aten/src/ATen/native/metal/MetalAten.mm", |
| "aten/src/ATen/native/metal/MetalGuardImpl.cpp", |
| "aten/src/ATen/native/metal/MetalPrepackOpRegister.cpp", |
| "aten/src/ATen/native/metal/MetalCommandBuffer.mm", |
| "aten/src/ATen/native/metal/MetalContext.mm", |
| "aten/src/ATen/native/metal/MetalConvParams.mm", |
| "aten/src/ATen/native/metal/MetalTensorImplStorage.mm", |
| "aten/src/ATen/native/metal/MetalTensorUtils.mm", |
| "aten/src/ATen/native/metal/mpscnn/MPSCNNClampOp.mm", |
| "aten/src/ATen/native/metal/mpscnn/MPSCNNConvOp.mm", |
| "aten/src/ATen/native/metal/mpscnn/MPSCNNFullyConnectedOp.mm", |
| "aten/src/ATen/native/metal/mpscnn/MPSCNNNeuronOp.mm", |
| "aten/src/ATen/native/metal/mpscnn/MPSCNNUtils.mm", |
| "aten/src/ATen/native/metal/mpscnn/MPSImage+Tensor.mm", |
| "aten/src/ATen/native/metal/mpscnn/MPSImageUtils.mm", |
| "aten/src/ATen/native/metal/mpscnn/MPSImageWrapper.mm", |
| "aten/src/ATen/native/metal/ops/MetalAddmm.mm", |
| "aten/src/ATen/native/metal/ops/MetalBinaryElementwise.mm", |
| "aten/src/ATen/native/metal/ops/MetalChunk.mm", |
| "aten/src/ATen/native/metal/ops/MetalClamp.mm", |
| "aten/src/ATen/native/metal/ops/MetalConcat.mm", |
| "aten/src/ATen/native/metal/ops/MetalConvolution.mm", |
| "aten/src/ATen/native/metal/ops/MetalCopy.mm", |
| "aten/src/ATen/native/metal/ops/MetalHardswish.mm", |
| "aten/src/ATen/native/metal/ops/MetalHardshrink.mm", |
| "aten/src/ATen/native/metal/ops/MetalLeakyReLU.mm", |
| "aten/src/ATen/native/metal/ops/MetalNeurons.mm", |
| "aten/src/ATen/native/metal/ops/MetalPadding.mm", |
| "aten/src/ATen/native/metal/ops/MetalPooling.mm", |
| "aten/src/ATen/native/metal/ops/MetalReduce.mm", |
| "aten/src/ATen/native/metal/ops/MetalReshape.mm", |
| "aten/src/ATen/native/metal/ops/MetalSoftmax.mm", |
| "aten/src/ATen/native/metal/ops/MetalTranspose.mm", |
| "aten/src/ATen/native/metal/ops/MetalUpsamplingNearest.mm", |
| ] |
| |
| UNET_METAL_PREPACK_SOURCE_LIST = [ |
| "unet_metal_prepack.cpp", |
| "unet_metal_prepack.mm", |
| ] |
| |
| METAL_MASKRCNN_SOURCE_LIST = [ |
| "maskrcnn/srcs/GenerateProposals.mm", |
| "maskrcnn/srcs/RoIAlign.mm", |
| ] |
| |
| # The get_template_source_dict() returns a dict containing a path prefix |
| # and a list of .cpp source files containing operator definitions and |
| # registrations that should get selected via templated selective build. |
| # The file selected_mobile_ops.h has the list of selected top level |
| # operators. |
| # NB: doesn't include generated files; copy_template_registration_files |
| # handles those specially |
| def get_template_source_dict(): |
| ret = {} |
| for file_path in TEMPLATE_SOURCE_LIST: |
| path_prefix = paths.dirname(file_path) |
| if path_prefix not in ret: |
| ret[path_prefix] = [] |
| ret[path_prefix].append(file_path) |
| return ret |
| |
| def get_gen_oplist_outs(): |
| return { |
| "SupportedMobileModelsRegistration.cpp": [ |
| "SupportedMobileModelsRegistration.cpp", |
| ], |
| "selected_mobile_ops.h": [ |
| "selected_mobile_ops.h", |
| ], |
| "selected_operators.yaml": [ |
| "selected_operators.yaml", |
| ], |
| } |
| |
| def get_generate_code_bin_outs(): |
| outs = { |
| "autograd/generated/ADInplaceOrViewTypeEverything.cpp": ["autograd/generated/ADInplaceOrViewTypeEverything.cpp"], |
| "autograd/generated/ADInplaceOrViewType_0.cpp": ["autograd/generated/ADInplaceOrViewType_0.cpp"], |
| "autograd/generated/ADInplaceOrViewType_1.cpp": ["autograd/generated/ADInplaceOrViewType_1.cpp"], |
| "autograd/generated/Functions.cpp": ["autograd/generated/Functions.cpp"], |
| "autograd/generated/Functions.h": ["autograd/generated/Functions.h"], |
| "autograd/generated/TraceTypeEverything.cpp": ["autograd/generated/TraceTypeEverything.cpp"], |
| "autograd/generated/TraceType_0.cpp": ["autograd/generated/TraceType_0.cpp"], |
| "autograd/generated/TraceType_1.cpp": ["autograd/generated/TraceType_1.cpp"], |
| "autograd/generated/TraceType_2.cpp": ["autograd/generated/TraceType_2.cpp"], |
| "autograd/generated/TraceType_3.cpp": ["autograd/generated/TraceType_3.cpp"], |
| "autograd/generated/TraceType_4.cpp": ["autograd/generated/TraceType_4.cpp"], |
| "autograd/generated/VariableType.h": ["autograd/generated/VariableType.h"], |
| "autograd/generated/VariableTypeEverything.cpp": ["autograd/generated/VariableTypeEverything.cpp"], |
| "autograd/generated/VariableType_0.cpp": ["autograd/generated/VariableType_0.cpp"], |
| "autograd/generated/VariableType_1.cpp": ["autograd/generated/VariableType_1.cpp"], |
| "autograd/generated/VariableType_2.cpp": ["autograd/generated/VariableType_2.cpp"], |
| "autograd/generated/VariableType_3.cpp": ["autograd/generated/VariableType_3.cpp"], |
| "autograd/generated/VariableType_4.cpp": ["autograd/generated/VariableType_4.cpp"], |
| "autograd/generated/variable_factories.h": ["autograd/generated/variable_factories.h"], |
| "autograd/generated/ViewFuncs.cpp": ["autograd/generated/ViewFuncs.cpp"], |
| "autograd/generated/ViewFuncs.h": ["autograd/generated/ViewFuncs.h"], |
| } |
| |
| if is_arvr_mode(): |
| outs.update({ |
| "autograd/generated/python_enum_tag.cpp": ["autograd/generated/python_enum_tag.cpp"], |
| "autograd/generated/python_fft_functions.cpp": ["autograd/generated/python_fft_functions.cpp"], |
| "autograd/generated/python_functions.h": ["autograd/generated/python_functions.h"], |
| "autograd/generated/python_functions_0.cpp": ["autograd/generated/python_functions_0.cpp"], |
| "autograd/generated/python_functions_1.cpp": ["autograd/generated/python_functions_1.cpp"], |
| "autograd/generated/python_functions_2.cpp": ["autograd/generated/python_functions_2.cpp"], |
| "autograd/generated/python_functions_3.cpp": ["autograd/generated/python_functions_3.cpp"], |
| "autograd/generated/python_functions_4.cpp": ["autograd/generated/python_functions_4.cpp"], |
| "autograd/generated/python_linalg_functions.cpp": ["autograd/generated/python_linalg_functions.cpp"], |
| "autograd/generated/python_nested_functions.cpp": ["autograd/generated/python_nested_functions.cpp"], |
| "autograd/generated/python_nn_functions.cpp": ["autograd/generated/python_nn_functions.cpp"], |
| "autograd/generated/python_return_types.h": ["autograd/generated/python_return_types.h"], |
| "autograd/generated/python_return_types.cpp": ["autograd/generated/python_return_types.cpp"], |
| "autograd/generated/python_sparse_functions.cpp": ["autograd/generated/python_sparse_functions.cpp"], |
| "autograd/generated/python_special_functions.cpp": ["autograd/generated/python_special_functions.cpp"], |
| "autograd/generated/python_torch_functions_0.cpp": ["autograd/generated/python_torch_functions_0.cpp"], |
| "autograd/generated/python_torch_functions_1.cpp": ["autograd/generated/python_torch_functions_1.cpp"], |
| "autograd/generated/python_torch_functions_2.cpp": ["autograd/generated/python_torch_functions_2.cpp"], |
| "autograd/generated/python_variable_methods.cpp": ["autograd/generated/python_variable_methods.cpp"], |
| }) |
| return outs |
| |
| def get_template_registration_files_outs(is_oss = False): |
| outs = {} |
| if not is_oss: |
| for file_path in TEMPLATE_MASKRCNN_SOURCE_LIST: |
| outs[file_path] = [file_path] |
| |
| for file_path in TEMPLATE_BATCH_BOX_COX_SOURCE_LIST: |
| outs[file_path] = [file_path] |
| |
| for file_path in TEMPLATE_SOURCE_LIST: |
| outs[file_path] = [file_path] |
| |
| for base_name in aten_ufunc_generated_all_cpu_sources(): |
| file_path = "aten/src/ATen/{}".format(base_name) |
| outs[file_path] = [file_path] |
| |
| return outs |
| |
| def get_template_registration_file_rules(rule_name, is_oss = False): |
| rules = [] |
| for file_path in TEMPLATE_SOURCE_LIST if is_oss else (TEMPLATE_SOURCE_LIST + TEMPLATE_MASKRCNN_SOURCE_LIST + TEMPLATE_BATCH_BOX_COX_SOURCE_LIST): |
| rules.append(":{}[{}]".format(rule_name, file_path)) |
| for file_path in aten_ufunc_generated_all_cpu_sources(): |
| rules.append(":{}[aten/src/ATen/{}]".format(rule_name, file_path)) |
| |
| return rules |
| |
| # ---------------------METAL RULES--------------------- |
| def get_metal_source_dict(): |
| ret = {} |
| for file_path in METAL_SOURCE_LIST: |
| path_prefix = paths.dirname(file_path) |
| if path_prefix not in ret: |
| ret[path_prefix] = [] |
| ret[path_prefix].append(file_path) |
| return ret |
| |
| def get_metal_registration_files_outs(): |
| outs = {} |
| for file_path in METAL_SOURCE_LIST: |
| outs[file_path] = [file_path] |
| |
| for file_path in UNET_METAL_PREPACK_SOURCE_LIST: |
| outs[file_path] = [file_path] |
| |
| for file_path in METAL_MASKRCNN_SOURCE_LIST: |
| outs[file_path] = [file_path] |
| return outs |
| |
| # There is a really weird issue with the arvr windows builds where |
| # the custom op files are breaking them. See https://fburl.com/za87443c |
| # The hack is just to not build them for that platform and pray they arent needed. |
| def get_metal_registration_files_outs_windows(): |
| outs = {} |
| for file_path in METAL_SOURCE_LIST: |
| outs[file_path] = [file_path] |
| return outs |
| |
| def get_metal_registration_files_rules(rule_name): |
| ret = {} |
| objc_rules = [] |
| cxx_rules = [] |
| |
| for file_path in METAL_SOURCE_LIST + METAL_MASKRCNN_SOURCE_LIST + UNET_METAL_PREPACK_SOURCE_LIST: |
| if ".cpp" not in file_path: |
| objc_rules.append(":{}[{}]".format(rule_name, file_path)) |
| else: |
| cxx_rules.append(":{}[{}]".format(rule_name, file_path)) |
| ret["objc"] = objc_rules |
| ret["cxx"] = cxx_rules |
| return ret |
| |
| def get_metal_registration_files_rules_windows(rule_name): |
| ret = {} |
| objc_rules = [] |
| cxx_rules = [] |
| |
| for file_path in METAL_SOURCE_LIST: |
| if ".cpp" not in file_path: |
| objc_rules.append(":{}[{}]".format(rule_name, file_path)) |
| else: |
| cxx_rules.append(":{}[{}]".format(rule_name, file_path)) |
| ret["objc"] = objc_rules |
| ret["cxx"] = cxx_rules |
| return ret |