Files
android_device_qcom_sepolicy/common/hal_camera.te
Krupal Divvela 7ee2d51654 sepolicy : add permissions to camera for sysfs entires
with the new restriction on sysfs access adding permissions for camera

CRs-Fixed: 2090534
Change-Id: I63e12da34e723959f993c95bf5a271fafa97e6a0
2017-08-10 11:50:33 +05:30

71 lines
3.1 KiB
Plaintext

# Copyright (c) 2017, The Linux Foundation. All rights reserved.
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are
# met:
# * Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
# * Redistributions in binary form must reproduce the above
# copyright notice, this list of conditions and the following
# disclaimer in the documentation and/or other materials provided
# with the distribution.
# * Neither the name of The Linux Foundation nor the names of its
# contributors may be used to endorse or promote products derived
# from this software without specific prior written permission.
#
# THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED
# WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
# MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT
# ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS
# BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
# CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
# SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
# BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
# WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
# OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN
# IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
allow hal_camera qdisplay_service:service_manager find;
#allow hal_camera surfaceflinger_service:service_manager find;
# added now for camera functionality. This should be using HIDL
#userdebug_or_eng(`
#binder_use(hal_camera)
#')
binder_call(hal_camera, surfaceflinger)
set_prop(hal_camera, camera_prop)
allow hal_camera gpu_device:chr_file rw_file_perms;
allow hal_camera sysfs:file r_file_perms;
#changes to access laser device
allow hal_camera input_device:chr_file r_file_perms;
r_dir_file(hal_camera, input_device);
allow hal_camera sysfs_laser:file w_file_perms;
r_dir_file(hal_camera, sysfs_laser);
vndbinder_use(hal_camera);
hal_client_domain(hal_camera_default, hal_perf)
#needed for full_treble
binder_call(hal_camera, hal_graphics_composer_default)
allow hal_camera_default hal_graphics_mapper_hwservice:hwservice_manager find;
allow hal_camera persist_file:dir r_dir_perms;
r_dir_file(hal_camera, sensors_persist_file);
r_dir_file(hal_camera_default, sysfs_graphics)
#allow hal_camera to access Isensormanager
allow hal_camera fwk_sensor_hwservice:hwservice_manager find;
binder_call(hal_camera, system_server)
# from sensors team
allow hal_camera self:socket create_socket_perms;
allowxperm hal_camera self:socket ioctl msm_sock_ipc_ioctls;
allow hal_camera_default sysfs_data:file read;
allow hal_camera sysfs_data:file r_file_perms;
allow hal_camera vendor_camera_data_file:dir w_dir_perms;
allow hal_camera vendor_camera_data_file:sock_file write;
unix_socket_send(hal_camera, camera, mm-qcamerad)
unix_socket_connect(hal_camera, thermal, thermal-engine)