diff options
| author | 2010-08-03 15:29:20 -0700 | |
|---|---|---|
| committer | 2010-08-03 15:29:20 -0700 | |
| commit | af3f29e62b35c0ce100f20f9d96affd5ef6e5e96 (patch) | |
| tree | b6c0433fb73b8d9835fdedf36def498aea94e280 | |
| parent | 6fcf3a518526d4f844830735ca1a2ae82a7500d8 (diff) | |
Replace CHECK with a failure return value when mCamera->setParameters() fails
if the camera is locked by someone else.
bug - 2827892
Change-Id: I217d4a00f04ebd57b557d3faef28787c14f23ea0
| -rw-r--r-- | media/libmediaplayerservice/StagefrightRecorder.cpp | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/media/libmediaplayerservice/StagefrightRecorder.cpp b/media/libmediaplayerservice/StagefrightRecorder.cpp index c40d285532e0..dfddae0317ca 100644 --- a/media/libmediaplayerservice/StagefrightRecorder.cpp +++ b/media/libmediaplayerservice/StagefrightRecorder.cpp @@ -833,7 +833,11 @@ status_t StagefrightRecorder::setupCameraSource() { params.setPreviewSize(mVideoWidth, mVideoHeight); params.setPreviewFrameRate(mFrameRate); String8 s = params.flatten(); - CHECK_EQ(OK, mCamera->setParameters(s)); + if (OK != mCamera->setParameters(s)) { + LOGE("Could not change settings." + " Someone else is using camera %d?", mCameraId); + return -EBUSY; + } CameraParameters newCameraParams(mCamera->getParameters()); // Check on video frame size @@ -854,6 +858,8 @@ status_t StagefrightRecorder::setupCameraSource() { "frame rate is %d", mFrameRate, frameRate); } + // This CHECK is good, since we just passed the lock/unlock + // check earlier by calling mCamera->setParameters(). CHECK_EQ(OK, mCamera->setPreviewDisplay(mPreviewSurface)); IPCThreadState::self()->restoreCallingIdentity(token); return OK; |