blob: c6e2bf9dc2fa56b71e82bd5feec99ad24e42df9d [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:
Avichal Rakeshf099b232022-10-27 15:44:50 -070049 static sp<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 */
Austin Borger1c1bee02023-06-01 16:51:35 -070065 void getCameraIdList(std::vector<std::string> *cameraIds);
Eino-Ville Talvalaf51fca22016-12-13 11:25:55 -080066
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
Shuzhen Wang4fa28d22020-01-23 15:57:25 -080073 template<class T>
74 void registerAvailCallback(const T *callback);
75
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080076 class DeathNotifier : public IBinder::DeathRecipient {
77 public:
Chih-Hung Hsiehd19d9942016-08-29 14:21:14 -070078 explicit DeathNotifier(CameraManagerGlobal* cm) : mCameraManager(cm) {}
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080079 protected:
80 // IBinder::DeathRecipient implementation
81 virtual void binderDied(const wp<IBinder>& who);
82 private:
83 const wp<CameraManagerGlobal> mCameraManager;
84 };
85 sp<DeathNotifier> mDeathNotifier;
86
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -080087 class CameraServiceListener final : public hardware::BnCameraServiceListener {
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080088 public:
Chih-Hung Hsiehd19d9942016-08-29 14:21:14 -070089 explicit CameraServiceListener(CameraManagerGlobal* cm) : mCameraManager(cm) {}
Biswarup Pal37a75182024-01-16 15:53:35 +000090 virtual binder::Status onStatusChanged(int32_t status, const std::string& cameraId,
91 int32_t deviceId);
Shuzhen Wang43858162020-01-10 13:42:15 -080092 virtual binder::Status onPhysicalCameraStatusChanged(int32_t status,
Biswarup Pal37a75182024-01-16 15:53:35 +000093 const std::string& cameraId, const std::string& physicalCameraId, int32_t deviceId);
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -080094
95 // Torch API not implemented yet
Biswarup Pal37a75182024-01-16 15:53:35 +000096 virtual binder::Status onTorchStatusChanged(int32_t, const std::string&, int32_t) {
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -080097 return binder::Status::ok();
98 }
Biswarup Pal37a75182024-01-16 15:53:35 +000099 virtual binder::Status onTorchStrengthLevelChanged(const std::string&, int32_t, int32_t) {
Rucha Katakwar38284522021-11-10 11:25:21 -0800100 return binder::Status::ok();
101 }
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800102
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800103 virtual binder::Status onCameraAccessPrioritiesChanged();
Biswarup Pal37a75182024-01-16 15:53:35 +0000104 virtual binder::Status onCameraOpened(const std::string&, const std::string&, int32_t) {
Shuzhen Wang695044d2020-03-06 09:02:23 -0800105 return binder::Status::ok();
106 }
Biswarup Pal37a75182024-01-16 15:53:35 +0000107 virtual binder::Status onCameraClosed(const std::string&, int32_t) {
Shuzhen Wang695044d2020-03-06 09:02:23 -0800108 return binder::Status::ok();
109 }
Emilian Peev53722fa2019-02-22 17:47:20 -0800110
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800111 private:
112 const wp<CameraManagerGlobal> mCameraManager;
113 };
114 sp<CameraServiceListener> mCameraServiceListener;
115
116 // Wrapper of ACameraManager_AvailabilityCallbacks so we can store it in std::set
117 struct Callback {
Chih-Hung Hsiehd19d9942016-08-29 14:21:14 -0700118 explicit Callback(const ACameraManager_AvailabilityCallbacks *callback) :
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800119 mAvailable(callback->onCameraAvailable),
120 mUnavailable(callback->onCameraUnavailable),
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800121 mAccessPriorityChanged(nullptr),
Shuzhen Wang43858162020-01-10 13:42:15 -0800122 mPhysicalCamAvailable(nullptr),
123 mPhysicalCamUnavailable(nullptr),
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800124 mContext(callback->context) {}
125
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800126 explicit Callback(const ACameraManager_ExtendedAvailabilityCallbacks *callback) :
127 mAvailable(callback->availabilityCallbacks.onCameraAvailable),
128 mUnavailable(callback->availabilityCallbacks.onCameraUnavailable),
129 mAccessPriorityChanged(callback->onCameraAccessPrioritiesChanged),
Shuzhen Wang43858162020-01-10 13:42:15 -0800130 mPhysicalCamAvailable(callback->onPhysicalCameraAvailable),
131 mPhysicalCamUnavailable(callback->onPhysicalCameraUnavailable),
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800132 mContext(callback->availabilityCallbacks.context) {}
133
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800134 bool operator == (const Callback& other) const {
135 return (mAvailable == other.mAvailable &&
136 mUnavailable == other.mUnavailable &&
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800137 mAccessPriorityChanged == other.mAccessPriorityChanged &&
Shuzhen Wang43858162020-01-10 13:42:15 -0800138 mPhysicalCamAvailable == other.mPhysicalCamAvailable &&
139 mPhysicalCamUnavailable == other.mPhysicalCamUnavailable &&
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800140 mContext == other.mContext);
141 }
142 bool operator != (const Callback& other) const {
143 return !(*this == other);
144 }
145 bool operator < (const Callback& other) const {
Yi Kong8cb642f2021-08-31 14:08:27 +0800146#pragma GCC diagnostic push
147#pragma GCC diagnostic ignored "-Wordered-compare-function-pointers"
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800148 if (*this == other) return false;
149 if (mContext != other.mContext) return mContext < other.mContext;
Shuzhen Wang43858162020-01-10 13:42:15 -0800150 if (mPhysicalCamAvailable != other.mPhysicalCamAvailable) {
151 return mPhysicalCamAvailable < other.mPhysicalCamAvailable;
152 }
153 if (mPhysicalCamUnavailable != other.mPhysicalCamUnavailable) {
154 return mPhysicalCamUnavailable < other.mPhysicalCamUnavailable;
155 }
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800156 if (mAccessPriorityChanged != other.mAccessPriorityChanged) {
157 return mAccessPriorityChanged < other.mAccessPriorityChanged;
158 }
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800159 if (mAvailable != other.mAvailable) return mAvailable < other.mAvailable;
160 return mUnavailable < other.mUnavailable;
Yi Kong8cb642f2021-08-31 14:08:27 +0800161#pragma GCC diagnostic pop
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800162 }
163 bool operator > (const Callback& other) const {
164 return (*this != other && !(*this < other));
165 }
166 ACameraManager_AvailabilityCallback mAvailable;
167 ACameraManager_AvailabilityCallback mUnavailable;
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800168 ACameraManager_AccessPrioritiesChangedCallback mAccessPriorityChanged;
Shuzhen Wang43858162020-01-10 13:42:15 -0800169 ACameraManager_PhysicalCameraAvailabilityCallback mPhysicalCamAvailable;
170 ACameraManager_PhysicalCameraAvailabilityCallback mPhysicalCamUnavailable;
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800171 void* mContext;
172 };
Shuzhen Wang7e540682020-04-10 13:30:25 -0700173
174 android::Condition mCallbacksCond;
175 size_t mPendingCallbackCnt = 0;
176 void onCallbackCalled();
177 void drainPendingCallbacksLocked();
178
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800179 std::set<Callback> mCallbacks;
180
181 // definition of handler and message
182 enum {
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800183 kWhatSendSingleCallback,
184 kWhatSendSingleAccessCallback,
Shuzhen Wang43858162020-01-10 13:42:15 -0800185 kWhatSendSinglePhysicalCameraCallback,
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800186 };
187 static const char* kCameraIdKey;
Shuzhen Wang43858162020-01-10 13:42:15 -0800188 static const char* kPhysicalCameraIdKey;
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800189 static const char* kCallbackFpKey;
190 static const char* kContextKey;
Shuzhen Wang7e540682020-04-10 13:30:25 -0700191 static const nsecs_t kCallbackDrainTimeout;
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800192 class CallbackHandler : public AHandler {
193 public:
Shuzhen Wang7e540682020-04-10 13:30:25 -0700194 CallbackHandler(wp<CameraManagerGlobal> parent) : mParent(parent) {}
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800195 void onMessageReceived(const sp<AMessage> &msg) override;
Shuzhen Wang7e540682020-04-10 13:30:25 -0700196
197 private:
198 wp<CameraManagerGlobal> mParent;
199 void notifyParent();
200 void onMessageReceivedInternal(const sp<AMessage> &msg);
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800201 };
202 sp<CallbackHandler> mHandler;
203 sp<ALooper> mCbLooper; // Looper thread where callbacks actually happen on
204
Jayant Chowdhary80f128b2019-10-30 16:13:31 -0700205 sp<hardware::ICameraService> getCameraServiceLocked();
Emilian Peevc6f2ab32019-03-04 11:18:59 -0800206 void onCameraAccessPrioritiesChanged();
Austin Borger1c1bee02023-06-01 16:51:35 -0700207 void onStatusChanged(int32_t status, const std::string& cameraId);
208 void onStatusChangedLocked(int32_t status, const std::string& cameraId);
209 void onStatusChanged(int32_t status, const std::string& cameraId, const std::string& physicalCameraId);
210 void onStatusChangedLocked(int32_t status, const std::string& cameraId,
211 const std::string& physicalCameraId);
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800212 // Utils for status
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800213 static bool validStatus(int32_t status);
214 static bool isStatusAvailable(int32_t status);
Austin Borger1c1bee02023-06-01 16:51:35 -0700215 bool supportsCamera2ApiLocked(const std::string &cameraId);
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800216
Yin-Chia Yeh03f55752018-03-14 15:28:02 -0700217 // The sort logic must match the logic in
218 // libcameraservice/common/CameraProviderManager.cpp::getAPI1CompatibleCameraDeviceIds
219 struct CameraIdComparator {
Austin Borger1c1bee02023-06-01 16:51:35 -0700220 bool operator()(const std::string& a, const std::string& b) const {
Yin-Chia Yeh03f55752018-03-14 15:28:02 -0700221 uint32_t aUint = 0, bUint = 0;
222 bool aIsUint = base::ParseUint(a.c_str(), &aUint);
223 bool bIsUint = base::ParseUint(b.c_str(), &bUint);
224
225 // Uint device IDs first
226 if (aIsUint && bIsUint) {
227 return aUint < bUint;
228 } else if (aIsUint) {
229 return true;
230 } else if (bIsUint) {
231 return false;
232 }
233 // Simple string compare if both id are not uint
234 return a < b;
235 }
236 };
237
Jayant Chowdhary80f128b2019-10-30 16:13:31 -0700238 struct StatusAndHAL3Support {
Shuzhen Wang43858162020-01-10 13:42:15 -0800239 private:
Jayant Chowdhary80f128b2019-10-30 16:13:31 -0700240 int32_t status = hardware::ICameraServiceListener::STATUS_NOT_PRESENT;
Shuzhen Wang43858162020-01-10 13:42:15 -0800241 mutable std::mutex mLock;
Austin Borger1c1bee02023-06-01 16:51:35 -0700242 std::set<std::string> unavailablePhysicalIds;
Shuzhen Wang43858162020-01-10 13:42:15 -0800243 public:
244 const bool supportsHAL3 = false;
Jayant Chowdhary80f128b2019-10-30 16:13:31 -0700245 StatusAndHAL3Support(int32_t st, bool HAL3support):
246 status(st), supportsHAL3(HAL3support) { };
247 StatusAndHAL3Support() = default;
Shuzhen Wang43858162020-01-10 13:42:15 -0800248
Austin Borger1c1bee02023-06-01 16:51:35 -0700249 bool addUnavailablePhysicalId(const std::string& physicalCameraId);
250 bool removeUnavailablePhysicalId(const std::string& physicalCameraId);
Shuzhen Wang43858162020-01-10 13:42:15 -0800251 int32_t getStatus();
252 void updateStatus(int32_t newStatus);
Austin Borger1c1bee02023-06-01 16:51:35 -0700253 std::set<std::string> getUnavailablePhysicalIds();
Jayant Chowdhary80f128b2019-10-30 16:13:31 -0700254 };
255
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800256 // Map camera_id -> status
Austin Borger1c1bee02023-06-01 16:51:35 -0700257 std::map<std::string, StatusAndHAL3Support, CameraIdComparator> mDeviceStatusMap;
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800258
259 // For the singleton instance
260 static Mutex sLock;
Avichal Rakeshf099b232022-10-27 15:44:50 -0700261 static wp<CameraManagerGlobal> sInstance;
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800262 CameraManagerGlobal() {};
263 ~CameraManagerGlobal();
264};
265
Jayant Chowdhary6df26072018-11-06 23:55:12 -0800266} // namespace acam;
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800267} // namespace android;
268
269/**
270 * ACameraManager opaque struct definition
271 * Leave outside of android namespace because it's NDK struct
272 */
273struct ACameraManager {
274 ACameraManager() :
Avichal Rakeshf099b232022-10-27 15:44:50 -0700275 mGlobalManager(android::acam::CameraManagerGlobal::getInstance()) {}
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800276 ~ACameraManager();
277 camera_status_t getCameraIdList(ACameraIdList** cameraIdList);
278 static void deleteCameraIdList(ACameraIdList* cameraIdList);
279
280 camera_status_t getCameraCharacteristics(
Yin-Chia Yehdd045bf2018-08-20 12:39:19 -0700281 const char* cameraId, android::sp<ACameraMetadata>* characteristics);
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800282 camera_status_t openCamera(const char* cameraId,
283 ACameraDevice_StateCallbacks* callback,
284 /*out*/ACameraDevice** device);
285
286 private:
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800287 enum {
288 kCameraIdListNotInit = -1
289 };
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800290 android::Mutex mLock;
Jayant Chowdhary6df26072018-11-06 23:55:12 -0800291 android::sp<android::acam::CameraManagerGlobal> mGlobalManager;
Yin-Chia Yeh0dea57f2015-12-09 16:46:07 -0800292};
293
294#endif //_ACAMERA_MANAGER_H