blob: 98cd934865355126f65c65713d1e12491317ad0e [file] [log] [blame]
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -08001/*
2 * Copyright (C) 2015 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
17#ifndef _ACAMERA_MANAGER_H
18#define _ACAMERA_MANAGER_H
19
Colin Cross7e8d4ba2017-05-04 16:17:42 -070020#include <camera/NdkCameraManager.h>
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080021
Yin-Chia Yeh03f55752018-03-14 15:28:02 -070022#include <android-base/parseint.h>
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -080023#include <android/hardware/ICameraService.h>
24#include <android/hardware/BnCameraServiceListener.h>
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080025#include <camera/CameraMetadata.h>
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080026#include <binder/IServiceManager.h>
27#include <utils/StrongPointer.h>
28#include <utils/Mutex.h>
29
30#include <media/stagefright/foundation/ALooper.h>
31#include <media/stagefright/foundation/AHandler.h>
32#include <media/stagefright/foundation/AMessage.h>
33
34#include <set>
35#include <map>
36
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080037namespace android {
Jayant Chowdhary6df26072018-11-06 23:55:12 -080038namespace acam {
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080039
40/**
41 * Per-process singleton instance of CameraManger. Shared by all ACameraManager
42 * instances. Created when first ACameraManager is created and destroyed when
43 * all ACameraManager instances are deleted.
44 *
Eino-Ville Talvalaf51fca22016-12-13 11:25:55 -080045 * TODO: maybe CameraManagerGlobal is better suited in libcameraclient?
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080046 */
47class CameraManagerGlobal final : public RefBase {
48 public:
49 static CameraManagerGlobal& getInstance();
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -080050 sp<hardware::ICameraService> getCameraService();
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080051
52 void registerAvailabilityCallback(
53 const ACameraManager_AvailabilityCallbacks *callback);
54 void unregisterAvailabilityCallback(
55 const ACameraManager_AvailabilityCallbacks *callback);
56
Emilian Peevc6f2ab32019-03-04 11:18:59 -080057 void registerExtendedAvailabilityCallback(
58 const ACameraManager_ExtendedAvailabilityCallbacks* callback);
59 void unregisterExtendedAvailabilityCallback(
60 const ACameraManager_ExtendedAvailabilityCallbacks* callback);
61
Eino-Ville Talvalaf51fca22016-12-13 11:25:55 -080062 /**
63 * Return camera IDs that support camera2
64 */
65 void getCameraIdList(std::vector<String8> *cameraIds);
66
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080067 private:
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -080068 sp<hardware::ICameraService> mCameraService;
Jayant Chowdhary80f128b2019-10-30 16:13:31 -070069 const int kCameraServicePollDelay = 500000; // 0.5s
70 const char* kCameraServiceName = "media.camera";
71 Mutex mLock;
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080072
73 class DeathNotifier : public IBinder::DeathRecipient {
74 public:
Chih-Hung Hsiehd19d9942016-08-29 14:21:14 -070075 explicit DeathNotifier(CameraManagerGlobal* cm) : mCameraManager(cm) {}
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080076 protected:
77 // IBinder::DeathRecipient implementation
78 virtual void binderDied(const wp<IBinder>& who);
79 private:
80 const wp<CameraManagerGlobal> mCameraManager;
81 };
82 sp<DeathNotifier> mDeathNotifier;
83
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -080084 class CameraServiceListener final : public hardware::BnCameraServiceListener {
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080085 public:
Chih-Hung Hsiehd19d9942016-08-29 14:21:14 -070086 explicit CameraServiceListener(CameraManagerGlobal* cm) : mCameraManager(cm) {}
Eino-Ville Talvalaf51fca22016-12-13 11:25:55 -080087 virtual binder::Status onStatusChanged(int32_t status, const String16& cameraId);
Shuzhen Wang43858162020-01-10 13:42:15 -080088 virtual binder::Status onPhysicalCameraStatusChanged(int32_t status,
89 const String16& cameraId, const String16& physicalCameraId);
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080090
91 // Torch API not implemented yet
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -080092 virtual binder::Status onTorchStatusChanged(int32_t, const String16&) {
93 return binder::Status::ok();
94 }
95
Emilian Peevc6f2ab32019-03-04 11:18:59 -080096 virtual binder::Status onCameraAccessPrioritiesChanged();
Emilian Peev53722fa2019-02-22 17:47:20 -080097
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080098 private:
99 const wp<CameraManagerGlobal> mCameraManager;
100 };
101 sp<CameraServiceListener> mCameraServiceListener;
102
103 // Wrapper of ACameraManager_AvailabilityCallbacks so we can store it in std::set
104 struct Callback {
Chih-Hung Hsiehd19d9942016-08-29 14:21:14 -0700105 explicit Callback(const ACameraManager_AvailabilityCallbacks *callback) :
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800106 mAvailable(callback->onCameraAvailable),
107 mUnavailable(callback->onCameraUnavailable),
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800108 mAccessPriorityChanged(nullptr),
Shuzhen Wang43858162020-01-10 13:42:15 -0800109 mPhysicalCamAvailable(nullptr),
110 mPhysicalCamUnavailable(nullptr),
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800111 mContext(callback->context) {}
112
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800113 explicit Callback(const ACameraManager_ExtendedAvailabilityCallbacks *callback) :
114 mAvailable(callback->availabilityCallbacks.onCameraAvailable),
115 mUnavailable(callback->availabilityCallbacks.onCameraUnavailable),
116 mAccessPriorityChanged(callback->onCameraAccessPrioritiesChanged),
Shuzhen Wang43858162020-01-10 13:42:15 -0800117 mPhysicalCamAvailable(callback->onPhysicalCameraAvailable),
118 mPhysicalCamUnavailable(callback->onPhysicalCameraUnavailable),
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800119 mContext(callback->availabilityCallbacks.context) {}
120
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800121 bool operator == (const Callback& other) const {
122 return (mAvailable == other.mAvailable &&
123 mUnavailable == other.mUnavailable &&
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800124 mAccessPriorityChanged == other.mAccessPriorityChanged &&
Shuzhen Wang43858162020-01-10 13:42:15 -0800125 mPhysicalCamAvailable == other.mPhysicalCamAvailable &&
126 mPhysicalCamUnavailable == other.mPhysicalCamUnavailable &&
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800127 mContext == other.mContext);
128 }
129 bool operator != (const Callback& other) const {
130 return !(*this == other);
131 }
132 bool operator < (const Callback& other) const {
133 if (*this == other) return false;
134 if (mContext != other.mContext) return mContext < other.mContext;
Shuzhen Wang43858162020-01-10 13:42:15 -0800135 if (mPhysicalCamAvailable != other.mPhysicalCamAvailable) {
136 return mPhysicalCamAvailable < other.mPhysicalCamAvailable;
137 }
138 if (mPhysicalCamUnavailable != other.mPhysicalCamUnavailable) {
139 return mPhysicalCamUnavailable < other.mPhysicalCamUnavailable;
140 }
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800141 if (mAccessPriorityChanged != other.mAccessPriorityChanged) {
142 return mAccessPriorityChanged < other.mAccessPriorityChanged;
143 }
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800144 if (mAvailable != other.mAvailable) return mAvailable < other.mAvailable;
145 return mUnavailable < other.mUnavailable;
146 }
147 bool operator > (const Callback& other) const {
148 return (*this != other && !(*this < other));
149 }
150 ACameraManager_AvailabilityCallback mAvailable;
151 ACameraManager_AvailabilityCallback mUnavailable;
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800152 ACameraManager_AccessPrioritiesChangedCallback mAccessPriorityChanged;
Shuzhen Wang43858162020-01-10 13:42:15 -0800153 ACameraManager_PhysicalCameraAvailabilityCallback mPhysicalCamAvailable;
154 ACameraManager_PhysicalCameraAvailabilityCallback mPhysicalCamUnavailable;
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800155 void* mContext;
156 };
157 std::set<Callback> mCallbacks;
158
159 // definition of handler and message
160 enum {
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800161 kWhatSendSingleCallback,
162 kWhatSendSingleAccessCallback,
Shuzhen Wang43858162020-01-10 13:42:15 -0800163 kWhatSendSinglePhysicalCameraCallback,
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800164 };
165 static const char* kCameraIdKey;
Shuzhen Wang43858162020-01-10 13:42:15 -0800166 static const char* kPhysicalCameraIdKey;
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800167 static const char* kCallbackFpKey;
168 static const char* kContextKey;
169 class CallbackHandler : public AHandler {
170 public:
171 CallbackHandler() {}
172 void onMessageReceived(const sp<AMessage> &msg) override;
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800173 };
174 sp<CallbackHandler> mHandler;
175 sp<ALooper> mCbLooper; // Looper thread where callbacks actually happen on
176
Jayant Chowdhary80f128b2019-10-30 16:13:31 -0700177 sp<hardware::ICameraService> getCameraServiceLocked();
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800178 void onCameraAccessPrioritiesChanged();
Eino-Ville Talvalaf51fca22016-12-13 11:25:55 -0800179 void onStatusChanged(int32_t status, const String8& cameraId);
180 void onStatusChangedLocked(int32_t status, const String8& cameraId);
Shuzhen Wang43858162020-01-10 13:42:15 -0800181 void onStatusChanged(int32_t status, const String8& cameraId, const String8& physicalCameraId);
182 void onStatusChangedLocked(int32_t status, const String8& cameraId,
183 const String8& physicalCameraId);
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800184 // Utils for status
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800185 static bool validStatus(int32_t status);
186 static bool isStatusAvailable(int32_t status);
Jayant Chowdhary80f128b2019-10-30 16:13:31 -0700187 bool supportsCamera2ApiLocked(const String8 &cameraId);
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800188
Yin-Chia Yeh03f55752018-03-14 15:28:02 -0700189 // The sort logic must match the logic in
190 // libcameraservice/common/CameraProviderManager.cpp::getAPI1CompatibleCameraDeviceIds
191 struct CameraIdComparator {
192 bool operator()(const String8& a, const String8& b) const {
193 uint32_t aUint = 0, bUint = 0;
194 bool aIsUint = base::ParseUint(a.c_str(), &aUint);
195 bool bIsUint = base::ParseUint(b.c_str(), &bUint);
196
197 // Uint device IDs first
198 if (aIsUint && bIsUint) {
199 return aUint < bUint;
200 } else if (aIsUint) {
201 return true;
202 } else if (bIsUint) {
203 return false;
204 }
205 // Simple string compare if both id are not uint
206 return a < b;
207 }
208 };
209
Jayant Chowdhary80f128b2019-10-30 16:13:31 -0700210 struct StatusAndHAL3Support {
Shuzhen Wang43858162020-01-10 13:42:15 -0800211 private:
Jayant Chowdhary80f128b2019-10-30 16:13:31 -0700212 int32_t status = hardware::ICameraServiceListener::STATUS_NOT_PRESENT;
Shuzhen Wang43858162020-01-10 13:42:15 -0800213 mutable std::mutex mLock;
214 std::set<String8> unavailablePhysicalIds;
215 public:
216 const bool supportsHAL3 = false;
Jayant Chowdhary80f128b2019-10-30 16:13:31 -0700217 StatusAndHAL3Support(int32_t st, bool HAL3support):
218 status(st), supportsHAL3(HAL3support) { };
219 StatusAndHAL3Support() = default;
Shuzhen Wang43858162020-01-10 13:42:15 -0800220
221 bool addUnavailablePhysicalId(const String8& physicalCameraId);
222 bool removeUnavailablePhysicalId(const String8& physicalCameraId);
223 int32_t getStatus();
224 void updateStatus(int32_t newStatus);
Jayant Chowdhary80f128b2019-10-30 16:13:31 -0700225 };
226
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800227 // Map camera_id -> status
Jayant Chowdhary80f128b2019-10-30 16:13:31 -0700228 std::map<String8, StatusAndHAL3Support, CameraIdComparator> mDeviceStatusMap;
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800229
230 // For the singleton instance
231 static Mutex sLock;
232 static CameraManagerGlobal* sInstance;
233 CameraManagerGlobal() {};
234 ~CameraManagerGlobal();
235};
236
Jayant Chowdhary6df26072018-11-06 23:55:12 -0800237} // namespace acam;
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800238} // namespace android;
239
240/**
241 * ACameraManager opaque struct definition
242 * Leave outside of android namespace because it's NDK struct
243 */
244struct ACameraManager {
245 ACameraManager() :
Jayant Chowdhary6df26072018-11-06 23:55:12 -0800246 mGlobalManager(&(android::acam::CameraManagerGlobal::getInstance())) {}
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800247 ~ACameraManager();
248 camera_status_t getCameraIdList(ACameraIdList** cameraIdList);
249 static void deleteCameraIdList(ACameraIdList* cameraIdList);
250
251 camera_status_t getCameraCharacteristics(
Yin-Chia Yehdd045bf2018-08-20 12:39:19 -0700252 const char* cameraId, android::sp<ACameraMetadata>* characteristics);
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800253 camera_status_t openCamera(const char* cameraId,
254 ACameraDevice_StateCallbacks* callback,
255 /*out*/ACameraDevice** device);
256
257 private:
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800258 enum {
259 kCameraIdListNotInit = -1
260 };
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800261 android::Mutex mLock;
Jayant Chowdhary6df26072018-11-06 23:55:12 -0800262 android::sp<android::acam::CameraManagerGlobal> mGlobalManager;
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800263};
264
265#endif //_ACAMERA_MANAGER_H