summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorTyler Luu <tluu@ti.com>2011-09-07 17:13:32 -0500
committerIliyan Malchev <malchev@google.com>2011-09-07 17:13:15 -0700
commitfba8211ebbceadc0836bd646bcd94bb99f205fe8 (patch)
treec4514f04ba3c694e68e9c5c76394fce0b9088ec1
parenteec9df1622b2125d221a5b0f5c39633a14648d5a (diff)
downloadhardware_ti_omap4-fba8211ebbceadc0836bd646bcd94bb99f205fe8.zip
hardware_ti_omap4-fba8211ebbceadc0836bd646bcd94bb99f205fe8.tar.gz
hardware_ti_omap4-fba8211ebbceadc0836bd646bcd94bb99f205fe8.tar.bz2
CameraHal: Handle stopPreview properly for preview in progress
During some cases like when phone orientation changes after startPreview call but before setPreviewDisplay, stopPreview is called by application. Before we were seeing some error messages from camera adapter state machine because we were trying to make some improper state transitions. This patch guards against that. This patch also resets the mPreviewStateInProgress flag in stopPreview Change-Id: If5e4c235b0937b37f567d9b1ed9bd4478ace69d4 Signed-off-by: Tyler Luu <tluu@ti.com>
-rw-r--r--camera/CameraHal.cpp51
1 files changed, 30 insertions, 21 deletions
diff --git a/camera/CameraHal.cpp b/camera/CameraHal.cpp
index dde2145..4db34d8 100644
--- a/camera/CameraHal.cpp
+++ b/camera/CameraHal.cpp
@@ -1087,12 +1087,6 @@ status_t CameraHal::freePreviewDataBufs()
mPreviewDataBufs = NULL;
}
- else
- {
- CAMHAL_LOGEA("Couldn't free PreviewDataBufs allocated by memory manager");
- ret = -EINVAL;
- }
-
}
LOG_FUNCTION_NAME_EXIT;
@@ -3136,24 +3130,38 @@ void CameraHal::forceStopPreview()
mAppCallbackNotifier->stopPreviewCallbacks();
}
- // since prerequisite for capturing is for camera system
- // to be previewing...cancel all captures before stopping
- // preview
- if ( mCameraAdapter->getState() == CameraAdapter::CAPTURE_STATE &&
- mCameraAdapter->getNextState() != CameraAdapter::PREVIEW_STATE) {
- mCameraAdapter->sendCommand(CameraAdapter::CAMERA_STOP_IMAGE_CAPTURE);
- }
-
if ( NULL != mCameraAdapter ) {
- // according to javadoc...FD should be stopped in stopPreview
- // and application needs to call startFaceDection again
- // to restart FD
- mCameraAdapter->sendCommand(CameraAdapter::CAMERA_STOP_FD);
+ CameraAdapter::AdapterState currentState;
+ CameraAdapter::AdapterState nextState;
- cancelAutoFocus();
+ currentState = mCameraAdapter->getState();
+ nextState = mCameraAdapter->getNextState();
- //Stop the source of frames
- mCameraAdapter->sendCommand(CameraAdapter::CAMERA_STOP_PREVIEW);
+ // since prerequisite for capturing is for camera system
+ // to be previewing...cancel all captures before stopping
+ // preview
+ if ( (currentState == CameraAdapter::CAPTURE_STATE) &&
+ (nextState != CameraAdapter::PREVIEW_STATE)) {
+ mCameraAdapter->sendCommand(CameraAdapter::CAMERA_STOP_IMAGE_CAPTURE);
+ }
+
+ // only need to send these control commands to state machine if we are
+ // passed the LOADED_PREVIEW_STATE
+ if (currentState > CameraAdapter::LOADED_PREVIEW_STATE) {
+ // according to javadoc...FD should be stopped in stopPreview
+ // and application needs to call startFaceDection again
+ // to restart FD
+ mCameraAdapter->sendCommand(CameraAdapter::CAMERA_STOP_FD);
+
+ cancelAutoFocus();
+ }
+
+ // only need to send these control commands to state machine if we are
+ // passed the INITIALIZED_STATE
+ if (currentState > CameraAdapter::INTIALIZED_STATE) {
+ //Stop the source of frames
+ mCameraAdapter->sendCommand(CameraAdapter::CAMERA_STOP_PREVIEW);
+ }
}
freePreviewBufs();
@@ -3161,6 +3169,7 @@ void CameraHal::forceStopPreview()
mPreviewEnabled = false;
mDisplayPaused = false;
+ mPreviewStartInProgress = false;
LOG_FUNCTION_NAME_EXIT;
}