/* * 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 "common/CameraModule.h" #include "camera/CaptureResult.h" namespace android { class IMemory; class CameraService; template <typename TClientBase> class Camera2ClientBase : public TClientBase, public CameraDeviceBase::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, int cameraId, int cameraFacing, int clientPid, uid_t clientUid, int servicePid); virtual ~Camera2ClientBase(); virtual status_t initialize(CameraModule *module); virtual status_t dumpClient(int fd, const Vector<String16>& args); /** * CameraDeviceBase::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 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: Lock(SharedCameraCallbacks &client); ~Lock(); sp<TCamCallbacks> &mRemoteCallback; private: SharedCameraCallbacks &mSharedClient; }; 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; 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; }; }; // namespace android #endif