Skip to content

Commit

Permalink
[CMS] Changes to build TF cms externals
Browse files Browse the repository at this point in the history
  • Loading branch information
cmsbuild committed Nov 1, 2023
1 parent ac5003a commit 4b8ac79
Show file tree
Hide file tree
Showing 25 changed files with 389 additions and 158 deletions.
5 changes: 5 additions & 0 deletions tensorflow/core/kernels/matmul_op_impl.h
Original file line number Diff line number Diff line change
Expand Up @@ -93,6 +93,7 @@ struct ParallelMatMulKernel {
z.device(d) = z.conjugate();
}

__attribute__((used))
static void Run(const OpKernelContext* context, const Tensor& in_x,
const Tensor& in_y, bool adj_x, bool adj_y, bool trans_x,
bool trans_y, const MatMulBCast& bcast, Tensor* out,
Expand Down Expand Up @@ -138,6 +139,7 @@ template <typename Scalar>
struct ParallelMatMulKernel<Scalar, false> {
static void Conjugate(const OpKernelContext* context, Tensor* out) {}

__attribute__((used))
static void Run(const OpKernelContext* context, const Tensor& in_x,
const Tensor& in_y, bool adj_x, bool adj_y, bool trans_x,
bool trans_y, const MatMulBCast& bcast, Tensor* out,
Expand Down Expand Up @@ -209,6 +211,7 @@ struct SequentialMatMulKernel {
t->dim_size(1), t->dim_size(2));
}

__attribute__((used))
static void Run(const Tensor& in_x, const Tensor& in_y, bool adj_x,
bool adj_y, bool trans_x, bool trans_y,
const MatMulBCast& bcast, Tensor* out, int start, int limit) {
Expand Down Expand Up @@ -270,6 +273,8 @@ struct SingleBatchParallelMatMulKernel {
return MatrixMap(t->flat<Scalar>().data(), t->dim_size(1), t->dim_size(2));
}


__attribute__((used))
static void Run(const CPUDevice& device, const Tensor& in_x,
const Tensor& in_y, bool adj_x, bool adj_y, bool trans_x,
bool trans_y, Tensor* out) {
Expand Down
6 changes: 2 additions & 4 deletions tensorflow/workspace0.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@ load("@bazel_toolchains//repositories:repositories.bzl", bazel_toolchains_reposi
load("@build_bazel_rules_apple//apple:repositories.bzl", "apple_rules_dependencies")
load("@build_bazel_rules_swift//swift:repositories.bzl", "swift_rules_dependencies")
load("@build_bazel_apple_support//lib:repositories.bzl", "apple_support_dependencies")
load("@com_github_grpc_grpc//bazel:grpc_extra_deps.bzl", "grpc_extra_deps")
load("@local_config_android//:android.bzl", "android_workspace")
load("@rules_foreign_cc//foreign_cc:repositories.bzl", "rules_foreign_cc_dependencies")

Expand All @@ -22,11 +21,11 @@ def _tf_bind():
# Needed by Protobuf
native.bind(
name = "grpc_cpp_plugin",
actual = "@com_github_grpc_grpc//src/compiler:grpc_cpp_plugin",
actual = "@com_github_grpc_grpc//:grpc_cpp_plugin",
)
native.bind(
name = "grpc_python_plugin",
actual = "@com_github_grpc_grpc//src/compiler:grpc_python_plugin",
actual = "@com_github_grpc_grpc//:grpc_python_plugin",
)

native.bind(
Expand Down Expand Up @@ -132,7 +131,6 @@ def workspace():
# at the end of the WORKSPACE file.
_tf_bind()

grpc_extra_deps()
rules_foreign_cc_dependencies()
config_googleapis()

Expand Down
2 changes: 0 additions & 2 deletions tensorflow/workspace1.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,6 @@

load("//third_party/android:android_configure.bzl", "android_configure")
load("@bazel_tools//tools/build_defs/repo:http.bzl", "http_archive")
load("@com_github_grpc_grpc//bazel:grpc_deps.bzl", "grpc_deps")
load("@com_google_benchmark//:bazel/benchmark_deps.bzl", "benchmark_deps")
load("@io_bazel_rules_closure//closure:defs.bzl", "closure_repositories")
load("@rules_pkg//:deps.bzl", "rules_pkg_dependencies")
Expand Down Expand Up @@ -31,7 +30,6 @@ def workspace(with_rules_cc = True):

android_configure(name = "local_config_android")

grpc_deps()
benchmark_deps()

# Alias so it can be loaded without assigning to a different symbol to prevent
Expand Down
138 changes: 4 additions & 134 deletions tensorflow/workspace2.bzl
Original file line number Diff line number Diff line change
Expand Up @@ -24,16 +24,13 @@ load("//third_party/absl:workspace.bzl", absl = "repo")
load("//third_party/benchmark:workspace.bzl", benchmark = "repo")
load("//third_party/dlpack:workspace.bzl", dlpack = "repo")
load("//third_party/ducc:workspace.bzl", ducc = "repo")
load("//third_party/eigen3:workspace.bzl", eigen3 = "repo")
load("//third_party/farmhash:workspace.bzl", farmhash = "repo")
load("//third_party/flatbuffers:workspace.bzl", flatbuffers = "repo")
load("//third_party/gemmlowp:workspace.bzl", gemmlowp = "repo")
load("//third_party/hexagon:workspace.bzl", hexagon_nn = "repo")
load("//third_party/highwayhash:workspace.bzl", highwayhash = "repo")
load("//third_party/hwloc:workspace.bzl", hwloc = "repo")
load("//third_party/implib_so:workspace.bzl", implib_so = "repo")
load("//third_party/icu:workspace.bzl", icu = "repo")
load("//third_party/jpeg:workspace.bzl", jpeg = "repo")
load("//third_party/libprotobuf_mutator:workspace.bzl", libprotobuf_mutator = "repo")
load("//third_party/nasm:workspace.bzl", nasm = "repo")
load("//third_party/py/ml_dtypes:workspace.bzl", ml_dtypes = "repo")
Expand All @@ -57,6 +54,9 @@ load("//tensorflow/tools/toolchains/remote:configure.bzl", "remote_execution_con
load("//tensorflow/tools/toolchains/clang6:repo.bzl", "clang6_configure")
load("@rules_jvm_external//:defs.bzl", "maven_install")

#import CMS specific repos
load("//third_party/cms:workspace.bzl", cms= "repos")

def _initialize_third_party():
""" Load third party repositories. See above load() statements. """
FP16()
Expand All @@ -65,16 +65,12 @@ def _initialize_third_party():
benchmark()
ducc()
dlpack()
eigen3()
farmhash()
flatbuffers()
gemmlowp()
hexagon_nn()
highwayhash()
hwloc()
icu()
implib_so()
jpeg()
kissfft()
libprotobuf_mutator()
ml_dtypes()
Expand All @@ -89,6 +85,7 @@ def _initialize_third_party():
vulkan_headers()
tensorrt()
triton()
cms()

# copybara: tsl vendor

Expand Down Expand Up @@ -309,74 +306,6 @@ def _tf_repositories():
urls = tf_mirror_urls("https://github.com/googleapis/googleapis/archive/6b3fdcea8bc5398be4e7e9930c693f0ea09316a0.tar.gz"),
)

tf_http_archive(
name = "png",
build_file = "//third_party:png.BUILD",
patch_file = ["//third_party:png_fix_rpi.patch"],
sha256 = "a00e9d2f2f664186e4202db9299397f851aea71b36a35e74910b8820e380d441",
strip_prefix = "libpng-1.6.39",
system_build_file = "//third_party/systemlibs:png.BUILD",
urls = tf_mirror_urls("https://github.com/glennrp/libpng/archive/v1.6.39.tar.gz"),
)

tf_http_archive(
name = "org_sqlite",
build_file = "//third_party:sqlite.BUILD",
sha256 = "bb5849ae4d7129c09d20596379a0b3f7b1ac59cf9998eba5ef283ea9b6c000a5",
strip_prefix = "sqlite-amalgamation-3430000",
system_build_file = "//third_party/systemlibs:sqlite.BUILD",
urls = tf_mirror_urls("https://www.sqlite.org/2023/sqlite-amalgamation-3430000.zip"),
)

tf_http_archive(
name = "gif",
build_file = "//third_party:gif.BUILD",
patch_file = [
"//third_party:gif_fix_strtok_r.patch",
"//third_party:gif_fix_image_counter.patch",
],
sha256 = "31da5562f44c5f15d63340a09a4fd62b48c45620cd302f77a6d9acf0077879bd",
strip_prefix = "giflib-5.2.1",
system_build_file = "//third_party/systemlibs:gif.BUILD",
urls = tf_mirror_urls("https://pilotfiber.dl.sourceforge.net/project/giflib/giflib-5.2.1.tar.gz"),
)

tf_http_archive(
name = "six_archive",
build_file = "//third_party:six.BUILD",
sha256 = "1e61c37477a1626458e36f7b1d82aa5c9b094fa4802892072e49de9c60c4c926",
strip_prefix = "six-1.16.0",
system_build_file = "//third_party/systemlibs:six.BUILD",
urls = tf_mirror_urls("https://pypi.python.org/packages/source/s/six/six-1.16.0.tar.gz"),
)

tf_http_archive(
name = "absl_py",
sha256 = "a7c51b2a0aa6357a9cbb2d9437e8cd787200531867dc02565218930b6a32166e",
strip_prefix = "abseil-py-1.0.0",
system_build_file = "//third_party/systemlibs:absl_py.BUILD",
system_link_files = {
"//third_party/systemlibs:absl_py.absl.BUILD": "absl/BUILD",
"//third_party/systemlibs:absl_py.absl.flags.BUILD": "absl/flags/BUILD",
"//third_party/systemlibs:absl_py.absl.testing.BUILD": "absl/testing/BUILD",
"//third_party/systemlibs:absl_py.absl.logging.BUILD": "absl/logging/BUILD",
},
urls = tf_mirror_urls("https://github.com/abseil/abseil-py/archive/refs/tags/v1.0.0.tar.gz"),
)

tf_http_archive(
name = "com_google_protobuf",
patch_file = ["//third_party/protobuf:protobuf.patch"],
sha256 = "f66073dee0bc159157b0bd7f502d7d1ee0bc76b3c1eac9836927511bdc4b3fc1",
strip_prefix = "protobuf-3.21.9",
system_build_file = "//third_party/systemlibs:protobuf.BUILD",
system_link_files = {
"//third_party/systemlibs:protobuf.bzl": "protobuf.bzl",
"//third_party/systemlibs:protobuf_deps.bzl": "protobuf_deps.bzl",
},
urls = tf_mirror_urls("https://github.com/protocolbuffers/protobuf/archive/v3.21.9.zip"),
)

tf_http_archive(
name = "nsync",
patch_file = ["//third_party:nsync.patch"],
Expand Down Expand Up @@ -407,37 +336,6 @@ def _tf_repositories():
urls = tf_mirror_urls("https://github.com/gflags/gflags/archive/v2.2.2.tar.gz"),
)

tf_http_archive(
name = "curl",
build_file = "//third_party:curl.BUILD",
sha256 = "816e41809c043ff285e8c0f06a75a1fa250211bbfb2dc0a037eeef39f1a9e427",
strip_prefix = "curl-8.4.0",
system_build_file = "//third_party/systemlibs:curl.BUILD",
urls = tf_mirror_urls("https://curl.se/download/curl-8.4.0.tar.gz"),
)

# WARNING: make sure ncteisen@ and vpai@ are cc-ed on any CL to change the below rule
tf_http_archive(
name = "com_github_grpc_grpc",
sha256 = "b956598d8cbe168b5ee717b5dafa56563eb5201a947856a6688bbeac9cac4e1f",
strip_prefix = "grpc-b54a5b338637f92bfcf4b0bc05e0f57a5fd8fadd",
system_build_file = "//third_party/systemlibs:grpc.BUILD",
patch_file = [
"//third_party/grpc:generate_cc_env_fix.patch",
"//third_party/grpc:register_go_toolchain.patch",
],
system_link_files = {
"//third_party/systemlibs:BUILD": "bazel/BUILD",
"//third_party/systemlibs:grpc.BUILD": "src/compiler/BUILD",
"//third_party/systemlibs:grpc.bazel.grpc_deps.bzl": "bazel/grpc_deps.bzl",
"//third_party/systemlibs:grpc.bazel.grpc_extra_deps.bzl": "bazel/grpc_extra_deps.bzl",
"//third_party/systemlibs:grpc.bazel.cc_grpc_library.bzl": "bazel/cc_grpc_library.bzl",
"//third_party/systemlibs:grpc.bazel.generate_cc.bzl": "bazel/generate_cc.bzl",
"//third_party/systemlibs:grpc.bazel.protobuf.bzl": "bazel/protobuf.bzl",
},
urls = tf_mirror_urls("https://github.com/grpc/grpc/archive/b54a5b338637f92bfcf4b0bc05e0f57a5fd8fadd.tar.gz"),
)

tf_http_archive(
name = "linenoise",
build_file = "//third_party:linenoise.BUILD",
Expand Down Expand Up @@ -474,16 +372,6 @@ def _tf_repositories():
urls = tf_mirror_urls("https://github.com/google/boringssl/archive/c00d7ca810e93780bd0c8ee4eea28f4f2ea4bcdc.tar.gz"),
)

# Note: if you update this, you have to update libpng too. See cl/437813808
tf_http_archive(
name = "zlib",
build_file = "//third_party:zlib.BUILD",
sha256 = "b3a24de97a8fdbc835b9833169501030b8977031bcb54b3b3ac13740f846ab30",
strip_prefix = "zlib-1.2.13",
system_build_file = "//third_party/systemlibs:zlib.BUILD",
urls = tf_mirror_urls("https://zlib.net/fossils/zlib-1.2.13.tar.gz"),
)

# LINT.IfChange
tf_http_archive(
name = "fft2d",
Expand Down Expand Up @@ -597,15 +485,6 @@ def _tf_repositories():
urls = tf_mirror_urls("https://github.com/NVIDIA/NVTX/archive/v3.0.1.tar.gz"),
)

tf_http_archive(
name = "cython",
build_file = "//third_party:cython.BUILD",
sha256 = "0c2eae8a4ceab7955be1e11a4ddc5dcc3aa06ce22ad594262f1555b9d10667f0",
strip_prefix = "cython-3.0.3",
system_build_file = "//third_party/systemlibs:cython.BUILD",
urls = tf_mirror_urls("https://github.com/cython/cython/archive/3.0.3.tar.gz"),
)

# LINT.IfChange
tf_http_archive(
name = "arm_neon_2_x86_sse",
Expand Down Expand Up @@ -755,15 +634,6 @@ def _tf_repositories():
urls = tf_mirror_urls("https://github.com/nlohmann/json/archive/v3.10.5.tar.gz"),
)

tf_http_archive(
name = "pybind11",
urls = tf_mirror_urls("https://github.com/pybind/pybind11/archive/v2.10.4.tar.gz"),
sha256 = "832e2f309c57da9c1e6d4542dedd34b24e4192ecb4d62f6f4866a737454c9970",
strip_prefix = "pybind11-2.10.4",
build_file = "//third_party:pybind11.BUILD",
system_build_file = "//third_party/systemlibs:pybind11.BUILD",
)

tf_http_archive(
name = "pybind11_protobuf",
urls = tf_mirror_urls("https://github.com/pybind/pybind11_protobuf/archive/80f3440cd8fee124e077e2e47a8a17b78b451363.zip"),
Expand Down
Empty file added third_party/cms/BUILD
Empty file.
43 changes: 43 additions & 0 deletions third_party/cms/repo.bzl
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
def _cms_new_local_repository(ctx):
cmd = ["mkdir", "-p", ctx.path(".")]
ctx.execute(cmd)

cms_root_file = ctx.os.environ["TF_CMS_EXTERNALS"]
cmd = ["cat", cms_root_file]
res = ctx.execute(cmd)
cms_path = [
line.split(":", 1)[1]
for line in res.stdout.split("\n")
if line.startswith(ctx.attr.name + ":")
][-1].strip()

if cms_path:
cmd = ["ls", cms_path + "/"]
res = ctx.execute(cmd)
for rfile in res.stdout.split("\n"):
if rfile:
ctx.symlink(cms_path + "/" + rfile, ctx.path(rfile))

ctx.template("BUILD.bazel", ctx.attr.build_file, {
"%prefix%": "external",
}, False)

for xfile in ctx.attr.create_files:
ctx.file(xfile, content="")

for src, dest in ctx.attr.symlinks.items():
if src.startswith("//") or src.startswith("@"):
src = Label(src)
ctx.symlink(src, dest)

cms_new_local_repository = repository_rule(
implementation = _cms_new_local_repository,
attrs = {
"build_file": attr.label(),
"symlinks": attr.string_dict(),
"create_files": attr.string_list(),
},
environ = [
"TF_CMS_EXTERNALS",
],
)
Loading

0 comments on commit 4b8ac79

Please sign in to comment.