From b9a1e7ba84d8afa4562e81b43b692670b8a8067e Mon Sep 17 00:00:00 2001 From: Svet Ganov <svetoslavganov@google.com> Date: Tue, 16 Jan 2018 21:14:34 -0800 Subject: [PATCH] Don't record audio if UID is idle - sepolicy If a UID is in an idle state we don't allow recording to protect user's privacy. If the UID is in an idle state we allow recording but report empty data (all zeros in the byte array) and once the process goes in an active state we report the real mic data. This avoids the race between the app being notified aboout its lifecycle and the audio system being notified about the state of a UID. Test: Added - AudioRecordTest#testRecordNoDataForIdleUids Passing - cts-tradefed run cts-dev -m CtsMediaTestCases -t android.media.cts.AudioRecordTest bug:63938985 Change-Id: I8c044e588bac4182efcdc08197925fddf593a717 --- private/audioserver.te | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/private/audioserver.te b/private/audioserver.te index 9119daa5d..b6deb280e 100644 --- a/private/audioserver.te +++ b/private/audioserver.te @@ -29,6 +29,7 @@ userdebug_or_eng(` ') add_service(audioserver, audioserver_service) +allow audioserver activity_service:service_manager find; allow audioserver appops_service:service_manager find; allow audioserver batterystats_service:service_manager find; allow audioserver permission_service:service_manager find; @@ -45,6 +46,17 @@ allow audioserver audio_device:chr_file { read write }; # For A2DP bridge which is loaded directly into audioserver unix_socket_connect(audioserver, bluetooth, bluetooth) +# Allow shell commands from ADB for CTS testing/dumping +allow audioserver adbd:fd use; +allow audioserver adbd:unix_stream_socket { read write }; + +# Allow shell commands from ADB for CTS testing/dumping +userdebug_or_eng(` + allow audioserver su:fd use; + allow audioserver su:fifo_file { read write }; + allow audioserver su:unix_stream_socket { read write }; +') + ### ### neverallow rules ### -- GitLab