summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEino-Ville Talvala <etalvala@google.com>2012-10-24 19:53:14 -0700
committerAndroid Git Automerger <android-git-automerger@android.com>2012-10-24 19:53:14 -0700
commitbd37975395b6517e155f6195d2300872bc26ee70 (patch)
treefc1c92d1719b2f3cb08d0432a91bff6832b7599e
parentf76ca8f6aaa56146b388239c034bd53f19b9abf2 (diff)
parent3618639002b5167b5dc19e9d5cfde948cf745306 (diff)
downloadframeworks_av-bd37975395b6517e155f6195d2300872bc26ee70.zip
frameworks_av-bd37975395b6517e155f6195d2300872bc26ee70.tar.gz
frameworks_av-bd37975395b6517e155f6195d2300872bc26ee70.tar.bz2
am 203836b7: am b8d6efba: Camera2: Don\'t hold locks while waiting to sync.
* commit '203836b7584ccb7787202578259d27d70a8a3ede': Camera2: Don't hold locks while waiting to sync.
-rw-r--r--services/camera/libcameraservice/Camera2Client.cpp68
1 files changed, 35 insertions, 33 deletions
diff --git a/services/camera/libcameraservice/Camera2Client.cpp b/services/camera/libcameraservice/Camera2Client.cpp
index 94630f9..e59a240 100644
--- a/services/camera/libcameraservice/Camera2Client.cpp
+++ b/services/camera/libcameraservice/Camera2Client.cpp
@@ -1068,42 +1068,44 @@ status_t Camera2Client::takePicture(int msgType) {
status_t res;
if ( (res = checkPid(__FUNCTION__) ) != OK) return res;
- SharedParameters::Lock l(mParameters);
- switch (l.mParameters.state) {
- case Parameters::DISCONNECTED:
- case Parameters::STOPPED:
- case Parameters::WAITING_FOR_PREVIEW_WINDOW:
- ALOGE("%s: Camera %d: Cannot take picture without preview enabled",
- __FUNCTION__, mCameraId);
- return INVALID_OPERATION;
- case Parameters::PREVIEW:
- // Good to go for takePicture
- res = commandStopFaceDetectionL(l.mParameters);
- if (res != OK) {
- ALOGE("%s: Camera %d: Unable to stop face detection for still capture",
+ {
+ SharedParameters::Lock l(mParameters);
+ switch (l.mParameters.state) {
+ case Parameters::DISCONNECTED:
+ case Parameters::STOPPED:
+ case Parameters::WAITING_FOR_PREVIEW_WINDOW:
+ ALOGE("%s: Camera %d: Cannot take picture without preview enabled",
__FUNCTION__, mCameraId);
- return res;
- }
- l.mParameters.state = Parameters::STILL_CAPTURE;
- break;
- case Parameters::RECORD:
- // Good to go for video snapshot
- l.mParameters.state = Parameters::VIDEO_SNAPSHOT;
- break;
- case Parameters::STILL_CAPTURE:
- case Parameters::VIDEO_SNAPSHOT:
- ALOGE("%s: Camera %d: Already taking a picture",
- __FUNCTION__, mCameraId);
- return INVALID_OPERATION;
- }
+ return INVALID_OPERATION;
+ case Parameters::PREVIEW:
+ // Good to go for takePicture
+ res = commandStopFaceDetectionL(l.mParameters);
+ if (res != OK) {
+ ALOGE("%s: Camera %d: Unable to stop face detection for still capture",
+ __FUNCTION__, mCameraId);
+ return res;
+ }
+ l.mParameters.state = Parameters::STILL_CAPTURE;
+ break;
+ case Parameters::RECORD:
+ // Good to go for video snapshot
+ l.mParameters.state = Parameters::VIDEO_SNAPSHOT;
+ break;
+ case Parameters::STILL_CAPTURE:
+ case Parameters::VIDEO_SNAPSHOT:
+ ALOGE("%s: Camera %d: Already taking a picture",
+ __FUNCTION__, mCameraId);
+ return INVALID_OPERATION;
+ }
- ALOGV("%s: Camera %d: Starting picture capture", __FUNCTION__, mCameraId);
+ ALOGV("%s: Camera %d: Starting picture capture", __FUNCTION__, mCameraId);
- res = mJpegProcessor->updateStream(l.mParameters);
- if (res != OK) {
- ALOGE("%s: Camera %d: Can't set up still image stream: %s (%d)",
- __FUNCTION__, mCameraId, strerror(-res), res);
- return res;
+ res = mJpegProcessor->updateStream(l.mParameters);
+ if (res != OK) {
+ ALOGE("%s: Camera %d: Can't set up still image stream: %s (%d)",
+ __FUNCTION__, mCameraId, strerror(-res), res);
+ return res;
+ }
}
// Need HAL to have correct settings before (possibly) triggering precapture