1/* 2 * Copyright (C) 2017 The Android Open Source Project 3 * 4 * Licensed under the Apache License, Version 2.0 (the "License"); 5 * you may not use this file except in compliance with the License. 6 * You may obtain a copy of the License at 7 * 8 * http://www.apache.org/licenses/LICENSE-2.0 9 * 10 * Unless required by applicable law or agreed to in writing, software 11 * distributed under the License is distributed on an "AS IS" BASIS, 12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13 * See the License for the specific language governing permissions and 14 * limitations under the License. 15 */ 16 17syntax = "proto2"; 18 19package com.android.server.job; 20 21option java_multiple_files = true; 22 23import "frameworks/base/core/proto/android/content/clipdata.proto"; 24import "frameworks/base/core/proto/android/content/component_name.proto"; 25import "frameworks/base/core/proto/android/content/intent.proto"; 26import "frameworks/base/core/proto/android/net/network.proto"; 27import "frameworks/base/core/proto/android/net/networkrequest.proto"; 28import "frameworks/base/core/proto/android/os/bundle.proto"; 29import "frameworks/base/core/proto/android/os/persistablebundle.proto"; 30import "frameworks/base/core/proto/android/server/appstatetracker.proto"; 31import "frameworks/base/core/proto/android/server/statlogger.proto"; 32import "frameworks/base/core/proto/android/privacy.proto"; 33import "frameworks/base/core/proto/android/util/quotatracker.proto"; 34import "frameworks/proto_logging/stats/enums/app/job/job_enums.proto"; 35import "frameworks/proto_logging/stats/enums/server/job/enums.proto"; 36 37message JobSchedulerServiceDumpProto { 38 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 39 40 optional ConstantsProto settings = 1; 41 42 reserved 14; // current_heartbeat 43 reserved 15; // next_heartbeat 44 reserved 16; // last_heartbeat_time_millis 45 reserved 17; // next_heartbeat_time_millis 46 reserved 18; // in_parole 47 optional bool in_thermal = 19; 48 49 repeated int32 started_users = 2; 50 51 message JobRestriction { 52 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 53 54 optional .android.app.job.InternalStopReasonEnum reason = 1; 55 optional bool is_restricting = 2; 56 } 57 58 message RegisteredJob { 59 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 60 61 optional JobStatusShortInfoProto info = 1; 62 optional JobStatusDumpProto dump = 2; 63 64 optional bool is_job_ready_to_be_executed = 10; 65 // A job is ready to be executed if: 66 // is_job_ready && are_users_started && !is_job_restricted && !is_job_pending && 67 // !is_job_currently_active && !is_uid_backing_up && 68 // is_component_usable. 69 optional bool is_job_ready = 3; 70 optional bool are_users_started = 4; 71 optional bool is_job_restricted = 11; 72 optional bool is_job_pending = 5; 73 optional bool is_job_currently_active = 6; 74 optional bool is_uid_backing_up = 7; 75 optional bool is_component_usable = 8; 76 77 repeated JobRestriction restrictions = 12; 78 79 reserved 9; // last_run_heartbeat 80 81 // Next tag: 13 82 } 83 repeated RegisteredJob registered_jobs = 3; 84 85 repeated StateControllerProto controllers = 4; 86 87 // Which uids are currently in the foreground. 88 message PriorityOverride { 89 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 90 91 optional int32 uid = 1; 92 // Use sint32 instead of an enum since priorities can technically be 93 // negative. 94 optional sint32 override_value = 2; 95 } 96 repeated PriorityOverride priority_overrides = 5; 97 98 // UIDs that are currently performing backups, so their jobs won't be 99 // allowed to run. 100 repeated int32 backing_up_uids = 6; 101 102 optional JobPackageHistoryProto history = 7; 103 optional JobPackageTrackerDumpProto package_tracker = 8; 104 105 message PendingJob { 106 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 107 108 optional JobStatusShortInfoProto info = 1; 109 optional JobStatusDumpProto dump = 2; 110 optional sint32 evaluated_priority = 3; 111 // How long this job has been pending. 112 optional int64 pending_duration_ms = 4; 113 } 114 repeated PendingJob pending_jobs = 9; 115 116 // From a service that has currently active or pending jobs. 117 message ActiveJob { 118 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 119 120 message InactiveJob { 121 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 122 123 optional int64 time_since_stopped_ms = 1; 124 // This is not always provided. 125 optional string stopped_reason = 2; 126 } 127 message RunningJob { 128 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 129 130 optional JobStatusShortInfoProto info = 1; 131 // How long this job has been running for. 132 optional int64 running_duration_ms = 2; 133 optional int64 time_until_timeout_ms = 3; 134 135 optional JobStatusDumpProto dump = 4; 136 137 optional sint32 evaluated_priority = 5; 138 139 optional int64 time_since_made_active_ms = 6; 140 // How long this job was pending before it became active. 141 optional int64 pending_duration_ms = 7; 142 } 143 oneof job { 144 InactiveJob inactive = 1; 145 RunningJob running = 2; 146 } 147 } 148 repeated ActiveJob active_jobs = 10; 149 150 // True when JobScheduler is allowed to run third party apps. 151 optional bool is_ready_to_rock = 11; 152 // What was last reported to DeviceIdleController about whether the device 153 // is active. 154 optional bool reported_active = 12; 155 // The current limit on the number of concurrent JobServiceContext entries 156 // we want to keep actively running a job. 157 optional int32 max_active_jobs = 13; 158 159 // Dump from JobConcurrencyManager. 160 optional JobConcurrencyManagerProto concurrency_manager = 20; 161 162 optional JobStorePersistStatsProto persist_stats = 21; 163 164 optional .android.util.quota.CountQuotaTrackerProto quota_tracker = 22; 165 166 // Next tag: 23 167} 168 169// A com.android.server.job.JobSchedulerService.Constants object. 170message ConstantsProto { 171 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 172 173 reserved 1; // min_idle_count 174 reserved 2; // min_charging_count 175 reserved 3; // min_battery_not_low_count 176 reserved 4; // min_storage_not_low_count 177 reserved 5; // min_connectivity_count 178 reserved 6; // min_content_count 179 reserved 7; // min_ready_jobs_count 180 // Minimum # of non-ACTIVE jobs for which the JMS will be happy running some work early. 181 optional int32 min_ready_non_active_jobs_count = 29; 182 // Don't batch a non-ACTIVE job if it's been delayed due to force batching attempts for 183 // at least this amount of time. 184 optional int64 max_non_active_job_batch_delay_ms = 30; 185 // This is the job execution factor that is considered to be heavy use of 186 // the system. 187 optional double heavy_use_factor = 8; 188 // This is the job execution factor that is considered to be moderate use of 189 // the system. 190 optional double moderate_use_factor = 9; 191 // The number of MAX_JOB_CONTEXTS_COUNT we reserve for the foreground app. 192 optional int32 fg_job_count = 10; 193 // The maximum number of background jobs we allow when the system is in a 194 // normal memory state. 195 optional int32 bg_normal_job_count = 11; 196 // The maximum number of background jobs we allow when the system is in a 197 // moderate memory state. 198 optional int32 bg_moderate_job_count = 12; 199 // The maximum number of background jobs we allow when the system is in a 200 // low memory state. 201 optional int32 bg_low_job_count = 13; 202 // The maximum number of background jobs we allow when the system is in a 203 // critical memory state. 204 optional int32 bg_critical_job_count = 14; 205 reserved 15; // max_standard_reschedule_count 206 reserved 16; // max_work_reschedule_count 207 // The minimum backoff time to allow for linear backoff. 208 optional int64 min_linear_backoff_time_ms = 17; 209 // The minimum backoff time to allow for exponential backoff. 210 optional int64 min_exp_backoff_time_ms = 18; 211 // How often we recalculate runnability based on apps' standby bucket 212 // assignment. This should be prime relative to common time interval lengths 213 // such as a quarter-hour or day, so that the heartbeat drifts relative to 214 // wall-clock milestones. 215 reserved 19; // standby_heartbeat_time_ms 216 // Mapping: standby bucket -> number of heartbeats between each sweep of 217 // that bucket's jobs. 218 // Bucket assignments as recorded in the JobStatus objects are normalized to 219 // be indices into this array, rather than the raw constants used by 220 // AppIdleHistory. 221 reserved 20; // standby_beats 222 // The fraction of a job's running window that must pass before we 223 // consider running it when the network is congested. 224 optional double conn_congestion_delay_frac = 21; 225 // The fraction of a prefetch job's running window that must pass before 226 // we consider matching it against a metered network. 227 optional double conn_prefetch_relax_frac = 22; 228 // Whether to use heartbeats or rolling window for quota management. True 229 // will use heartbeats, false will use a rolling window. 230 reserved 23; // use_heartbeats 231 // Whether to enable quota limits on APIs. 232 optional bool enable_api_quotas = 31; 233 // The maximum number of schedule() calls an app can make in a set amount of time. 234 optional int32 api_quota_schedule_count = 32; 235 // The time window that {@link #API_QUOTA_SCHEDULE_COUNT} should be evaluated over. 236 optional int64 api_quota_schedule_window_ms = 33; 237 // Whether or not to throw an exception when an app hits its schedule quota limit. 238 optional bool api_quota_schedule_throw_exception = 34; 239 // Whether or not to return a failure result when an app hits its schedule quota limit. 240 optional bool api_quota_schedule_return_failure_result = 35; 241 242 message QuotaController { 243 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 244 245 // How much time each app will have to run jobs within their standby bucket window. 246 optional int64 allowed_time_per_period_ms = 1; 247 // How much time the package should have before transitioning from out-of-quota to in-quota. 248 // This should not affect processing if the package is already in-quota. 249 optional int64 in_quota_buffer_ms = 2; 250 // The quota window size of the particular standby bucket. Apps in this standby bucket are 251 // expected to run only {@link QUOTA_CONTROLLER_ALLOWED_TIME_PER_PERIOD_MS} within the past 252 // WINDOW_SIZE_MS. 253 optional int64 active_window_size_ms = 3; 254 // The quota window size of the particular standby bucket. Apps in this standby bucket are 255 // expected to run only {@link QUOTA_CONTROLLER_ALLOWED_TIME_PER_PERIOD_MS} within the past 256 // WINDOW_SIZE_MS. 257 optional int64 working_window_size_ms = 4; 258 // The quota window size of the particular standby bucket. Apps in this standby bucket are 259 // expected to run only {@link QUOTA_CONTROLLER_ALLOWED_TIME_PER_PERIOD_MS} within the past 260 // WINDOW_SIZE_MS. 261 optional int64 frequent_window_size_ms = 5; 262 // The quota window size of the particular standby bucket. Apps in this standby bucket are 263 // expected to run only {@link QUOTA_CONTROLLER_ALLOWED_TIME_PER_PERIOD_MS} within the past 264 // WINDOW_SIZE_MS. 265 optional int64 rare_window_size_ms = 6; 266 // The quota window size of the particular standby bucket. Apps in this standby bucket are 267 // expected to run only {@link QUOTA_CONTROLLER_ALLOWED_TIME_PER_PERIOD_MS} within the past 268 // WINDOW_SIZE_MS. 269 optional int64 restricted_window_size_ms = 20; 270 // The maximum amount of time an app can have its jobs running within a 24 hour window. 271 optional int64 max_execution_time_ms = 7; 272 // The maximum number of jobs an app can run within this particular standby bucket's 273 // window size. 274 optional int32 max_job_count_active = 8; 275 // The maximum number of jobs an app can run within this particular standby bucket's 276 // window size. 277 optional int32 max_job_count_working = 9; 278 // The maximum number of jobs an app can run within this particular standby bucket's 279 // window size. 280 optional int32 max_job_count_frequent = 10; 281 // The maximum number of jobs an app can run within this particular standby bucket's 282 // window size. 283 optional int32 max_job_count_rare = 11; 284 // The maximum number of jobs an app can run within this particular standby bucket's 285 // window size. 286 optional int32 max_job_count_restricted = 21; 287 // The period of time used to rate limit recently run jobs. 288 optional int32 rate_limiting_window_ms = 19; 289 // The maximum number of jobs that should be allowed to run in the past 290 // rate_limiting_window_ms. 291 optional int32 max_job_count_per_rate_limiting_window = 12; 292 // The maximum number of timing sessions an app can run within this particular standby 293 // bucket's window size. 294 optional int32 max_session_count_active = 13; 295 // The maximum number of timing sessions an app can run within this particular standby 296 // bucket's window size. 297 optional int32 max_session_count_working = 14; 298 // The maximum number of timing sessions an app can run within this particular standby 299 // bucket's window size. 300 optional int32 max_session_count_frequent = 15; 301 // The maximum number of timing sessions an app can run within this particular standby 302 // bucket's window size. 303 optional int32 max_session_count_rare = 16; 304 // The maximum number of timing sessions an app can run within this particular standby 305 // bucket's window size. 306 optional int32 max_session_count_restricted = 22; 307 // The maximum number of timing sessions that should be allowed to run in the past 308 // rate_limiting_window_ms. 309 optional int32 max_session_count_per_rate_limiting_window = 17; 310 // Treat two distinct {@link TimingSession}s as the same if they start and end within this 311 // amount of time of each other. 312 optional int64 timing_session_coalescing_duration_ms = 18; 313 // The minimum amount of time between quota check alarms. 314 optional int64 min_quota_check_delay_ms = 23; 315 316 // The total expedited job session limit of the particular standby bucket. Apps in this 317 // standby bucket can only have expedited job sessions totalling EJ_LIMIT (without factoring 318 // in any rewards or free EJs). 319 optional int64 expedited_job_limit_active_ms = 24; 320 // The total expedited job session limit of the particular standby bucket. Apps in this 321 // standby bucket can only have expedited job sessions totalling EJ_LIMIT (without factoring 322 // in any rewards or free EJs). 323 optional int64 expedited_job_limit_working_ms = 25; 324 // The total expedited job session limit of the particular standby bucket. Apps in this 325 // standby bucket can only have expedited job sessions totalling EJ_LIMIT (without factoring 326 // in any rewards or free EJs). 327 optional int64 expedited_job_limit_frequent_ms = 26; 328 // The total expedited job session limit of the particular standby bucket. Apps in this 329 // standby bucket can only have expedited job sessions totalling EJ_LIMIT (without factoring 330 // in any rewards or free EJs). 331 optional int64 expedited_job_limit_rare_ms = 27; 332 // The total expedited job session limit of the particular standby bucket. Apps in this 333 // standby bucket can only have expedited job sessions totalling EJ_LIMIT (without factoring 334 // in any rewards or free EJs). 335 optional int64 expedited_job_limit_restricted_ms = 28; 336 // The period of time used to calculate expedited job sessions. Apps can only have expedited 337 // job sessions totalling EJ_LIMIT_<bucket>_MS within this period of time (without factoring 338 // in any rewards or free EJs). 339 optional int64 expedited_job_window_size_ms = 29; 340 // Length of time used to split an app's top time into chunks. 341 optional int64 expedited_job_top_app_time_chunk_size_ms = 30; 342 // How much EJ quota to give back to an app based on the number of top app time chunks 343 // it had. 344 optional int64 expedited_job_reward_top_app_ms = 31; 345 // How much EJ quota to give back to an app based on each non-top user interaction. 346 optional int64 expedited_job_reward_interaction_ms = 32; 347 // How much EJ quota to give back to an app based on each notification seen event. 348 optional int64 expedited_job_reward_notification_seen_ms = 33; 349 350 // Next tag: 34 351 } 352 optional QuotaController quota_controller = 24; 353 354 message TimeController { 355 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 356 357 // Whether or not TimeController should skip setting wakeup alarms for jobs that aren't 358 // ready now. 359 reserved 1; // skip_not_ready_jobs 360 // Whether or not TimeController will use a non-wakeup alarm for delay constraints. 361 reserved 2; // use_non_wakeup_alarm_for_delay 362 } 363 optional TimeController time_controller = 25; 364 365 // Max number of jobs, when screen is ON. 366 optional MaxJobCountsPerMemoryTrimLevelProto max_job_counts_screen_on = 26; 367 368 // Max number of jobs, when screen is OFF. 369 optional MaxJobCountsPerMemoryTrimLevelProto max_job_counts_screen_off = 27; 370 371 // In this time after screen turns on, we increase job concurrency. 372 optional int32 screen_off_job_concurrency_increase_delay_ms = 28; 373 374 // Next tag: 36 375} 376 377// Next tag: 4 378message MaxJobCountsProto { 379 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 380 381 // Total number of jobs to run simultaneously. 382 optional int32 total_jobs = 1; 383 384 // Max number of BG (== owned by non-TOP apps) jobs to run simultaneously. 385 optional int32 max_bg = 2; 386 387 // We try to run at least this many BG (== owned by non-TOP apps) jobs, when there are any 388 // pending, rather than always running the TOTAL number of FG jobs. 389 optional int32 min_bg = 3; 390} 391 392// Next tag: 5 393message MaxJobCountsPerMemoryTrimLevelProto { 394 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 395 396 optional MaxJobCountsProto normal = 1; 397 optional MaxJobCountsProto moderate = 2; 398 optional MaxJobCountsProto low = 3; 399 optional MaxJobCountsProto critical = 4; 400} 401 402message StateControllerProto { 403 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 404 405 message BackgroundJobsController { 406 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 407 408 optional com.android.server.AppStateTrackerProto app_state_tracker = 1; 409 410 message TrackedJob { 411 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 412 413 optional JobStatusShortInfoProto info = 1; 414 optional int32 source_uid = 2; 415 optional string source_package_name = 3; 416 optional bool is_in_foreground = 4; 417 optional bool is_whitelisted = 5; 418 optional bool can_run_any_in_background = 6; 419 // If the constraints are satisfied, then the controller will mark 420 // the job as RUNNABLE, otherwise, it will be WAITING. 421 optional bool are_constraints_satisfied = 7; 422 } 423 repeated TrackedJob tracked_jobs = 2; 424 } 425 message BatteryController { 426 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 427 428 optional bool is_on_stable_power = 1; 429 optional bool is_battery_not_low = 2; 430 431 // Whether or not the controller is monitoring battery changes. 432 optional bool is_monitoring = 3; 433 // Only valid if is_monitoring is true. 434 optional int32 last_broadcast_sequence_number = 4; 435 436 message TrackedJob { 437 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 438 439 optional JobStatusShortInfoProto info = 1; 440 optional int32 source_uid = 2; 441 } 442 repeated TrackedJob tracked_jobs = 5; 443 } 444 message ConnectivityController { 445 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 446 447 reserved 1; // is_connected 448 449 message TrackedJob { 450 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 451 452 optional JobStatusShortInfoProto info = 1; 453 optional int32 source_uid = 2; 454 optional .android.net.NetworkRequestProto required_network = 3; 455 } 456 repeated TrackedJob tracked_jobs = 2; 457 458 // List of the UIDs that ConnectivityController has requested that NetworkPolicyManager 459 // grant an exception to in the app standby chain. 460 repeated int32 requested_standby_exception_uids = 3; 461 462 repeated .android.net.NetworkProto available_networks = 4; 463 } 464 message ContentObserverController { 465 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 466 467 message TrackedJob { 468 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 469 470 optional JobStatusShortInfoProto info = 1; 471 optional int32 source_uid = 2; 472 } 473 repeated TrackedJob tracked_jobs = 1; 474 475 message Observer { 476 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 477 478 optional int32 user_id = 1; 479 480 message TriggerContentData { 481 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 482 483 optional string uri = 1 [ 484 (.android.privacy).dest = DEST_EXPLICIT 485 ]; 486 optional int32 flags = 2; 487 488 // A 489 // com.android.server.job.controllers.ContentObserverController.JobInstance 490 // object. 491 message JobInstance { 492 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 493 494 optional JobStatusShortInfoProto info = 1; 495 optional int32 source_uid = 2; 496 497 optional int64 trigger_content_update_delay_ms = 3; 498 optional int64 trigger_content_max_delay_ms = 4; 499 500 repeated string changed_authorities = 5 [ 501 (.android.privacy).dest = DEST_EXPLICIT 502 ]; 503 repeated string changed_uris = 6 [ 504 (.android.privacy).dest = DEST_EXPLICIT 505 ]; 506 } 507 repeated JobInstance jobs = 3; 508 } 509 repeated TriggerContentData triggers = 2; 510 } 511 repeated Observer observers = 2; 512 } 513 message DeviceIdleJobsController { 514 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 515 516 // True when in device idle mode. 517 optional bool is_device_idle_mode = 1; 518 519 message TrackedJob { 520 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 521 522 optional JobStatusShortInfoProto info = 1; 523 optional int32 source_uid = 2; 524 optional string source_package_name = 3; 525 // If the constraints are satisfied, then the controller will mark 526 // the job as RUNNABLE, otherwise, it will be WAITING. 527 optional bool are_constraints_satisfied = 4; 528 optional bool is_doze_whitelisted = 5; 529 // A job that is exempted from Doze when the app is temp whitelisted 530 // or in the foreground. 531 optional bool is_allowed_in_doze = 6; 532 } 533 repeated TrackedJob tracked_jobs = 2; 534 } 535 message IdleController { 536 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 537 538 optional bool is_idle = 1; 539 540 message TrackedJob { 541 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 542 543 optional JobStatusShortInfoProto info = 1; 544 optional int32 source_uid = 2; 545 } 546 repeated TrackedJob tracked_jobs = 2; 547 548 message IdlenessTracker { 549 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 550 551 message CarIdlenessTracker { 552 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 553 554 optional bool is_idle = 1; 555 optional bool is_garage_mode_on = 2; 556 } 557 558 message DeviceIdlenessTracker { 559 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 560 561 optional bool is_idle = 1; 562 optional bool is_screen_on = 2; 563 optional bool is_dock_idle = 3; 564 reserved 4; // in_car_mode 565 optional bool projection_active = 5; 566 } 567 568 oneof active_tracker { 569 DeviceIdlenessTracker device_idleness_tracker = 1; 570 CarIdlenessTracker car_idleness_tracker = 2; 571 } 572 } 573 optional IdlenessTracker idleness_tracker = 3; 574 } 575 message QuotaController { 576 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 577 578 optional bool is_charging = 1; 579 reserved 2; // is_in_parole 580 optional int64 elapsed_realtime = 6; 581 582 // List of UIDs currently in the foreground. 583 repeated int32 foreground_uids = 3; 584 585 message TrackedJob { 586 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 587 588 optional JobStatusShortInfoProto info = 1; 589 optional int32 source_uid = 2; 590 optional JobStatusDumpProto.Bucket effective_standby_bucket = 3; 591 // If the job started while the app was in the TOP state. 592 optional bool is_top_started_job = 4; 593 optional bool has_quota = 5; 594 // The amount of time that this job has remaining in its quota. This 595 // can be negative if the job is out of quota. 596 optional int64 remaining_quota_ms = 6; 597 // True if the app has requested that this be a foreground job. 598 optional bool is_requested_foreground_job = 7; 599 // True if this job is within the foreground quota bounds and is therefore allowed to 600 // run as a foreground job. Valid only if is_foreground_requested_job is true. 601 optional bool is_within_fg_job_quota = 8; 602 } 603 repeated TrackedJob tracked_jobs = 4; 604 605 message AlarmListener { 606 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 607 608 // Whether the listener is waiting for an alarm or not. 609 optional bool is_waiting = 1; 610 // The time at which the alarm should go off, in the elapsed realtime timebase. Only 611 // valid if is_waiting is true. 612 optional int64 trigger_time_elapsed = 2; 613 } 614 615 message ExecutionStats { 616 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 617 618 optional JobStatusDumpProto.Bucket standby_bucket = 1; 619 620 // The time after which this record should be considered invalid (out of date), in the 621 // elapsed realtime timebase. 622 optional int64 expiration_time_elapsed = 2; 623 optional int64 window_size_ms = 3; 624 625 optional int32 job_count_limit = 14; 626 optional int32 session_count_limit = 15; 627 628 // The total amount of time the app ran in its respective bucket window size. 629 optional int64 execution_time_in_window_ms = 4; 630 optional int32 bg_job_count_in_window = 5; 631 632 // The total amount of time the app ran in the last 633 // {@link QuotaController#MAX_PERIOD_MS}. 634 optional int64 execution_time_in_max_period_ms = 6; 635 optional int32 bg_job_count_in_max_period = 7; 636 637 // The number of {@link TimingSession}s within the bucket window size. This will include 638 // sessions that started before the window as long as they end within the window. 639 optional int32 session_count_in_window = 11; 640 641 // The time after which the app will be under the bucket quota. This is only valid if 642 // execution_time_in_window_ms >= 643 // ConstantsProto.QuotaController.allowed_time_per_period_ms 644 // or 645 // execution_time_in_max_period_ms >= 646 // ConstantsProto.QuotaController.max_execution_time_ms 647 // or 648 // bg_job_count_in_window >= job_count_limit 649 // or 650 // session_count_in_window >= session_count_limit. 651 optional int64 in_quota_time_elapsed = 8; 652 653 // The time after which job_count_in_rate_limiting_window should be considered invalid, 654 // in the elapsed realtime timebase. 655 optional int64 job_count_expiration_time_elapsed = 9; 656 657 // The number of jobs that ran in at least the last 658 // ConstantsProto.QuotaController.rate_limiting_window_ms. 659 // It may contain a few stale entries since cleanup won't happen exactly every 660 // ConstantsProto.QuotaController.rate_limiting_window_ms. This should only be 661 // considered valid before elapsed realtime has reached 662 // job_count_expiration_time_elapsed. 663 optional int32 job_count_in_rate_limiting_window = 10; 664 665 // The time after which {@link #timingSessionCountInAllowedTime} should be considered 666 // invalid, in the elapsed realtime timebase. 667 optional int64 session_count_expiration_time_elapsed = 12; 668 669 // The number of {@link TimingSession}s that ran in at least the last 670 // ConstantsProto.QuotaController.rate_limiting_window_ms. It may contain a few stale 671 // entries since cleanup won't happen exactly every 672 // ConstantsProto.QuotaController.rate_limiting_window_ms. This should only be considered 673 // valid before elapsed realtime has reached session_count_expiration_time_elapsed. 674 optional int32 session_count_in_rate_limiting_window = 13; 675 } 676 677 message Package { 678 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 679 680 optional int32 user_id = 1; 681 optional string name = 2; 682 } 683 684 message TimingSession { 685 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 686 687 optional int64 start_time_elapsed = 1; 688 optional int64 end_time_elapsed = 2; 689 // The number of background jobs that ran during this session. 690 optional int32 bg_job_count = 3; 691 } 692 693 message Timer { 694 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 695 696 optional Package pkg = 1; 697 // True if the Timer is actively tracking jobs. 698 optional bool is_active = 2; 699 // The time this timer last became active. Only valid if is_active is true. 700 optional int64 start_time_elapsed = 3; 701 // How many background jobs are currently running. Valid only if is_active is true. 702 optional int32 bg_job_count = 4; 703 // All of the jobs that the Timer is currently tracking. 704 repeated JobStatusShortInfoProto running_jobs = 5; 705 } 706 707 message TopAppTimer { 708 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 709 710 optional Package pkg = 1; 711 // True if the Timer is actively tracking jobs. 712 optional bool is_active = 2; 713 // The time this timer last became active. Only valid if is_active is true. 714 optional int64 start_time_elapsed = 3; 715 // How many activities are currently in the RESUMED state. Valid only if is_active is 716 // true. 717 optional int32 activity_count = 4; 718 } 719 720 message PackageStats { 721 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 722 723 optional Package pkg = 1; 724 725 optional Timer timer = 2; 726 727 repeated TimingSession saved_sessions = 3; 728 729 repeated ExecutionStats execution_stats = 4; 730 731 reserved 5; // in_quota_alarm_listener 732 733 optional Timer fg_job_timer = 6; 734 } 735 repeated PackageStats package_stats = 5; 736 737 // Set of package names for each UID. 738 message UidPackageMapping { 739 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 740 741 optional int32 uid = 1; 742 repeated string package_names = 2; 743 } 744 repeated UidPackageMapping uid_to_package_cache = 7; 745 746 message InQuotaAlarmListener { 747 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 748 749 // The time at which the alarm is set to go off, in the elapsed realtime timebase. 750 optional int64 trigger_time_elapsed = 1; 751 752 message Alarm { 753 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 754 755 optional Package pkg = 1; 756 757 // The time at which the package will be in quota, in the elapsed realtime timebase. 758 optional int64 in_quota_time_elapsed = 2; 759 } 760 repeated Alarm alarms = 2; 761 } 762 optional InQuotaAlarmListener in_quota_alarm_listener = 8; 763 764 // Next tag: 9 765 } 766 message StorageController { 767 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 768 769 optional bool is_storage_not_low = 1; 770 optional int32 last_broadcast_sequence_number = 2; 771 772 message TrackedJob { 773 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 774 775 optional JobStatusShortInfoProto info = 1; 776 optional int32 source_uid = 2; 777 } 778 repeated TrackedJob tracked_jobs = 3; 779 } 780 message TimeController { 781 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 782 783 optional int64 now_elapsed_realtime = 1; 784 optional int64 time_until_next_delay_alarm_ms = 2; 785 optional int64 time_until_next_deadline_alarm_ms = 3; 786 787 message TrackedJob { 788 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 789 790 optional JobStatusShortInfoProto info = 1; 791 optional int32 source_uid = 2; 792 793 optional bool has_timing_delay_constraint = 3; 794 // Only valid if has_timing_delay_constraint is true. Can be 795 // negative if the delay is in the past. 796 optional int64 delay_time_remaining_ms = 4; 797 798 optional bool has_deadline_constraint = 5; 799 // Only valid if has_timing_delay_constraint is true. Can be 800 // negative in certain situations. 801 optional int64 time_remaining_until_deadline_ms = 6; 802 } 803 repeated TrackedJob tracked_jobs = 4; 804 } 805 oneof controller { 806 BackgroundJobsController background = 1; 807 BatteryController battery = 2; 808 ConnectivityController connectivity = 3; 809 ContentObserverController content_observer = 4; 810 DeviceIdleJobsController device_idle = 5; 811 IdleController idle = 6; 812 QuotaController quota = 9; 813 StorageController storage = 7; 814 TimeController time = 8; 815 // Next tag: 10 816 } 817} 818 819// A com.android.server.job.JobPackageTracker.DataSet object. 820message DataSetProto { 821 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 822 823 optional int64 start_clock_time_ms = 1; 824 // How much time has elapsed since the DataSet was instantiated. 825 optional int64 elapsed_time_ms = 2; 826 optional int64 period_ms = 3; 827 828 // Represents a com.android.server.job.JobPackageTracker.PackageEntry 829 // object, but with some extra data. 830 message PackageEntryProto { 831 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 832 833 optional int32 uid = 1; 834 optional string package_name = 2; 835 836 message State { 837 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 838 839 optional int64 duration_ms = 1; 840 optional int32 count = 2; 841 } 842 optional State pending_state = 3; 843 optional State active_state = 4; 844 optional State active_top_state = 5; 845 846 // True if the PackageEntry is currently pending or has been pending in 847 // the past. 848 optional bool pending = 6; 849 // True if the PackageEntry is currently active or has been active in 850 // the past. 851 optional bool active = 7; 852 // True if the PackageEntry is currently active top or has been active 853 // top in the past. 854 optional bool active_top = 8; 855 856 message StopReasonCount { 857 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 858 859 optional .android.app.job.InternalStopReasonEnum reason = 1; 860 optional int32 count = 2; 861 } 862 repeated StopReasonCount stop_reasons = 9; 863 } 864 repeated PackageEntryProto package_entries = 4; 865 866 optional int32 max_concurrency = 5; 867 optional int32 max_foreground_concurrency = 6; 868} 869 870// Dump from com.android.server.job.GrantedUriPermissions. 871message GrantedUriPermissionsDumpProto { 872 option (.android.msg_privacy).dest = DEST_EXPLICIT; 873 874 optional int32 flags = 1 [ (.android.privacy).dest = DEST_AUTOMATIC ]; 875 optional int32 source_user_id = 2 [ 876 (.android.privacy).dest = DEST_AUTOMATIC 877 ]; 878 optional string tag = 3; 879 optional string permission_owner = 4; 880 repeated string uris = 5; 881} 882 883message JobPackageTrackerDumpProto { 884 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 885 886 repeated DataSetProto historical_stats = 1; 887 optional DataSetProto current_stats = 2; 888} 889 890message JobPackageHistoryProto { 891 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 892 893 enum Event { 894 UNKNOWN = 0; 895 START_JOB = 1; 896 STOP_JOB = 2; 897 START_PERIODIC_JOB = 3; 898 STOP_PERIODIC_JOB = 4; 899 } 900 message HistoryEvent { 901 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 902 903 optional Event event = 1; 904 optional int64 time_since_event_ms = 2; 905 optional int32 uid = 3; 906 // Job IDs can technically be negative. 907 optional int32 job_id = 4; 908 optional string tag = 5; 909 // Only valid for STOP_JOB or STOP_PERIODIC_JOB Events. 910 optional .android.app.job.InternalStopReasonEnum stop_reason = 6; 911 } 912 repeated HistoryEvent history_event = 1; 913} 914 915message JobStatusShortInfoProto { 916 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 917 918 optional int32 calling_uid = 1; 919 // Job IDs can technically be negative. 920 optional int32 job_id = 2; 921 optional string battery_name = 3; 922} 923 924// Dump from a com.android.server.job.controllers.JobStatus object. 925message JobStatusDumpProto { 926 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 927 928 // The UID that scheduled the job. 929 optional int32 calling_uid = 1; 930 optional string tag = 2; 931 932 // The UID for which the job is being run. 933 optional int32 source_uid = 3; 934 optional int32 source_user_id = 4; 935 // The package for which the job is being run. 936 optional string source_package_name = 5; 937 938 // Custom dump of android.app.job.JobInfo object. 939 message JobInfo { 940 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 941 942 optional .android.content.ComponentNameProto service = 1; 943 944 optional bool is_periodic = 2; 945 // Only valid if is_periodic is true. 946 optional int64 period_interval_ms = 3; 947 // Only valid if is_periodic is true. 948 optional int64 period_flex_ms = 4; 949 950 optional bool is_persisted = 5; 951 optional sint32 priority = 6; 952 optional int32 flags = 7; 953 954 optional bool requires_charging = 8; 955 optional bool requires_battery_not_low = 9; 956 optional bool requires_device_idle = 10; 957 958 message TriggerContentUri { 959 optional int32 flags = 1 [ 960 (.android.privacy).dest = DEST_AUTOMATIC 961 ]; 962 optional string uri = 2 [ (.android.privacy).dest = DEST_EXPLICIT ]; 963 } 964 repeated TriggerContentUri trigger_content_uris = 11; 965 optional int64 trigger_content_update_delay_ms = 12; 966 optional int64 trigger_content_max_delay_ms = 13; 967 968 optional .android.os.PersistableBundleProto extras = 14; 969 optional .android.os.BundleProto transient_extras = 15; 970 // ClipData of information that is returned to the application at 971 // execution time, but not persisted by the system. This is provided by 972 // the app and the main purpose of providing a ClipData is to allow 973 // granting of URI permissions for data associated with the clip. The 974 // exact kind of permission grant to perform is specified in the flags 975 // field. 976 optional .android.content.ClipDataProto clip_data = 16; 977 978 optional GrantedUriPermissionsDumpProto granted_uri_permissions = 17; 979 980 optional .android.net.NetworkRequestProto required_network = 18; 981 982 reserved 19; // total_network_bytes 983 984 // The estimated download bytes of the job. Will have a value of 985 // {@link JobInfo.NETWORK_BYTES_UNKNOWN} if any part of the job download is unknown. 986 optional int64 total_network_download_bytes = 25; 987 988 // The estimated upload bytes of the job. Will have a value of 989 // {@link JobInfo.NETWORK_BYTES_UNKNOWN} if any part of the job upload is unknown. 990 optional int64 total_network_upload_bytes = 26; 991 992 optional int64 min_latency_ms = 20; 993 optional int64 max_execution_delay_ms = 21; 994 995 message Backoff { 996 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 997 998 enum Policy { 999 BACKOFF_POLICY_LINEAR = 0; 1000 BACKOFF_POLICY_EXPONENTIAL = 1; 1001 } 1002 optional Policy policy = 1; 1003 optional int64 initial_backoff_ms = 2; 1004 } 1005 optional Backoff backoff_policy = 22; 1006 1007 optional bool has_early_constraint = 23; 1008 optional bool has_late_constraint = 24; 1009 1010 // Next tag: 27 1011 } 1012 optional JobInfo job_info = 6; 1013 1014 repeated ConstraintEnum required_constraints = 7; 1015 // Dynamic constraints are additional constraints imposed by the system that MUST be met before 1016 // the app can run if the app does not have quota. 1017 repeated ConstraintEnum dynamic_constraints = 31; 1018 repeated ConstraintEnum satisfied_constraints = 8; 1019 repeated ConstraintEnum unsatisfied_constraints = 9; 1020 optional bool is_doze_whitelisted = 10; 1021 optional bool is_uid_active = 26; 1022 1023 message ImplicitConstraints { 1024 // The device isn't Dozing or this job will be in the foreground. This 1025 // implicit constraint must be satisfied for the job to run. 1026 optional bool is_not_dozing = 1; 1027 // The job is not restricted from running in the background (due to 1028 // Battery Saver). This implicit constraint must be satisfied for the 1029 // job to run. 1030 optional bool is_not_restricted_in_bg = 2; 1031 // True if dynamic constraints have been satisfied. 1032 optional bool is_dynamic_satisfied = 3; 1033 } 1034 optional ImplicitConstraints implicit_constraints = 25; 1035 1036 enum TrackingController { 1037 TRACKING_BATTERY = 0; 1038 TRACKING_CONNECTIVITY = 1; 1039 TRACKING_CONTENT = 2; 1040 TRACKING_IDLE = 3; 1041 TRACKING_STORAGE = 4; 1042 TRACKING_TIME = 5; 1043 TRACKING_QUOTA = 6; 1044 } 1045 // Controllers that are currently tracking the job. 1046 repeated TrackingController tracking_controllers = 11; 1047 1048 repeated string changed_authorities = 12 [ 1049 (.android.privacy).dest = DEST_EXPLICIT 1050 ]; 1051 repeated string changed_uris = 13 [ 1052 (.android.privacy).dest = DEST_EXPLICIT 1053 ]; 1054 1055 optional .android.net.NetworkProto network = 14; 1056 1057 // Only the desired data from an android.app.job.JobWorkItem object. 1058 message JobWorkItem { 1059 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 1060 1061 optional int32 work_id = 1; 1062 optional int32 delivery_count = 2; 1063 optional .android.content.IntentProto intent = 3; 1064 optional GrantedUriPermissionsDumpProto uri_grants = 4; 1065 } 1066 repeated JobWorkItem pending_work = 15; 1067 repeated JobWorkItem executing_work = 16; 1068 1069 enum Bucket { 1070 ACTIVE = 0; 1071 WORKING_SET = 1; 1072 FREQUENT = 2; 1073 RARE = 3; 1074 NEVER = 4; 1075 RESTRICTED = 5; 1076 EXEMPTED = 6; 1077 } 1078 optional Bucket standby_bucket = 17; 1079 optional bool is_exempted_from_app_standby = 27; 1080 1081 optional int64 enqueue_duration_ms = 18; 1082 // Can be negative if the earliest runtime deadline has passed. 1083 optional sint64 time_until_earliest_runtime_ms = 19; 1084 // Can be negative if the latest runtime deadline has passed. 1085 optional sint64 time_until_latest_runtime_ms = 20; 1086 // The original latest runtime value, in the elapsed realtime timebase. Valid only for periodic 1087 // jobs. 1088 optional uint64 original_latest_runtime_elapsed = 30; 1089 1090 optional int32 num_failures = 21; 1091 1092 // Last time a job finished successfully for a periodic job, in currentTimeMillis time. 1093 optional int64 last_successful_run_time = 22; 1094 // Last time a job finished unsuccessfully, in currentTimeMillis time. 1095 optional int64 last_failed_run_time = 23; 1096 1097 optional int64 internal_flags = 24; 1098 1099 // Amount of time since this job was first deferred due to standby bucketing policy. Will be 1100 // 0 if this job was never deferred. 1101 optional int64 time_since_first_deferral_ms = 28; 1102 1103 // Amount of time since JobScheduler first tried to force batch this job. Will be 0 if there 1104 // was no attempt. 1105 optional int64 time_since_first_force_batch_attempt_ms = 29; 1106 1107 // Next tag: 32 1108} 1109 1110// Dump from com.android.server.job.JobConcurrencyManager. 1111// Next tag: 7 1112message JobConcurrencyManagerProto { 1113 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 1114 1115 // Whether the device is interactive (== screen on) now or not. 1116 optional bool current_interactive_state = 1; 1117 // Similar to current_interactive_state, screen on or not, but it takes into account the off timeout. 1118 optional bool effective_interactive_state = 2; 1119 // How many milliseconds have passed since the last screen on. (i.e. 1000 == 1 sec ago) 1120 optional int64 time_since_last_screen_on_ms = 3; 1121 // How many milliseconds have passed since the last screen off. (i.e. 1000 == 1 sec ago) 1122 optional int64 time_since_last_screen_off_ms = 4; 1123 // Current max number of jobs. 1124 optional JobCountTrackerProto job_count_tracker = 5; 1125 // Current memory trim level. 1126 optional int32 memory_trim_level = 6; 1127 // Performance stats. 1128 optional StatLoggerProto stats = 7; 1129} 1130 1131// Dump from com.android.server.job.JobConcurrencyManager.JobCountTracker. 1132// Next tag: 8 1133message JobCountTrackerProto { 1134 option (.android.msg_privacy).dest = DEST_AUTOMATIC; 1135 1136 // Number of total jos that can run simultaneously. 1137 optional int32 config_num_max_total_jobs = 1; 1138 // Number of background jos that can run simultaneously. 1139 optional int32 config_num_max_bg_jobs = 2; 1140 // Out of total jobs, this many background jobs should be guaranteed to be executed, even if 1141 // there are the config_num_max_total_jobs count of foreground jobs pending. 1142 optional int32 config_num_min_bg_jobs = 3; 1143 1144 // Number of running foreground jobs. 1145 optional int32 num_running_fg_jobs = 4; 1146 // Number of running background jobs. 1147 optional int32 num_running_bg_jobs = 5; 1148 1149 // Number of pending foreground jobs. 1150 optional int32 num_pending_fg_jobs = 6; 1151 // Number of pending background jobs. 1152 optional int32 num_pending_bg_jobs = 7; 1153 1154 optional int32 num_actual_max_fg_jobs = 8; 1155 optional int32 num_actual_max_bg_jobs = 9; 1156 1157 optional int32 num_reserved_for_bg = 10; 1158 1159 optional int32 num_starting_fg_jobs = 11; 1160 optional int32 num_starting_bg_jobs = 12; 1161} 1162 1163message JobStorePersistStatsProto { 1164 message Stats { 1165 optional int32 num_total_jobs = 1; 1166 optional int32 num_system_server_jobs = 2; 1167 optional int32 num_system_sync_manager_jobs = 3; 1168 } 1169 1170 optional Stats first_load = 1; 1171 optional Stats last_save = 2; 1172} 1173