summaryrefslogtreecommitdiffhomepage
path: root/test/syscalls/linux/rseq/BUILD
diff options
context:
space:
mode:
authorgVisor bot <gvisor-bot@google.com>2020-04-20 12:31:22 -0700
committergVisor bot <gvisor-bot@google.com>2020-04-20 12:31:22 -0700
commit763d16f912aba6216937f88b0376b8b1dafbd59c (patch)
tree16163ee16cf7bb6998e460b32c753b65e190856f /test/syscalls/linux/rseq/BUILD
parent9ba3086d9dfc7e9a4a957446f443786b179cd84e (diff)
parentc71e97784cfc57a0664a07cb798aca3d39d6bb11 (diff)
Merge pull request #2060 from xiaobo55x:rseq
PiperOrigin-RevId: 307453436
Diffstat (limited to 'test/syscalls/linux/rseq/BUILD')
-rw-r--r--test/syscalls/linux/rseq/BUILD43
1 files changed, 23 insertions, 20 deletions
diff --git a/test/syscalls/linux/rseq/BUILD b/test/syscalls/linux/rseq/BUILD
index ed488dbc2..853258b04 100644
--- a/test/syscalls/linux/rseq/BUILD
+++ b/test/syscalls/linux/rseq/BUILD
@@ -1,7 +1,7 @@
# This package contains a standalone rseq test binary. This binary must not
# depend on libc, which might use rseq itself.
-load("//tools:defs.bzl", "cc_flags_supplier", "cc_library", "cc_toolchain")
+load("//tools:defs.bzl", "cc_flags_supplier", "cc_library", "cc_toolchain", "select_arch")
package(licenses = ["notice"])
@@ -9,32 +9,35 @@ genrule(
name = "rseq_binary",
srcs = [
"critical.h",
- "critical.S",
+ "critical_amd64.S",
+ "critical_arm64.S",
"rseq.cc",
"syscalls.h",
- "start.S",
+ "start_amd64.S",
+ "start_arm64.S",
"test.h",
"types.h",
"uapi.h",
],
outs = ["rseq"],
- cmd = " ".join([
- "$(CC)",
- "$(CC_FLAGS) ",
- "-I.",
- "-Wall",
- "-Werror",
- "-O2",
- "-std=c++17",
- "-static",
- "-nostdlib",
- "-ffreestanding",
- "-o",
- "$(location rseq)",
- "$(location critical.S)",
- "$(location rseq.cc)",
- "$(location start.S)",
- ]),
+ cmd = "$(CC) " +
+ "$(CC_FLAGS) " +
+ "-I. " +
+ "-Wall " +
+ "-Werror " +
+ "-O2 " +
+ "-std=c++17 " +
+ "-static " +
+ "-nostdlib " +
+ "-ffreestanding " +
+ "-o " +
+ "$(location rseq) " +
+ select_arch(
+ amd64 = "$(location critical_amd64.S) $(location start_amd64.S) ",
+ arm64 = "$(location critical_arm64.S) $(location start_arm64.S) ",
+ no_match_error = "unsupported architecture",
+ ) +
+ "$(location rseq.cc)",
toolchains = [
cc_toolchain,
":no_pie_cc_flags",