| /* |
| * Copyright (C) 2017, Samsung Electronics Co. LTD |
| * |
| * 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 EXYNOS_CAMERA_REQUEST_MANAGER_H__ |
| #define EXYNOS_CAMERA_REQUEST_MANAGER_H__ |
| #define CALLBACK_FPS_CHECK |
| |
| #include <log/log.h> |
| #include <utils/RefBase.h> |
| #include <hardware/camera3.h> |
| #include <CameraMetadata.h> |
| #include <map> |
| #include <list> |
| #include <android/sync.h> |
| |
| #include "ExynosCameraDefine.h" |
| #include "ExynosCameraObject.h" |
| #include "ExynosCameraStreamManager.h" |
| #include "ExynosCameraFrameFactory.h" |
| #include "ExynosCameraParameters.h" |
| #include "ExynosCameraSensorInfo.h" |
| #include "ExynosCameraMetadataConverter.h" |
| |
| namespace android { |
| |
| using namespace std; |
| |
| namespace EXYNOS_REQUEST_RESULT { |
| enum TYPE { |
| CALLBACK_INVALID = -1, |
| CALLBACK_NOTIFY_ONLY = 0x00, |
| CALLBACK_BUFFER_ONLY = 0x01, |
| CALLBACK_PARTIAL_3AA = 0x02, |
| CALLBACK_ALL_RESULT = 0x03, |
| CALLBACK_NOTIFY_ERROR = 0x04, |
| CALLBACK_PARTIAL_SHUTTER = 0x05, |
| CALLBACK_MAX = 0x06, |
| }; |
| |
| enum ERROR { |
| ERROR_UNKNOWN, |
| |
| /* An error has occurred in processing a request. No output (metadata or buffers) will be produced for this request. */ |
| ERROR_REQUEST, |
| |
| /* An error has occurred in producing an output result metadata buffer for a request, but output stream buffers for it will still be available. */ |
| ERROR_RESULT, |
| |
| /* An error has occurred in placing an output buffer into a stream for a request. The frame metadata and other buffers may still be available. */ |
| ERROR_BUFFER, |
| }; |
| }; |
| |
| namespace EXYNOS_LIST_OPER { |
| enum MODE { |
| SINGLE_BACK = 0, |
| SINGLE_FRONT = 1, |
| SINGLE_ORDER = 2, |
| MULTI_GET = 3 |
| }; |
| }; |
| |
| typedef list< camera3_stream_buffer_t* > StreamBufferList; |
| |
| class ExynosCamera; |
| class ExynosCameraRequest; |
| class ExynosCameraFrameFactory; |
| |
| typedef sp<ExynosCameraRequest> ExynosCameraRequestSP_sprt_t; |
| typedef sp<ExynosCameraRequest>& ExynosCameraRequestSP_dptr_t; |
| |
| typedef ExynosCameraList<uint32_t> stream_callback_queue_t; |
| typedef ExynosCameraThread<ExynosCameraRequestManager> callbackThread; |
| |
| typedef bool (ExynosCamera::*factory_donehandler_t)(); |
| |
| class ExynosCameraRequestResult : public virtual RefBase { |
| public: |
| ExynosCameraRequestResult(uint32_t key, uint32_t requestKey, uint32_t frameCount, EXYNOS_REQUEST_RESULT::TYPE type); |
| ~ExynosCameraRequestResult(); |
| |
| virtual uint32_t getFrameCount(); |
| virtual uint32_t getRequestKey(); |
| virtual uint32_t getKey(); |
| |
| virtual EXYNOS_REQUEST_RESULT::TYPE getType(); |
| virtual camera3_capture_result_t* getCaptureResult(); |
| virtual camera3_notify_msg_t* getNotifyMsg(); |
| virtual camera3_stream_buffer_t* getStreamBuffer(); |
| |
| private: |
| status_t m_init(); |
| status_t m_deinit(); |
| |
| private: |
| uint32_t m_key; |
| uint32_t m_requestKey; |
| EXYNOS_REQUEST_RESULT::TYPE m_type; |
| uint32_t m_frameCount; |
| camera3_capture_result_t m_captureResult; |
| camera3_notify_msg_t m_notityMsg; |
| camera3_stream_buffer_t m_streamBuffer; |
| }; |
| |
| namespace EXYNOS_REQUEST { |
| enum STATE { |
| STATE_INVALID = -1, /* invalid state */ |
| STATE_ERROR, /* request error callbck state */ |
| STATE_SERVICE, /* request success callbck state */ |
| STATE_RUNNING, /* request running state */ |
| }; |
| }; |
| |
| typedef sp<ExynosCameraRequestResult> ResultRequest; |
| typedef list< uint32_t > ResultRequestkeys; |
| typedef list< uint32_t >::iterator ResultRequestkeysIterator; |
| |
| typedef list< sp<ExynosCameraRequestResult> > ResultRequestList; |
| typedef map< uint32_t, sp<ExynosCameraRequestResult> > ResultRequestMap; |
| typedef list< sp<ExynosCameraRequestResult> >::iterator ResultRequestListIterator; |
| typedef map< uint32_t, sp<ExynosCameraRequestResult> >::iterator ResultRequestMapIterator; |
| |
| typedef map< int32_t, ExynosCameraFrameFactory* > FrameFactoryMap; |
| typedef map< int32_t, ExynosCameraFrameFactory* >::iterator FrameFactoryMapIterator; |
| typedef list<ExynosCameraFrameFactory*> FrameFactoryList; |
| typedef list<ExynosCameraFrameFactory*>::iterator FrameFactoryListIterator; |
| |
| typedef map< int32_t, sp<callbackThread>> StreamThreadMap; |
| typedef map< int32_t, sp<callbackThread>>::iterator StreamThreadMapIterator; |
| |
| class ExynosCameraRequest : public virtual RefBase { |
| public: |
| ExynosCameraRequest(camera3_capture_request_t* request, CameraMetadata previousMeta); |
| ~ExynosCameraRequest(); |
| |
| virtual uint32_t getKey(); |
| virtual void setFrameCount(uint32_t frameCount); |
| virtual uint32_t getFrameCount(); |
| |
| virtual camera3_capture_request_t* getServiceRequest(); |
| |
| virtual CameraMetadata* getServiceMeta(); |
| virtual struct camera2_shot_ext* getServiceShot(); |
| virtual struct CameraMetaParameters* getMetaParameters(); |
| |
| virtual void setRequestLock(); |
| virtual void setRequestUnlock(); |
| |
| virtual status_t setRequestState(EXYNOS_REQUEST::STATE state); |
| virtual EXYNOS_REQUEST::STATE getRequestState(void); |
| |
| virtual uint64_t getSensorTimestamp(); |
| virtual void setSensorTimestamp(uint64_t timeStamp); |
| virtual uint32_t getNumOfInputBuffer(); |
| virtual camera3_stream_buffer_t* getInputBuffer(); |
| |
| virtual uint32_t getNumOfOutputBuffer(); |
| virtual const camera3_stream_buffer_t* getOutputBuffers(); |
| |
| virtual status_t pushFrameFactory(int StreamID, ExynosCameraFrameFactory* factory); |
| virtual ExynosCameraFrameFactory* popFrameFactory(int streamID); |
| virtual ExynosCameraFrameFactory* getFrameFactory(int streamID); |
| virtual bool isFrameFactory(int streamID); |
| virtual status_t getFrameFactoryList(FrameFactoryList *list); |
| virtual status_t setFactoryAddrList(ExynosCameraFrameFactory *factoryAddr[FRAME_FACTORY_TYPE_MAX]); |
| virtual status_t getFactoryAddrList(enum FRAME_FACTORY_TYPE factoryType, FrameFactoryList *list); |
| |
| virtual void increaseCompleteBufferCount(void); |
| virtual void resetCompleteBufferCount(void); |
| virtual int getCompleteBufferCount(void); |
| |
| virtual void setRequestId(int reqId); |
| virtual int getRequestId(); |
| virtual status_t getAllRequestOutputStreams(List<int> **list); |
| virtual status_t pushRequestOutputStreams(int requestStreamId); |
| virtual status_t getAllRequestInputStreams(List <int> **list); |
| virtual status_t pushRequestInputStreams(int requestStreamId); |
| |
| virtual status_t setCallbackDone(EXYNOS_REQUEST_RESULT::TYPE reqType, bool flag); |
| virtual bool getCallbackDone(EXYNOS_REQUEST_RESULT::TYPE reqType); |
| virtual status_t setCallbackStreamDone(int streamId, bool flag); |
| virtual bool getCallbackStreamDone(int streamId); |
| virtual void printCallbackDoneState(); |
| virtual bool isComplete(); |
| |
| virtual int getStreamIdwithBufferIdx(int bufferIndex); |
| virtual bool hasStream(int streamIdx); |
| virtual int getStreamIdwithStreamIdx(int index); |
| virtual int getBufferIndex(int streamId); |
| |
| virtual void increasePipelineDepth(void); |
| virtual void updatePipelineDepth(void); |
| virtual CameraMetadata get3AAResultMeta(void); |
| virtual CameraMetadata getShutterMeta(); |
| virtual void get3AAResultMetaVendor(CameraMetadata &minimal_resultMeta); |
| |
| virtual status_t setStreamBufferStatus(int streamId, camera3_buffer_status_t bufferStatus); |
| virtual camera3_buffer_status_t getStreamBufferStatus(int streamId); |
| |
| virtual void setSkipMetaResult(bool skip); |
| virtual bool getSkipMetaResult(void); |
| |
| virtual void setSkipCaptureResult(bool skip); |
| virtual bool getSkipCaptureResult(void); |
| |
| virtual void setDsInputPortId(int dsInputPortId); |
| virtual int getDsInputPortId(void); |
| |
| virtual status_t setAcquireFenceDone(buffer_handle_t *handle, bool done); |
| virtual bool getAcquireFenceDone(buffer_handle_t *handle); |
| private: |
| virtual status_t m_init(); |
| virtual status_t m_deinit(); |
| |
| virtual status_t m_push(int key, ExynosCameraFrameFactory* item, FrameFactoryMap *list, Mutex *lock); |
| virtual status_t m_pop(int key, ExynosCameraFrameFactory** item, FrameFactoryMap *list, Mutex *lock); |
| virtual status_t m_get(int streamID, ExynosCameraFrameFactory** item, FrameFactoryMap *list, Mutex *lock); |
| virtual bool m_find(int streamID, FrameFactoryMap *list, Mutex *lock); |
| virtual status_t m_getList(FrameFactoryList *factorylist, FrameFactoryMap *list, Mutex *lock); |
| virtual bool m_isInputStreamId(int streamId); |
| virtual int m_getOutputBufferIndex(int streamId); |
| virtual status_t m_setCallbackDone(EXYNOS_REQUEST_RESULT::TYPE reqType, bool flag, Mutex *lock); |
| virtual bool m_getCallbackDone(EXYNOS_REQUEST_RESULT::TYPE reqType, Mutex *lock); |
| virtual status_t m_setCallbackStreamDone(int streamId, bool flag, Mutex *lock); |
| virtual bool m_getCallbackStreamDone(int streamId, Mutex *lock); |
| virtual status_t m_setStreamBufferStatus(int streamId, camera3_buffer_status_t status, Mutex *lock); |
| virtual camera3_buffer_status_t m_getStreamBufferStatus(int streamId, Mutex *lock); |
| virtual void m_updateMetaDataU8(uint32_t tag, CameraMetadata &resultMeta); |
| virtual void m_updateMetaDataI32(uint32_t tag, CameraMetadata &resultMeta); |
| |
| private: |
| uint32_t m_key; |
| uint32_t m_frameCount; |
| camera3_capture_request_t *m_request; |
| CameraMetadata m_serviceMeta; |
| struct camera2_shot_ext m_serviceShot; |
| int m_streamIdList[HAL_STREAM_ID_MAX]; |
| struct CameraMetaParameters m_metaParameters; |
| |
| EXYNOS_REQUEST::STATE m_requestState; |
| int m_requestId; |
| |
| map<buffer_handle_t *, bool> m_acquireFenceDoneMap; |
| mutable Mutex m_acquireFenceDoneLock; |
| |
| bool m_resultStatus[EXYNOS_REQUEST_RESULT::CALLBACK_MAX]; |
| mutable Mutex m_resultStatusLock; |
| |
| bool m_inputStreamDone; |
| bool m_outputStreamDone[HAL_STREAM_ID_MAX]; |
| |
| camera3_buffer_status_t m_inputStreamStatus; |
| camera3_buffer_status_t m_outputStreamStatus[HAL_STREAM_ID_MAX]; |
| mutable Mutex m_streamStatusLock; |
| |
| int m_numOfOutputBuffers; |
| int m_numOfCompleteBuffers; |
| List<int> m_requestOutputStreamList; |
| List<int> m_requestInputStreamList; |
| |
| FrameFactoryMap m_factoryMap; |
| mutable Mutex m_factoryMapLock; |
| |
| unsigned int m_pipelineDepth; |
| |
| bool m_isSkipMetaResult; |
| mutable Mutex m_SkipMetaResultLock; |
| |
| bool m_isSkipCaptureResult; |
| mutable Mutex m_SkipCaptureResultLock; |
| |
| uint64_t m_sensorTimeStampBoot; |
| |
| mutable Mutex m_requestLock; |
| |
| FrameFactoryList m_previewFactoryAddrList; |
| FrameFactoryList m_captureFactoryAddrList; |
| |
| int m_dsInputPortId; |
| }; |
| |
| typedef list< uint32_t > CallbackListkeys; |
| typedef list< uint32_t >::iterator CallbackListkeysIter; |
| |
| class ExynosCameraCallbackSequencer{ |
| public: |
| ExynosCameraCallbackSequencer(); |
| ~ExynosCameraCallbackSequencer(); |
| |
| status_t pushToRunningKeyList(uint32_t key); |
| uint32_t popFromRunningKeyList(); |
| uint32_t getFrontKeyFromRunningKeyList(); |
| uint32_t getRunningKeyListSize(); |
| status_t getRunningKeyList(CallbackListkeys *list); |
| status_t deleteRunningKey(uint32_t key); |
| void dumpList(); |
| status_t flush(); |
| |
| private: |
| status_t m_init(); |
| status_t m_deinit(); |
| status_t m_push(EXYNOS_LIST_OPER::MODE operMode, uint32_t key, CallbackListkeys *list, Mutex *lock); |
| uint32_t m_pop(EXYNOS_LIST_OPER::MODE operMode, CallbackListkeys *list, Mutex *lock); |
| uint32_t m_get(EXYNOS_LIST_OPER::MODE operMode, CallbackListkeys *list, Mutex *lock); |
| status_t m_delete(uint32_t key, CallbackListkeys *list, Mutex *lock); |
| |
| private: |
| CallbackListkeys m_runningRequestKeys; |
| mutable Mutex m_requestCbListLock; |
| |
| }; |
| |
| typedef ExynosCameraList<ResultRequest> result_queue_t; |
| |
| class ExynosCameraRequestManager : public ExynosCameraObject, public virtual RefBase { |
| public: |
| /* Constructor */ |
| ExynosCameraRequestManager(int cameraId, ExynosCameraParameters *param); |
| |
| /* Destructor */ |
| virtual ~ExynosCameraRequestManager(); |
| |
| public: |
| /* related to camera3 device operations */ |
| status_t constructDefaultRequestSettings(int type, camera_metadata_t **request); |
| |
| /* Android meta data translation functions */ |
| ExynosCameraRequestSP_sprt_t registerToServiceList(camera3_capture_request *srcRequest); |
| ExynosCameraRequestSP_sprt_t registerToServiceList(ExynosCameraRequestSP_sprt_t request); |
| ExynosCameraRequestSP_sprt_t eraseFromServiceList(void); |
| status_t registerToRunningList(ExynosCameraRequestSP_sprt_t request_in); |
| ExynosCameraRequestSP_sprt_t getRunningRequest(uint32_t frameCount); |
| |
| status_t setMetaDataConverter(ExynosCameraMetadataConverter *converter); |
| ExynosCameraMetadataConverter* getMetaDataConverter(); |
| |
| |
| status_t setRequestsInfo(int key, ExynosCameraFrameFactory *factory); |
| void clearFrameFactory(void); |
| ExynosCameraFrameFactory* getFrameFactory(int key); |
| |
| void notifyDeviceError(void); |
| |
| status_t pushResultRequest(ResultRequest result); |
| |
| status_t flush(); |
| |
| /* other helper functions */ |
| status_t isPrevRequest(void); |
| status_t clearPrevRequest(void); |
| |
| status_t setCallbackOps(const camera3_callback_ops *callbackOps); |
| ResultRequest createResultRequest(uint32_t requestKey, uint32_t frameCount, |
| EXYNOS_REQUEST_RESULT::TYPE type); |
| uint32_t getAllRequestCount(void); |
| uint32_t getServiceRequestCount(void); |
| uint32_t getRunningRequestCount(void); |
| |
| status_t setFrameCount(uint32_t frameCount, uint32_t requestKey); |
| status_t waitforRequestflush(); |
| |
| int32_t getResultRenew(void); |
| void incResultRenew(void); |
| void resetResultRenew(void); |
| void dump(void); |
| |
| private: |
| typedef map<uint32_t, ExynosCameraRequestSP_sprt_t> RequestInfoMap; |
| typedef map<uint32_t, ExynosCameraRequestSP_sprt_t>::iterator RequestInfoMapIterator; |
| typedef list<ExynosCameraRequestSP_sprt_t> RequestInfoList; |
| typedef list<ExynosCameraRequestSP_sprt_t>::iterator RequestInfoListIterator; |
| typedef map<uint32_t, uint32_t> RequestFrameCountMap; |
| typedef map<uint32_t, uint32_t>::iterator RequestFrameCountMapIterator; |
| |
| status_t m_pushBack(ExynosCameraRequestSP_sprt_t item, RequestInfoList *list, Mutex *lock); |
| status_t m_popBack(ExynosCameraRequestSP_dptr_t item, RequestInfoList *list, Mutex *lock); |
| status_t m_pushFront(ExynosCameraRequestSP_sprt_t item, RequestInfoList *list, Mutex *lock); |
| status_t m_popFront(ExynosCameraRequestSP_dptr_t item, RequestInfoList *list, Mutex *lock); |
| status_t m_get(uint32_t frameCount, ExynosCameraRequestSP_dptr_t item, RequestInfoList *list, Mutex *lock); |
| |
| status_t m_push(ExynosCameraRequestSP_sprt_t item, RequestInfoMap *list, Mutex *lock); |
| status_t m_pop(uint32_t frameCount, ExynosCameraRequestSP_dptr_t item, RequestInfoMap *list, Mutex *lock); |
| status_t m_get(uint32_t frameCount, ExynosCameraRequestSP_dptr_t item, RequestInfoMap *list, Mutex *lock); |
| |
| void m_printAllServiceRequestInfo(void); |
| void m_printAllRequestInfo(RequestInfoMap *map, Mutex *lock); |
| |
| status_t m_removeFromRunningList(uint32_t requestKey); |
| |
| status_t m_pushFactory(int key, ExynosCameraFrameFactory* item, FrameFactoryMap *list, Mutex *lock); |
| status_t m_popFactory(int key, ExynosCameraFrameFactory** item, FrameFactoryMap *list, Mutex *lock); |
| status_t m_getFactory(int key, ExynosCameraFrameFactory** item, FrameFactoryMap *list, Mutex *lock); |
| |
| status_t m_callbackOpsCaptureResult(camera3_capture_result_t *result); |
| status_t m_callbackOpsNotify(camera3_notify_msg_t *msg); |
| |
| status_t m_getKey(uint32_t *key, uint32_t frameCount); |
| status_t m_popKey(uint32_t *key, uint32_t frameCount); |
| uint32_t m_generateResultKey(); |
| |
| status_t m_sendCallbackResult(ResultRequest result); |
| |
| status_t m_increasePipelineDepth(RequestInfoMap *map, Mutex *lock); |
| |
| void m_debugCallbackFPS(); |
| |
| bool m_resultCallback(void); |
| bool m_resultCallbackThreadFunc(void); |
| |
| bool m_notifyCallback(ExynosCameraRequestSP_sprt_t curRequest, ResultRequest result); |
| bool m_partialMetaCallback(ExynosCameraRequestSP_sprt_t curRequest, ResultRequest result); |
| bool m_allMetaCallback(ExynosCameraRequestSP_sprt_t curRequest, ResultRequest result); |
| bool m_bufferOnlyCallback(ExynosCameraRequestSP_sprt_t curRequest, ResultRequest result); |
| bool m_notifyErrorCallback(ExynosCameraRequestSP_sprt_t curRequest, ResultRequest result); |
| |
| bool m_requestDeleteFunc(ExynosCameraRequestSP_sprt_t curRequest); |
| |
| void m_setFlushFlag(bool falg); |
| bool m_getFlushFlag(void); |
| |
| #if 0 |
| /* Other helper functions */ |
| status_t initShotData(void); |
| status_t checkAvailableStreamFormat(int format); |
| uint32_t getFrameNumber(void); |
| #endif |
| private: |
| bool m_flushFlag; |
| mutable Mutex m_flushLock; |
| |
| RequestInfoList m_serviceRequests; |
| RequestInfoMap m_runningRequests; |
| mutable Mutex m_requestLock; |
| |
| camera_metadata_t *m_defaultRequestTemplate[CAMERA3_TEMPLATE_COUNT]; |
| CameraMetadata m_previousMeta; |
| |
| ExynosCameraParameters *m_parameters; |
| ExynosCameraMetadataConverter *m_converter; |
| |
| const camera3_callback_ops_t *m_callbackOps; |
| |
| int32_t m_requestResultKey; |
| mutable Mutex m_requestResultKeyLock; |
| |
| FrameFactoryMap m_factoryMap; |
| mutable Mutex m_factoryMapLock; |
| |
| RequestFrameCountMap m_requestFrameCountMap; |
| mutable Mutex m_requestFrameCountMapLock; |
| |
| ExynosCameraDurationTimer m_callbackFlushTimer; |
| |
| #ifdef CALLBACK_FPS_CHECK |
| int32_t m_callbackFrameCnt = 0; |
| ExynosCameraDurationTimer m_callbackDurationTimer; |
| #endif |
| |
| result_queue_t m_resultCallbackQ; |
| sp<callbackThread> m_resultCallbackThread; |
| |
| ExynosCameraCallbackSequencer *m_notifySequencer; |
| ExynosCameraCallbackSequencer *m_allMetaSequencer; |
| |
| int32_t m_resultRenew; |
| int32_t m_lastResultKey[EXYNOS_REQUEST_RESULT::CALLBACK_MAX]; |
| }; |
| |
| }; /* namespace android */ |
| #endif |