blob: 27c5df9958dec703a9a6ffd3850310eba86e8be3 [file] [log] [blame]
Vadim Caend64cf752022-11-04 12:51:18 +00001# virtual_camera - virtual camera daemon
2
3type virtual_camera, domain, coredomain;
Vadim Caenf6e88ec2023-09-29 16:15:23 +02004type virtual_camera_exec, system_file_type, exec_type, file_type;
Vadim Caend64cf752022-11-04 12:51:18 +00005
Vadim Caenf6e88ec2023-09-29 16:15:23 +02006init_daemon_domain(virtual_camera)
Vadim Caend64cf752022-11-04 12:51:18 +00007
Vadim Caenf6e88ec2023-09-29 16:15:23 +02008# Since virtual_camera is not a real HAL we don't set the
9# hal_server_domain(virtual_camera, hal_camera) macro but only the rules that
10# we actually need from halserverdomain and hal_camera_server:
11binder_use(virtual_camera)
Ján Sebechlebský5d6b66c2023-11-20 09:39:22 +000012binder_call(virtual_camera, cameraserver)
13binder_call(virtual_camera, system_server)
Vadim Caend64cf752022-11-04 12:51:18 +000014
Jan Sebechlebsky0fd6d1b2023-12-27 17:26:52 +010015# Allow virtual_camera to communicate with
16# mediaserver (required for using Surface originating
17# from virtual camera in mediaserver).
18binder_call(virtual_camera, mediaserver)
19
20# Required for the codecs to be able to decode
21# video into surface provided by virtual camera.
22hal_client_domain(virtual_camera, hal_codec2)
23hal_client_domain(virtual_camera, hal_omx)
Jan Sebechlebsky6e1795c2023-12-06 09:31:17 +010024
25# Allow virtualCamera to call apps via binder.
26binder_call(virtual_camera, appdomain)
27
Vadim Caenf6e88ec2023-09-29 16:15:23 +020028# Allow virtual_camera to use fd from apps
29allow virtual_camera { appdomain -isolated_app }:fd use;
Vadim Caend64cf752022-11-04 12:51:18 +000030
Vadim Caen68dc59d2024-03-15 17:12:37 +010031# Allow virtual_camera to use fd from surface flinger
32allow virtual_camera surfaceflinger:fd use;
33
Vadim Caenf6e88ec2023-09-29 16:15:23 +020034# Only allow virtual_camera to add a virtual_camera_service and no one else.
35add_service(virtual_camera, virtual_camera_service);
36
37# Allow virtual_camera to map graphic buffers
38hal_client_domain(virtual_camera, hal_graphics_allocator)
Jan Sebechlebsky267b6a92023-11-17 10:08:16 +010039
40# Allow virtual_camera to use GPU
41allow virtual_camera gpu_device:chr_file rw_file_perms;
42allow virtual_camera gpu_device:dir r_dir_perms;
Jan Sebechlebskyde644172023-11-30 10:57:16 +010043
Jan Sebechlebskyfd7e2852024-02-26 11:55:16 +010044# Allow virtual camera to use graphics composer fd-s (fences).
45allow virtual_camera hal_graphics_composer:fd use;
46
Jan Sebechlebskyde644172023-11-30 10:57:16 +010047# For collecting bugreports.
48allow virtual_camera dumpstate:fd use;
49allow virtual_camera dumpstate:fifo_file write;
Jan Sebechlebsky0959bef2023-12-05 14:17:07 +010050
51# Needed for permission checks.
52allow virtual_camera permission_service:service_manager find;
Jan Sebechlebsky7f271ce2024-04-15 08:25:19 +000053
54# Allow 'adb shell cmd' to configure test instances of camera.
55allow virtual_camera adbd:fd use;
56allow virtual_camera adbd:unix_stream_socket { getattr read write };
57allow virtual_camera shell:fifo_file { getattr read write };