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