17f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He/* Copyright (c) 2012-2016, The Linux Foundation. All rights reserved. 27f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * 37f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * Redistribution and use in source and binary forms, with or without 47f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * modification, are permitted provided that the following conditions are 57f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * met: 67f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * * Redistributions of source code must retain the above copyright 77f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * notice, this list of conditions and the following disclaimer. 87f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * * Redistributions in binary form must reproduce the above 97f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * copyright notice, this list of conditions and the following 107f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * disclaimer in the documentation and/or other materials provided 117f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * with the distribution. 127f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * * Neither the name of The Linux Foundation nor the names of its 137f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * contributors may be used to endorse or promote products derived 147f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * from this software without specific prior written permission. 157f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * 167f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * THIS SOFTWARE IS PROVIDED "AS IS" AND ANY EXPRESS OR IMPLIED 177f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 187f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT 197f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS 207f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR 217f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF 227f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR 237f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, 247f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE 257f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN 267f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 277f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He * 287f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He */ 297f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 307f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He#ifndef __QCAMERA_STREAM_H__ 317f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He#define __QCAMERA_STREAM_H__ 327f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 337f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He// Camera dependencies 347f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He#include "camera.h" 357f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He#include "QCameraCmdThread.h" 367f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He#include "QCameraMem.h" 377f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He#include "QCameraAllocator.h" 387f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 397f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun Heextern "C" { 407f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He#include "mm_camera_interface.h" 417f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He} 427f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 437f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun Henamespace qcamera { 447f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 457f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun Heclass QCameraStream; 467f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun Hetypedef void (*stream_cb_routine)(mm_camera_super_buf_t *frame, 477f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He QCameraStream *stream, 487f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He void *userdata); 497f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 507f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He#define CAMERA_MAX_CONSUMER_BATCH_BUFFER_SIZE 16 517f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He#define CAMERA_MIN_VIDEO_BATCH_BUFFERS 3 527f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 537f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 547f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun Heclass QCameraStream 557f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He{ 567f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun Hepublic: 577f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He QCameraStream(QCameraAllocator &allocator, 587f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint32_t camHandle, uint32_t chId, 597f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_ops_t *camOps, cam_padding_info_t *paddingInfo, 607f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He bool deffered = false, cam_rotation_t online_rotation = ROTATE_0); 617f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He virtual ~QCameraStream(); 627f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He virtual int32_t init(QCameraHeapMemory *streamInfoBuf, 637f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He QCameraHeapMemory *miscBuf, 647f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t minStreamBufNum, 657f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He stream_cb_routine stream_cb, 667f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He void *userdata, 677f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He bool bDynallocBuf); 687f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He virtual int32_t processZoomDone(preview_stream_ops_t *previewWindow, 697f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He cam_crop_data_t &crop_info); 707f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He virtual int32_t bufDone(uint32_t index); 717f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He virtual int32_t bufDone(const void *opaque, bool isMetaData); 727f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He virtual int32_t processDataNotify(mm_camera_super_buf_t *bufs); 737f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He virtual int32_t start(); 747f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He virtual int32_t stop(); 757f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 767f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He /* Used for deffered allocation of buffers */ 777f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He virtual int32_t allocateBuffers(); 787f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He virtual int32_t mapBuffers(); 797f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He virtual int32_t releaseBuffs(); 807f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 817f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He static void dataNotifyCB(mm_camera_super_buf_t *recvd_frame, void *userdata); 827f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He static void dataNotifySYNCCB(mm_camera_super_buf_t *recvd_frame, 837f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He void *userdata); 847f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He static void *dataProcRoutine(void *data); 857f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He static void *BufAllocRoutine(void *data); 867f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint32_t getMyHandle() const {return mHandle;} 877f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He bool isTypeOf(cam_stream_type_t type); 887f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He bool isOrignalTypeOf(cam_stream_type_t type); 897f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t getFrameOffset(cam_frame_len_offset_t &offset); 907f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t getCropInfo(cam_rect_t &crop); 917f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t setCropInfo(cam_rect_t crop); 927f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t getFrameDimension(cam_dimension_t &dim); 937f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t getFormat(cam_format_t &fmt); 947f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He QCameraMemory *getStreamBufs() {return mStreamBufs;}; 957f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He QCameraHeapMemory *getStreamInfoBuf() {return mStreamInfoBuf;}; 967f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He QCameraHeapMemory *getMiscBuf() {return mMiscBuf;}; 977f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint32_t getMyServerID(); 987f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He cam_stream_type_t getMyType(); 997f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He cam_stream_type_t getMyOriginalType(); 1007f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t acquireStreamBufs(); 1017f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 1027f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t mapBuf(uint8_t buf_type, uint32_t buf_idx, 1037f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t plane_idx, int fd, void *buffer, size_t size, 1047f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_map_unmap_ops_tbl_t *ops_tbl = NULL); 1057f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t mapBufs(cam_buf_map_type_list bufMapList, 1067f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_map_unmap_ops_tbl_t *ops_tbl = NULL); 1077f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t mapNewBuffer(uint32_t index); 1087f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t unmapBuf(uint8_t buf_type, uint32_t buf_idx, int32_t plane_idx, 1097f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_map_unmap_ops_tbl_t *ops_tbl = NULL); 1107f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t setParameter(cam_stream_parm_buffer_t ¶m); 1117f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t getParameter(cam_stream_parm_buffer_t ¶m); 1127f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t syncRuntimeParams(); 1137f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He cam_stream_parm_buffer_t getOutputCrop() { return m_OutputCrop;}; 1147f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He cam_stream_parm_buffer_t getImgProp() { return m_ImgProp;}; 1157f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 1167f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He static void releaseFrameData(void *data, void *user_data); 1177f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t configStream(); 1187f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He bool isDeffered() const { return mDefferedAllocation; } 1197f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He bool isSyncCBEnabled() {return mSyncCBEnabled;}; 1207f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He void deleteStream(); 1217f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 1227f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t getBufferCount() { return mNumBufs; } 1237f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint32_t getChannelHandle() { return mChannelHandle; } 1247f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t getNumQueuedBuf(); 1257f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 1267f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint32_t mDumpFrame; 1277f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint32_t mDumpMetaFrame; 1287f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint32_t mDumpSkipCnt; 1297f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 1307f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He void cond_wait(); 1317f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He void cond_signal(bool forceExit = false); 1327f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 1337f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t setSyncDataCB(stream_cb_routine data_cb); 1347f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He //Stream time stamp. We need this for preview stream to update display 1357f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He nsecs_t mStreamTimestamp; 1367f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 1377f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He //Frame Buffer will be stored here in case framework batch mode. 1387f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He camera_memory_t *mCurMetaMemory; // Current metadata buffer ptr 1397f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int8_t mCurBufIndex; // Buffer count filled in current metadata 1407f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int8_t mCurMetaIndex; // Active metadata buffer index 1417f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 1427f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He nsecs_t mFirstTimeStamp; // Timestamp of first frame in Metadata. 1437f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 1447f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He // Buffer storage structure. 1457f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He typedef struct { 1467f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He bool consumerOwned; // Metadata is with Consumer if TRUE 1477f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t numBuffers; // Num of buffer need to released 1487f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t buf_index[CAMERA_MAX_CONSUMER_BATCH_BUFFER_SIZE]; 1497f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He } MetaMemory; 1507f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He MetaMemory mStreamMetaMemory[CAMERA_MIN_VIDEO_BATCH_BUFFERS]; 1517f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 1527f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun Heprivate: 1537f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint32_t mCamHandle; 1547f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint32_t mChannelHandle; 1557f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint32_t mHandle; // stream handle from mm-camera-interface 1567f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_ops_t *mCamOps; 1577f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He cam_stream_info_t *mStreamInfo; // ptr to stream info buf 1587f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_stream_mem_vtbl_t mMemVtbl; 1597f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t mNumBufs; 1607f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t mNumPlaneBufs; 1617f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t mNumBufsNeedAlloc; 1627f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t *mRegFlags; 1637f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He stream_cb_routine mDataCB; 1647f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He stream_cb_routine mSYNCDataCB; 1657f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He void *mUserData; 1667f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 1677f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He QCameraQueue mDataQ; 1687f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He QCameraCmdThread mProcTh; // thread for dataCB 1697f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 1707f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He QCameraHeapMemory *mStreamInfoBuf; 1717f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He QCameraHeapMemory *mMiscBuf; 1727f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He QCameraMemory *mStreamBufs; 1737f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He QCameraMemory *mStreamBatchBufs; 1747f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He QCameraAllocator &mAllocator; 1757f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_buf_def_t *mBufDefs; 1767f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_buf_def_t *mPlaneBufDefs; 1777f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He cam_frame_len_offset_t mFrameLenOffset; 1787f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He cam_padding_info_t mPaddingInfo; 1797f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He cam_rect_t mCropInfo; 1807f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He cam_rotation_t mOnlineRotation; 1817f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He pthread_mutex_t mCropLock; // lock to protect crop info 1827f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He pthread_mutex_t mParameterLock; // lock to sync access to parameters 1837f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He bool mStreamBufsAcquired; 1847f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He bool m_bActive; // if stream mProcTh is active 1857f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He bool mDynBufAlloc; // allow buf allocation in 2 steps 1867f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He pthread_t mBufAllocPid; 1877f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_map_unmap_ops_tbl_t m_MemOpsTbl; 1887f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He cam_stream_parm_buffer_t m_OutputCrop; 1897f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He cam_stream_parm_buffer_t m_ImgProp; 1907f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 1917f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He static int32_t get_bufs( 1927f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He cam_frame_len_offset_t *offset, 1937f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t *num_bufs, 1947f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t **initial_reg_flag, 1957f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_buf_def_t **bufs, 1967f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_map_unmap_ops_tbl_t *ops_tbl, 1977f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He void *user_data); 1987f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 1997f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He static int32_t get_bufs_deffered( 2007f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He cam_frame_len_offset_t *offset, 2017f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t *num_bufs, 2027f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t **initial_reg_flag, 2037f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_buf_def_t **bufs, 2047f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_map_unmap_ops_tbl_t *ops_tbl, 2057f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He void *user_data); 2067f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 2077f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He static int32_t put_bufs( 2087f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_map_unmap_ops_tbl_t *ops_tbl, 2097f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He void *user_data); 2107f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 2117f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He static int32_t put_bufs_deffered( 2127f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_map_unmap_ops_tbl_t *ops_tbl, 2137f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He void *user_data); 2147f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 2157f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He static int32_t set_config_ops( 2167f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_map_unmap_ops_tbl_t *ops_tbl, 2177f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He void *user_data); 2187f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 2197f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He static int32_t invalidate_buf(uint32_t index, void *user_data); 2207f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He static int32_t clean_invalidate_buf(uint32_t index, void *user_data); 2217f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 2227f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He static int32_t backgroundAllocate(void* data); 2237f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He static int32_t backgroundMap(void* data); 2247f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 2257f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t getBufs(cam_frame_len_offset_t *offset, 2267f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t *num_bufs, 2277f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t **initial_reg_flag, 2287f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_buf_def_t **bufs, 2297f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_map_unmap_ops_tbl_t *ops_tbl); 2307f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t getBufsDeferred(cam_frame_len_offset_t *offset, 2317f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t *num_bufs, 2327f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t **initial_reg_flag, 2337f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_buf_def_t **bufs, 2347f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_map_unmap_ops_tbl_t *ops_tbl); 2357f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t putBufs(mm_camera_map_unmap_ops_tbl_t *ops_tbl); 2367f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t putBufsDeffered(); 2377f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 2387f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He /* Used for deffered allocation of buffers */ 2397f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t allocateBatchBufs(cam_frame_len_offset_t *offset, 2407f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint8_t *num_bufs, uint8_t **initial_reg_flag, 2417f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_buf_def_t **bufs, mm_camera_map_unmap_ops_tbl_t *ops_tbl); 2427f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 2437f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t releaseBatchBufs(mm_camera_map_unmap_ops_tbl_t *ops_tbl); 2447f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 2457f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t invalidateBuf(uint32_t index); 2467f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t cleanInvalidateBuf(uint32_t index); 2477f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t calcOffset(cam_stream_info_t *streamInfo); 2487f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t unmapStreamInfoBuf(); 2497f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t releaseStreamInfoBuf(); 2507f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t releaseMiscBuf(); 2517f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t mapBufs(QCameraMemory *heapBuf, cam_mapping_buf_type bufType, 2527f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_map_unmap_ops_tbl_t *ops_tbl = NULL); 2537f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He int32_t unMapBuf(QCameraMemory *heapBuf, cam_mapping_buf_type bufType, 2547f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He mm_camera_map_unmap_ops_tbl_t *ops_tbl = NULL); 2557f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 2567f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He bool mDefferedAllocation; 2577f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 2587f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He bool wait_for_cond; 2597f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He pthread_mutex_t m_lock; 2607f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He pthread_cond_t m_cond; 2617f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 2627f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He BackgroundTask mAllocTask; 2637f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint32_t mAllocTaskId; 2647f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He BackgroundTask mMapTask; 2657f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He uint32_t mMapTaskId; 2667f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 2677f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He bool mSyncCBEnabled; 2687f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He}; 2697f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 2707f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He}; // namespace qcamera 2717f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He 2727f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He#endif /* __QCAMERA_STREAM_H__ */ 273