summaryrefslogtreecommitdiffstats
path: root/services
diff options
context:
space:
mode:
authorEino-Ville Talvala <etalvala@google.com>2012-10-07 09:10:36 -0700
committerAndroid Git Automerger <android-git-automerger@android.com>2012-10-07 09:10:36 -0700
commit5b9c992c7128bf857e82d42ac8027285ad86b1e0 (patch)
treeb91c3b361865033e3d471860ac5374304c059515 /services
parent056a76e1b9275833ec8134a5ff56a4489e86d952 (diff)
parent196438b3ad32da3607517f7dc1650ff8c017cc81 (diff)
downloadframeworks_av-5b9c992c7128bf857e82d42ac8027285ad86b1e0.zip
frameworks_av-5b9c992c7128bf857e82d42ac8027285ad86b1e0.tar.gz
frameworks_av-5b9c992c7128bf857e82d42ac8027285ad86b1e0.tar.bz2
am 3576742a: am 4d410ede: Camera2: Fix off-by-one error in ZSL selection.
* commit '3576742a2bb3dc10bf8256579d600d85f17c3835': Camera2: Fix off-by-one error in ZSL selection.
Diffstat (limited to 'services')
-rw-r--r--services/camera/libcameraservice/camera2/ZslProcessor.cpp9
1 files changed, 6 insertions, 3 deletions
diff --git a/services/camera/libcameraservice/camera2/ZslProcessor.cpp b/services/camera/libcameraservice/camera2/ZslProcessor.cpp
index 5208574..1937955 100644
--- a/services/camera/libcameraservice/camera2/ZslProcessor.cpp
+++ b/services/camera/libcameraservice/camera2/ZslProcessor.cpp
@@ -254,11 +254,14 @@ status_t ZslProcessor::pushToReprocess(int32_t requestId) {
if (mZslQueueTail != mZslQueueHead) {
CameraMetadata request;
size_t index = mZslQueueTail;
- while (request.isEmpty() && index != mZslQueueHead) {
- request = mZslQueue[index].frame;
+ while (index != mZslQueueHead) {
+ if (!mZslQueue[index].frame.isEmpty()) {
+ request = mZslQueue[index].frame;
+ break;
+ }
index = (index + 1) % kZslBufferDepth;
}
- if (request.isEmpty()) {
+ if (index == mZslQueueHead) {
ALOGV("%s: ZSL queue has no valid frames to send yet.",
__FUNCTION__);
return NOT_ENOUGH_DATA;