blob: 8169d8f105de7baef3003d5bede3b38c386a6ac3 [file] [log] [blame]
Primiano Tucci5a304532018-01-09 14:15:43 +00001# Copyright (C) 2017 The Android Open Source Project
2#
3# Licensed under the Apache License, Version 2.0 (the "License");
4# you may not use this file except in compliance with the License.
5# You may obtain a copy of the License at
6#
7# http://www.apache.org/licenses/LICENSE-2.0
8#
9# Unless required by applicable law or agreed to in writing, software
10# distributed under the License is distributed on an "AS IS" BASIS,
11# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12# See the License for the specific language governing permissions and
13# limitations under the License.
14
15service traced /system/bin/traced
16 class late_start
17 disabled
18 socket traced_consumer stream 0666 root root
19 socket traced_producer stream 0666 root root
20 user nobody
21 group nobody
Primiano Tucciaf7f5382024-07-17 14:49:55 +000022 task_profiles ProcessCapacityHigh
Primiano Tucci5a304532018-01-09 14:15:43 +000023
24service traced_probes /system/bin/traced_probes
25 class late_start
26 disabled
27 user nobody
Primiano Tuccia3645202020-08-03 16:28:18 +020028 # Despite the "log" group below, traced_probes is allowed to read log
29 # only on userdebug/eng via selinux (see traced_probes.te).
Primiano Tucci2cb13ea2022-01-14 20:32:15 +000030 group nobody readproc log readtracefs
Primiano Tucciaf7f5382024-07-17 14:49:55 +000031 task_profiles ProcessCapacityHigh
Florian Mayer7d1a9a22018-02-14 15:17:58 +000032 # Clean up procfs configuration even if traced_probes crashes
33 # unexpectedly.
34 onrestart exec_background - nobody shell -- /system/bin/traced_probes --cleanup-after-crash
Florian Mayera98c6f52018-02-19 13:56:07 +000035 file /dev/kmsg w
Primiano Tuccid6e84852018-03-29 20:26:57 +000036 capabilities DAC_READ_SEARCH
Ryan Savitski061d1aa2024-12-19 18:39:53 +000037 shared_kallsyms
Primiano Tucci5a304532018-01-09 14:15:43 +000038
Hector Dearmanf1d1cd82019-04-05 16:25:10 +010039on property:persist.device_config.global_settings.sys_traced=1
Hector Dearmane9bdfe52018-03-21 13:24:28 +000040 setprop persist.traced.enable 1
41
Hector Dearmanf1d1cd82019-04-05 16:25:10 +010042on property:persist.device_config.global_settings.sys_traced=0
Hector Dearmane9bdfe52018-03-21 13:24:28 +000043 setprop persist.traced.enable 0
44
Lalit Magantidabc5292018-05-23 19:18:55 +010045on property:debug.atrace.user_initiated=1
46 stop traced_probes
47
48on property:persist.traced.enable=1 && property:debug.atrace.user_initiated=""
49 start traced_probes
50
Primiano Tucci71758822018-01-25 12:51:45 +000051on property:persist.traced.enable=1
Primiano Tucci7e2b67a2018-01-16 16:38:49 +000052 # Trace files need to be:
53 # - Written by either uid:shell or uid:statsd.
Primiano Tucci34f7ad32020-10-13 21:43:29 +020054 # - Read by shell and incidentd.
Primiano Tucci7e2b67a2018-01-16 16:38:49 +000055 mkdir /data/misc/perfetto-traces 0773 root shell
56
Primiano Tuccif0706d12021-01-14 15:20:16 +010057 # Traces in this directory are only accessed by dumpstate (read+unlink) and
58 # by the bug reporting UI (ls+getattr).
59 mkdir /data/misc/perfetto-traces/bugreport 0773 root shell
60
Carmen Jacksonad5a2452024-02-20 19:26:56 +000061 # Traces in this directory are only accessed by system server
Yisroel Forta6b5b6d42024-06-06 19:22:05 +000062 mkdir /data/misc/perfetto-traces/profiling 0777 root shell
Carmen Jacksonad5a2452024-02-20 19:26:56 +000063
Primiano Tucci34f7ad32020-10-13 21:43:29 +020064 # This directory allows shell to save configs file in a place where the
65 # perfetto cmdline client can read then. /data/local/tmp/ isn't safe because
66 # too many other domains can write into that. See b/170404111.
67 mkdir /data/misc/perfetto-configs 0775 root shell
68
Primiano Tucci5a304532018-01-09 14:15:43 +000069 start traced
70 start traced_probes
Hector Dearman7549fff2018-02-09 17:25:30 +000071
72on property:persist.traced.enable=0
73 stop traced
74 stop traced_probes
Hector Dearmandedfd762019-11-28 18:13:49 +000075
76# Reset the Perfetto guard rail state on boot:
77on post-fs-data
78 rm /data/misc/perfetto-traces/.guardraildata
Kalesh Singh8c1eb4b2021-03-30 11:59:09 -040079
80#############################################################################
81# mm_events - Arms a perfetto trace config that is triggered
82# on memory pressure (kmem_activity trigger)
83#############################################################################
84
85service mm_events /system/bin/mm_events
86 class late_start
87 disabled
88 oneshot
89 user nobody
90 group nobody
91
92on property:persist.mm_events.enabled=true && property:persist.traced.enable=1
93 restart mm_events # Restart to reset backoff interval
94
95on property:persist.mm_events.enabled=false
96 stop mm_events
Daniele Di Proiettoe84bb9e2021-09-30 17:39:55 +010097
98#############################################################################
Daniele Di Proiettobf487cf2021-10-04 17:17:43 +010099# perfetto_trace_on_boot - Starts a perfetto trace on boot
Daniele Di Proiettoe84bb9e2021-09-30 17:39:55 +0100100#############################################################################
101#
102# There are two separate actions (a trigger action and a start action) to make
Daniele Di Proiettobf487cf2021-10-04 17:17:43 +0100103# sure that perfetto_trace_on_boot is started only once on boot (otherwise,
104# whenever persist.debug.perfetto.boottrace=1 is set, perfetto_trace_on_boot
105# would start immediately).
Daniele Di Proiettoe84bb9e2021-09-30 17:39:55 +0100106#
107# persist.debug.perfetto.boottrace=1 can be manually set after boot (to record
108# a trace on the next reboot) and we don't want to immediately start a trace
109# when setting the debug property. So we turn "ro.persistent_properties.ready"
110# into a trigger, and then check whether we should start tracing when the
111# trigger fires.
Daniele Di Proiettobf487cf2021-10-04 17:17:43 +0100112on perfetto_maybe_trace_on_boot && property:persist.debug.perfetto.boottrace=1 && property:persist.traced.enable=1
Daniele Di Proiettoe84bb9e2021-09-30 17:39:55 +0100113 setprop persist.debug.perfetto.boottrace ""
114 rm /data/misc/perfetto-traces/boottrace.perfetto-trace
115 # Set by traced after listen()ing on the consumer socket. Without this,
116 # perfetto could try to connect to traced before traced is ready to listen.
117 wait_for_prop sys.trace.traced_started 1
Daniele Di Proiettobf487cf2021-10-04 17:17:43 +0100118 start perfetto_trace_on_boot
Daniele Di Proiettoe84bb9e2021-09-30 17:39:55 +0100119
120on property:ro.persistent_properties.ready=true
Daniele Di Proiettobf487cf2021-10-04 17:17:43 +0100121 trigger perfetto_maybe_trace_on_boot
Daniele Di Proiettoe84bb9e2021-09-30 17:39:55 +0100122
Daniele Di Proiettobf487cf2021-10-04 17:17:43 +0100123service perfetto_trace_on_boot /system/bin/perfetto -c /data/misc/perfetto-configs/boottrace.pbtxt --txt -o /data/misc/perfetto-traces/boottrace.perfetto-trace
Daniele Di Proiettoe84bb9e2021-09-30 17:39:55 +0100124 disabled
Parth Sane08413132023-03-29 10:42:44 +0000125 gentle_kill
Daniele Di Proiettoe84bb9e2021-09-30 17:39:55 +0100126 oneshot
127 user shell
128 group nobody
Parth Sane08413132023-03-29 10:42:44 +0000129
130# This is meant to stop the boot tracing.
131# To use this, add a trigger with mode STOP_TRACING in the configuration used in perfetto_trace_on_boot.
132# Then create a new config which contains `activate_triggers: <trigger name>` where <trigger name> is
133# the name specified in configuration used in perfetto_trace_on_boot.
Parth Sane1973d5a2023-07-04 15:57:06 +0000134on property:sys.boot_completed=1 && property:init.svc.perfetto_trace_on_boot=running
Parth Sane08413132023-03-29 10:42:44 +0000135 exec -- /system/bin/perfetto -c /data/misc/perfetto-configs/stopboottracetrigger.pbtxt --txt
Parth Sane1973d5a2023-07-04 15:57:06 +0000136
137# Forcefully enable select userspace (atrace) tracing categories early into the
138# userspace boot. This is primarily for capturing zygote events without waiting
139# for perfetto daemons or the /data partition.
140on late-init && property:ro.boot.fastboot.boottrace=enabled
141 setprop debug.atrace.tags.enableflags 802922
142
143# disable on boot complete when using textual ftrace tracing without perfetto.
144on property:sys.boot_completed=1 && property:ro.boot.fastboot.boottrace=enabled && property:init.svc.perfetto_trace_on_boot=
145 setprop debug.atrace.tags.enableflags 0
146 write /sys/kernel/debug/tracing/tracing_on 0
147 write /sys/kernel/tracing/tracing_on 0
Nolan Scobie11cbee22023-04-23 17:29:02 -0400148
149# These must be set as soon as possible for processes guarded by
150# android.sdk_sysprop_guard to find and cache the memory locations of
151# where these sysprops are stored, particularly SurfaceFlinger which starts
152# very early.
153# TODO(b/281329340): remove this when no longer needed.
154on init
155 setprop debug.perfetto.sdk_sysprop_guard_generation 0
156 setprop debug.hwui.skia_tracing_enabled false
157 setprop debug.hwui.skia_use_perfetto_track_events false
158 setprop debug.renderengine.skia_tracing_enabled false
159 setprop debug.renderengine.skia_use_perfetto_track_events false
Daniele Di Proiettoe8068062024-02-16 17:54:03 +0000160
161##############################################################################
162# perfetto_persistent_sysui_tracing_for_bugreport - Keeps a persistent active
163# tracing session, for debugging purposes
164##############################################################################
165
166on property:persist.debug.perfetto.persistent_sysui_tracing_for_bugreport=1 && property:persist.traced.enable=1 && property:ro.debuggable=1
167 # Set by traced after listen()ing on the consumer socket. Without this,
168 # perfetto could try to connect to traced before traced is ready to listen.
169 wait_for_prop sys.trace.traced_started 1
170 start perfetto_persistent_sysui_tracing_for_bugreport
171
172# If something disables traced, we don't want init to respawn the service (that will fail) continuously.
173on property:persist.traced.enable=0
174 stop perfetto_persistent_sysui_tracing_for_bugreport
175
176on property:persist.debug.perfetto.persistent_sysui_tracing_for_bugreport=0
177 setprop persist.debug.perfetto.persistent_sysui_tracing_for_bugreport ""
178
179on property:persist.debug.perfetto.persistent_sysui_tracing_for_bugreport=""
180 stop perfetto_persistent_sysui_tracing_for_bugreport
181
182service perfetto_persistent_sysui_tracing_for_bugreport /system/bin/perfetto -c /system/etc/perfetto/persistent_cfg.pbtxt --txt -o /dev/null
183 disabled
184 timeout_period 86400
185 restart_period 60
186 user nobody
187 group nobody