blob: 84bcdb8849351246d9075f78aa9fedbf812f37e5 [file] [log] [blame]
Mathias Agopian65ab4712010-07-14 17:59:35 -07001/*
Ruben Brunkd1176ef2014-02-21 10:51:38 -08002 * Copyright (C) 2008 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 */
Mathias Agopian65ab4712010-07-14 17:59:35 -070016
17#ifndef ANDROID_SERVERS_CAMERA_CAMERASERVICE_H
18#define ANDROID_SERVERS_CAMERA_CAMERASERVICE_H
19
Igor Murashkin634a5152013-02-20 17:15:11 -080020#include <utils/Vector.h>
Ruben Brunkb2119af2014-05-09 19:57:56 -070021#include <utils/KeyedVector.h>
Eino-Ville Talvalaceb388d2013-02-19 10:40:14 -080022#include <binder/AppOpsManager.h>
Mathias Agopian5462fc92010-07-14 18:41:18 -070023#include <binder/BinderService.h>
Eino-Ville Talvalaceb388d2013-02-19 10:40:14 -080024#include <binder/IAppOpsCallback.h>
Mathias Agopian65ab4712010-07-14 17:59:35 -070025#include <camera/ICameraService.h>
Iliyan Malchev8951a972011-04-14 16:55:59 -070026#include <hardware/camera.h>
Mathias Agopian65ab4712010-07-14 17:59:35 -070027
Igor Murashkinc073ba52013-02-26 14:32:34 -080028#include <camera/ICamera.h>
29#include <camera/ICameraClient.h>
30#include <camera/IProCameraUser.h>
31#include <camera/IProCameraCallbacks.h>
Eino-Ville Talvala7b82efe2013-07-25 17:12:35 -070032#include <camera/camera2/ICameraDeviceUser.h>
33#include <camera/camera2/ICameraDeviceCallbacks.h>
Ruben Brunkd1176ef2014-02-21 10:51:38 -080034#include <camera/VendorTagDescriptor.h>
Jianing Weicb0652e2014-03-12 18:29:36 -070035#include <camera/CaptureResult.h>
Ruben Brunkb2119af2014-05-09 19:57:56 -070036#include <camera/CameraParameters.h>
Igor Murashkinc073ba52013-02-26 14:32:34 -080037
Igor Murashkinbfc99152013-02-27 12:55:20 -080038#include <camera/ICameraServiceListener.h>
Chien-Yu Chen3068d732015-02-09 13:29:57 -080039#include "CameraFlashlight.h"
40
Igor Murashkinbfc99152013-02-27 12:55:20 -080041
Yin-Chia Yehe074a932015-01-30 10:29:02 -080042#include "common/CameraModule.h"
43
Mathias Agopian65ab4712010-07-14 17:59:35 -070044/* This needs to be increased if we can have more cameras */
45#define MAX_CAMERAS 2
46
47namespace android {
48
Eino-Ville Talvala5e08d602012-05-16 14:59:25 -070049extern volatile int32_t gLogLevel;
50
Mathias Agopian65ab4712010-07-14 17:59:35 -070051class MemoryHeapBase;
52class MediaPlayer;
53
Mathias Agopian5462fc92010-07-14 18:41:18 -070054class CameraService :
55 public BinderService<CameraService>,
Igor Murashkinecf17e82012-10-02 16:05:11 -070056 public BnCameraService,
Igor Murashkincba2c162013-03-20 15:56:31 -070057 public IBinder::DeathRecipient,
58 public camera_module_callbacks_t
Mathias Agopian65ab4712010-07-14 17:59:35 -070059{
Mathias Agopian5462fc92010-07-14 18:41:18 -070060 friend class BinderService<CameraService>;
Mathias Agopian65ab4712010-07-14 17:59:35 -070061public:
Eino-Ville Talvala5e08d602012-05-16 14:59:25 -070062 class Client;
Igor Murashkin634a5152013-02-20 17:15:11 -080063 class BasicClient;
64
65 // Implementation of BinderService<T>
Mathias Agopian5462fc92010-07-14 18:41:18 -070066 static char const* getServiceName() { return "media.camera"; }
Mathias Agopian65ab4712010-07-14 17:59:35 -070067
68 CameraService();
69 virtual ~CameraService();
70
Igor Murashkin634a5152013-02-20 17:15:11 -080071 /////////////////////////////////////////////////////////////////////
Igor Murashkincba2c162013-03-20 15:56:31 -070072 // HAL Callbacks
73 virtual void onDeviceStatusChanged(int cameraId,
74 int newStatus);
Chien-Yu Chen3068d732015-02-09 13:29:57 -080075 virtual void onTorchStatusChanged(const String16& cameraId,
76 ICameraServiceListener::TorchStatus
77 newStatus);
Igor Murashkincba2c162013-03-20 15:56:31 -070078
79 /////////////////////////////////////////////////////////////////////
Igor Murashkin634a5152013-02-20 17:15:11 -080080 // ICameraService
Mathias Agopian65ab4712010-07-14 17:59:35 -070081 virtual int32_t getNumberOfCameras();
82 virtual status_t getCameraInfo(int cameraId,
83 struct CameraInfo* cameraInfo);
Zhijun He2b59be82013-09-25 10:14:30 -070084 virtual status_t getCameraCharacteristics(int cameraId,
85 CameraMetadata* cameraInfo);
Ruben Brunkd1176ef2014-02-21 10:51:38 -080086 virtual status_t getCameraVendorTagDescriptor(/*out*/ sp<VendorTagDescriptor>& desc);
Eino-Ville Talvalaceb388d2013-02-19 10:40:14 -080087
Ruben Brunk0f61d8f2013-08-08 13:07:18 -070088 virtual status_t connect(const sp<ICameraClient>& cameraClient, int cameraId,
89 const String16& clientPackageName, int clientUid,
90 /*out*/
91 sp<ICamera>& device);
92
Zhijun Heb10cdad2014-06-16 16:38:35 -070093 virtual status_t connectLegacy(const sp<ICameraClient>& cameraClient, int cameraId,
94 int halVersion, const String16& clientPackageName, int clientUid,
95 /*out*/
96 sp<ICamera>& device);
97
Ruben Brunk0f61d8f2013-08-08 13:07:18 -070098 virtual status_t connectPro(const sp<IProCameraCallbacks>& cameraCb,
99 int cameraId, const String16& clientPackageName, int clientUid,
100 /*out*/
101 sp<IProCameraUser>& device);
102
103 virtual status_t connectDevice(
Igor Murashkine7ee7632013-06-11 18:10:18 -0700104 const sp<ICameraDeviceCallbacks>& cameraCb,
105 int cameraId,
106 const String16& clientPackageName,
Ruben Brunk0f61d8f2013-08-08 13:07:18 -0700107 int clientUid,
108 /*out*/
109 sp<ICameraDeviceUser>& device);
Mathias Agopian65ab4712010-07-14 17:59:35 -0700110
Igor Murashkinbfc99152013-02-27 12:55:20 -0800111 virtual status_t addListener(const sp<ICameraServiceListener>& listener);
112 virtual status_t removeListener(
113 const sp<ICameraServiceListener>& listener);
114
Igor Murashkin65d14b92014-06-17 12:03:20 -0700115 virtual status_t getLegacyParameters(
116 int cameraId,
117 /*out*/
118 String16* parameters);
119
Chien-Yu Chen3068d732015-02-09 13:29:57 -0800120 virtual status_t setTorchMode(const String16& cameraId, bool enabled,
121 const sp<IBinder>& clientBinder);
122
Igor Murashkin65d14b92014-06-17 12:03:20 -0700123 // OK = supports api of that version, -EOPNOTSUPP = does not support
124 virtual status_t supportsCameraApi(
125 int cameraId, int apiVersion);
126
Igor Murashkin634a5152013-02-20 17:15:11 -0800127 // Extra permissions checks
Mathias Agopian65ab4712010-07-14 17:59:35 -0700128 virtual status_t onTransact(uint32_t code, const Parcel& data,
129 Parcel* reply, uint32_t flags);
Igor Murashkin634a5152013-02-20 17:15:11 -0800130
131 virtual status_t dump(int fd, const Vector<String16>& args);
132
133 /////////////////////////////////////////////////////////////////////
134 // Client functionality
135 virtual void removeClientByRemote(const wp<IBinder>& remoteBinder);
Mathias Agopian65ab4712010-07-14 17:59:35 -0700136
137 enum sound_kind {
138 SOUND_SHUTTER = 0,
139 SOUND_RECORDING = 1,
140 NUM_SOUNDS
141 };
142
143 void loadSound();
144 void playSound(sound_kind kind);
145 void releaseSound();
146
Igor Murashkin98e24722013-06-19 19:51:04 -0700147 /////////////////////////////////////////////////////////////////////
148 // CameraDeviceFactory functionality
149 int getDeviceVersion(int cameraId, int* facing = NULL);
150
Eino-Ville Talvalaf67e23e2014-07-23 17:17:59 -0700151 /////////////////////////////////////////////////////////////////////
152 // Shared utilities
153 static status_t filterOpenErrorCode(status_t err);
154 static status_t filterGetInfoErrorCode(status_t err);
Igor Murashkin634a5152013-02-20 17:15:11 -0800155
156 /////////////////////////////////////////////////////////////////////
157 // CameraClient functionality
158
159 // returns plain pointer of client. Note that mClientLock should be acquired to
160 // prevent the client from destruction. The result can be NULL.
Igor Murashkine7ee7632013-06-11 18:10:18 -0700161 virtual BasicClient* getClientByIdUnsafe(int cameraId);
Igor Murashkin634a5152013-02-20 17:15:11 -0800162 virtual Mutex* getClientLockById(int cameraId);
163
164 class BasicClient : public virtual RefBase {
165 public:
Yin-Chia Yehe074a932015-01-30 10:29:02 -0800166 virtual status_t initialize(CameraModule *module) = 0;
Eino-Ville Talvalaf67e23e2014-07-23 17:17:59 -0700167 virtual void disconnect();
Igor Murashkin634a5152013-02-20 17:15:11 -0800168
Igor Murashkine7ee7632013-06-11 18:10:18 -0700169 // because we can't virtually inherit IInterface, which breaks
170 // virtual inheritance
171 virtual sp<IBinder> asBinderWrapper() = 0;
172
Igor Murashkine6800ce2013-03-04 17:25:57 -0800173 // Return the remote callback binder object (e.g. IProCameraCallbacks)
Eino-Ville Talvalaf67e23e2014-07-23 17:17:59 -0700174 sp<IBinder> getRemote() {
Igor Murashkin44cfcf02013-03-01 16:22:28 -0800175 return mRemoteBinder;
Igor Murashkin634a5152013-02-20 17:15:11 -0800176 }
177
Eino-Ville Talvalaf67e23e2014-07-23 17:17:59 -0700178 virtual status_t dump(int fd, const Vector<String16>& args) = 0;
Igor Murashkine7ee7632013-06-11 18:10:18 -0700179
Igor Murashkin634a5152013-02-20 17:15:11 -0800180 protected:
181 BasicClient(const sp<CameraService>& cameraService,
182 const sp<IBinder>& remoteCallback,
Eino-Ville Talvalaceb388d2013-02-19 10:40:14 -0800183 const String16& clientPackageName,
Igor Murashkin634a5152013-02-20 17:15:11 -0800184 int cameraId,
185 int cameraFacing,
186 int clientPid,
Eino-Ville Talvalaceb388d2013-02-19 10:40:14 -0800187 uid_t clientUid,
Igor Murashkin634a5152013-02-20 17:15:11 -0800188 int servicePid);
189
190 virtual ~BasicClient();
191
192 // the instance is in the middle of destruction. When this is set,
193 // the instance should not be accessed from callback.
194 // CameraService's mClientLock should be acquired to access this.
195 // - subclasses should set this to true in their destructors.
196 bool mDestructionStarted;
197
198 // these are initialized in the constructor.
199 sp<CameraService> mCameraService; // immutable after constructor
200 int mCameraId; // immutable after constructor
201 int mCameraFacing; // immutable after constructor
Eino-Ville Talvalaceb388d2013-02-19 10:40:14 -0800202 const String16 mClientPackageName;
Igor Murashkin634a5152013-02-20 17:15:11 -0800203 pid_t mClientPid;
Eino-Ville Talvalaceb388d2013-02-19 10:40:14 -0800204 uid_t mClientUid; // immutable after constructor
Igor Murashkin634a5152013-02-20 17:15:11 -0800205 pid_t mServicePid; // immutable after constructor
206
207 // - The app-side Binder interface to receive callbacks from us
Igor Murashkine7ee7632013-06-11 18:10:18 -0700208 sp<IBinder> mRemoteBinder; // immutable after constructor
Eino-Ville Talvalaceb388d2013-02-19 10:40:14 -0800209
210 // permissions management
211 status_t startCameraOps();
212 status_t finishCameraOps();
213
214 // Notify client about a fatal error
Jianing Weicb0652e2014-03-12 18:29:36 -0700215 virtual void notifyError(
216 ICameraDeviceCallbacks::CameraErrorCode errorCode,
217 const CaptureResultExtras& resultExtras) = 0;
Eino-Ville Talvalaceb388d2013-02-19 10:40:14 -0800218 private:
219 AppOpsManager mAppOpsManager;
220
221 class OpsCallback : public BnAppOpsCallback {
222 public:
223 OpsCallback(wp<BasicClient> client);
224 virtual void opChanged(int32_t op, const String16& packageName);
225
226 private:
227 wp<BasicClient> mClient;
228
229 }; // class OpsCallback
230
231 sp<OpsCallback> mOpsCallback;
232 // Track whether startCameraOps was called successfully, to avoid
233 // finishing what we didn't start.
234 bool mOpsActive;
235
236 // IAppOpsCallback interface, indirected through opListener
237 virtual void opChanged(int32_t op, const String16& packageName);
238 }; // class BasicClient
Igor Murashkin634a5152013-02-20 17:15:11 -0800239
240 class Client : public BnCamera, public BasicClient
Eino-Ville Talvala5e08d602012-05-16 14:59:25 -0700241 {
242 public:
Igor Murashkin44cfcf02013-03-01 16:22:28 -0800243 typedef ICameraClient TCamCallbacks;
244
Eino-Ville Talvala5e08d602012-05-16 14:59:25 -0700245 // ICamera interface (see ICamera for details)
246 virtual void disconnect();
247 virtual status_t connect(const sp<ICameraClient>& client) = 0;
248 virtual status_t lock() = 0;
249 virtual status_t unlock() = 0;
Eino-Ville Talvala1ce7c342013-08-21 13:57:21 -0700250 virtual status_t setPreviewTarget(const sp<IGraphicBufferProducer>& bufferProducer)=0;
Eino-Ville Talvala5e08d602012-05-16 14:59:25 -0700251 virtual void setPreviewCallbackFlag(int flag) = 0;
Eino-Ville Talvala3ee35502013-04-02 15:45:11 -0700252 virtual status_t setPreviewCallbackTarget(
253 const sp<IGraphicBufferProducer>& callbackProducer) = 0;
Eino-Ville Talvala5e08d602012-05-16 14:59:25 -0700254 virtual status_t startPreview() = 0;
255 virtual void stopPreview() = 0;
256 virtual bool previewEnabled() = 0;
257 virtual status_t storeMetaDataInBuffers(bool enabled) = 0;
258 virtual status_t startRecording() = 0;
259 virtual void stopRecording() = 0;
260 virtual bool recordingEnabled() = 0;
261 virtual void releaseRecordingFrame(const sp<IMemory>& mem) = 0;
262 virtual status_t autoFocus() = 0;
263 virtual status_t cancelAutoFocus() = 0;
264 virtual status_t takePicture(int msgType) = 0;
265 virtual status_t setParameters(const String8& params) = 0;
266 virtual String8 getParameters() const = 0;
267 virtual status_t sendCommand(int32_t cmd, int32_t arg1, int32_t arg2) = 0;
268
269 // Interface used by CameraService
270 Client(const sp<CameraService>& cameraService,
271 const sp<ICameraClient>& cameraClient,
Eino-Ville Talvalaceb388d2013-02-19 10:40:14 -0800272 const String16& clientPackageName,
Eino-Ville Talvala5e08d602012-05-16 14:59:25 -0700273 int cameraId,
274 int cameraFacing,
Igor Murashkinecf17e82012-10-02 16:05:11 -0700275 int clientPid,
Eino-Ville Talvalaceb388d2013-02-19 10:40:14 -0800276 uid_t clientUid,
Igor Murashkinecf17e82012-10-02 16:05:11 -0700277 int servicePid);
Eino-Ville Talvala5e08d602012-05-16 14:59:25 -0700278 ~Client();
279
280 // return our camera client
Igor Murashkin44cfcf02013-03-01 16:22:28 -0800281 const sp<ICameraClient>& getRemoteCallback() {
282 return mRemoteCallback;
Eino-Ville Talvala5e08d602012-05-16 14:59:25 -0700283 }
284
Igor Murashkine7ee7632013-06-11 18:10:18 -0700285 virtual sp<IBinder> asBinderWrapper() {
Marco Nelissen06b46062014-11-14 07:58:25 -0800286 return asBinder(this);
Igor Murashkine7ee7632013-06-11 18:10:18 -0700287 }
288
Eino-Ville Talvala5e08d602012-05-16 14:59:25 -0700289 protected:
290 static Mutex* getClientLockFromCookie(void* user);
291 // convert client from cookie. Client lock should be acquired before getting Client.
292 static Client* getClientFromCookie(void* user);
293
Jianing Weicb0652e2014-03-12 18:29:36 -0700294 virtual void notifyError(ICameraDeviceCallbacks::CameraErrorCode errorCode,
295 const CaptureResultExtras& resultExtras);
Eino-Ville Talvalaceb388d2013-02-19 10:40:14 -0800296
Igor Murashkin634a5152013-02-20 17:15:11 -0800297 // Initialized in constructor
Eino-Ville Talvala5e08d602012-05-16 14:59:25 -0700298
Igor Murashkin634a5152013-02-20 17:15:11 -0800299 // - The app-side Binder interface to receive callbacks from us
Igor Murashkin44cfcf02013-03-01 16:22:28 -0800300 sp<ICameraClient> mRemoteCallback;
Eino-Ville Talvalaceb388d2013-02-19 10:40:14 -0800301
302 }; // class Client
Igor Murashkin634a5152013-02-20 17:15:11 -0800303
304 class ProClient : public BnProCameraUser, public BasicClient {
305 public:
Igor Murashkin44cfcf02013-03-01 16:22:28 -0800306 typedef IProCameraCallbacks TCamCallbacks;
307
Igor Murashkin634a5152013-02-20 17:15:11 -0800308 ProClient(const sp<CameraService>& cameraService,
309 const sp<IProCameraCallbacks>& remoteCallback,
Eino-Ville Talvalaceb388d2013-02-19 10:40:14 -0800310 const String16& clientPackageName,
Igor Murashkin634a5152013-02-20 17:15:11 -0800311 int cameraId,
312 int cameraFacing,
313 int clientPid,
Eino-Ville Talvalaceb388d2013-02-19 10:40:14 -0800314 uid_t clientUid,
Igor Murashkin634a5152013-02-20 17:15:11 -0800315 int servicePid);
316
317 virtual ~ProClient();
318
319 const sp<IProCameraCallbacks>& getRemoteCallback() {
320 return mRemoteCallback;
321 }
322
Igor Murashkin634a5152013-02-20 17:15:11 -0800323 /***
324 IProCamera implementation
325 ***/
Igor Murashkine6800ce2013-03-04 17:25:57 -0800326 virtual status_t connect(const sp<IProCameraCallbacks>& callbacks)
327 = 0;
328 virtual status_t exclusiveTryLock() = 0;
329 virtual status_t exclusiveLock() = 0;
330 virtual status_t exclusiveUnlock() = 0;
Igor Murashkin634a5152013-02-20 17:15:11 -0800331
Igor Murashkine6800ce2013-03-04 17:25:57 -0800332 virtual bool hasExclusiveLock() = 0;
Igor Murashkin634a5152013-02-20 17:15:11 -0800333
334 // Note that the callee gets a copy of the metadata.
335 virtual int submitRequest(camera_metadata_t* metadata,
Igor Murashkine6800ce2013-03-04 17:25:57 -0800336 bool streaming = false) = 0;
337 virtual status_t cancelRequest(int requestId) = 0;
Igor Murashkin634a5152013-02-20 17:15:11 -0800338
Igor Murashkinbfc99152013-02-27 12:55:20 -0800339 // Callbacks from camera service
Igor Murashkine6800ce2013-03-04 17:25:57 -0800340 virtual void onExclusiveLockStolen() = 0;
Igor Murashkinbfc99152013-02-27 12:55:20 -0800341
Igor Murashkin634a5152013-02-20 17:15:11 -0800342 protected:
Jianing Weicb0652e2014-03-12 18:29:36 -0700343 virtual void notifyError(ICameraDeviceCallbacks::CameraErrorCode errorCode,
344 const CaptureResultExtras& resultExtras);
Eino-Ville Talvala5e08d602012-05-16 14:59:25 -0700345
Eino-Ville Talvalaceb388d2013-02-19 10:40:14 -0800346 sp<IProCameraCallbacks> mRemoteCallback;
347 }; // class ProClient
Eino-Ville Talvala5e08d602012-05-16 14:59:25 -0700348
Mathias Agopian65ab4712010-07-14 17:59:35 -0700349private:
Igor Murashkin634a5152013-02-20 17:15:11 -0800350
351 // Delay-load the Camera HAL module
352 virtual void onFirstRef();
353
Igor Murashkine6800ce2013-03-04 17:25:57 -0800354 // Step 1. Check if we can connect, before we acquire the service lock.
Ruben Brunk0f61d8f2013-08-08 13:07:18 -0700355 status_t validateConnect(int cameraId,
Igor Murashkine6800ce2013-03-04 17:25:57 -0800356 /*inout*/
357 int& clientUid) const;
358
359 // Step 2. Check if we can connect, after we acquire the service lock.
360 bool canConnectUnsafe(int cameraId,
361 const String16& clientPackageName,
362 const sp<IBinder>& remoteCallback,
363 /*out*/
Igor Murashkine7ee7632013-06-11 18:10:18 -0700364 sp<BasicClient> &client);
Igor Murashkine6800ce2013-03-04 17:25:57 -0800365
366 // When connection is successful, initialize client and track its death
Ruben Brunk0f61d8f2013-08-08 13:07:18 -0700367 status_t connectFinishUnsafe(const sp<BasicClient>& client,
Igor Murashkine7ee7632013-06-11 18:10:18 -0700368 const sp<IBinder>& remoteCallback);
Igor Murashkine6800ce2013-03-04 17:25:57 -0800369
Igor Murashkin634a5152013-02-20 17:15:11 -0800370 virtual sp<BasicClient> getClientByRemote(const wp<IBinder>& cameraClient);
371
Mathias Agopian65ab4712010-07-14 17:59:35 -0700372 Mutex mServiceLock;
Igor Murashkine7ee7632013-06-11 18:10:18 -0700373 // either a Client or CameraDeviceClient
374 wp<BasicClient> mClient[MAX_CAMERAS]; // protected by mServiceLock
Keun young Parkd8973a72012-03-28 14:13:09 -0700375 Mutex mClientLock[MAX_CAMERAS]; // prevent Client destruction inside callbacks
Mathias Agopian65ab4712010-07-14 17:59:35 -0700376 int mNumberOfCameras;
377
Igor Murashkin634a5152013-02-20 17:15:11 -0800378 typedef wp<ProClient> weak_pro_client_ptr;
379 Vector<weak_pro_client_ptr> mProClientList[MAX_CAMERAS];
380
Igor Murashkinecf17e82012-10-02 16:05:11 -0700381 // needs to be called with mServiceLock held
Igor Murashkine7ee7632013-06-11 18:10:18 -0700382 sp<BasicClient> findClientUnsafe(const wp<IBinder>& cameraClient, int& outIndex);
Igor Murashkin634a5152013-02-20 17:15:11 -0800383 sp<ProClient> findProClientUnsafe(
384 const wp<IBinder>& cameraCallbacksRemote);
Igor Murashkinecf17e82012-10-02 16:05:11 -0700385
Mathias Agopian65ab4712010-07-14 17:59:35 -0700386 // atomics to record whether the hardware is allocated to some client.
387 volatile int32_t mBusy[MAX_CAMERAS];
388 void setCameraBusy(int cameraId);
389 void setCameraFree(int cameraId);
390
391 // sounds
Chih-Chung Changff4f55c2011-10-17 19:03:12 +0800392 MediaPlayer* newMediaPlayer(const char *file);
393
Mathias Agopian65ab4712010-07-14 17:59:35 -0700394 Mutex mSoundLock;
395 sp<MediaPlayer> mSoundPlayer[NUM_SOUNDS];
396 int mSoundRef; // reference count (release all MediaPlayer when 0)
397
Yin-Chia Yehe074a932015-01-30 10:29:02 -0800398 CameraModule* mModule;
Igor Murashkinecf17e82012-10-02 16:05:11 -0700399
Igor Murashkinbfc99152013-02-27 12:55:20 -0800400 Vector<sp<ICameraServiceListener> >
401 mListenerList;
402
403 // guard only mStatusList and the broadcasting of ICameraServiceListener
Igor Murashkincba2c162013-03-20 15:56:31 -0700404 mutable Mutex mStatusMutex;
Igor Murashkinbfc99152013-02-27 12:55:20 -0800405 ICameraServiceListener::Status
406 mStatusList[MAX_CAMERAS];
407
Igor Murashkincba2c162013-03-20 15:56:31 -0700408 // Read the current status (locks mStatusMutex)
409 ICameraServiceListener::Status
410 getStatus(int cameraId) const;
411
Igor Murashkin93747b92013-05-01 15:42:20 -0700412 typedef Vector<ICameraServiceListener::Status> StatusVector;
Igor Murashkinbfc99152013-02-27 12:55:20 -0800413 // Broadcast the new status if it changed (locks the service mutex)
414 void updateStatus(
415 ICameraServiceListener::Status status,
Igor Murashkin93747b92013-05-01 15:42:20 -0700416 int32_t cameraId,
417 const StatusVector *rejectSourceStates = NULL);
Igor Murashkinbfc99152013-02-27 12:55:20 -0800418
Chien-Yu Chen3068d732015-02-09 13:29:57 -0800419 // flashlight control
420 sp<CameraFlashlight> mFlashlight;
421 // guard mTorchStatusMap and mTorchClientMap
422 Mutex mTorchStatusMutex;
423 // camera id -> torch status
424 KeyedVector<String16, ICameraServiceListener::TorchStatus> mTorchStatusMap;
425 // camera id -> torch client binder
426 // only store the last client that turns on each camera's torch mode
427 KeyedVector<String16, sp<IBinder> > mTorchClientMap;
428
429 // check and handle if torch client's process has died
430 void handleTorchClientBinderDied(const wp<IBinder> &who);
431
432 // handle torch mode status change and invoke callbacks. mTorchStatusMutex
433 // should be locked.
434 void onTorchStatusChangedLocked(const String16& cameraId,
435 ICameraServiceListener::TorchStatus newStatus);
436
437 // get a camera's torch status. mTorchStatusMutex should be locked.
438 ICameraServiceListener::TorchStatus getTorchStatusLocked(
439 const String16 &cameraId) const;
440
441 // set a camera's torch status. mTorchStatusMutex should be locked.
442 status_t setTorchStatusLocked(const String16 &cameraId,
443 ICameraServiceListener::TorchStatus status);
444
Igor Murashkinecf17e82012-10-02 16:05:11 -0700445 // IBinder::DeathRecipient implementation
Igor Murashkinbfc99152013-02-27 12:55:20 -0800446 virtual void binderDied(const wp<IBinder> &who);
Igor Murashkin634a5152013-02-20 17:15:11 -0800447
448 // Helpers
Igor Murashkinbfc99152013-02-27 12:55:20 -0800449
450 bool isValidCameraId(int cameraId);
Ruben Brunkd1176ef2014-02-21 10:51:38 -0800451
452 bool setUpVendorTags();
Ruben Brunkb2119af2014-05-09 19:57:56 -0700453
454 /**
455 * A mapping of camera ids to CameraParameters returned by that camera device.
456 *
457 * This cache is used to generate CameraCharacteristic metadata when using
458 * the HAL1 shim.
459 */
460 KeyedVector<int, CameraParameters> mShimParams;
461
462 /**
463 * Initialize and cache the metadata used by the HAL1 shim for a given cameraId.
464 *
465 * Returns OK on success, or a negative error code.
466 */
467 status_t initializeShimMetadata(int cameraId);
468
469 /**
Igor Murashkin65d14b92014-06-17 12:03:20 -0700470 * Get the cached CameraParameters for the camera. If they haven't been
471 * cached yet, then initialize them for the first time.
472 *
473 * Returns OK on success, or a negative error code.
474 */
475 status_t getLegacyParametersLazy(int cameraId, /*out*/CameraParameters* parameters);
476
477 /**
Ruben Brunkb2119af2014-05-09 19:57:56 -0700478 * Generate the CameraCharacteristics metadata required by the Camera2 API
479 * from the available HAL1 CameraParameters and CameraInfo.
480 *
481 * Returns OK on success, or a negative error code.
482 */
483 status_t generateShimMetadata(int cameraId, /*out*/CameraMetadata* cameraInfo);
484
485 /**
486 * Connect a new camera client. This should only be used while holding the
487 * mutex for mServiceLock.
488 *
489 * Returns OK on success, or a negative error code.
490 */
Igor Murashkina858ea02014-08-19 14:53:08 -0700491 status_t connectHelperLocked(
492 /*out*/
493 sp<Client>& client,
494 /*in*/
495 const sp<ICameraClient>& cameraClient,
496 int cameraId,
497 const String16& clientPackageName,
498 int clientUid,
499 int callingPid,
500 int halVersion = CAMERA_HAL_API_VERSION_UNSPECIFIED,
501 bool legacyMode = false);
Mathias Agopian65ab4712010-07-14 17:59:35 -0700502};
503
504} // namespace android
505
506#endif