xref: /aosp_15_r20/build/soong/ui/metrics/metrics_proto/metrics.proto (revision 333d2b3687b3a337dbcca9d65000bca186795e39)
1*333d2b36SAndroid Build Coastguard Worker// Copyright 2018 Google Inc. All Rights Reserved.
2*333d2b36SAndroid Build Coastguard Worker//
3*333d2b36SAndroid Build Coastguard Worker// Licensed under the Apache License, Version 2.0 (the "License");
4*333d2b36SAndroid Build Coastguard Worker// you may not use this file except in compliance with the License.
5*333d2b36SAndroid Build Coastguard Worker// You may obtain a copy of the License at
6*333d2b36SAndroid Build Coastguard Worker//
7*333d2b36SAndroid Build Coastguard Worker//   http://www.apache.org/licenses/LICENSE-2.0
8*333d2b36SAndroid Build Coastguard Worker//
9*333d2b36SAndroid Build Coastguard Worker// Unless required by applicable law or agreed to in writing, software
10*333d2b36SAndroid Build Coastguard Worker// distributed under the License is distributed on an "AS IS" BASIS,
11*333d2b36SAndroid Build Coastguard Worker// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12*333d2b36SAndroid Build Coastguard Worker// See the License for the specific language governing permissions and
13*333d2b36SAndroid Build Coastguard Worker// limitations under the License.
14*333d2b36SAndroid Build Coastguard Worker
15*333d2b36SAndroid Build Coastguard Workersyntax = "proto2";
16*333d2b36SAndroid Build Coastguard Worker
17*333d2b36SAndroid Build Coastguard Workerpackage soong_build_metrics;
18*333d2b36SAndroid Build Coastguard Workeroption go_package = "android/soong/ui/metrics/metrics_proto";
19*333d2b36SAndroid Build Coastguard Worker
20*333d2b36SAndroid Build Coastguard Workermessage MetricsBase {
21*333d2b36SAndroid Build Coastguard Worker  // Timestamp generated when the build starts.
22*333d2b36SAndroid Build Coastguard Worker  optional int64 build_date_timestamp = 1;
23*333d2b36SAndroid Build Coastguard Worker
24*333d2b36SAndroid Build Coastguard Worker  // It is usually used to specify the branch name [and release candidate].
25*333d2b36SAndroid Build Coastguard Worker  optional string build_id  = 2;
26*333d2b36SAndroid Build Coastguard Worker
27*333d2b36SAndroid Build Coastguard Worker  // The platform version codename, eg. P, Q, REL.
28*333d2b36SAndroid Build Coastguard Worker  optional string platform_version_codename = 3;
29*333d2b36SAndroid Build Coastguard Worker
30*333d2b36SAndroid Build Coastguard Worker  // The target product information, eg. aosp_arm.
31*333d2b36SAndroid Build Coastguard Worker  optional string target_product = 4;
32*333d2b36SAndroid Build Coastguard Worker
33*333d2b36SAndroid Build Coastguard Worker  enum BuildVariant {
34*333d2b36SAndroid Build Coastguard Worker    USER = 0;
35*333d2b36SAndroid Build Coastguard Worker    USERDEBUG = 1;
36*333d2b36SAndroid Build Coastguard Worker    ENG = 2;
37*333d2b36SAndroid Build Coastguard Worker  }
38*333d2b36SAndroid Build Coastguard Worker  // The target build variant information, eg. eng.
39*333d2b36SAndroid Build Coastguard Worker  optional BuildVariant target_build_variant = 5 [default = ENG];
40*333d2b36SAndroid Build Coastguard Worker
41*333d2b36SAndroid Build Coastguard Worker  enum Arch {
42*333d2b36SAndroid Build Coastguard Worker    UNKNOWN = 0;
43*333d2b36SAndroid Build Coastguard Worker    ARM = 1;
44*333d2b36SAndroid Build Coastguard Worker    ARM64 = 2;
45*333d2b36SAndroid Build Coastguard Worker    X86 = 3;
46*333d2b36SAndroid Build Coastguard Worker    X86_64 = 4;
47*333d2b36SAndroid Build Coastguard Worker  }
48*333d2b36SAndroid Build Coastguard Worker  // The target arch information, eg. arm.
49*333d2b36SAndroid Build Coastguard Worker  optional Arch target_arch = 6 [default = UNKNOWN];
50*333d2b36SAndroid Build Coastguard Worker
51*333d2b36SAndroid Build Coastguard Worker  // The target arch variant information, eg. armv7-a-neon.
52*333d2b36SAndroid Build Coastguard Worker  optional string target_arch_variant = 7;
53*333d2b36SAndroid Build Coastguard Worker
54*333d2b36SAndroid Build Coastguard Worker  // The target cpu variant information, eg. generic.
55*333d2b36SAndroid Build Coastguard Worker  optional string target_cpu_variant = 8;
56*333d2b36SAndroid Build Coastguard Worker
57*333d2b36SAndroid Build Coastguard Worker  // The host arch information, eg. x86_64.
58*333d2b36SAndroid Build Coastguard Worker  optional Arch host_arch = 9 [default = UNKNOWN];
59*333d2b36SAndroid Build Coastguard Worker
60*333d2b36SAndroid Build Coastguard Worker  // The host 2nd arch information, eg. x86.
61*333d2b36SAndroid Build Coastguard Worker  optional Arch host_2nd_arch = 10 [default = UNKNOWN];
62*333d2b36SAndroid Build Coastguard Worker
63*333d2b36SAndroid Build Coastguard Worker  // The host os information, eg. linux.
64*333d2b36SAndroid Build Coastguard Worker  optional string host_os = 11;
65*333d2b36SAndroid Build Coastguard Worker
66*333d2b36SAndroid Build Coastguard Worker  // The host os extra information, eg. Linux-4.17.0-3rodete2-amd64-x86_64-Debian-GNU.
67*333d2b36SAndroid Build Coastguard Worker  optional string host_os_extra = 12;
68*333d2b36SAndroid Build Coastguard Worker
69*333d2b36SAndroid Build Coastguard Worker  // The host cross os information, eg. windows.
70*333d2b36SAndroid Build Coastguard Worker  optional string host_cross_os = 13;
71*333d2b36SAndroid Build Coastguard Worker
72*333d2b36SAndroid Build Coastguard Worker  // The host cross arch information, eg. x86.
73*333d2b36SAndroid Build Coastguard Worker  optional string host_cross_arch = 14;
74*333d2b36SAndroid Build Coastguard Worker
75*333d2b36SAndroid Build Coastguard Worker  // The host cross 2nd arch information, eg. x86_64.
76*333d2b36SAndroid Build Coastguard Worker  optional string host_cross_2nd_arch = 15;
77*333d2b36SAndroid Build Coastguard Worker
78*333d2b36SAndroid Build Coastguard Worker  // The directory for generated built artifacts installation, eg. out.
79*333d2b36SAndroid Build Coastguard Worker  optional string out_dir = 16;
80*333d2b36SAndroid Build Coastguard Worker
81*333d2b36SAndroid Build Coastguard Worker  // The metrics for calling various tools (microfactory) before Soong_UI starts.
82*333d2b36SAndroid Build Coastguard Worker  repeated PerfInfo setup_tools = 17;
83*333d2b36SAndroid Build Coastguard Worker
84*333d2b36SAndroid Build Coastguard Worker  // The metrics for calling Kati by multiple times.
85*333d2b36SAndroid Build Coastguard Worker  repeated PerfInfo kati_runs = 18;
86*333d2b36SAndroid Build Coastguard Worker
87*333d2b36SAndroid Build Coastguard Worker  // The metrics for calling Soong.
88*333d2b36SAndroid Build Coastguard Worker  repeated PerfInfo soong_runs = 19;
89*333d2b36SAndroid Build Coastguard Worker
90*333d2b36SAndroid Build Coastguard Worker  // The metrics for calling Ninja.
91*333d2b36SAndroid Build Coastguard Worker  repeated PerfInfo ninja_runs = 20;
92*333d2b36SAndroid Build Coastguard Worker
93*333d2b36SAndroid Build Coastguard Worker  // The metrics for the whole build
94*333d2b36SAndroid Build Coastguard Worker  optional PerfInfo total = 21;
95*333d2b36SAndroid Build Coastguard Worker
96*333d2b36SAndroid Build Coastguard Worker  // Deprecated because instead of embedding in a MetricsBase, we keep
97*333d2b36SAndroid Build Coastguard Worker  // SoongBuildMetrics in its own file
98*333d2b36SAndroid Build Coastguard Worker  optional SoongBuildMetrics soong_build_metrics = 22 [deprecated=true];
99*333d2b36SAndroid Build Coastguard Worker
100*333d2b36SAndroid Build Coastguard Worker  optional BuildConfig build_config = 23;
101*333d2b36SAndroid Build Coastguard Worker
102*333d2b36SAndroid Build Coastguard Worker  // The hostname of the machine.
103*333d2b36SAndroid Build Coastguard Worker  optional string hostname = 24;
104*333d2b36SAndroid Build Coastguard Worker
105*333d2b36SAndroid Build Coastguard Worker  // The system resource information such as total physical memory.
106*333d2b36SAndroid Build Coastguard Worker  optional SystemResourceInfo system_resource_info = 25;
107*333d2b36SAndroid Build Coastguard Worker
108*333d2b36SAndroid Build Coastguard Worker  // The build command that the user entered to the build system.
109*333d2b36SAndroid Build Coastguard Worker  optional string build_command = 26;
110*333d2b36SAndroid Build Coastguard Worker
111*333d2b36SAndroid Build Coastguard Worker  // The metrics for calling Bazel.
112*333d2b36SAndroid Build Coastguard Worker  repeated PerfInfo bazel_runs = 27;
113*333d2b36SAndroid Build Coastguard Worker
114*333d2b36SAndroid Build Coastguard Worker  // The metrics of the experiment config fetcher
115*333d2b36SAndroid Build Coastguard Worker  optional ExpConfigFetcher exp_config_fetcher = 28;
116*333d2b36SAndroid Build Coastguard Worker
117*333d2b36SAndroid Build Coastguard Worker  // Whether the build exited with a panic or non-zero exit code, includes both
118*333d2b36SAndroid Build Coastguard Worker  // non-zero exits of recorded phases and non-recorded phases of the build.
119*333d2b36SAndroid Build Coastguard Worker  optional bool non_zero_exit = 29;
120*333d2b36SAndroid Build Coastguard Worker
121*333d2b36SAndroid Build Coastguard Worker  // The error message due to a non-zero exit _only_ if it did not occur in a
122*333d2b36SAndroid Build Coastguard Worker  // recorded phase of the build.
123*333d2b36SAndroid Build Coastguard Worker  optional string error_message = 30;
124*333d2b36SAndroid Build Coastguard Worker
125*333d2b36SAndroid Build Coastguard Worker  // The Git Manifest for the user's branch.
126*333d2b36SAndroid Build Coastguard Worker  optional string manifest_url = 31;
127*333d2b36SAndroid Build Coastguard Worker
128*333d2b36SAndroid Build Coastguard Worker  // The branch on which the build occurred.
129*333d2b36SAndroid Build Coastguard Worker  // Example: refs/heads/master
130*333d2b36SAndroid Build Coastguard Worker  optional string branch = 32;
131*333d2b36SAndroid Build Coastguard Worker
132*333d2b36SAndroid Build Coastguard Worker  // The metric of critical path in build
133*333d2b36SAndroid Build Coastguard Worker  optional CriticalPathInfo critical_path_info = 33;
134*333d2b36SAndroid Build Coastguard Worker
135*333d2b36SAndroid Build Coastguard Worker  // Environment variables that have changed value since the previous build,
136*333d2b36SAndroid Build Coastguard Worker  // which were responsible for retriggering build analysis.
137*333d2b36SAndroid Build Coastguard Worker  // Note that not all changed environment variables result in analysis retriggering.
138*333d2b36SAndroid Build Coastguard Worker  // If there was no previous build, this list will be empty.
139*333d2b36SAndroid Build Coastguard Worker  repeated string changed_environment_variable = 34;
140*333d2b36SAndroid Build Coastguard Worker
141*333d2b36SAndroid Build Coastguard Worker  // Metrics related to optimized builds.
142*333d2b36SAndroid Build Coastguard Worker  optional OptimizedBuildMetrics optimized_build_metrics = 35;
143*333d2b36SAndroid Build Coastguard Worker}
144*333d2b36SAndroid Build Coastguard Worker
145*333d2b36SAndroid Build Coastguard Workermessage BuildConfig {
146*333d2b36SAndroid Build Coastguard Worker  enum NinjaWeightListSource {
147*333d2b36SAndroid Build Coastguard Worker    NOT_USED = 0;
148*333d2b36SAndroid Build Coastguard Worker    NINJA_LOG = 1;
149*333d2b36SAndroid Build Coastguard Worker    EVENLY_DISTRIBUTED = 2;
150*333d2b36SAndroid Build Coastguard Worker    EXTERNAL_FILE = 3;
151*333d2b36SAndroid Build Coastguard Worker    HINT_FROM_SOONG = 4;
152*333d2b36SAndroid Build Coastguard Worker  }
153*333d2b36SAndroid Build Coastguard Worker
154*333d2b36SAndroid Build Coastguard Worker  optional bool use_goma = 1;
155*333d2b36SAndroid Build Coastguard Worker
156*333d2b36SAndroid Build Coastguard Worker  optional bool use_rbe = 2;
157*333d2b36SAndroid Build Coastguard Worker
158*333d2b36SAndroid Build Coastguard Worker  optional bool force_use_goma = 3;
159*333d2b36SAndroid Build Coastguard Worker
160*333d2b36SAndroid Build Coastguard Worker  // Whether the Bazel is acting as the Ninja executor for this build.
161*333d2b36SAndroid Build Coastguard Worker  optional bool bazel_as_ninja = 4;
162*333d2b36SAndroid Build Coastguard Worker
163*333d2b36SAndroid Build Coastguard Worker  // Whether build is occurring in a mixed build mode, where Bazel maintains the
164*333d2b36SAndroid Build Coastguard Worker  // definition and build of some modules in cooperation with Soong.
165*333d2b36SAndroid Build Coastguard Worker  optional bool bazel_mixed_build = 5;
166*333d2b36SAndroid Build Coastguard Worker
167*333d2b36SAndroid Build Coastguard Worker  // These are the targets soong passes to ninja, these targets include special
168*333d2b36SAndroid Build Coastguard Worker  // targets such as droid as well as the regular build targets.
169*333d2b36SAndroid Build Coastguard Worker  repeated string targets = 6;
170*333d2b36SAndroid Build Coastguard Worker
171*333d2b36SAndroid Build Coastguard Worker  // Whether the user explicitly disabled bazel mixed builds for this build.
172*333d2b36SAndroid Build Coastguard Worker  optional bool force_disable_bazel_mixed_build = 7;
173*333d2b36SAndroid Build Coastguard Worker
174*333d2b36SAndroid Build Coastguard Worker  // NOT_USED - ninja doesn't use weight list.
175*333d2b36SAndroid Build Coastguard Worker  // NINJA_LOG - ninja uses weight list based on previous builds by ninja log
176*333d2b36SAndroid Build Coastguard Worker  // EVENLY_DISTRIBUTED - ninja thinks every task has the same weight.
177*333d2b36SAndroid Build Coastguard Worker  // EXTERNAL_FILE - ninja uses an external custom weight list
178*333d2b36SAndroid Build Coastguard Worker  // HINT_FROM_SOONG - ninja uses a prioritized module list from Soong
179*333d2b36SAndroid Build Coastguard Worker  optional NinjaWeightListSource ninja_weight_list_source = 8 [default = NOT_USED];
180*333d2b36SAndroid Build Coastguard Worker}
181*333d2b36SAndroid Build Coastguard Worker
182*333d2b36SAndroid Build Coastguard Workermessage SystemResourceInfo {
183*333d2b36SAndroid Build Coastguard Worker  // The total physical memory in bytes.
184*333d2b36SAndroid Build Coastguard Worker  optional uint64 total_physical_memory = 1;
185*333d2b36SAndroid Build Coastguard Worker
186*333d2b36SAndroid Build Coastguard Worker  // The total of available cores for building
187*333d2b36SAndroid Build Coastguard Worker  optional int32 available_cpus = 2;
188*333d2b36SAndroid Build Coastguard Worker
189*333d2b36SAndroid Build Coastguard Worker  // Information about the machine's CPU(s).
190*333d2b36SAndroid Build Coastguard Worker  optional SystemCpuInfo cpu_info = 3;
191*333d2b36SAndroid Build Coastguard Worker
192*333d2b36SAndroid Build Coastguard Worker  // Information about the machine's memory.
193*333d2b36SAndroid Build Coastguard Worker  optional SystemMemInfo mem_info = 4;
194*333d2b36SAndroid Build Coastguard Worker}
195*333d2b36SAndroid Build Coastguard Worker
196*333d2b36SAndroid Build Coastguard Workermessage SystemCpuInfo {
197*333d2b36SAndroid Build Coastguard Worker  // The vendor id
198*333d2b36SAndroid Build Coastguard Worker  optional string vendor_id = 1;
199*333d2b36SAndroid Build Coastguard Worker
200*333d2b36SAndroid Build Coastguard Worker  // The model name
201*333d2b36SAndroid Build Coastguard Worker  optional string model_name = 2;
202*333d2b36SAndroid Build Coastguard Worker
203*333d2b36SAndroid Build Coastguard Worker  // The number of CPU cores
204*333d2b36SAndroid Build Coastguard Worker  optional int32 cpu_cores = 3;
205*333d2b36SAndroid Build Coastguard Worker
206*333d2b36SAndroid Build Coastguard Worker  // The CPU flags
207*333d2b36SAndroid Build Coastguard Worker  optional string flags = 4;
208*333d2b36SAndroid Build Coastguard Worker}
209*333d2b36SAndroid Build Coastguard Worker
210*333d2b36SAndroid Build Coastguard Workermessage SystemMemInfo {
211*333d2b36SAndroid Build Coastguard Worker  // The total system memory
212*333d2b36SAndroid Build Coastguard Worker  optional uint64 mem_total = 1;
213*333d2b36SAndroid Build Coastguard Worker
214*333d2b36SAndroid Build Coastguard Worker  // The free system memory
215*333d2b36SAndroid Build Coastguard Worker  optional uint64 mem_free = 2;
216*333d2b36SAndroid Build Coastguard Worker
217*333d2b36SAndroid Build Coastguard Worker  // The available system memory
218*333d2b36SAndroid Build Coastguard Worker  optional uint64 mem_available = 3;
219*333d2b36SAndroid Build Coastguard Worker}
220*333d2b36SAndroid Build Coastguard Worker
221*333d2b36SAndroid Build Coastguard Workermessage PerfInfo {
222*333d2b36SAndroid Build Coastguard Worker  // The description for the phase/action/part while the tool running.
223*333d2b36SAndroid Build Coastguard Worker  optional string description = 1;
224*333d2b36SAndroid Build Coastguard Worker
225*333d2b36SAndroid Build Coastguard Worker  // The name for the running phase/action/part.
226*333d2b36SAndroid Build Coastguard Worker  optional string name = 2;
227*333d2b36SAndroid Build Coastguard Worker
228*333d2b36SAndroid Build Coastguard Worker  // The absolute start time.
229*333d2b36SAndroid Build Coastguard Worker  // The number of nanoseconds elapsed since January 1, 1970 UTC.
230*333d2b36SAndroid Build Coastguard Worker  optional uint64 start_time = 3;
231*333d2b36SAndroid Build Coastguard Worker
232*333d2b36SAndroid Build Coastguard Worker  // The real running time.
233*333d2b36SAndroid Build Coastguard Worker  // The number of nanoseconds elapsed since start_time.
234*333d2b36SAndroid Build Coastguard Worker  optional uint64 real_time = 4;
235*333d2b36SAndroid Build Coastguard Worker
236*333d2b36SAndroid Build Coastguard Worker  // The number of MB for memory use (deprecated as it is too generic).
237*333d2b36SAndroid Build Coastguard Worker  optional uint64 memory_use = 5 [deprecated=true];
238*333d2b36SAndroid Build Coastguard Worker
239*333d2b36SAndroid Build Coastguard Worker  // The resource information of each executed process.
240*333d2b36SAndroid Build Coastguard Worker  repeated ProcessResourceInfo processes_resource_info = 6;
241*333d2b36SAndroid Build Coastguard Worker
242*333d2b36SAndroid Build Coastguard Worker  // Whether the phase of tool running exited with a panic or non-zero exit
243*333d2b36SAndroid Build Coastguard Worker  // code.
244*333d2b36SAndroid Build Coastguard Worker  optional bool non_zero_exit = 7;
245*333d2b36SAndroid Build Coastguard Worker
246*333d2b36SAndroid Build Coastguard Worker  // The error message, if any, due to a non-zero exit.
247*333d2b36SAndroid Build Coastguard Worker  optional string error_message = 8;
248*333d2b36SAndroid Build Coastguard Worker}
249*333d2b36SAndroid Build Coastguard Worker
250*333d2b36SAndroid Build Coastguard Workermessage PerfCounters {
251*333d2b36SAndroid Build Coastguard Worker  // The timestamp of these counters in nanoseconds.
252*333d2b36SAndroid Build Coastguard Worker  optional uint64 time = 1;
253*333d2b36SAndroid Build Coastguard Worker
254*333d2b36SAndroid Build Coastguard Worker  // A list of counter names and values.
255*333d2b36SAndroid Build Coastguard Worker  repeated PerfCounterGroup groups = 2;
256*333d2b36SAndroid Build Coastguard Worker}
257*333d2b36SAndroid Build Coastguard Worker
258*333d2b36SAndroid Build Coastguard Workermessage PerfCounterGroup {
259*333d2b36SAndroid Build Coastguard Worker  // The name of this counter group (e.g. "cpu" or "memory")
260*333d2b36SAndroid Build Coastguard Worker  optional string name = 1;
261*333d2b36SAndroid Build Coastguard Worker
262*333d2b36SAndroid Build Coastguard Worker  // The counters in this group
263*333d2b36SAndroid Build Coastguard Worker  repeated PerfCounter counters = 2;
264*333d2b36SAndroid Build Coastguard Worker}
265*333d2b36SAndroid Build Coastguard Worker
266*333d2b36SAndroid Build Coastguard Workermessage PerfCounter {
267*333d2b36SAndroid Build Coastguard Worker  // The name of this counter.
268*333d2b36SAndroid Build Coastguard Worker  optional string name = 1;
269*333d2b36SAndroid Build Coastguard Worker
270*333d2b36SAndroid Build Coastguard Worker  // The value of this counter.
271*333d2b36SAndroid Build Coastguard Worker  optional int64 value = 2;
272*333d2b36SAndroid Build Coastguard Worker}
273*333d2b36SAndroid Build Coastguard Worker
274*333d2b36SAndroid Build Coastguard Workermessage ProcessResourceInfo {
275*333d2b36SAndroid Build Coastguard Worker  // The name of the process for identification.
276*333d2b36SAndroid Build Coastguard Worker  optional string name = 1;
277*333d2b36SAndroid Build Coastguard Worker
278*333d2b36SAndroid Build Coastguard Worker  // The amount of time spent executing in user space in microseconds.
279*333d2b36SAndroid Build Coastguard Worker  optional uint64 user_time_micros = 2;
280*333d2b36SAndroid Build Coastguard Worker
281*333d2b36SAndroid Build Coastguard Worker  // The amount of time spent executing in kernel mode in microseconds.
282*333d2b36SAndroid Build Coastguard Worker  optional uint64 system_time_micros = 3;
283*333d2b36SAndroid Build Coastguard Worker
284*333d2b36SAndroid Build Coastguard Worker  // The maximum resident set size memory used in kilobytes.
285*333d2b36SAndroid Build Coastguard Worker  optional uint64 max_rss_kb = 4;
286*333d2b36SAndroid Build Coastguard Worker
287*333d2b36SAndroid Build Coastguard Worker  // The number of minor page faults serviced without any I/O activity.
288*333d2b36SAndroid Build Coastguard Worker  optional uint64 minor_page_faults = 5;
289*333d2b36SAndroid Build Coastguard Worker
290*333d2b36SAndroid Build Coastguard Worker  // The number of major page faults serviced that required I/O activity.
291*333d2b36SAndroid Build Coastguard Worker  optional uint64 major_page_faults = 6;
292*333d2b36SAndroid Build Coastguard Worker
293*333d2b36SAndroid Build Coastguard Worker  // Total IO input in kilobytes.
294*333d2b36SAndroid Build Coastguard Worker  optional uint64 io_input_kb= 7;
295*333d2b36SAndroid Build Coastguard Worker
296*333d2b36SAndroid Build Coastguard Worker  // Total IO output in kilobytes.
297*333d2b36SAndroid Build Coastguard Worker  optional uint64 io_output_kb = 8;
298*333d2b36SAndroid Build Coastguard Worker
299*333d2b36SAndroid Build Coastguard Worker  // The number of voluntary context switches
300*333d2b36SAndroid Build Coastguard Worker  optional uint64 voluntary_context_switches = 9;
301*333d2b36SAndroid Build Coastguard Worker
302*333d2b36SAndroid Build Coastguard Worker  // The number of involuntary context switches
303*333d2b36SAndroid Build Coastguard Worker  optional uint64 involuntary_context_switches = 10;
304*333d2b36SAndroid Build Coastguard Worker}
305*333d2b36SAndroid Build Coastguard Worker
306*333d2b36SAndroid Build Coastguard Workermessage ModuleTypeInfo {
307*333d2b36SAndroid Build Coastguard Worker  enum BuildSystem {
308*333d2b36SAndroid Build Coastguard Worker    UNKNOWN = 0;
309*333d2b36SAndroid Build Coastguard Worker    SOONG = 1;
310*333d2b36SAndroid Build Coastguard Worker    MAKE = 2;
311*333d2b36SAndroid Build Coastguard Worker  }
312*333d2b36SAndroid Build Coastguard Worker  // The build system, e.g. Soong or Make.
313*333d2b36SAndroid Build Coastguard Worker  optional BuildSystem build_system = 1 [default = UNKNOWN];
314*333d2b36SAndroid Build Coastguard Worker
315*333d2b36SAndroid Build Coastguard Worker  // The module type, e.g. java_library, cc_binary, and etc.
316*333d2b36SAndroid Build Coastguard Worker  optional string module_type = 2;
317*333d2b36SAndroid Build Coastguard Worker
318*333d2b36SAndroid Build Coastguard Worker  // The number of logical modules.
319*333d2b36SAndroid Build Coastguard Worker  optional uint32 num_of_modules = 3;
320*333d2b36SAndroid Build Coastguard Worker}
321*333d2b36SAndroid Build Coastguard Worker
322*333d2b36SAndroid Build Coastguard Workermessage CriticalUserJourneyMetrics {
323*333d2b36SAndroid Build Coastguard Worker  // The name of a critical user journey test.
324*333d2b36SAndroid Build Coastguard Worker  optional string name = 1;
325*333d2b36SAndroid Build Coastguard Worker
326*333d2b36SAndroid Build Coastguard Worker  // The metrics produced when running the critical user journey test.
327*333d2b36SAndroid Build Coastguard Worker  optional MetricsBase metrics = 2;
328*333d2b36SAndroid Build Coastguard Worker}
329*333d2b36SAndroid Build Coastguard Worker
330*333d2b36SAndroid Build Coastguard Workermessage CriticalUserJourneysMetrics {
331*333d2b36SAndroid Build Coastguard Worker  // A set of metrics from a run of the critical user journey tests.
332*333d2b36SAndroid Build Coastguard Worker  repeated CriticalUserJourneyMetrics cujs = 1;
333*333d2b36SAndroid Build Coastguard Worker}
334*333d2b36SAndroid Build Coastguard Worker
335*333d2b36SAndroid Build Coastguard Workermessage SoongBuildMetrics {
336*333d2b36SAndroid Build Coastguard Worker  // The number of modules handled by soong_build.
337*333d2b36SAndroid Build Coastguard Worker  optional uint32 modules = 1;
338*333d2b36SAndroid Build Coastguard Worker
339*333d2b36SAndroid Build Coastguard Worker  // The total number of variants handled by soong_build.
340*333d2b36SAndroid Build Coastguard Worker  optional uint32 variants = 2;
341*333d2b36SAndroid Build Coastguard Worker
342*333d2b36SAndroid Build Coastguard Worker  // The total number of allocations in soong_build.
343*333d2b36SAndroid Build Coastguard Worker  optional uint64 total_alloc_count = 3;
344*333d2b36SAndroid Build Coastguard Worker
345*333d2b36SAndroid Build Coastguard Worker  // The total size of allocations in soong_build in bytes.
346*333d2b36SAndroid Build Coastguard Worker  optional uint64 total_alloc_size = 4;
347*333d2b36SAndroid Build Coastguard Worker
348*333d2b36SAndroid Build Coastguard Worker  // The approximate maximum size of the heap in soong_build in bytes.
349*333d2b36SAndroid Build Coastguard Worker  optional uint64 max_heap_size = 5;
350*333d2b36SAndroid Build Coastguard Worker
351*333d2b36SAndroid Build Coastguard Worker  // Runtime metrics for soong_build execution.
352*333d2b36SAndroid Build Coastguard Worker  repeated PerfInfo events = 6;
353*333d2b36SAndroid Build Coastguard Worker
354*333d2b36SAndroid Build Coastguard Worker  // Mixed Builds information
355*333d2b36SAndroid Build Coastguard Worker  optional MixedBuildsInfo mixed_builds_info = 7;
356*333d2b36SAndroid Build Coastguard Worker
357*333d2b36SAndroid Build Coastguard Worker  // Performance during for soong_build execution.
358*333d2b36SAndroid Build Coastguard Worker  repeated PerfCounters perf_counters = 8;
359*333d2b36SAndroid Build Coastguard Worker}
360*333d2b36SAndroid Build Coastguard Worker
361*333d2b36SAndroid Build Coastguard Workermessage ExpConfigFetcher {
362*333d2b36SAndroid Build Coastguard Worker  enum ConfigStatus {
363*333d2b36SAndroid Build Coastguard Worker    NO_CONFIG = 0;
364*333d2b36SAndroid Build Coastguard Worker    CONFIG = 1;
365*333d2b36SAndroid Build Coastguard Worker    ERROR = 2;
366*333d2b36SAndroid Build Coastguard Worker    MISSING_GCERT = 3;
367*333d2b36SAndroid Build Coastguard Worker  }
368*333d2b36SAndroid Build Coastguard Worker  // The result of the call to expconfigfetcher
369*333d2b36SAndroid Build Coastguard Worker  // NO_CONFIG - Not part of experiment
370*333d2b36SAndroid Build Coastguard Worker  // CONFIG - Part of experiment, config copied successfully
371*333d2b36SAndroid Build Coastguard Worker  // ERROR - expconfigfetcher failed
372*333d2b36SAndroid Build Coastguard Worker  optional ConfigStatus status = 1;
373*333d2b36SAndroid Build Coastguard Worker
374*333d2b36SAndroid Build Coastguard Worker  // The output config filename
375*333d2b36SAndroid Build Coastguard Worker  optional string filename = 2;
376*333d2b36SAndroid Build Coastguard Worker
377*333d2b36SAndroid Build Coastguard Worker  // Time, in microseconds, taken by the expconfigfetcher
378*333d2b36SAndroid Build Coastguard Worker  optional uint64 micros = 3;
379*333d2b36SAndroid Build Coastguard Worker}
380*333d2b36SAndroid Build Coastguard Worker
381*333d2b36SAndroid Build Coastguard Workermessage MixedBuildsInfo{
382*333d2b36SAndroid Build Coastguard Worker  // Modules may be listed below as both enabled for Mixed Builds
383*333d2b36SAndroid Build Coastguard Worker  // and disabled for Mixed Builds. This implies that some variants
384*333d2b36SAndroid Build Coastguard Worker  // of the module are handled by Bazel in a Mixed Build, and other
385*333d2b36SAndroid Build Coastguard Worker  // variants of the same module are handled by Soong.
386*333d2b36SAndroid Build Coastguard Worker
387*333d2b36SAndroid Build Coastguard Worker  // Modules that are enabled for Mixed Builds.
388*333d2b36SAndroid Build Coastguard Worker  repeated string mixed_build_enabled_modules = 1;
389*333d2b36SAndroid Build Coastguard Worker
390*333d2b36SAndroid Build Coastguard Worker  // Modules that are not currently eligible to be handled
391*333d2b36SAndroid Build Coastguard Worker  // by Bazel in a Mixed Build.
392*333d2b36SAndroid Build Coastguard Worker  // Note that not all modules exempt from Bazel handling are
393*333d2b36SAndroid Build Coastguard Worker  // listed. This list includes only modules which are of a
394*333d2b36SAndroid Build Coastguard Worker  // Mixed-Build supported module type but are nevertheless not
395*333d2b36SAndroid Build Coastguard Worker  // handled by Bazel. This may occur due to being present in
396*333d2b36SAndroid Build Coastguard Worker  // the mixed build denylist, or as part of an unsupported
397*333d2b36SAndroid Build Coastguard Worker  // mixed build variant type such as Windows.
398*333d2b36SAndroid Build Coastguard Worker
399*333d2b36SAndroid Build Coastguard Worker  // Modules that are not enabled for MixedBuilds
400*333d2b36SAndroid Build Coastguard Worker  repeated string mixed_build_disabled_modules = 2;
401*333d2b36SAndroid Build Coastguard Worker}
402*333d2b36SAndroid Build Coastguard Worker
403*333d2b36SAndroid Build Coastguard Worker// CriticalPathInfo contains critical path nodes's information.
404*333d2b36SAndroid Build Coastguard Worker// A critical path is a path determining the minimum time needed for the whole build given perfect parallelism.
405*333d2b36SAndroid Build Coastguard Workermessage CriticalPathInfo {
406*333d2b36SAndroid Build Coastguard Worker  // Real time which the build system spent in microseconds
407*333d2b36SAndroid Build Coastguard Worker  optional uint64 elapsed_time_micros = 1;
408*333d2b36SAndroid Build Coastguard Worker  // The sum of execution time of the longest path from leave to the root in microseconds
409*333d2b36SAndroid Build Coastguard Worker  optional uint64 critical_path_time_micros = 2;
410*333d2b36SAndroid Build Coastguard Worker  // Detailed job information in a critical path.
411*333d2b36SAndroid Build Coastguard Worker  repeated JobInfo critical_path = 4;
412*333d2b36SAndroid Build Coastguard Worker  // Detailed job information for long running jobs (>30 seconds). These may or may not also be on a critical path.
413*333d2b36SAndroid Build Coastguard Worker  repeated JobInfo long_running_jobs = 5;
414*333d2b36SAndroid Build Coastguard Worker}
415*333d2b36SAndroid Build Coastguard Worker
416*333d2b36SAndroid Build Coastguard Workermessage JobInfo {
417*333d2b36SAndroid Build Coastguard Worker  // Real time which a job spent in microseconds
418*333d2b36SAndroid Build Coastguard Worker  optional uint64 elapsed_time_micros = 1;
419*333d2b36SAndroid Build Coastguard Worker  // Description of a job
420*333d2b36SAndroid Build Coastguard Worker  optional string job_description = 2;
421*333d2b36SAndroid Build Coastguard Worker}
422*333d2b36SAndroid Build Coastguard Worker
423*333d2b36SAndroid Build Coastguard Workermessage OptimizedBuildMetrics {
424*333d2b36SAndroid Build Coastguard Worker  // The total time spent analyzing what/how to optimize everything.
425*333d2b36SAndroid Build Coastguard Worker  optional PerfInfo analysis_perf = 1;
426*333d2b36SAndroid Build Coastguard Worker  // The total time spent packaging artifacts.
427*333d2b36SAndroid Build Coastguard Worker  optional PerfInfo packaging_perf = 2;
428*333d2b36SAndroid Build Coastguard Worker  // Information for a single target (e.g. general-tests).
429*333d2b36SAndroid Build Coastguard Worker  repeated TargetOptimizationResult target_result = 3;
430*333d2b36SAndroid Build Coastguard Worker
431*333d2b36SAndroid Build Coastguard Worker  message TargetOptimizationResult {
432*333d2b36SAndroid Build Coastguard Worker    // Target name (e.g. general-tests).
433*333d2b36SAndroid Build Coastguard Worker    optional string name = 1;
434*333d2b36SAndroid Build Coastguard Worker    // Whether or not this target was optimized.
435*333d2b36SAndroid Build Coastguard Worker    optional bool optimized = 2;
436*333d2b36SAndroid Build Coastguard Worker    // Reasoning for why the target wasn't optimized if it wasn't
437*333d2b36SAndroid Build Coastguard Worker    optional string optimization_rationale = 3;
438*333d2b36SAndroid Build Coastguard Worker    // Time spent packaging this specific target (if it was optimized).
439*333d2b36SAndroid Build Coastguard Worker    optional PerfInfo packaging_perf = 4;
440*333d2b36SAndroid Build Coastguard Worker    // Information for each different artifact produced by this target (if it
441*333d2b36SAndroid Build Coastguard Worker    // was optimized).
442*333d2b36SAndroid Build Coastguard Worker    repeated OutputArtifact output_artifact = 5;
443*333d2b36SAndroid Build Coastguard Worker
444*333d2b36SAndroid Build Coastguard Worker    message OutputArtifact {
445*333d2b36SAndroid Build Coastguard Worker      // Artifact file name (e.g. general-tests.zip)
446*333d2b36SAndroid Build Coastguard Worker      optional string name = 1;
447*333d2b36SAndroid Build Coastguard Worker      // Size of the file.
448*333d2b36SAndroid Build Coastguard Worker      optional int64 size = 2;
449*333d2b36SAndroid Build Coastguard Worker      // Lists of modules packaged into this artifact.
450*333d2b36SAndroid Build Coastguard Worker      repeated string included_modules = 3;
451*333d2b36SAndroid Build Coastguard Worker    }
452*333d2b36SAndroid Build Coastguard Worker  }
453*333d2b36SAndroid Build Coastguard Worker}
454