/* * 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 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& callbacks); virtual binder::Status disconnect(); /** * Interface used by CameraService */ // TODO: too many params, move into a ClientArgs Camera2ClientBase(const sp& cameraService, const sp& remoteCallback, const String16& clientPackageName, const std::unique_ptr& clientFeatureId, const String8& cameraId, int api1CameraId, int cameraFacing, int clientPid, uid_t clientUid, int servicePid); virtual ~Camera2ClientBase(); virtual status_t initialize(sp manager, const String8& monitorTags); virtual status_t dumpClient(int fd, const Vector& 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& getCameraDevice(); int getCameraDeviceVersion() const; const sp& 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 &mRemoteCallback; private: SharedCameraCallbacks &mSharedClient; }; explicit SharedCameraCallbacks(const sp& client); SharedCameraCallbacks& operator=(const sp& client); void clear(); private: sp mRemoteCallback; mutable Mutex mRemoteCallbackLock; } mSharedCameraCallbacks; protected: // The PID provided in the constructor call pid_t mInitialClientPid; virtual sp asBinderWrapper() { return IInterface::asBinder(this); } virtual status_t dumpDevice(int fd, const Vector& 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 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 status_t initializeImpl(TProviderPtr providerPtr, const String8& monitorTags); }; }; // namespace android #endif