| # ============================================================================== |
| # Policy File of /vendor/bin/hw/camerahalserver Executable File |
| |
| # ============================================================================== |
| # Common SEPolicy Rule |
| # ============================================================================== |
| |
| type mtk_hal_camera, domain; |
| type mtk_hal_camera_exec, exec_type, file_type, vendor_file_type; |
| |
| # Set up a transition from init to the camerahalserver upon executing its binary. |
| init_daemon_domain(mtk_hal_camera) |
| |
| # Allow a base set of permissions required for a domain to offer a |
| # HAL implementation of the specified type over HwBinder. |
| hal_server_domain(mtk_hal_camera, hal_camera) |
| hal_server_domain(mtk_hal_camera, hal_mtk_bgs) |
| |
| # Allow camerahalserver to use vendor binder IPC. |
| vndbinder_use(mtk_hal_camera) |
| |
| # callback to cameraserver |
| binder_call(mtk_hal_camera, cameraserver) |
| |
| # callback to shell for debugging |
| binder_call(mtk_hal_camera, shell) |
| |
| # call the graphics allocator hal |
| binder_call(mtk_hal_camera, hal_graphics_allocator) |
| |
| # call to surfaceflinger |
| binder_call(mtk_hal_camera, surfaceflinger) |
| |
| # call PowerHal |
| hal_client_domain(mtk_hal_camera, hal_power) |
| |
| # ----------------------------------- |
| # Purpose: Allow camerahalserver to find a service from hwservice_manager |
| # ----------------------------------- |
| allow mtk_hal_camera hal_graphics_mapper_hwservice:hwservice_manager find; |
| allow mtk_hal_camera fwk_sensor_hwservice:hwservice_manager find; |
| allow mtk_hal_camera nvram_data_file:lnk_file create_file_perms; |
| allow mtk_hal_camera nvdata_file:lnk_file create_file_perms; |
| allow mtk_hal_camera fwk_display_hwservice:hwservice_manager find; |
| hal_client_domain(mtk_hal_camera, hal_graphics_allocator) |
| |
| # ----------------------------------- |
| # Purpose: Camera-related devices (driver) |
| # ----------------------------------- |
| allow mtk_hal_camera proc_mtk_jpeg:file r_file_perms; |
| allowxperm mtk_hal_camera proc_mtk_jpeg:file ioctl { |
| JPG_BRIDGE_ENC_IO_INIT |
| JPG_BRIDGE_ENC_IO_CONFIG |
| JPG_BRIDGE_ENC_IO_WAIT |
| JPG_BRIDGE_ENC_IO_DEINIT |
| JPG_BRIDGE_ENC_IO_START |
| }; |
| |
| allow mtk_hal_camera camera_sysram_device:chr_file r_file_perms; |
| allow mtk_hal_camera camera_pipemgr_device:chr_file r_file_perms; |
| allow mtk_hal_camera camera_mem_device:chr_file rw_file_perms; |
| allow mtk_hal_camera camera_isp_device:chr_file rw_file_perms; |
| allow mtk_hal_camera camera_dip_device:chr_file rw_file_perms; |
| allow mtk_hal_camera camera_tsf_device:chr_file rw_file_perms; |
| allow mtk_hal_camera kd_camera_hw_device:chr_file rw_file_perms; |
| allow mtk_hal_camera kd_camera_flashlight_device:chr_file rw_file_perms; |
| allow mtk_hal_camera flashlight_device:chr_file rw_file_perms; |
| allow mtk_hal_camera lens_device:chr_file rw_file_perms; |
| allow mtk_hal_camera seninf_device:chr_file rw_file_perms; |
| |
| # FDVT Driver |
| allow mtk_hal_camera camera_fdvt_device:chr_file rw_file_perms; |
| |
| # DPE Driver |
| allow mtk_hal_camera camera_dpe_device:chr_file rw_file_perms; |
| |
| # MFB Driver |
| allow mtk_hal_camera camera_mfb_device:chr_file rw_file_perms; |
| |
| # WPE Driver |
| allow mtk_hal_camera camera_wpe_device:chr_file rw_file_perms; |
| |
| # PDA Driver |
| allow mtk_hal_camera camera_pda_device:chr_file rw_file_perms; |
| |
| # mtk_jpeg |
| allow mtk_hal_camera mtk_jpeg_device:chr_file r_file_perms; |
| |
| allow mtk_hal_camera ccu_device:chr_file rw_file_perms; |
| |
| # APUSYS |
| allow mtk_hal_camera vpu_device:chr_file rw_file_perms; |
| allow mtk_hal_camera mdla_device:chr_file rw_file_perms; |
| allow mtk_hal_camera apusys_device:chr_file rw_file_perms; |
| allow mtk_hal_camera sysfs_apusys_queue:dir r_dir_perms; |
| allow mtk_hal_camera sysfs_apusys_queue:file r_file_perms; |
| |
| # Date: 2021/12/10 |
| # Operation : allow camera hal server to read dla network file |
| allow mtk_hal_camera vendor_etc_nn_file:dir r_dir_perms; |
| allow mtk_hal_camera vendor_etc_nn_file:file r_file_perms; |
| allowxperm mtk_hal_camera vendor_etc_nn_file:file ioctl VT_SENDSIG; |
| |
| # Purpose: RSC driver |
| allow mtk_hal_camera camera_rsc_device:chr_file rw_file_perms; |
| |
| # Purpose: OWE driver |
| allow mtk_hal_camera camera_owe_device:chr_file rw_file_perms; |
| |
| # Purpose: AF related |
| allow mtk_hal_camera MAINAF_device:chr_file rw_file_perms; |
| allow mtk_hal_camera MAIN2AF_device:chr_file rw_file_perms; |
| allow mtk_hal_camera MAIN3AF_device:chr_file rw_file_perms; |
| allow mtk_hal_camera MAIN4AF_device:chr_file rw_file_perms; |
| allow mtk_hal_camera SUBAF_device:chr_file rw_file_perms; |
| allow mtk_hal_camera SUB2AF_device:chr_file rw_file_perms; |
| allow mtk_hal_camera FM50AF_device:chr_file rw_file_perms; |
| allow mtk_hal_camera AD5820AF_device:chr_file rw_file_perms; |
| allow mtk_hal_camera DW9714AF_device:chr_file rw_file_perms; |
| allow mtk_hal_camera DW9814AF_device:chr_file rw_file_perms; |
| allow mtk_hal_camera AK7345AF_device:chr_file rw_file_perms; |
| allow mtk_hal_camera DW9714A_device:chr_file rw_file_perms; |
| allow mtk_hal_camera LC898122AF_device:chr_file rw_file_perms; |
| allow mtk_hal_camera LC898212AF_device:chr_file rw_file_perms; |
| allow mtk_hal_camera BU6429AF_device:chr_file rw_file_perms; |
| allow mtk_hal_camera DW9718AF_device:chr_file rw_file_perms; |
| allow mtk_hal_camera BU64745GWZAF_device:chr_file rw_file_perms; |
| |
| # Purpose: Camera EEPROM Calibration |
| allow mtk_hal_camera CAM_CAL_DRV_device:chr_file rw_file_perms; |
| allow mtk_hal_camera CAM_CAL_DRV1_device:chr_file rw_file_perms; |
| allow mtk_hal_camera CAM_CAL_DRV2_device:chr_file rw_file_perms; |
| allow mtk_hal_camera camera_eeprom_device:chr_file rw_file_perms; |
| allow mtk_hal_camera seninf_n3d_device:chr_file rw_file_perms; |
| |
| # ----------------------------------- |
| # Purpose: Other device drivers used by camera |
| # ----------------------------------- |
| allow mtk_hal_camera ion_device:chr_file rw_file_perms; |
| allow mtk_hal_camera sw_sync_device:chr_file rw_file_perms; |
| allow mtk_hal_camera MTK_SMI_device:chr_file r_file_perms; |
| |
| # ----------------------------------- |
| # Purpose: Filesystem in Userspace (FUSE) |
| # - sdcard access (buffer dump for EM mode) |
| # ----------------------------------- |
| allow mtk_hal_camera fuse:dir rw_dir_perms; |
| allow mtk_hal_camera fuse:file rw_file_perms; |
| |
| # ----------------------------------- |
| # Purpose: Storage access |
| # ----------------------------------- |
| ## Date : WK14.XX-15.XX |
| ## nvram access |
| allow mtk_hal_camera nvram_data_file:dir create_dir_perms; |
| allow mtk_hal_camera nvram_data_file:file create_file_perms; |
| |
| ## nvram access (dumchar case for nand and legacy chip) |
| allow mtk_hal_camera nvram_device:chr_file rw_file_perms; |
| allow mtk_hal_camera self:netlink_kobject_uevent_socket create_socket_perms_no_ioctl; |
| |
| ## Date : WK14.XX-15.XX |
| ## sdcard access - dump for debug |
| allow mtk_hal_camera sdcard_type:dir create_dir_perms; |
| allow mtk_hal_camera sdcard_type:file create_file_perms; |
| |
| # ----------------------------------- |
| # Android O |
| # Purpose: Shell Debugging |
| # ----------------------------------- |
| # Purpose: Allow shell to invoke "lshal debug <interface>", where <interface> is "ICameraProvider". |
| # (used in user build) |
| allow mtk_hal_camera shell:unix_stream_socket { read write }; |
| allow mtk_hal_camera shell:fifo_file w_file_perms; |
| |
| # ----------------------------------- |
| # Android O |
| # Purpose: Debugging |
| # ----------------------------------- |
| # Purpose: libmemunreachable.so/GetUnreachableMemory() |
| allow mtk_hal_camera self:process { ptrace }; |
| |
| ########################## |
| # Date : WK14.XX-15.XX |
| # Operation : Copy from Media server |
| allow mtk_hal_camera self:capability { setuid ipc_lock sys_nice }; |
| allow mtk_hal_camera sysfs_wake_lock:file rw_file_perms; |
| allow mtk_hal_camera nvdata_file:file create_file_perms; |
| allow mtk_hal_camera proc_meminfo:file r_file_perms; |
| |
| ## Purpose : for low SD card latency issue |
| allow mtk_hal_camera sysfs_lowmemorykiller:file r_file_perms; |
| |
| ## Purpose : for change thermal policy when needed |
| allow mtk_hal_camera proc_mtkcooler:dir search; |
| allow mtk_hal_camera proc_mtktz:dir search; |
| allow mtk_hal_camera proc_thermal:dir search; |
| allow mtk_hal_camera thermal_manager_data_file:file create_file_perms; |
| allow mtk_hal_camera thermal_manager_data_file:dir { rw_dir_perms setattr }; |
| |
| ## Purpose : cts search strange app |
| allow mtk_hal_camera untrusted_app:dir search; |
| |
| ## Purpose : offloadservice |
| allow mtk_hal_camera offloadservice_device:chr_file rw_file_perms; |
| |
| ## Purpose: for camera middleware dump image buffer to sdcard & audio frameworks dump |
| allow mtk_hal_camera storage_file:lnk_file rw_file_perms; |
| allow mtk_hal_camera mnt_user_file:dir rw_dir_perms; |
| allow mtk_hal_camera mnt_user_file:lnk_file rw_file_perms; |
| |
| ## Purpose: Allow mtk_hal_camera to read binder from surfaceflinger |
| allow mtk_hal_camera surfaceflinger:fifo_file rw_file_perms; |
| |
| ## Purpose : camera read/write /nvcfg/camera data |
| allow mtk_hal_camera nvcfg_file:dir create_dir_perms; |
| allow mtk_hal_camera nvcfg_file:file create_file_perms; |
| |
| # Purpose : for camera init |
| allow mtk_hal_camera system_server:unix_stream_socket { read write }; |
| |
| ########################## |
| # Date : WK16 |
| # Operation : N Migration |
| ## Purpose: research root dir "/" |
| allow mtk_hal_camera tmpfs:dir search; |
| |
| ## Purpose : EGL file access |
| allow mtk_hal_camera system_file:dir r_dir_perms; |
| allow mtk_hal_camera gpu_device:dir search; |
| allow mtk_hal_camera gpu_device:chr_file rw_file_perms; |
| |
| ## Purpose: Allow to access ged for gralloc_extra functions |
| allow mtk_hal_camera proc_ged:file rw_file_perms; |
| allowxperm mtk_hal_camera proc_ged:file ioctl { proc_ged_ioctls }; |
| |
| |
| ## Purpose : camera3 IT/CTS |
| allow mtk_hal_camera hal_graphics_composer_default:fd use; |
| |
| # Date : WK17.30 |
| # Operation : O Migration |
| # Purpose: Allow to access cmdq driver |
| allow mtk_hal_camera mtk_cmdq_device:chr_file r_file_perms; |
| allow mtk_hal_camera mtk_mdp_device:chr_file r_file_perms; |
| allow mtk_hal_camera mtk_mdp_sync_device:chr_file r_file_perms; |
| |
| # Date : WK17.36 |
| # Operation : O Migration |
| # Purpose: Allow to access battery status |
| allow mtk_hal_camera sysfs_batteryinfo:dir search; |
| allow mtk_hal_camera sysfs_batteryinfo:file r_file_perms; |
| |
| # Date : WK17.39 |
| # Operation : O Migration |
| # Purpose: Change thermal config |
| set_prop(mtk_hal_camera, vendor_mtk_thermal_config_prop) |
| |
| # Date : WK18.31 |
| # Stage: P Migration |
| # Purpose: CCT |
| allow mtk_hal_camera graphics_device:chr_file rw_file_perms; |
| allow mtk_hal_camera graphics_device:dir search; |
| allow mtk_hal_camera cct_data_file:dir create_dir_perms; |
| allow mtk_hal_camera cct_data_file:file create_file_perms; |
| allow mtk_hal_camera cct_data_file:fifo_file create_file_perms; |
| allow mtk_hal_camera sysfs_boot_mode:file r_file_perms; |
| allow mtk_hal_camera mnt_vendor_file:dir create_dir_perms; |
| allow mtk_hal_camera mnt_vendor_file:fifo_file create_file_perms; |
| |
| # Date : WK18.02 |
| # Stage: O Migration |
| # Purpose: ISP tuning remapping |
| set_prop(mtk_hal_camera, vendor_mtk_mediatek_prop) |
| |
| # Date : WK18.22 |
| # Stage: p Migration |
| # Purpose: NVRAM |
| allow mtk_hal_camera nvdata_file:dir create_dir_perms; |
| allow mtk_hal_camera nvcfg_file:lnk_file r_file_perms; |
| allow mtk_hal_camera mnt_vendor_file:file create_file_perms; |
| |
| # Allow Camera HAL to set vendor_mtk_emcamera_prop |
| set_prop(mtk_hal_camera, vendor_mtk_emcamera_prop) |
| |
| # AAO |
| allow mtk_hal_camera data_vendor_aao_file:dir create_dir_perms; |
| allow mtk_hal_camera data_vendor_aao_file:file create_file_perms; |
| allow mtk_hal_camera data_vendor_aaoHwBuf_file:dir create_dir_perms; |
| allow mtk_hal_camera data_vendor_aaoHwBuf_file:file create_file_perms; |
| allow mtk_hal_camera data_vendor_AAObitTrue_file:dir create_dir_perms; |
| allow mtk_hal_camera data_vendor_AAObitTrue_file:file create_file_perms; |
| |
| # Flash |
| allow mtk_hal_camera data_vendor_flash_file:dir create_dir_perms; |
| allow mtk_hal_camera data_vendor_flash_file:file create_file_perms; |
| |
| # Flicker |
| allow mtk_hal_camera data_vendor_flicker_file:dir create_dir_perms; |
| allow mtk_hal_camera data_vendor_flicker_file:file create_file_perms; |
| |
| # AFO |
| allow mtk_hal_camera data_vendor_afo_file:dir create_dir_perms; |
| allow mtk_hal_camera data_vendor_afo_file:file create_file_perms; |
| |
| # PDO |
| allow mtk_hal_camera data_vendor_pdo_file:dir create_dir_perms; |
| allow mtk_hal_camera data_vendor_pdo_file:file create_file_perms; |
| |
| # Date : WK18.35 |
| # Purpose: allow mtk_hal_camera to access gz_device node |
| allow mtk_hal_camera gz_device:chr_file rw_file_perms; |
| |
| #data/dipdebug |
| allow mtk_hal_camera aee_dipdebug_vendor_file:dir rw_dir_perms; |
| allow mtk_hal_camera aee_dipdebug_vendor_file:file create_file_perms; |
| |
| allow mtk_hal_camera proc_isp_p2:dir search; |
| allow mtk_hal_camera proc_isp_p2:file create_file_perms; |
| |
| # Date: 2019/06/14 |
| # Operation : Migration |
| allow mtk_hal_camera sysfs_dt_firmware_android:dir search; |
| |
| # Date: 2019/07/09 |
| # Operation : For M4U security |
| allow mtk_hal_camera proc_m4u:file r_file_perms; |
| allowxperm mtk_hal_camera proc_m4u:file ioctl{ |
| MTK_M4U_T_ALLOC_MVA |
| MTK_M4U_T_DEALLOC_MVA |
| MTK_M4U_T_CONFIG_PORT |
| MTK_M4U_T_DMA_OP |
| MTK_M4U_T_SEC_INIT |
| MTK_M4U_GZ_SEC_INIT |
| }; |
| |
| # Date: 2019/07/04 |
| binder_call(mtk_hal_camera, platform_app) |
| |
| # Date : 2020/09/03 |
| # Purpose: mtk MMQoS set camera max BW |
| allow mtk_hal_camera sysfs_camera_max_bw:file { w_file_perms ioctl }; |
| allow mtk_hal_camera sysfs_camera_max_bw_v2:file { w_file_perms ioctl }; |
| allowxperm mtk_hal_camera sysfs_camera_max_bw:file ioctl VT_SENDSIG; |
| allowxperm mtk_hal_camera sysfs_camera_max_bw_v2:file ioctl VT_SENDSIG; |
| |
| # Date : 2020/09/24 |
| # Purpose: mtk camsys raw dump file |
| allow mtk_hal_camera data_vendor_raw_file:dir create_dir_perms; |
| allow mtk_hal_camera data_vendor_raw_file:file create_file_perms; |
| |
| # Date : 2020/12/05 |
| # Purpose : allow media sources to access /sys/bus/platform/drivers/mem_bw_ctrl/* |
| allow mtk_hal_camera sysfs_concurrency_scenario:file rw_file_perms; |
| |
| # Date : 2020/07/10 |
| # Purpose : allow media sources to access /sys/bus/platform/drivers/emi_ctrl/* |
| allow mtk_hal_camera sysfs_emi_ctrl_concurrency_scenario:file rw_file_perms; |
| |
| # Date : 2020/12/21 |
| # Operation : To access imgsys daemon driver |
| allow mtk_hal_camera mtk_hcp_device:chr_file rw_file_perms; |
| |
| # Allow ReadDefaultFstab(). |
| read_fstab(mtk_hal_camera) |
| |
| # Data : 2020/12/30 |
| # Purpose : DBReleasePlan |
| allow mtk_hal_camera vendor_bin_crossbuild_file:file r_file_perms; |
| |
| # Date: 2021/08/27 |
| # Operation : For DMABUF security |
| allow mtk_hal_camera dmabuf_system_secure_heap_device:chr_file r_file_perms_no_map; |
| |
| # Date : 2021/08/31 |
| # Purpose : allow camera hal to access /dev/hfmanager/* |
| allow mtk_hal_camera hf_manager_device:chr_file rw_file_perms_no_map; |
| |
| # Data : 2021/10/27 |
| # Purpose : DBReleasePlan |
| allowxperm mtk_hal_camera vendor_bin_crossbuild_file:file ioctl VT_SENDSIG; |