diff options
Diffstat (limited to 'libcamera')
-rw-r--r-- | libcamera/SecCameraHWInterface.cpp | 19 | ||||
-rw-r--r-- | libcamera/SecCameraHWInterface.h | 1 |
2 files changed, 8 insertions, 12 deletions
diff --git a/libcamera/SecCameraHWInterface.cpp b/libcamera/SecCameraHWInterface.cpp index 3df798f..f01024a 100644 --- a/libcamera/SecCameraHWInterface.cpp +++ b/libcamera/SecCameraHWInterface.cpp @@ -30,7 +30,6 @@ #include <ui/Overlay.h> #define CACHEABLE_BUFFERS 0x1 #define ALL_BUFFERS_FLUSHED -66 -int buf_idx = 0; #endif #ifdef SEND_YUV_RECORD_DATA @@ -76,6 +75,7 @@ CameraHardwareSec::CameraHardwareSec(int cameraId) mCurrentPreviewFrame(0), #if defined(BOARD_USES_OVERLAY) mUseOverlay(false), + mOverlayBufferIdx(0), #endif mRecordRunning(false) #ifdef JPEG_FROM_SENSOR @@ -448,14 +448,9 @@ int CameraHardwareSec::previewThread() #if defined(BOARD_USES_OVERLAY) if (mUseOverlay) { int ret; - - if (buf_idx == 0) - buf_idx = 1; - else - buf_idx = 0; - + mOverlayBufferIdx ^= 1; memcpy(static_cast<unsigned char*>(mPreviewHeap->base()) + offset + frame_size + sizeof(phyYAddr) + sizeof(phyCAddr), - &buf_idx, sizeof(buf_idx)); + &mOverlayBufferIdx, sizeof(mOverlayBufferIdx)); ret = mOverlay->queueBuffer((void*)(static_cast<unsigned char *>(mPreviewHeap->base()) + (offset + frame_size))); @@ -1207,14 +1202,15 @@ int CameraHardwareSec::pictureThread() #endif memcpy(mRawHeap->base(),PostviewHeap->base(), postviewHeapSize); +#if defined(BOARD_USES_OVERLAY) /* Put postview image to Overlay */ unsigned int index = 0; unsigned int offset = ((mPostViewWidth*mPostViewHeight*3/2) + 16) * index; unsigned int overlay_header[4]; - buf_idx ^= 1; + mOverlayBufferIdx ^= 1; overlay_header[0]= mSecCamera->getPhyAddrY(index); overlay_header[1]= overlay_header[0] + mPostViewWidth*mPostViewHeight; - overlay_header[2]= buf_idx; + overlay_header[2]= mOverlayBufferIdx; YUY2toNV21(mRawHeap->base(), (void*)(static_cast<unsigned char *>(mPreviewHeap->base()) + offset), mPostViewWidth, mPostViewHeight); @@ -1226,7 +1222,6 @@ int CameraHardwareSec::pictureThread() (mPostViewWidth*mPostViewHeight * 3 / 2))); if (ret == ALL_BUFFERS_FLUSHED) { - LOGE("%s ALL_BUFFERS_FLUSHED",__func__); goto PostviewOverlayEnd; } else if (ret == -1) { LOGE("ERR(%s):overlay queueBuffer fail", __func__); @@ -1237,7 +1232,6 @@ int CameraHardwareSec::pictureThread() ret = mOverlay->dequeueBuffer(&overlay_buffer); if (ret == ALL_BUFFERS_FLUSHED) { - LOGE("%s ALL_BUFFERS_FLUSHED",__func__); goto PostviewOverlayEnd; } else if (ret == -1) { LOGE("ERR(%s):overlay dequeueBuffer fail", __func__); @@ -1245,6 +1239,7 @@ int CameraHardwareSec::pictureThread() } PostviewOverlayEnd: +#endif if (mMsgEnabled & CAMERA_MSG_RAW_IMAGE) { mDataCb(CAMERA_MSG_RAW_IMAGE, buffer, mCallbackCookie); } diff --git a/libcamera/SecCameraHWInterface.h b/libcamera/SecCameraHWInterface.h index 7a151e7..fde5486 100644 --- a/libcamera/SecCameraHWInterface.h +++ b/libcamera/SecCameraHWInterface.h @@ -186,6 +186,7 @@ private: #if defined(BOARD_USES_OVERLAY) sp<Overlay> mOverlay; bool mUseOverlay; + int mOverlayBufferIdx; #endif // protected by mLock |