|  | /* | 
|  | * Copyright (C) 2013 The Android Open Source Project | 
|  | * | 
|  | * Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | * you may not use this file except in compliance with the License. | 
|  | * You may obtain a copy of the License at | 
|  | * | 
|  | *      http://www.apache.org/licenses/LICENSE-2.0 | 
|  | * | 
|  | * Unless required by applicable law or agreed to in writing, software | 
|  | * distributed under the License is distributed on an "AS IS" BASIS, | 
|  | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | * See the License for the specific language governing permissions and | 
|  | * limitations under the License. | 
|  | */ | 
|  |  | 
|  | #ifndef ANDROID_SERVERS_CAMERA_CAMERA2CLIENT_BASE_H | 
|  | #define ANDROID_SERVERS_CAMERA_CAMERA2CLIENT_BASE_H | 
|  |  | 
|  | #include "common/CameraDeviceBase.h" | 
|  | #include "camera/CaptureResult.h" | 
|  |  | 
|  | namespace android { | 
|  |  | 
|  | class IMemory; | 
|  |  | 
|  | class CameraService; | 
|  |  | 
|  | template <typename TClientBase> | 
|  | class Camera2ClientBase : | 
|  | public TClientBase, | 
|  | public NotificationListener | 
|  | { | 
|  | public: | 
|  | typedef typename TClientBase::TCamCallbacks TCamCallbacks; | 
|  |  | 
|  | /** | 
|  | * Base binder interface (see ICamera/ICameraDeviceUser for details) | 
|  | */ | 
|  | virtual status_t       connect(const sp<TCamCallbacks>& callbacks); | 
|  | virtual binder::Status disconnect(); | 
|  |  | 
|  | /** | 
|  | * Interface used by CameraService | 
|  | */ | 
|  |  | 
|  | // TODO: too many params, move into a ClientArgs<T> | 
|  | Camera2ClientBase(const sp<CameraService>& cameraService, | 
|  | const sp<TCamCallbacks>& remoteCallback, | 
|  | const String16& clientPackageName, | 
|  | const std::optional<String16>& clientFeatureId, | 
|  | const String8& cameraId, | 
|  | int api1CameraId, | 
|  | int cameraFacing, | 
|  | int clientPid, | 
|  | uid_t clientUid, | 
|  | int servicePid); | 
|  | virtual ~Camera2ClientBase(); | 
|  |  | 
|  | virtual status_t      initialize(sp<CameraProviderManager> manager, const String8& monitorTags); | 
|  | virtual status_t      dumpClient(int fd, const Vector<String16>& args); | 
|  |  | 
|  | /** | 
|  | * NotificationListener implementation | 
|  | */ | 
|  |  | 
|  | virtual void          notifyError(int32_t errorCode, | 
|  | const CaptureResultExtras& resultExtras); | 
|  | virtual void          notifyIdle(); | 
|  | virtual void          notifyShutter(const CaptureResultExtras& resultExtras, | 
|  | nsecs_t timestamp); | 
|  | virtual void          notifyAutoFocus(uint8_t newState, int triggerId); | 
|  | virtual void          notifyAutoExposure(uint8_t newState, int triggerId); | 
|  | virtual void          notifyAutoWhitebalance(uint8_t newState, | 
|  | int triggerId); | 
|  | virtual void          notifyPrepared(int streamId); | 
|  | virtual void          notifyRequestQueueEmpty(); | 
|  | virtual void          notifyRepeatingRequestError(long lastFrameNumber); | 
|  |  | 
|  | int                   getCameraId() const; | 
|  | const sp<CameraDeviceBase>& | 
|  | getCameraDevice(); | 
|  | int                   getCameraDeviceVersion() const; | 
|  | const sp<CameraService>& | 
|  | getCameraService(); | 
|  |  | 
|  | /** | 
|  | * Interface used by independent components of CameraClient2Base. | 
|  | */ | 
|  |  | 
|  | // Simple class to ensure that access to TCamCallbacks is serialized | 
|  | // by requiring mRemoteCallbackLock to be locked before access to | 
|  | // mRemoteCallback is possible. | 
|  | class SharedCameraCallbacks { | 
|  | public: | 
|  | class Lock { | 
|  | public: | 
|  | explicit Lock(SharedCameraCallbacks &client); | 
|  | ~Lock(); | 
|  | sp<TCamCallbacks> &mRemoteCallback; | 
|  | private: | 
|  | SharedCameraCallbacks &mSharedClient; | 
|  | }; | 
|  | explicit SharedCameraCallbacks(const sp<TCamCallbacks>& client); | 
|  | SharedCameraCallbacks& operator=(const sp<TCamCallbacks>& client); | 
|  | void clear(); | 
|  | private: | 
|  | sp<TCamCallbacks> mRemoteCallback; | 
|  | mutable Mutex mRemoteCallbackLock; | 
|  | } mSharedCameraCallbacks; | 
|  |  | 
|  | protected: | 
|  |  | 
|  | // The PID provided in the constructor call | 
|  | pid_t mInitialClientPid; | 
|  |  | 
|  | virtual sp<IBinder> asBinderWrapper() { | 
|  | return IInterface::asBinder(this); | 
|  | } | 
|  |  | 
|  | virtual status_t      dumpDevice(int fd, const Vector<String16>& args); | 
|  |  | 
|  | /** Binder client interface-related private members */ | 
|  |  | 
|  | // Mutex that must be locked by methods implementing the binder client | 
|  | // interface. Ensures serialization between incoming client calls. | 
|  | // All methods in this class hierarchy that append 'L' to the name assume | 
|  | // that mBinderSerializationLock is locked when they're called | 
|  | mutable Mutex         mBinderSerializationLock; | 
|  |  | 
|  | /** CameraDeviceBase instance wrapping HAL3+ entry */ | 
|  |  | 
|  | const int mDeviceVersion; | 
|  |  | 
|  | // Set to const to avoid mDevice being updated (update of sp<> is racy) during | 
|  | // dumpDevice (which is important to be lock free for debugging purpose) | 
|  | const sp<CameraDeviceBase>  mDevice; | 
|  |  | 
|  | /** Utility members */ | 
|  |  | 
|  | // Verify that caller is the owner of the camera | 
|  | status_t              checkPid(const char *checkLocation) const; | 
|  |  | 
|  | virtual void          detachDevice(); | 
|  |  | 
|  | bool                  mDeviceActive; | 
|  |  | 
|  | const int             mApi1CameraId; // -1 if client is API2 | 
|  |  | 
|  | private: | 
|  | template<typename TProviderPtr> | 
|  | status_t              initializeImpl(TProviderPtr providerPtr, const String8& monitorTags); | 
|  | }; | 
|  |  | 
|  | }; // namespace android | 
|  |  | 
|  | #endif |