Primiano Tucci | 5a30453 | 2018-01-09 14:15:43 +0000 | [diff] [blame] | 1 | # 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 | |
| 15 | service 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 |
Suren Baghdasaryan | a08f53b | 2021-06-17 18:48:43 -0700 | [diff] [blame] | 22 | task_profiles ServiceCapacityLow |
Primiano Tucci | 5a30453 | 2018-01-09 14:15:43 +0000 | [diff] [blame] | 23 | |
| 24 | service traced_probes /system/bin/traced_probes |
| 25 | class late_start |
| 26 | disabled |
| 27 | user nobody |
Primiano Tucci | a364520 | 2020-08-03 16:28:18 +0200 | [diff] [blame] | 28 | # Despite the "log" group below, traced_probes is allowed to read log |
| 29 | # only on userdebug/eng via selinux (see traced_probes.te). |
Primiano Tucci | 2cb13ea | 2022-01-14 20:32:15 +0000 | [diff] [blame] | 30 | group nobody readproc log readtracefs |
Suren Baghdasaryan | a08f53b | 2021-06-17 18:48:43 -0700 | [diff] [blame] | 31 | task_profiles ServiceCapacityLow |
Florian Mayer | 7d1a9a2 | 2018-02-14 15:17:58 +0000 | [diff] [blame] | 32 | # 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 Mayer | a98c6f5 | 2018-02-19 13:56:07 +0000 | [diff] [blame] | 35 | file /dev/kmsg w |
Primiano Tucci | d6e8485 | 2018-03-29 20:26:57 +0000 | [diff] [blame] | 36 | capabilities DAC_READ_SEARCH |
Primiano Tucci | 5a30453 | 2018-01-09 14:15:43 +0000 | [diff] [blame] | 37 | |
Hector Dearman | f1d1cd8 | 2019-04-05 16:25:10 +0100 | [diff] [blame] | 38 | on property:persist.device_config.global_settings.sys_traced=1 |
Hector Dearman | e9bdfe5 | 2018-03-21 13:24:28 +0000 | [diff] [blame] | 39 | setprop persist.traced.enable 1 |
| 40 | |
Hector Dearman | f1d1cd8 | 2019-04-05 16:25:10 +0100 | [diff] [blame] | 41 | on property:persist.device_config.global_settings.sys_traced=0 |
Hector Dearman | e9bdfe5 | 2018-03-21 13:24:28 +0000 | [diff] [blame] | 42 | setprop persist.traced.enable 0 |
| 43 | |
Lalit Maganti | dabc529 | 2018-05-23 19:18:55 +0100 | [diff] [blame] | 44 | on property:debug.atrace.user_initiated=1 |
| 45 | stop traced_probes |
| 46 | |
| 47 | on property:persist.traced.enable=1 && property:debug.atrace.user_initiated="" |
| 48 | start traced_probes |
| 49 | |
Primiano Tucci | 7175882 | 2018-01-25 12:51:45 +0000 | [diff] [blame] | 50 | on property:persist.traced.enable=1 |
Primiano Tucci | 7e2b67a | 2018-01-16 16:38:49 +0000 | [diff] [blame] | 51 | # Trace files need to be: |
| 52 | # - Written by either uid:shell or uid:statsd. |
Primiano Tucci | 34f7ad3 | 2020-10-13 21:43:29 +0200 | [diff] [blame] | 53 | # - Read by shell and incidentd. |
Primiano Tucci | 7e2b67a | 2018-01-16 16:38:49 +0000 | [diff] [blame] | 54 | mkdir /data/misc/perfetto-traces 0773 root shell |
| 55 | |
Primiano Tucci | f0706d1 | 2021-01-14 15:20:16 +0100 | [diff] [blame] | 56 | # Traces in this directory are only accessed by dumpstate (read+unlink) and |
| 57 | # by the bug reporting UI (ls+getattr). |
| 58 | mkdir /data/misc/perfetto-traces/bugreport 0773 root shell |
| 59 | |
Primiano Tucci | 34f7ad3 | 2020-10-13 21:43:29 +0200 | [diff] [blame] | 60 | # This directory allows shell to save configs file in a place where the |
| 61 | # perfetto cmdline client can read then. /data/local/tmp/ isn't safe because |
| 62 | # too many other domains can write into that. See b/170404111. |
| 63 | mkdir /data/misc/perfetto-configs 0775 root shell |
| 64 | |
Primiano Tucci | 5a30453 | 2018-01-09 14:15:43 +0000 | [diff] [blame] | 65 | start traced |
| 66 | start traced_probes |
Hector Dearman | 7549fff | 2018-02-09 17:25:30 +0000 | [diff] [blame] | 67 | |
| 68 | on property:persist.traced.enable=0 |
| 69 | stop traced |
| 70 | stop traced_probes |
Hector Dearman | dedfd76 | 2019-11-28 18:13:49 +0000 | [diff] [blame] | 71 | |
| 72 | # Reset the Perfetto guard rail state on boot: |
| 73 | on post-fs-data |
| 74 | rm /data/misc/perfetto-traces/.guardraildata |
Kalesh Singh | 8c1eb4b | 2021-03-30 11:59:09 -0400 | [diff] [blame] | 75 | |
| 76 | ############################################################################# |
| 77 | # mm_events - Arms a perfetto trace config that is triggered |
| 78 | # on memory pressure (kmem_activity trigger) |
| 79 | ############################################################################# |
| 80 | |
| 81 | service mm_events /system/bin/mm_events |
| 82 | class late_start |
| 83 | disabled |
| 84 | oneshot |
| 85 | user nobody |
| 86 | group nobody |
| 87 | |
| 88 | on property:persist.mm_events.enabled=true && property:persist.traced.enable=1 |
| 89 | restart mm_events # Restart to reset backoff interval |
| 90 | |
| 91 | on property:persist.mm_events.enabled=false |
| 92 | stop mm_events |
Daniele Di Proietto | e84bb9e | 2021-09-30 17:39:55 +0100 | [diff] [blame] | 93 | |
| 94 | ############################################################################# |
Daniele Di Proietto | bf487cf | 2021-10-04 17:17:43 +0100 | [diff] [blame] | 95 | # perfetto_trace_on_boot - Starts a perfetto trace on boot |
Daniele Di Proietto | e84bb9e | 2021-09-30 17:39:55 +0100 | [diff] [blame] | 96 | ############################################################################# |
| 97 | # |
| 98 | # There are two separate actions (a trigger action and a start action) to make |
Daniele Di Proietto | bf487cf | 2021-10-04 17:17:43 +0100 | [diff] [blame] | 99 | # sure that perfetto_trace_on_boot is started only once on boot (otherwise, |
| 100 | # whenever persist.debug.perfetto.boottrace=1 is set, perfetto_trace_on_boot |
| 101 | # would start immediately). |
Daniele Di Proietto | e84bb9e | 2021-09-30 17:39:55 +0100 | [diff] [blame] | 102 | # |
| 103 | # persist.debug.perfetto.boottrace=1 can be manually set after boot (to record |
| 104 | # a trace on the next reboot) and we don't want to immediately start a trace |
| 105 | # when setting the debug property. So we turn "ro.persistent_properties.ready" |
| 106 | # into a trigger, and then check whether we should start tracing when the |
| 107 | # trigger fires. |
Daniele Di Proietto | bf487cf | 2021-10-04 17:17:43 +0100 | [diff] [blame] | 108 | on perfetto_maybe_trace_on_boot && property:persist.debug.perfetto.boottrace=1 && property:persist.traced.enable=1 |
Daniele Di Proietto | e84bb9e | 2021-09-30 17:39:55 +0100 | [diff] [blame] | 109 | setprop persist.debug.perfetto.boottrace "" |
| 110 | rm /data/misc/perfetto-traces/boottrace.perfetto-trace |
| 111 | # Set by traced after listen()ing on the consumer socket. Without this, |
| 112 | # perfetto could try to connect to traced before traced is ready to listen. |
| 113 | wait_for_prop sys.trace.traced_started 1 |
Daniele Di Proietto | bf487cf | 2021-10-04 17:17:43 +0100 | [diff] [blame] | 114 | start perfetto_trace_on_boot |
Daniele Di Proietto | e84bb9e | 2021-09-30 17:39:55 +0100 | [diff] [blame] | 115 | |
| 116 | on property:ro.persistent_properties.ready=true |
Daniele Di Proietto | bf487cf | 2021-10-04 17:17:43 +0100 | [diff] [blame] | 117 | trigger perfetto_maybe_trace_on_boot |
Daniele Di Proietto | e84bb9e | 2021-09-30 17:39:55 +0100 | [diff] [blame] | 118 | |
Daniele Di Proietto | bf487cf | 2021-10-04 17:17:43 +0100 | [diff] [blame] | 119 | service 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 Proietto | e84bb9e | 2021-09-30 17:39:55 +0100 | [diff] [blame] | 120 | disabled |
| 121 | oneshot |
| 122 | user shell |
| 123 | group nobody |