1/*
2 * Copyright (C) 2018 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 perfetto.protos;
20
21import "protos/perfetto/common/sys_stats_counters.proto";
22
23// This file defines the configuration for the Linux /proc poller data source,
24// which injects counters in the trace.
25// Counters that are needed in the trace must be explicitly listed in the
26// *_counters fields. This is to avoid spamming the trace with all counters
27// at all times.
28// The sampling rate is configurable. All polling rates (*_period_ms) need
29// to be integer multiples of each other.
30// OK:     [10ms, 10ms, 10ms],  [10ms, 20ms, 10ms],  [10ms, 20ms, 60ms]
31// Not OK: [10ms, 10ms, 11ms],  [10ms, 15ms, 20ms]
32message SysStatsConfig {
33  // Polls /proc/meminfo every X ms, if non-zero.
34  // This is required to be > 10ms to avoid excessive CPU usage.
35  // Cost: 0.3 ms [read] + 0.07 ms [parse + trace injection]
36  optional uint32 meminfo_period_ms = 1;
37
38  // If empty all known counters are reported. Otherwise, only the counters
39  // specified below are reported.
40  repeated MeminfoCounters meminfo_counters = 2;
41
42  // Polls /proc/vmstat every X ms, if non-zero.
43  // This is required to be > 10ms to avoid excessive CPU usage.
44  // Cost: 0.2 ms [read] + 0.3 ms [parse + trace injection]
45  optional uint32 vmstat_period_ms = 3;
46  repeated VmstatCounters vmstat_counters = 4;
47
48  // Pols /proc/stat every X ms, if non-zero.
49  // This is required to be > 10ms to avoid excessive CPU usage.
50  // Cost: 4.1 ms [read] + 1.9 ms [parse + trace injection]
51  optional uint32 stat_period_ms = 5;
52  enum StatCounters {
53    STAT_UNSPECIFIED = 0;
54    STAT_CPU_TIMES = 1;
55    STAT_IRQ_COUNTS = 2;
56    STAT_SOFTIRQ_COUNTS = 3;
57    STAT_FORK_COUNT = 4;
58  }
59  repeated StatCounters stat_counters = 6;
60
61  // Polls /sys/devfreq/*/curfreq every X ms, if non-zero.
62  // This is required to be > 10ms to avoid excessive CPU usage.
63  // This option can be used to record unchanging values.
64  // Updates from frequency changes can come from ftrace/set_clock_rate.
65  optional uint32 devfreq_period_ms = 7;
66}
67