forked from envoyproxy/envoy
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathenvoy_binary.bzl
112 lines (104 loc) · 3.42 KB
/
envoy_binary.bzl
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
load("@rules_cc//cc:defs.bzl", "cc_binary")
# DO NOT LOAD THIS FILE. Load envoy_build_system.bzl instead.
# Envoy binary targets
load(
":envoy_internal.bzl",
"envoy_copts",
"envoy_external_dep_path",
"envoy_stdlib_deps",
"tcmalloc_external_dep",
)
# Envoy C++ binary targets should be specified with this function.
def envoy_cc_binary(
name,
srcs = [],
data = [],
testonly = 0,
visibility = None,
external_deps = [],
repository = "",
stamped = False,
deps = [],
linkopts = [],
tags = []):
if not linkopts:
linkopts = _envoy_linkopts()
if stamped:
linkopts = linkopts + _envoy_stamped_linkopts()
deps = deps + _envoy_stamped_deps()
deps = deps + [envoy_external_dep_path(dep) for dep in external_deps] + envoy_stdlib_deps()
cc_binary(
name = name,
srcs = srcs,
data = data,
copts = envoy_copts(repository),
linkopts = linkopts,
testonly = testonly,
linkstatic = 1,
visibility = visibility,
malloc = tcmalloc_external_dep(repository),
stamp = 1,
deps = deps,
tags = tags,
)
# Select the given values if exporting is enabled in the current build.
def _envoy_select_exported_symbols(xs):
return select({
"@envoy//bazel:enable_exported_symbols": xs,
"//conditions:default": [],
})
# Compute the final linkopts based on various options.
def _envoy_linkopts():
return select({
# The macOS system library transitively links common libraries (e.g., pthread).
"@envoy//bazel:apple": [
# See note here: https://luajit.org/install.html
"-pagezero_size 10000",
"-image_base 100000000",
],
"@envoy//bazel:windows_x86_64": [
"-DEFAULTLIB:advapi32.lib",
"-DEFAULTLIB:ws2_32.lib",
"-DEFAULTLIB:iphlpapi.lib",
"-WX",
],
"//conditions:default": [
"-pthread",
"-lrt",
"-ldl",
"-Wl,-z,relro,-z,now",
"-Wl,--hash-style=gnu",
],
}) + select({
"@envoy//bazel:boringssl_fips": [],
"@envoy//bazel:windows_x86_64": [],
"//conditions:default": ["-pie"],
}) + _envoy_select_exported_symbols(["-Wl,-E"])
def _envoy_stamped_deps():
return select({
"@envoy//bazel:windows_x86_64": [],
"@envoy//bazel:apple": [
"@envoy//bazel:raw_build_id.ldscript",
],
"//conditions:default": [
"@envoy//bazel:gnu_build_id.ldscript",
],
})
def _envoy_stamped_linkopts():
return select({
# Coverage builds in CI are failing to link when setting a build ID.
#
# /usr/bin/ld.gold: internal error in write_build_id, at ../../gold/layout.cc:5419
"@envoy//bazel:coverage_build": [],
"@envoy//bazel:windows_x86_64": [],
# macOS doesn't have an official equivalent to the `.note.gnu.build-id`
# ELF section, so just stuff the raw ID into a new text section.
"@envoy//bazel:apple": [
"-sectcreate __TEXT __build_id",
"$(location @envoy//bazel:raw_build_id.ldscript)",
],
# Note: assumes GNU GCC (or compatible) handling of `--build-id` flag.
"//conditions:default": [
"-Wl,@$(location @envoy//bazel:gnu_build_id.ldscript)",
],
})