forked from pytorch/executorch
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathtargets.bzl
More file actions
167 lines (150 loc) · 5.66 KB
/
targets.bzl
File metadata and controls
167 lines (150 loc) · 5.66 KB
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
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
load("@fbsource//xplat/executorch/build:runtime_wrapper.bzl", "get_oss_build_kwargs", "is_xplat", "runtime")
load("@fbsource//xplat/executorch/codegen:codegen.bzl", "et_operator_library", "executorch_generated_lib", "ScalarType")
def define_common_targets():
"""Defines targets that should be shared between fbcode and xplat.
The directory containing this targets.bzl file should also contain both
TARGETS and BUCK files that call this function.
"""
# Select all ops: register all the ops in portable/functions.yaml
et_operator_library(
name = "select_all_ops",
include_all_operators = True,
)
executorch_generated_lib(
name = "select_all_lib",
functions_yaml_target = "//executorch/kernels/portable:functions.yaml",
kernel_deps = [
"//executorch/kernels/portable:operators",
],
deps = [
":select_all_ops",
],
)
if runtime.is_oss or is_xplat():
executorch_generated_lib(
name = "select_all_dtype_selective_lib",
functions_yaml_target = "//executorch/kernels/portable:functions.yaml",
kernel_deps = [
"//executorch/kernels/portable:operators",
],
# Setting dtype_selective_build without using list or dict selection isn't a
# typical use case; we just do it here so that we can test that our mechanism
# for getting buck deps right for dtype_selective_build is working.
dtype_selective_build = True,
deps = [
":select_all_ops",
],
)
# Select a list of operators: defined in `ops`
et_operator_library(
name = "select_ops_in_list",
ops = [
"aten::add.out",
"aten::mm.out",
],
)
executorch_generated_lib(
name = "select_ops_in_list_lib",
functions_yaml_target = "//executorch/kernels/portable:functions.yaml",
kernel_deps = [
"//executorch/kernels/portable:operators",
],
deps = [
":select_ops_in_list",
],
)
# Select a dictionary of ops with kernel metadata
et_operator_library(
name = "select_ops_in_dict",
ops_dict = {
# 1. Use kernel key, generated with a model, or
# 2. Specify the dtype, from executorch/codegen/codegen.bzl
"aten::add.out": ["v1/3;0,1", ScalarType("Float")], # int, float
"aten::mm.out": [], # all dtypes
},
)
executorch_generated_lib(
name = "select_ops_in_dict_lib",
functions_yaml_target = "//executorch/kernels/portable:functions.yaml",
kernel_deps = [
"//executorch/kernels/portable:operators",
],
deps = [
":select_ops_in_dict",
],
dtype_selective_build = is_xplat(),
visibility = ["//executorch/..."],
)
executorch_generated_lib(
name = "select_ops_in_dict_lib_optimized",
functions_yaml_target = "//executorch/kernels/optimized:optimized.yaml",
kernel_deps = [
"//executorch/kernels/optimized:optimized_operators",
],
deps = [
":select_ops_in_dict",
],
dtype_selective_build = is_xplat(),
visibility = ["//executorch/..."],
)
# Select all ops from a yaml file
et_operator_library(
name = "select_ops_from_yaml",
ops_schema_yaml_target = "//executorch/examples/portable/custom_ops:custom_ops.yaml",
)
executorch_generated_lib(
name = "select_ops_from_yaml_lib",
custom_ops_yaml_target = "//executorch/examples/portable/custom_ops:custom_ops.yaml",
kernel_deps = [
"//executorch/examples/portable/custom_ops:custom_ops_1",
"//executorch/examples/portable/custom_ops:custom_ops_2",
],
deps = [
":select_ops_from_yaml",
],
)
# Select all ops from a given model
# TODO(larryliu0820): Add this
if not runtime.is_oss and not is_xplat():
runtime.genrule(
name = "add_mul_model",
outs = {"add_mul": ["add_mul.pte"]},
cmd = "$(exe fbcode//executorch/examples/portable/scripts:export) --model_name add_mul --output_dir $OUT",
macros_only = False,
visibility = ["//executorch/..."],
)
et_operator_library(
name = "select_ops_from_model",
model = ":add_mul_model[add_mul]",
)
executorch_generated_lib(
name = "select_ops_from_model_lib",
functions_yaml_target = "//executorch/kernels/portable:functions.yaml",
kernel_deps = ["//executorch/kernels/portable:operators"],
deps = [":select_ops_from_model"],
visibility = ["//executorch/kernels/..."],
)
# ~~~ Test binary for selective build ~~~
select_ops = native.read_config("executorch", "select_ops", None)
lib = []
if select_ops == "all":
lib.append(":select_all_lib")
elif select_ops == "list":
lib.append(":select_ops_in_list_lib")
elif select_ops == "dict":
lib.append(":select_ops_in_dict_lib")
elif select_ops == "dict_optimized":
lib.append(":select_ops_in_dict_lib_optimized")
elif select_ops == "yaml":
lib.append(":select_ops_from_yaml_lib")
elif select_ops == "model":
lib.append(":select_ops_from_model_lib")
runtime.cxx_binary(
name = "selective_build_test",
srcs = [],
deps = [
"//executorch/examples/portable/executor_runner:executor_runner_lib",
] + lib,
define_static_target = True,
**get_oss_build_kwargs()
)