blob: 8af704d8cc60348e1e2f9373a8103ad25a699701 [file] [log] [blame]
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -08001/*
2 * Copyright (C) 2013 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17package android.hardware;
18
19import android.hardware.ICamera;
20import android.hardware.ICameraClient;
21import android.hardware.camera2.ICameraDeviceUser;
22import android.hardware.camera2.ICameraDeviceCallbacks;
23import android.hardware.camera2.params.VendorTagDescriptor;
Emilian Peev71c73a22017-03-21 16:35:51 +000024import android.hardware.camera2.params.VendorTagDescriptorCache;
Jayant Chowdhary2bbdce42020-01-12 14:55:41 -080025import android.hardware.camera2.utils.ConcurrentCameraIdCombination;
26import android.hardware.camera2.utils.CameraIdAndSessionConfiguration;
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -080027import android.hardware.camera2.impl.CameraMetadataNative;
28import android.hardware.ICameraServiceListener;
29import android.hardware.CameraInfo;
Eino-Ville Talvalaf51fca22016-12-13 11:25:55 -080030import android.hardware.CameraStatus;
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -080031
32/**
33 * Binder interface for the native camera service running in mediaserver.
34 *
35 * @hide
36 */
37interface ICameraService
38{
39 /**
40 * All camera service and device Binder calls may return a
41 * ServiceSpecificException with the following error codes
42 */
43 const int ERROR_PERMISSION_DENIED = 1;
44 const int ERROR_ALREADY_EXISTS = 2;
45 const int ERROR_ILLEGAL_ARGUMENT = 3;
46 const int ERROR_DISCONNECTED = 4;
47 const int ERROR_TIMED_OUT = 5;
48 const int ERROR_DISABLED = 6;
49 const int ERROR_CAMERA_IN_USE = 7;
50 const int ERROR_MAX_CAMERAS_IN_USE = 8;
51 const int ERROR_DEPRECATED_HAL = 9;
52 const int ERROR_INVALID_OPERATION = 10;
53
54 /**
55 * Types for getNumberOfCameras
56 */
57 const int CAMERA_TYPE_BACKWARD_COMPATIBLE = 0;
58 const int CAMERA_TYPE_ALL = 1;
59
60 /**
61 * Return the number of camera devices available in the system
62 */
63 int getNumberOfCameras(int type);
64
65 /**
66 * Fetch basic camera information for a camera device
67 */
68 CameraInfo getCameraInfo(int cameraId);
69
70 /**
71 * Default UID/PID values for non-privileged callers of
Eino-Ville Talvalaa976df82019-06-13 18:01:58 -070072 * connect() and connectDevice()
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -080073 */
74 const int USE_CALLING_UID = -1;
75 const int USE_CALLING_PID = -1;
76
77 /**
78 * Open a camera device through the old camera API
79 */
80 ICamera connect(ICameraClient client,
81 int cameraId,
82 String opPackageName,
83 int clientUid, int clientPid);
84
85 /**
86 * Open a camera device through the new camera API
87 * Only supported for device HAL versions >= 3.2
88 */
89 ICameraDeviceUser connectDevice(ICameraDeviceCallbacks callbacks,
Eino-Ville Talvalaf51fca22016-12-13 11:25:55 -080090 String cameraId,
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -080091 String opPackageName,
Philip P. Moltmann9e648f62019-11-04 12:52:45 -080092 @nullable String featureId,
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -080093 int clientUid);
94
95 /**
Eino-Ville Talvalaf51fca22016-12-13 11:25:55 -080096 * Add listener for changes to camera device and flashlight state.
97 *
98 * Also returns the set of currently-known camera IDs and state of each device.
99 * Adding a listener will trigger the torch status listener to fire for all
Emilian Peev53722fa2019-02-22 17:47:20 -0800100 * devices that have a flash unit.
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800101 */
Eino-Ville Talvalaf51fca22016-12-13 11:25:55 -0800102 CameraStatus[] addListener(ICameraServiceListener listener);
103
104 /**
Jayant Chowdhary2bbdce42020-01-12 14:55:41 -0800105 * Get a list of combinations of camera ids which support concurrent streaming.
106 *
107 */
Jayant Chowdharycad23c22020-03-10 15:04:59 -0700108 ConcurrentCameraIdCombination[] getConcurrentCameraIds();
Jayant Chowdhary2bbdce42020-01-12 14:55:41 -0800109
110 /**
111 * Check whether a particular set of session configurations are concurrently supported by the
112 * corresponding camera ids.
113 *
114 * @param sessions the set of camera id and session configuration pairs to be queried.
115 * @return true - the set of concurrent camera id and stream combinations is supported.
116 * false - the set of concurrent camera id and stream combinations is not supported
117 * OR the method was called with a set of camera ids not returned by
Jayant Chowdharycad23c22020-03-10 15:04:59 -0700118 * getConcurrentCameraIds().
Jayant Chowdhary2bbdce42020-01-12 14:55:41 -0800119 */
120 boolean isConcurrentSessionConfigurationSupported(
121 in CameraIdAndSessionConfiguration[] sessions);
122
123 /**
Eino-Ville Talvalaf51fca22016-12-13 11:25:55 -0800124 * Remove listener for changes to camera device and flashlight state.
125 */
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800126 void removeListener(ICameraServiceListener listener);
127
128 /**
129 * Read the static camera metadata for a camera device.
130 * Only supported for device HAL versions >= 3.2
131 */
Eino-Ville Talvalaf51fca22016-12-13 11:25:55 -0800132 CameraMetadataNative getCameraCharacteristics(String cameraId);
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800133
134 /**
135 * Read in the vendor tag descriptors from the camera module HAL.
136 * Intended to be used by the native code of CameraMetadataNative to correctly
137 * interpret camera metadata with vendor tags.
138 */
139 VendorTagDescriptor getCameraVendorTagDescriptor();
140
141 /**
Emilian Peev71c73a22017-03-21 16:35:51 +0000142 * Retrieve the vendor tag descriptor cache which can have multiple vendor
143 * providers.
144 * Intended to be used by the native code of CameraMetadataNative to correctly
145 * interpret camera metadata with vendor tags.
146 */
147 VendorTagDescriptorCache getCameraVendorTagCache();
148
149 /**
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800150 * Read the legacy camera1 parameters into a String
151 */
152 String getLegacyParameters(int cameraId);
153
154 /**
155 * apiVersion constants for supportsCameraApi
156 */
157 const int API_VERSION_1 = 1;
158 const int API_VERSION_2 = 2;
159
Shuzhen Wangf9d2c022018-08-21 12:07:35 -0700160 // Determines if a particular API version is supported directly for a cameraId.
Eino-Ville Talvalaf51fca22016-12-13 11:25:55 -0800161 boolean supportsCameraApi(String cameraId, int apiVersion);
Shuzhen Wangf9d2c022018-08-21 12:07:35 -0700162 // Determines if a cameraId is a hidden physical camera of a logical multi-camera.
163 boolean isHiddenPhysicalCamera(String cameraId);
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800164
Eino-Ville Talvalaf51fca22016-12-13 11:25:55 -0800165 void setTorchMode(String cameraId, boolean enabled, IBinder clientBinder);
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800166
167 /**
168 * Notify the camera service of a system event. Should only be called from system_server.
169 *
170 * Callers require the android.permission.CAMERA_SEND_SYSTEM_EVENTS permission.
171 */
172 const int EVENT_NONE = 0;
Eino-Ville Talvala63f36112018-12-06 14:57:03 -0800173 const int EVENT_USER_SWITCHED = 1; // The argument is the set of new foreground user IDs.
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800174 oneway void notifySystemEvent(int eventId, in int[] args);
Eino-Ville Talvala63f36112018-12-06 14:57:03 -0800175
176 /**
177 * Notify the camera service of a device physical status change. May only be called from
178 * a privileged process.
179 *
180 * newState is a bitfield consisting of DEVICE_STATE_* values combined together. Valid state
181 * combinations are device-specific. At device startup, the camera service will assume the device
182 * state is NORMAL until otherwise notified.
183 *
184 * Callers require the android.permission.CAMERA_SEND_SYSTEM_EVENTS permission.
185 */
186 oneway void notifyDeviceStateChange(long newState);
187
188 // Bitfield constants for notifyDeviceStateChange
189 // All bits >= 32 are for custom vendor states
190 // Written as ints since AIDL does not support long constants.
191 const int DEVICE_STATE_NORMAL = 0;
192 const int DEVICE_STATE_BACK_COVERED = 1;
193 const int DEVICE_STATE_FRONT_COVERED = 2;
194 const int DEVICE_STATE_FOLDED = 4;
195 const int DEVICE_STATE_LAST_FRAMEWORK_BIT = 0x80000000; // 1 << 31;
196
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800197}