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 &param);
1117f47f6bd7178f8bf54cf78a003a52c3f4585158cZhijun He    int32_t getParameter(cam_stream_parm_buffer_t &param);
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