From 0e06c13784e50183401ca95fed2be49b0ead26fd Mon Sep 17 00:00:00 2001 From: Nick Kralevich <nnk@google.com> Date: Wed, 30 Apr 2014 11:35:02 -0700 Subject: [PATCH] Allow shell debugfs read access Developers should be able to use systrace with user builds. This requires read access to /sys/kernel/debug/tracing/trace, otherwise the following error occurs: $ atrace capturing trace... done TRACE: error opening /sys/kernel/debug/tracing/trace: Permission denied (13) with the following SELinux denial: <4>[ 79.830542] type=1400 audit(11940551.039:8): avc: denied { read } for pid=1156 comm="atrace" name="trace" dev="debugfs" ino=3024 scontext=u:r:shell:s0 tcontext=u:object_r:debugfs:s0 tclass=file At least on the kernel I've tested this on, debugfs doesn't support setting SELinux file labels. Grant read access to all of debugfs to work around this limitation. Bug: 13904660 Change-Id: Ib58e98972c5012e9b34fec9e0a6094641638cd9a --- shelldomain.te | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/shelldomain.te b/shelldomain.te index e894d9daf..0a8642656 100644 --- a/shelldomain.te +++ b/shelldomain.te @@ -25,3 +25,10 @@ allow shelldomain shell_prop:property_service set; allow shelldomain ctl_dumpstate_prop:property_service set; allow shelldomain debug_prop:property_service set; allow shelldomain powerctl_prop:property_service set; + +# systrace support - allow atrace to run +# debugfs doesn't support labeling individual files, so we have +# to grant read access to all of /sys/kernel/debug. +# Directory read access and file write access is already granted +# in domain.te. +allow shelldomain debugfs:file r_file_perms; -- GitLab