Camera2Client.cpp revision 428b77a2b94b74665a47375b3fdb893b98d71269
161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala/*
261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala * Copyright (C) 2012 The Android Open Source Project
361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala *
461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala * Licensed under the Apache License, Version 2.0 (the "License");
561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala * you may not use this file except in compliance with the License.
661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala * You may obtain a copy of the License at
761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala *
861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala *      http://www.apache.org/licenses/LICENSE-2.0
961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala *
1061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala * Unless required by applicable law or agreed to in writing, software
1161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala * distributed under the License is distributed on an "AS IS" BASIS,
1261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
1361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala * See the License for the specific language governing permissions and
1461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala * limitations under the License.
1561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala */
1661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
1761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#define LOG_TAG "Camera2Client"
18a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala#define ATRACE_TAG ATRACE_TAG_CAMERA
1961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala//#define LOG_NDEBUG 0
20a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala
21f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala#include <utils/Log.h>
22a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala#include <utils/Trace.h>
2361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
2461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#include <cutils/properties.h>
2561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#include <gui/SurfaceTextureClient.h>
2661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#include <gui/Surface.h>
2778822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala#include <media/hardware/MetadataBufferType.h>
2861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
29f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala#include <math.h>
30f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
3161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#include "Camera2Client.h"
3261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
3361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalanamespace android {
3461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
3561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#define ALOG1(...) ALOGD_IF(gLogLevel >= 1, __VA_ARGS__);
3661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#define ALOG2(...) ALOGD_IF(gLogLevel >= 2, __VA_ARGS__);
3761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
3861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatic int getCallingPid() {
3961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala    return IPCThreadState::self()->getCallingPid();
4061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
4161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
4261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatic int getCallingUid() {
4361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala    return IPCThreadState::self()->getCallingUid();
4461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
4561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
4661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala// Interface used by CameraService
4761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
4861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville TalvalaCamera2Client::Camera2Client(const sp<CameraService>& cameraService,
4961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala        const sp<ICameraClient>& cameraClient,
5061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala        int cameraId,
5161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala        int cameraFacing,
5261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala        int clientPid):
5361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala        Client(cameraService, cameraClient,
54f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                cameraId, cameraFacing, clientPid),
556db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        mState(NOT_INITIALIZED),
56d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        mPreviewStreamId(NO_STREAM),
57d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        mPreviewRequest(NULL),
58d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        mCaptureStreamId(NO_STREAM),
599cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        mCaptureRequest(NULL),
609cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        mRecordingStreamId(NO_STREAM),
619cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        mRecordingRequest(NULL)
62f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala{
63a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
6461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
65f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    mDevice = new Camera2Device(cameraId);
66f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala}
67f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
68f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvalastatus_t Camera2Client::initialize(camera_module_t *module)
69f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala{
70a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
719e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala    ALOGV("%s: E", __FUNCTION__);
72f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    status_t res;
73f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
74f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    res = mDevice->initialize(module);
75f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    if (res != OK) {
76f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        ALOGE("%s: Camera %d: unable to initialize device: %s (%d)",
77f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                __FUNCTION__, mCameraId, strerror(-res), res);
78f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        return NO_INIT;
79f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
80f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
81f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    res = buildDefaultParameters();
82f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    if (res != OK) {
83f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        ALOGE("%s: Camera %d: unable to build defaults: %s (%d)",
84f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                __FUNCTION__, mCameraId, strerror(-res), res);
85f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        return NO_INIT;
86f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
873cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
88f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    if (gLogLevel >= 1) {
89836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        LockedParameters::Key k(mParameters);
90f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        ALOGD("%s: Default parameters converted from camera %d:", __FUNCTION__,
91f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala              mCameraId);
92836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        ALOGD("%s", k.mParameters.paramsFlattened.string());
93f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
94f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
956db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    mState = STOPPED;
966db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala
97f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    return OK;
9861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
9961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
10061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville TalvalaCamera2Client::~Camera2Client() {
101a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
1024ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala    ALOGV("%s: Camera %d: Shutting down", __FUNCTION__, mCameraId);
1034ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala
104f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    mDestructionStarted = true;
105f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
106f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    disconnect();
1073cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
10861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
10961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
11061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::dump(int fd, const Vector<String16>& args) {
111611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala    String8 result;
1123297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    result.appendFormat("Client2[%d] (%p) PID: %d, dump:\n",
113611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala            mCameraId,
114611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala            getCameraClient()->asBinder().get(),
115611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala            mClientPid);
1167f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.append("  State: ");
1177f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala#define CASE_APPEND_ENUM(x) case x: result.append(#x "\n"); break;
1187f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
119836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    const Parameters& p = mParameters.unsafeUnlock();
120836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala
1214ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala    result.append(getStateName(mState));
1227f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
1234ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala    result.append("\n  Current parameters:\n");
1247f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.appendFormat("    Preview size: %d x %d\n",
125836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            p.previewWidth, p.previewHeight);
1267f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.appendFormat("    Preview FPS range: %d - %d\n",
127836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            p.previewFpsRange[0], p.previewFpsRange[1]);
1287f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.appendFormat("    Preview HAL pixel format: 0x%x\n",
129836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            p.previewFormat);
13011b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala    result.appendFormat("    Preview transform: %x\n",
131836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            p.previewTransform);
1327f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.appendFormat("    Picture size: %d x %d\n",
133836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            p.pictureWidth, p.pictureHeight);
1347f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.appendFormat("    Jpeg thumbnail size: %d x %d\n",
135836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            p.jpegThumbSize[0], p.jpegThumbSize[1]);
1367f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.appendFormat("    Jpeg quality: %d, thumbnail quality: %d\n",
137836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            p.jpegQuality, p.jpegThumbQuality);
138836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    result.appendFormat("    Jpeg rotation: %d\n", p.jpegRotation);
1397f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.appendFormat("    GPS tags %s\n",
140836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            p.gpsEnabled ? "enabled" : "disabled");
141836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (p.gpsEnabled) {
1427f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        result.appendFormat("    GPS lat x long x alt: %f x %f x %f\n",
143836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                p.gpsCoordinates[0], p.gpsCoordinates[1],
144836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                p.gpsCoordinates[2]);
1457f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        result.appendFormat("    GPS timestamp: %lld\n",
146836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                p.gpsTimestamp);
1477f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        result.appendFormat("    GPS processing method: %s\n",
148836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                p.gpsProcessingMethod.string());
1497f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    }
1507f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
1517f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.append("    White balance mode: ");
152836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    switch (p.wbMode) {
1537f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_AUTO)
1547f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_INCANDESCENT)
1557f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_FLUORESCENT)
1567f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_WARM_FLUORESCENT)
1577f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_DAYLIGHT)
1587f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_CLOUDY_DAYLIGHT)
1597f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_TWILIGHT)
1607f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_SHADE)
1617f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        default: result.append("UNKNOWN\n");
1627f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    }
1637f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
1647f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.append("    Effect mode: ");
165836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    switch (p.effectMode) {
1667f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_OFF)
1677f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MONO)
1687f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_NEGATIVE)
1697f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_SOLARIZE)
1707f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_SEPIA)
1717f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_POSTERIZE)
1727f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_WHITEBOARD)
1737f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_BLACKBOARD)
1747f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_AQUA)
1757f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        default: result.append("UNKNOWN\n");
1767f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    }
1777f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
1787f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.append("    Antibanding mode: ");
179836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    switch (p.antibandingMode) {
1807f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_AE_ANTIBANDING_AUTO)
1817f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_AE_ANTIBANDING_OFF)
1827f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_AE_ANTIBANDING_50HZ)
1837f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_AE_ANTIBANDING_60HZ)
1847f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        default: result.append("UNKNOWN\n");
1857f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    }
1867f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
1877f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.append("    Scene mode: ");
188836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    switch (p.sceneMode) {
1897f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        case ANDROID_CONTROL_SCENE_MODE_UNSUPPORTED:
1907f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala            result.append("AUTO\n"); break;
1917f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_ACTION)
1927f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_PORTRAIT)
1937f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_LANDSCAPE)
1947f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_NIGHT)
1957f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_NIGHT_PORTRAIT)
1967f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_THEATRE)
1977f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_BEACH)
1987f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_SNOW)
1997f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_SUNSET)
2007f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_STEADYPHOTO)
2017f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_FIREWORKS)
2027f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_SPORTS)
2037f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_PARTY)
2047f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_CANDLELIGHT)
2057f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_BARCODE)
2067f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        default: result.append("UNKNOWN\n");
2077f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    }
2087f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
2097f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.append("    Flash mode: ");
210836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    switch (p.flashMode) {
2117f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(Parameters::FLASH_MODE_OFF)
2127f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(Parameters::FLASH_MODE_AUTO)
2137f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(Parameters::FLASH_MODE_ON)
2147f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(Parameters::FLASH_MODE_TORCH)
2157f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(Parameters::FLASH_MODE_RED_EYE)
2167f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(Parameters::FLASH_MODE_INVALID)
2177f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        default: result.append("UNKNOWN\n");
2187f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    }
2197f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
2207f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.append("    Focus mode: ");
221836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    switch (p.focusMode) {
2227f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(Parameters::FOCUS_MODE_AUTO)
2237f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(Parameters::FOCUS_MODE_MACRO)
2247f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(Parameters::FOCUS_MODE_CONTINUOUS_VIDEO)
2257f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(Parameters::FOCUS_MODE_CONTINUOUS_PICTURE)
2267f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(Parameters::FOCUS_MODE_EDOF)
2277f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(Parameters::FOCUS_MODE_INFINITY)
2287f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(Parameters::FOCUS_MODE_FIXED)
2297f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        CASE_APPEND_ENUM(Parameters::FOCUS_MODE_INVALID)
2307f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        default: result.append("UNKNOWN\n");
2317f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    }
2327f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
2337f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.append("    Focusing areas:\n");
234836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    for (size_t i = 0; i < p.focusingAreas.size(); i++) {
2357f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        result.appendFormat("      [ (%d, %d, %d, %d), weight %d ]\n",
236836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                p.focusingAreas[i].left,
237836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                p.focusingAreas[i].top,
238836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                p.focusingAreas[i].right,
239836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                p.focusingAreas[i].bottom,
240836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                p.focusingAreas[i].weight);
2417f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    }
2427f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
2437f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.appendFormat("    Exposure compensation index: %d\n",
244836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            p.exposureCompensation);
2457f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
2467f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.appendFormat("    AE lock %s, AWB lock %s\n",
247836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            p.autoExposureLock ? "enabled" : "disabled",
248836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            p.autoWhiteBalanceLock ? "enabled" : "disabled" );
2497f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
2507f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    result.appendFormat("    Metering areas:\n");
251836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    for (size_t i = 0; i < p.meteringAreas.size(); i++) {
2527f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala        result.appendFormat("      [ (%d, %d, %d, %d), weight %d ]\n",
253836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                p.meteringAreas[i].left,
254836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                p.meteringAreas[i].top,
255836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                p.meteringAreas[i].right,
256836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                p.meteringAreas[i].bottom,
257836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                p.meteringAreas[i].weight);
2587f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala    }
2597f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
260836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    result.appendFormat("    Zoom index: %d\n", p.zoom);
261836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    result.appendFormat("    Video size: %d x %d\n", p.videoWidth,
262836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            p.videoHeight);
2637f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
2643297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    result.appendFormat("    Recording hint is %s\n",
265836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            p.recordingHint ? "set" : "not set");
2667f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
2673297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    result.appendFormat("    Video stabilization is %s\n",
268836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            p.videoStabilization ? "enabled" : "disabled");
2697f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
2703297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    result.append("  Current streams:\n");
2713297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    result.appendFormat("    Preview stream ID: %d\n", mPreviewStreamId);
2723297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    result.appendFormat("    Capture stream ID: %d\n", mCaptureStreamId);
273836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    result.appendFormat("    Recording stream ID: %d\n", mRecordingStreamId);
2743297daae9681004775012faba9181d65e097e00cEino-Ville Talvala
2753297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    result.append("  Current requests:\n");
2763297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    if (mPreviewRequest != NULL) {
2773297daae9681004775012faba9181d65e097e00cEino-Ville Talvala        result.append("    Preview request:\n");
2783297daae9681004775012faba9181d65e097e00cEino-Ville Talvala        write(fd, result.string(), result.size());
279428b77a2b94b74665a47375b3fdb893b98d71269Eino-Ville Talvala        dump_indented_camera_metadata(mPreviewRequest, fd, 2, 6);
2803297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    } else {
2813297daae9681004775012faba9181d65e097e00cEino-Ville Talvala        result.append("    Preview request: undefined\n");
2823297daae9681004775012faba9181d65e097e00cEino-Ville Talvala        write(fd, result.string(), result.size());
2833297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    }
2843297daae9681004775012faba9181d65e097e00cEino-Ville Talvala
2853297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    if (mCaptureRequest != NULL) {
2863297daae9681004775012faba9181d65e097e00cEino-Ville Talvala        result = "    Capture request:\n";
2873297daae9681004775012faba9181d65e097e00cEino-Ville Talvala        write(fd, result.string(), result.size());
288428b77a2b94b74665a47375b3fdb893b98d71269Eino-Ville Talvala        dump_indented_camera_metadata(mCaptureRequest, fd, 2, 6);
2893297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    } else {
2903297daae9681004775012faba9181d65e097e00cEino-Ville Talvala        result = "    Capture request: undefined\n";
2913297daae9681004775012faba9181d65e097e00cEino-Ville Talvala        write(fd, result.string(), result.size());
2923297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    }
2933297daae9681004775012faba9181d65e097e00cEino-Ville Talvala
294428b77a2b94b74665a47375b3fdb893b98d71269Eino-Ville Talvala    if (mRecordingRequest != NULL) {
295428b77a2b94b74665a47375b3fdb893b98d71269Eino-Ville Talvala        result = "    Recording request:\n";
296428b77a2b94b74665a47375b3fdb893b98d71269Eino-Ville Talvala        write(fd, result.string(), result.size());
297428b77a2b94b74665a47375b3fdb893b98d71269Eino-Ville Talvala        dump_indented_camera_metadata(mRecordingRequest, fd, 2, 6);
298428b77a2b94b74665a47375b3fdb893b98d71269Eino-Ville Talvala    } else {
299428b77a2b94b74665a47375b3fdb893b98d71269Eino-Ville Talvala        result = "    Recording request: undefined\n";
300428b77a2b94b74665a47375b3fdb893b98d71269Eino-Ville Talvala        write(fd, result.string(), result.size());
301428b77a2b94b74665a47375b3fdb893b98d71269Eino-Ville Talvala    }
302428b77a2b94b74665a47375b3fdb893b98d71269Eino-Ville Talvala
3033297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    result = "  Device dump:\n";
304611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala    write(fd, result.string(), result.size());
3057f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
3063297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    status_t res = mDevice->dump(fd, args);
3073297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    if (res != OK) {
3083297daae9681004775012faba9181d65e097e00cEino-Ville Talvala        result = String8::format("   Error dumping device: %s (%d)",
3093297daae9681004775012faba9181d65e097e00cEino-Ville Talvala                strerror(-res), res);
3103297daae9681004775012faba9181d65e097e00cEino-Ville Talvala        write(fd, result.string(), result.size());
3113297daae9681004775012faba9181d65e097e00cEino-Ville Talvala    }
3127f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala
3137f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala#undef CASE_APPEND_ENUM
314611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala    return NO_ERROR;
31561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
31661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
3174ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvalaconst char* Camera2Client::getStateName(State state) {
3184ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala#define CASE_ENUM_TO_CHAR(x) case x: return(#x); break;
3194ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala    switch(state) {
3204ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala        CASE_ENUM_TO_CHAR(NOT_INITIALIZED)
3214ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala        CASE_ENUM_TO_CHAR(STOPPED)
3224ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala        CASE_ENUM_TO_CHAR(WAITING_FOR_PREVIEW_WINDOW)
3234ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala        CASE_ENUM_TO_CHAR(PREVIEW)
3244ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala        CASE_ENUM_TO_CHAR(RECORD)
3254ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala        CASE_ENUM_TO_CHAR(STILL_CAPTURE)
3264ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala        CASE_ENUM_TO_CHAR(VIDEO_SNAPSHOT)
3274ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala        default:
3284ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala            return "Unknown state!";
3294ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala            break;
3304ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala    }
3314ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala#undef CASE_ENUM_TO_CHAR
3324ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala}
3334ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala
33461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala// ICamera interface
33561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
33661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::disconnect() {
337a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
3389e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala    ALOGV("%s: E", __FUNCTION__);
339ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
340ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala
341f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    if (mDevice == 0) return;
342f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
343ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    stopPreviewLocked();
3446db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala
345d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    mDevice->waitUntilDrained();
346d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
347d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    if (mPreviewStreamId != NO_STREAM) {
3486db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        mDevice->deleteStream(mPreviewStreamId);
349d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        mPreviewStreamId = NO_STREAM;
350d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    }
351d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
352d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    if (mCaptureStreamId != NO_STREAM) {
353d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        mDevice->deleteStream(mCaptureStreamId);
354d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        mCaptureStreamId = NO_STREAM;
3556db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    }
356f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
357898a9a9b867e5d209671feee4c92266f90a55aa3Eino-Ville Talvala    if (mRecordingStreamId != NO_STREAM) {
358898a9a9b867e5d209671feee4c92266f90a55aa3Eino-Ville Talvala        mDevice->deleteStream(mRecordingStreamId);
359898a9a9b867e5d209671feee4c92266f90a55aa3Eino-Ville Talvala        mRecordingStreamId = NO_STREAM;
360898a9a9b867e5d209671feee4c92266f90a55aa3Eino-Ville Talvala    }
361898a9a9b867e5d209671feee4c92266f90a55aa3Eino-Ville Talvala
36261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala    CameraService::Client::disconnect();
36361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
36461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
36561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::connect(const sp<ICameraClient>& client) {
366a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
3679e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala    ALOGV("%s: E", __FUNCTION__);
368ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
369ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala
3709cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (mClientPid != 0 && getCallingPid() != mClientPid) {
3719cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        ALOGE("%s: Camera %d: Connection attempt from pid %d; "
3729cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                "current locked to pid %d", __FUNCTION__,
3739cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                mCameraId, getCallingPid(), mClientPid);
3749cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        return BAD_VALUE;
3759cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
3769cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
3779cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    mClientPid = getCallingPid();
3789cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    mCameraClient = client;
3799cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
3809cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    return OK;
38161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
38261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
38361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::lock() {
384a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
3859e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala    ALOGV("%s: E", __FUNCTION__);
386ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
3879cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    ALOGV("%s: Camera %d: Lock call from pid %d; current client pid %d",
3889cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            __FUNCTION__, mCameraId, getCallingPid(), mClientPid);
389ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala
3909cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (mClientPid == 0) {
3919cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        mClientPid = getCallingPid();
3929cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        return OK;
3939cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
3949cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
3959cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (mClientPid != getCallingPid()) {
3969cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        ALOGE("%s: Camera %d: Lock call from pid %d; currently locked to pid %d",
3979cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                __FUNCTION__, mCameraId, getCallingPid(), mClientPid);
3989cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        return EBUSY;
3999cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
4009cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
4019cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    return OK;
40261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
40361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
40461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::unlock() {
405a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
4069e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala    ALOGV("%s: E", __FUNCTION__);
407ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
4089cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    ALOGV("%s: Camera %d: Unlock call from pid %d; current client pid %d",
4099cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            __FUNCTION__, mCameraId, getCallingPid(), mClientPid);
410ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala
4119cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    // TODO: Check for uninterruptable conditions
4129cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
4139cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (mClientPid == getCallingPid()) {
4149cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        mClientPid = 0;
4159cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        mCameraClient.clear();
4169cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        return OK;
4179cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
4189cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
4199cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    ALOGE("%s: Camera %d: Unlock call from pid %d; currently locked to pid %d",
4209cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            __FUNCTION__, mCameraId, getCallingPid(), mClientPid);
4219cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    return EBUSY;
42261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
42361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
4246db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvalastatus_t Camera2Client::setPreviewDisplay(
4256db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        const sp<Surface>& surface) {
426a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
4279e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala    ALOGV("%s: E", __FUNCTION__);
428ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
429ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala
4306db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    sp<IBinder> binder;
4316db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    sp<ANativeWindow> window;
4326db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    if (surface != 0) {
4336db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        binder = surface->asBinder();
4346db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        window = surface;
4356db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    }
4366db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala
437d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    return setPreviewWindowLocked(binder,window);
43861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
43961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
4406db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvalastatus_t Camera2Client::setPreviewTexture(
4416db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        const sp<ISurfaceTexture>& surfaceTexture) {
442a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
4439e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala    ALOGV("%s: E", __FUNCTION__);
444ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
445ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala
4466db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    sp<IBinder> binder;
4476db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    sp<ANativeWindow> window;
4486db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    if (surfaceTexture != 0) {
4496db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        binder = surfaceTexture->asBinder();
4506db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        window = new SurfaceTextureClient(surfaceTexture);
4516db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    }
452d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    return setPreviewWindowLocked(binder, window);
4536db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala}
4546db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala
455d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvalastatus_t Camera2Client::setPreviewWindowLocked(const sp<IBinder>& binder,
456be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        sp<ANativeWindow> window) {
457a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
4586db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    status_t res;
4596db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala
4606db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    if (binder == mPreviewSurface) {
4619e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala        ALOGV("%s: Camera %d: New window is same as old window",
4629e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala                __FUNCTION__, mCameraId);
4636db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        return NO_ERROR;
4646db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    }
4656db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala
4669cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    switch (mState) {
4679cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        case NOT_INITIALIZED:
4689cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        case RECORD:
4699cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        case STILL_CAPTURE:
4709cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        case VIDEO_SNAPSHOT:
4719cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            ALOGE("%s: Camera %d: Cannot set preview display while in state %s",
4729cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    __FUNCTION__, mCameraId, getStateName(mState));
4739cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            return INVALID_OPERATION;
4749cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        case STOPPED:
4759cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        case WAITING_FOR_PREVIEW_WINDOW:
4769cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            // OK
4779cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            break;
4789cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        case PREVIEW:
4799cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            // Already running preview - need to stop and create a new stream
4809cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            // TODO: Optimize this so that we don't wait for old stream to drain
4819cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            // before spinning up new stream
4829cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            mDevice->setStreamingRequest(NULL);
4839cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            mState = WAITING_FOR_PREVIEW_WINDOW;
4849cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            break;
4859cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
4869cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
487d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    if (mPreviewStreamId != NO_STREAM) {
488be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        res = mDevice->waitUntilDrained();
489be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        if (res != OK) {
490be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ALOGE("%s: Error waiting for preview to drain: %s (%d)",
491be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                    __FUNCTION__, strerror(-res), res);
492be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            return res;
493be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        }
4946db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        res = mDevice->deleteStream(mPreviewStreamId);
4956db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        if (res != OK) {
496be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ALOGE("%s: Unable to delete old preview stream: %s (%d)",
497be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                    __FUNCTION__, strerror(-res), res);
4986db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala            return res;
4996db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        }
500be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        mPreviewStreamId = NO_STREAM;
5016db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    }
5026db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala
503bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala    mPreviewSurface = binder;
504be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    mPreviewWindow = window;
505bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala
5066db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    if (mState == WAITING_FOR_PREVIEW_WINDOW) {
507d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        return startPreviewLocked();
5086db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    }
5096db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala
5106db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    return OK;
51161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
51261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
51361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::setPreviewCallbackFlag(int flag) {
514a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
515ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
51661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
51761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
51861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::startPreview() {
519a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
5209e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala    ALOGV("%s: E", __FUNCTION__);
521ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
522d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    return startPreviewLocked();
523d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala}
524ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala
525d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvalastatus_t Camera2Client::startPreviewLocked() {
526d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    ATRACE_CALL();
5276db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    status_t res;
5284ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala    if (mState >= PREVIEW) {
5294ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala        ALOGE("%s: Can't start preview in state %s",
5304ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala                __FUNCTION__, getStateName(mState));
5314ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala        return INVALID_OPERATION;
5324ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala    }
5336db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala
534be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (mPreviewWindow == 0) {
5356db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        mState = WAITING_FOR_PREVIEW_WINDOW;
5366db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        return OK;
5376db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    }
538be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    mState = STOPPED;
5396db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala
540836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    LockedParameters::Key k(mParameters);
5419cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
542836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    res = updatePreviewStream(k.mParameters);
543be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) {
544be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        ALOGE("%s: Camera %d: Unable to update preview stream: %s (%d)",
545be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                __FUNCTION__, mCameraId, strerror(-res), res);
546be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        return res;
5476db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    }
5486db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala
549be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (mPreviewRequest == NULL) {
550836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        res = updatePreviewRequest(k.mParameters);
551be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        if (res != OK) {
552be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ALOGE("%s: Camera %d: Unable to create preview request: %s (%d)",
553be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                    __FUNCTION__, mCameraId, strerror(-res), res);
554be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            return res;
555be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        }
5566db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    }
5576db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala
558be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(mPreviewRequest,
559be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_REQUEST_OUTPUT_STREAMS,
560be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            &mPreviewStreamId, 1);
5616db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    if (res != OK) {
5626db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        ALOGE("%s: Camera %d: Unable to set up preview request: %s (%d)",
5636db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala                __FUNCTION__, mCameraId, strerror(-res), res);
564be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        return res;
565be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
566be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = sort_camera_metadata(mPreviewRequest);
567be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) {
568be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        ALOGE("%s: Camera %d: Error sorting preview request: %s (%d)",
569be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                __FUNCTION__, mCameraId, strerror(-res), res);
5706db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        return res;
5716db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    }
5726db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala
5736db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    res = mDevice->setStreamingRequest(mPreviewRequest);
5746db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    if (res != OK) {
575bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala        ALOGE("%s: Camera %d: Unable to set preview request to start preview: "
576bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                "%s (%d)",
5776db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala                __FUNCTION__, mCameraId, strerror(-res), res);
5786db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        return res;
5796db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    }
5806db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    mState = PREVIEW;
5816db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala
5826db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    return OK;
58361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
58461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
58561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::stopPreview() {
586a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
5879e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala    ALOGV("%s: E", __FUNCTION__);
588ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
589ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    stopPreviewLocked();
590ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala}
591ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala
592ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvalavoid Camera2Client::stopPreviewLocked() {
593ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    ATRACE_CALL();
594d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    switch (mState) {
595d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        case NOT_INITIALIZED:
596d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            ALOGE("%s: Camera %d: Call before initialized",
597d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                    __FUNCTION__, mCameraId);
598d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            break;
599d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        case STOPPED:
600d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            break;
601d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        case STILL_CAPTURE:
602d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            ALOGE("%s: Camera %d: Cannot stop preview during still capture.",
603d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                    __FUNCTION__, mCameraId);
604d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            break;
605d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        case RECORD:
606d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            // TODO: Handle record stop here
607d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        case PREVIEW:
608d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            mDevice->setStreamingRequest(NULL);
6092267106c98f461b730c772a913da946c391a178cEino-Ville Talvala            mDevice->waitUntilDrained();
610d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        case WAITING_FOR_PREVIEW_WINDOW:
611d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            mState = STOPPED;
612d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            break;
613d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        default:
614d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            ALOGE("%s: Camera %d: Unknown state %d", __FUNCTION__, mCameraId,
615d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                    mState);
616d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    }
61761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
61861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
61961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalabool Camera2Client::previewEnabled() {
620a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
621ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
6226db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    return mState == PREVIEW;
62361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
62461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
62561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::storeMetaDataInBuffers(bool enabled) {
626a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
627ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
62878822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala    switch (mState) {
62978822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        case RECORD:
63078822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        case VIDEO_SNAPSHOT:
63178822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala            ALOGE("%s: Camera %d: Can't be called in state %s",
63278822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala                    __FUNCTION__, mCameraId, getStateName(mState));
63378822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala            return INVALID_OPERATION;
63478822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        default:
63578822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala            // OK
63678822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala            break;
63778822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala    }
638836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    LockedParameters::Key k(mParameters);
63978822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala
640836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.storeMetadataInBuffers = enabled;
64178822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala
64278822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala    return OK;
64361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
64461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
64561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::startRecording() {
646a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
6479e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala    ALOGV("%s: E", __FUNCTION__);
648ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
6499cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    status_t res;
6509cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    switch (mState) {
6519cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        case STOPPED:
6529cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            res = startPreviewLocked();
6539cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            if (res != OK) return res;
6549cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            break;
6559cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        case PREVIEW:
6569cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            // Ready to go
6579cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            break;
6589cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        case RECORD:
6599cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        case VIDEO_SNAPSHOT:
6609cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            // OK to call this when recording is already on
6619cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            return OK;
6629cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            break;
6639cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        default:
6649cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            ALOGE("%s: Camera %d: Can't start recording in state %s",
6659cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    __FUNCTION__, mCameraId, getStateName(mState));
6669cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            return INVALID_OPERATION;
6679cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    };
6689cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
669836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    LockedParameters::Key k(mParameters);
6709cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
671836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (!k.mParameters.storeMetadataInBuffers) {
67278822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        ALOGE("%s: Camera %d: Recording only supported in metadata mode, but "
67378822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala                "non-metadata recording mode requested!", __FUNCTION__,
67478822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala                mCameraId);
67578822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        return INVALID_OPERATION;
67678822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala    }
67778822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala
678836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    res = updateRecordingStream(k.mParameters);
6799cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (res != OK) {
6809cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        ALOGE("%s: Camera %d: Unable to update recording stream: %s (%d)",
6819cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                __FUNCTION__, mCameraId, strerror(-res), res);
6829cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        return res;
6839cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
6849cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
6859cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (mRecordingRequest == NULL) {
686836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        res = updateRecordingRequest(k.mParameters);
6879cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        if (res != OK) {
6889cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            ALOGE("%s: Camera %d: Unable to create recording request: %s (%d)",
6899cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    __FUNCTION__, mCameraId, strerror(-res), res);
6909cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            return res;
6919cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        }
6929cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
6939cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
6949cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    uint8_t outputStreams[2] = { mPreviewStreamId, mRecordingStreamId };
6959cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    res = updateEntry(mRecordingRequest,
6969cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            ANDROID_REQUEST_OUTPUT_STREAMS,
6979cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            outputStreams, 2);
6989cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (res != OK) {
6999cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        ALOGE("%s: Camera %d: Unable to set up recording request: %s (%d)",
7009cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                __FUNCTION__, mCameraId, strerror(-res), res);
7019cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        return res;
7029cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
7039cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    res = sort_camera_metadata(mRecordingRequest);
7049cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (res != OK) {
7059cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        ALOGE("%s: Camera %d: Error sorting recording request: %s (%d)",
7069cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                __FUNCTION__, mCameraId, strerror(-res), res);
7079cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        return res;
7089cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
7099cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
7109cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    res = mDevice->setStreamingRequest(mRecordingRequest);
7119cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (res != OK) {
7129cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        ALOGE("%s: Camera %d: Unable to set recording request to start "
7139cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                "recording: %s (%d)", __FUNCTION__, mCameraId,
7149cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                strerror(-res), res);
7159cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        return res;
7169cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
7179cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    mState = RECORD;
7189cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
7199cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    return OK;
72061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
72161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
72261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::stopRecording() {
723a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
7249e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala    ALOGV("%s: E", __FUNCTION__);
725ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
7269cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    status_t res;
7279cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    switch (mState) {
7289cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        case RECORD:
7299cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            // OK to stop
7309cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            break;
7319cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        case STOPPED:
7329cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        case PREVIEW:
7339cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        case STILL_CAPTURE:
7349cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        case VIDEO_SNAPSHOT:
7359cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        default:
7369cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            ALOGE("%s: Camera %d: Can't stop recording in state %s",
7379cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    __FUNCTION__, mCameraId, getStateName(mState));
7389cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            return;
7399cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    };
7409cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
7419cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    // Back to preview. Since record can only be reached through preview,
7429cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    // all preview stream setup should be up to date.
7439cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    res = mDevice->setStreamingRequest(mPreviewRequest);
7449cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (res != OK) {
7459cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        ALOGE("%s: Camera %d: Unable to switch back to preview request: "
7469cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                "%s (%d)", __FUNCTION__, mCameraId, strerror(-res), res);
7479cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        return;
7489cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
7499cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
7509cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    // TODO: Should recording heap be freed? Can't do it yet since requests
7519cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    // could still be in flight.
7529cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
7539cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    mState = PREVIEW;
75461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
75561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
75661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalabool Camera2Client::recordingEnabled() {
757a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
758ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
7599cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    return (mState == RECORD || mState == VIDEO_SNAPSHOT);
76061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
76161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
76261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::releaseRecordingFrame(const sp<IMemory>& mem) {
763a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
764ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
7659cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    // Make sure this is for the current heap
7669cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    ssize_t offset;
7679cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    size_t size;
76878822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala    status_t res;
7699cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    sp<IMemoryHeap> heap = mem->getMemory(&offset, &size);
7709cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (heap->getHeapID() != mRecordingHeap->mHeap->getHeapID()) {
7719cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        ALOGW("%s: Camera %d: Mismatched heap ID, ignoring release "
7729cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                "(got %x, expected %x)", __FUNCTION__, mCameraId,
7739cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                heap->getHeapID(), mRecordingHeap->mHeap->getHeapID());
7749cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        return;
7759cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
77678822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala    uint8_t *data = (uint8_t*)heap->getBase() + offset;
77778822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala    uint32_t type = *(uint32_t*)data;
77878822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala    if (type != kMetadataBufferTypeGrallocSource) {
77978822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        ALOGE("%s: Camera %d: Recording frame type invalid (got %x, expected %x)",
78078822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala                __FUNCTION__, mCameraId, type, kMetadataBufferTypeGrallocSource);
78178822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        return;
78278822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala    }
78378822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala    buffer_handle_t imgBuffer = *(buffer_handle_t*)(data + 4);
78478822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala    ALOGV("%s: Camera %d: Freeing buffer_handle_t %p", __FUNCTION__, mCameraId,
785803cbf6190f16f7b2c43cbc51d0df21ec888abddEino-Ville Talvala            imgBuffer);
78678822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala    res = mRecordingConsumer->freeBuffer(imgBuffer);
78778822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala    if (res != OK) {
78878822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        ALOGE("%s: Camera %d: Unable to free recording frame (buffer_handle_t: %p):"
78978822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala                "%s (%d)",
79078822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala                __FUNCTION__, mCameraId, imgBuffer, strerror(-res), res);
79178822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        return;
79278822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala    }
79378822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala
7949cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    mRecordingHeapFree++;
79561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
79661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
79761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::autoFocus() {
798a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
799ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
8006db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    return OK;
80161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
80261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
80361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::cancelAutoFocus() {
804a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
805ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
8066db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    return OK;
80761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
80861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
80961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::takePicture(int msgType) {
810a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
811ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
812d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    status_t res;
813d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
814d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    switch (mState) {
815d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        case NOT_INITIALIZED:
816d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        case STOPPED:
817d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        case WAITING_FOR_PREVIEW_WINDOW:
818d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            ALOGE("%s: Camera %d: Cannot take picture without preview enabled",
819d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                    __FUNCTION__, mCameraId);
820d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            return INVALID_OPERATION;
821d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        case PREVIEW:
822d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        case RECORD:
823d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            // Good to go for takePicture
824d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            break;
825d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        case STILL_CAPTURE:
826d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        case VIDEO_SNAPSHOT:
827d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            ALOGE("%s: Camera %d: Already taking a picture",
828d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                    __FUNCTION__, mCameraId);
829d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            return INVALID_OPERATION;
830d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    }
831d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
832836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    LockedParameters::Key k(mParameters);
833d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
834836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    res = updateCaptureStream(k.mParameters);
8354ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala    if (res != OK) {
836be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        ALOGE("%s: Camera %d: Can't set up still image stream: %s (%d)",
837be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                __FUNCTION__, mCameraId, strerror(-res), res);
8384ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala        return res;
8394ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala    }
840d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
841d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    if (mCaptureRequest == NULL) {
842836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        res = updateCaptureRequest(k.mParameters);
8434ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala        if (res != OK) {
844be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ALOGE("%s: Camera %d: Can't create still image capture request: "
845be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                    "%s (%d)", __FUNCTION__, mCameraId, strerror(-res), res);
8464ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala            return res;
8474ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala        }
848d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    }
849d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
850d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    camera_metadata_entry_t outputStreams;
8519cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (mState == PREVIEW) {
8529cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        uint8_t streamIds[2] = { mPreviewStreamId, mCaptureStreamId };
8539cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        res = updateEntry(mCaptureRequest, ANDROID_REQUEST_OUTPUT_STREAMS,
8549cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                &streamIds, 2);
8559cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    } else if (mState == RECORD) {
8569cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        uint8_t streamIds[3] = { mPreviewStreamId, mRecordingStreamId,
8579cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                                 mCaptureStreamId };
8589cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        res = updateEntry(mCaptureRequest, ANDROID_REQUEST_OUTPUT_STREAMS,
8599cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                &streamIds, 3);
8609cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
8619cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
862d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    if (res != OK) {
863d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        ALOGE("%s: Camera %d: Unable to set up still image capture request: "
864d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                "%s (%d)",
865d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                __FUNCTION__, mCameraId, strerror(-res), res);
866d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        return res;
867d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    }
868be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = sort_camera_metadata(mCaptureRequest);
869be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) {
870be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        ALOGE("%s: Camera %d: Unable to sort capture request: %s (%d)",
871be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                __FUNCTION__, mCameraId, strerror(-res), res);
872be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        return res;
873be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
874d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
875d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    camera_metadata_t *captureCopy = clone_camera_metadata(mCaptureRequest);
876d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    if (captureCopy == NULL) {
877d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        ALOGE("%s: Camera %d: Unable to copy capture request for HAL device",
878d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                __FUNCTION__, mCameraId);
879d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        return NO_MEMORY;
880d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    }
881d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
882d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    if (mState == PREVIEW) {
883d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        res = mDevice->setStreamingRequest(NULL);
884d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        if (res != OK) {
885d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            ALOGE("%s: Camera %d: Unable to stop preview for still capture: "
886d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                    "%s (%d)",
887d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                    __FUNCTION__, mCameraId, strerror(-res), res);
888d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            return res;
889d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        }
890d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    }
8919cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    // TODO: Capture should be atomic with setStreamingRequest here
892d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    res = mDevice->capture(captureCopy);
893d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    if (res != OK) {
894d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        ALOGE("%s: Camera %d: Unable to submit still image capture request: "
895d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                "%s (%d)",
896d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                __FUNCTION__, mCameraId, strerror(-res), res);
897d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        return res;
898d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    }
899d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
900d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    switch (mState) {
901d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        case PREVIEW:
902d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            mState = STILL_CAPTURE;
903d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            break;
904d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        case RECORD:
905d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            mState = VIDEO_SNAPSHOT;
906d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            break;
907d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        default:
908d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            ALOGE("%s: Camera %d: Unknown state for still capture!",
909d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                    __FUNCTION__, mCameraId);
910d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            return INVALID_OPERATION;
911d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    }
912d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
913d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    return OK;
91461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
91561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
91661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::setParameters(const String8& params) {
917a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
9189e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala    ALOGV("%s: E", __FUNCTION__);
919ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
920836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    LockedParameters::Key k(mParameters);
9216861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    status_t res;
9226861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
9236861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    CameraParameters newParams(params);
9246861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
9256861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // TODO: Currently ignoring any changes to supposedly read-only
9266861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // parameters such as supported preview sizes, etc. Should probably
9276861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // produce an error if they're changed.
9286861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
9296861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    /** Extract and verify new parameters */
9306861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
9316861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    size_t i;
9326861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
9336861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // PREVIEW_SIZE
9346861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    int previewWidth, previewHeight;
9356861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    newParams.getPreviewSize(&previewWidth, &previewHeight);
9366861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
937836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (previewWidth != k.mParameters.previewWidth ||
938836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            previewHeight != k.mParameters.previewHeight) {
9396861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (mState >= PREVIEW) {
9406861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Preview size cannot be updated when preview "
9419cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    "is active! (Currently %d x %d, requested %d x %d",
9429cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    __FUNCTION__,
943836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                    k.mParameters.previewWidth, k.mParameters.previewHeight,
9449cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    previewWidth, previewHeight);
9456861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
9466861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
9476861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        camera_metadata_entry_t availablePreviewSizes =
9486861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            staticInfo(ANDROID_SCALER_AVAILABLE_PROCESSED_SIZES);
9496861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        for (i = 0; i < availablePreviewSizes.count; i += 2 ) {
9506861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            if (availablePreviewSizes.data.i32[i] == previewWidth &&
9516861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    availablePreviewSizes.data.i32[i+1] == previewHeight) break;
9526861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
9536861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (i == availablePreviewSizes.count) {
9546861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Requested preview size %d x %d is not supported",
9556861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    __FUNCTION__, previewWidth, previewHeight);
9566861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
9576861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
9586861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
9596861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
9606861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // PREVIEW_FPS_RANGE
96111b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala    int previewFpsRange[2];
96211b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala    int previewFps = 0;
9636861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    bool fpsRangeChanged = false;
96411b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala    newParams.getPreviewFpsRange(&previewFpsRange[0], &previewFpsRange[1]);
965836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (previewFpsRange[0] != k.mParameters.previewFpsRange[0] ||
966836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            previewFpsRange[1] != k.mParameters.previewFpsRange[1]) {
9676861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        fpsRangeChanged = true;
9686861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        camera_metadata_entry_t availablePreviewFpsRanges =
9696861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            staticInfo(ANDROID_CONTROL_AE_AVAILABLE_TARGET_FPS_RANGES, 2);
9706861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        for (i = 0; i < availablePreviewFpsRanges.count; i += 2) {
9716861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            if ((availablePreviewFpsRanges.data.i32[i] ==
97211b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala                    previewFpsRange[0]) &&
9736861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                (availablePreviewFpsRanges.data.i32[i+1] ==
97411b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala                    previewFpsRange[1]) ) {
9756861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                break;
9766861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            }
9776861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
9786861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (i == availablePreviewFpsRanges.count) {
9796861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Requested preview FPS range %d - %d is not supported",
98011b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala                __FUNCTION__, previewFpsRange[0], previewFpsRange[1]);
9816861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
9826861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
98311b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala        previewFps = previewFpsRange[0];
9846861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
9856861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
9866861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // PREVIEW_FORMAT
9876861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    int previewFormat = formatStringToEnum(newParams.getPreviewFormat());
988836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (previewFormat != k.mParameters.previewFormat) {
9896861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (mState >= PREVIEW) {
9906861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Preview format cannot be updated when preview "
9916861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    "is active!", __FUNCTION__);
9926861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
9936861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
9946861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        camera_metadata_entry_t availableFormats =
9956861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            staticInfo(ANDROID_SCALER_AVAILABLE_FORMATS);
9966861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        for (i = 0; i < availableFormats.count; i++) {
9976861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            if (availableFormats.data.i32[i] == previewFormat) break;
9986861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
9996861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (i == availableFormats.count) {
10006861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Requested preview format %s (0x%x) is not supported",
10016861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    __FUNCTION__, newParams.getPreviewFormat(), previewFormat);
10026861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
10036861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
10046861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
10056861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
10066861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // PREVIEW_FRAME_RATE
10076861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // Deprecated, only use if the preview fps range is unchanged this time.
10086861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // The single-value FPS is the same as the minimum of the range.
10096861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    if (!fpsRangeChanged) {
10106861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        previewFps = newParams.getPreviewFrameRate();
1011836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        if (previewFps != k.mParameters.previewFps) {
10126861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            camera_metadata_entry_t availableFrameRates =
10136861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                staticInfo(ANDROID_CONTROL_AE_AVAILABLE_TARGET_FPS_RANGES);
10146861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            for (i = 0; i < availableFrameRates.count; i+=2) {
10156861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                if (availableFrameRates.data.i32[i] == previewFps) break;
10166861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            }
10176861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            if (i == availableFrameRates.count) {
10186861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                ALOGE("%s: Requested preview frame rate %d is not supported",
10196861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                        __FUNCTION__, previewFps);
10206861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                return BAD_VALUE;
10216861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            }
102211b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala            previewFpsRange[0] = availableFrameRates.data.i32[i];
102311b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala            previewFpsRange[1] = availableFrameRates.data.i32[i+1];
10246861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
10256861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
10266861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
10276861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // PICTURE_SIZE
10286861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    int pictureWidth, pictureHeight;
10296861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    newParams.getPictureSize(&pictureWidth, &pictureHeight);
1030836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (pictureWidth == k.mParameters.pictureWidth ||
1031836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            pictureHeight == k.mParameters.pictureHeight) {
10326861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        camera_metadata_entry_t availablePictureSizes =
10336861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            staticInfo(ANDROID_SCALER_AVAILABLE_JPEG_SIZES);
10346861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        for (i = 0; i < availablePictureSizes.count; i+=2) {
10356861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            if (availablePictureSizes.data.i32[i] == pictureWidth &&
10366861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    availablePictureSizes.data.i32[i+1] == pictureHeight) break;
10376861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
10386861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (i == availablePictureSizes.count) {
10396861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Requested picture size %d x %d is not supported",
10406861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    __FUNCTION__, pictureWidth, pictureHeight);
10416861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
10426861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
10436861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
10446861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
10456861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // JPEG_THUMBNAIL_WIDTH/HEIGHT
104611b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala    int jpegThumbSize[2];
104711b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala    jpegThumbSize[0] =
10486861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            newParams.getInt(CameraParameters::KEY_JPEG_THUMBNAIL_WIDTH);
104911b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala    jpegThumbSize[1] =
10506861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            newParams.getInt(CameraParameters::KEY_JPEG_THUMBNAIL_HEIGHT);
1051836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (jpegThumbSize[0] != k.mParameters.jpegThumbSize[0] ||
1052836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            jpegThumbSize[1] != k.mParameters.jpegThumbSize[1]) {
10536861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        camera_metadata_entry_t availableJpegThumbSizes =
10546861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            staticInfo(ANDROID_JPEG_AVAILABLE_THUMBNAIL_SIZES);
10556861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        for (i = 0; i < availableJpegThumbSizes.count; i+=2) {
105611b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala            if (availableJpegThumbSizes.data.i32[i] == jpegThumbSize[0] &&
105711b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala                    availableJpegThumbSizes.data.i32[i+1] == jpegThumbSize[1]) {
10586861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                break;
10596861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            }
10606861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
10616861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (i == availableJpegThumbSizes.count) {
10626861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Requested JPEG thumbnail size %d x %d is not supported",
106311b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala                    __FUNCTION__, jpegThumbSize[0], jpegThumbSize[1]);
10646861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
10656861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
10666861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
10676861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
10686861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // JPEG_THUMBNAIL_QUALITY
10696861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    int jpegThumbQuality =
10706861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            newParams.getInt(CameraParameters::KEY_JPEG_THUMBNAIL_QUALITY);
10716861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    if (jpegThumbQuality < 0 || jpegThumbQuality > 100) {
10726861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        ALOGE("%s: Requested JPEG thumbnail quality %d is not supported",
10736861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                __FUNCTION__, jpegThumbQuality);
10746861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        return BAD_VALUE;
10756861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
10766861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
10776861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // JPEG_QUALITY
10786861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    int jpegQuality =
10796861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            newParams.getInt(CameraParameters::KEY_JPEG_QUALITY);
10806861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    if (jpegQuality < 0 || jpegQuality > 100) {
10816861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        ALOGE("%s: Requested JPEG quality %d is not supported",
10826861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                __FUNCTION__, jpegQuality);
10836861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        return BAD_VALUE;
10846861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
10856861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
10866861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // ROTATION
10876861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    int jpegRotation =
10886861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            newParams.getInt(CameraParameters::KEY_ROTATION);
10896861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    if (jpegRotation != 0 &&
10906861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            jpegRotation != 90 &&
10916861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            jpegRotation != 180 &&
10926861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            jpegRotation != 270) {
10936861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        ALOGE("%s: Requested picture rotation angle %d is not supported",
10946861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                __FUNCTION__, jpegRotation);
10956861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        return BAD_VALUE;
10966861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
10976861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
10986861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // GPS
10996861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    bool gpsEnabled = false;
110011b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala    double gpsCoordinates[3] = {0,0,0};
11016861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    int64_t gpsTimestamp = 0;
11026861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    String8 gpsProcessingMethod;
11036861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    const char *gpsLatStr =
11046861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            newParams.get(CameraParameters::KEY_GPS_LATITUDE);
11056861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    if (gpsLatStr != NULL) {
11066861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        const char *gpsLongStr =
11076861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                newParams.get(CameraParameters::KEY_GPS_LONGITUDE);
11086861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        const char *gpsAltitudeStr =
11096861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                newParams.get(CameraParameters::KEY_GPS_ALTITUDE);
11106861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        const char *gpsTimeStr =
11116861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                newParams.get(CameraParameters::KEY_GPS_TIMESTAMP);
11126861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        const char *gpsProcMethodStr =
11136861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                newParams.get(CameraParameters::KEY_GPS_PROCESSING_METHOD);
11146861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (gpsLongStr == NULL ||
11156861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                gpsAltitudeStr == NULL ||
11166861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                gpsTimeStr == NULL ||
11176861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                gpsProcMethodStr == NULL) {
11186861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Incomplete set of GPS parameters provided",
11196861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    __FUNCTION__);
11206861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
11216861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
11226861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        char *endPtr;
11236861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        errno = 0;
112411b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala        gpsCoordinates[0] = strtod(gpsLatStr, &endPtr);
11256861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (errno || endPtr == gpsLatStr) {
11266861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Malformed GPS latitude: %s", __FUNCTION__, gpsLatStr);
11276861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
11286861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
11296861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        errno = 0;
113011b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala        gpsCoordinates[1] = strtod(gpsLongStr, &endPtr);
11316861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (errno || endPtr == gpsLongStr) {
11326861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Malformed GPS longitude: %s", __FUNCTION__, gpsLongStr);
11336861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
11346861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
11356861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        errno = 0;
113611b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala        gpsCoordinates[2] = strtod(gpsAltitudeStr, &endPtr);
11376861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (errno || endPtr == gpsAltitudeStr) {
11386861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Malformed GPS altitude: %s", __FUNCTION__,
11396861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    gpsAltitudeStr);
11406861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
11416861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
11426861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        errno = 0;
11436861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        gpsTimestamp = strtoll(gpsTimeStr, &endPtr, 10);
11446861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (errno || endPtr == gpsTimeStr) {
11456861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Malformed GPS timestamp: %s", __FUNCTION__, gpsTimeStr);
11466861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
11476861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
11486861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        gpsProcessingMethod = gpsProcMethodStr;
11496861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
11506861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        gpsEnabled = true;
11516861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
11526861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
11536861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // WHITE_BALANCE
11546861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    int wbMode = wbModeStringToEnum(
11556861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        newParams.get(CameraParameters::KEY_WHITE_BALANCE) );
1156836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (wbMode != k.mParameters.wbMode) {
11576861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        camera_metadata_entry_t availableWbModes =
11586861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            staticInfo(ANDROID_CONTROL_AWB_AVAILABLE_MODES);
11596861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        for (i = 0; i < availableWbModes.count; i++) {
11606861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            if (wbMode == availableWbModes.data.u8[i]) break;
11616861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
11626861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (i == availableWbModes.count) {
11636861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Requested white balance mode %s is not supported",
11646861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    __FUNCTION__,
11656861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    newParams.get(CameraParameters::KEY_WHITE_BALANCE));
11666861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
11676861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
11686861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
11696861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
11706861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // EFFECT
11716861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    int effectMode = effectModeStringToEnum(
11726861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        newParams.get(CameraParameters::KEY_EFFECT) );
1173836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (effectMode != k.mParameters.effectMode) {
11746861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        camera_metadata_entry_t availableEffectModes =
11756861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            staticInfo(ANDROID_CONTROL_AVAILABLE_EFFECTS);
11766861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        for (i = 0; i < availableEffectModes.count; i++) {
11776861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            if (effectMode == availableEffectModes.data.u8[i]) break;
11786861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
11796861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (i == availableEffectModes.count) {
11806861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Requested effect mode \"%s\" is not supported",
11816861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    __FUNCTION__,
11826861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    newParams.get(CameraParameters::KEY_EFFECT) );
11836861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
11846861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
11856861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
11866861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
11876861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // ANTIBANDING
11886861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    int antibandingMode = abModeStringToEnum(
11896861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        newParams.get(CameraParameters::KEY_ANTIBANDING) );
1190836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (antibandingMode != k.mParameters.antibandingMode) {
11916861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        camera_metadata_entry_t availableAbModes =
11926861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            staticInfo(ANDROID_CONTROL_AE_AVAILABLE_ANTIBANDING_MODES);
11936861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        for (i = 0; i < availableAbModes.count; i++) {
11946861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            if (antibandingMode == availableAbModes.data.u8[i]) break;
11956861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
11966861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (i == availableAbModes.count) {
11976861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Requested antibanding mode \"%s\" is not supported",
11986861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    __FUNCTION__,
11996861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    newParams.get(CameraParameters::KEY_ANTIBANDING));
12006861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
12016861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
12026861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
12036861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
12046861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // SCENE_MODE
12056861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    int sceneMode = sceneModeStringToEnum(
12066861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        newParams.get(CameraParameters::KEY_SCENE_MODE) );
1207836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (sceneMode != k.mParameters.sceneMode) {
12086861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        camera_metadata_entry_t availableSceneModes =
12096861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            staticInfo(ANDROID_CONTROL_AVAILABLE_SCENE_MODES);
12106861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        for (i = 0; i < availableSceneModes.count; i++) {
12116861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            if (sceneMode == availableSceneModes.data.u8[i]) break;
12126861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
12136861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (i == availableSceneModes.count) {
12146861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Requested scene mode \"%s\" is not supported",
12156861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    __FUNCTION__,
12166861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    newParams.get(CameraParameters::KEY_SCENE_MODE));
12176861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
12186861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
12196861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
12206861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
12216861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // FLASH_MODE
12226861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    Parameters::flashMode_t flashMode = flashModeStringToEnum(
12236861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        newParams.get(CameraParameters::KEY_FLASH_MODE) );
1224836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (flashMode != k.mParameters.flashMode) {
12256861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        camera_metadata_entry_t flashAvailable =
12266861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            staticInfo(ANDROID_FLASH_AVAILABLE, 1, 1);
12276861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (!flashAvailable.data.u8[0] &&
12286861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                flashMode != Parameters::FLASH_MODE_OFF) {
12296861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Requested flash mode \"%s\" is not supported: "
12306861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    "No flash on device", __FUNCTION__,
12316861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    newParams.get(CameraParameters::KEY_FLASH_MODE));
12326861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
12336861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        } else if (flashMode == Parameters::FLASH_MODE_RED_EYE) {
12346861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            camera_metadata_entry_t availableAeModes =
12356861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                staticInfo(ANDROID_CONTROL_AE_AVAILABLE_MODES);
12366861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            for (i = 0; i < availableAeModes.count; i++) {
12376861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                if (flashMode == availableAeModes.data.u8[i]) break;
12386861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            }
12396861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            if (i == availableAeModes.count) {
12406861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                ALOGE("%s: Requested flash mode \"%s\" is not supported",
12416861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                        __FUNCTION__,
12426861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                        newParams.get(CameraParameters::KEY_FLASH_MODE));
12436861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                return BAD_VALUE;
12446861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            }
12456861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        } else if (flashMode == -1) {
12466861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Requested flash mode \"%s\" is unknown",
12476861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    __FUNCTION__,
12486861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    newParams.get(CameraParameters::KEY_FLASH_MODE));
12496861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
12506861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
12516861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
12526861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
12536861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // FOCUS_MODE
12546861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    Parameters::focusMode_t focusMode = focusModeStringToEnum(
12556861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        newParams.get(CameraParameters::KEY_FOCUS_MODE));
1256836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (focusMode != k.mParameters.focusMode) {
12576861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (focusMode != Parameters::FOCUS_MODE_FIXED) {
12586861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            camera_metadata_entry_t minFocusDistance =
12596861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                staticInfo(ANDROID_LENS_MINIMUM_FOCUS_DISTANCE);
12606861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            if (minFocusDistance.data.f[0] == 0) {
12616861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                ALOGE("%s: Requested focus mode \"%s\" is not available: "
12626861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                        "fixed focus lens",
12636861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                        __FUNCTION__,
12646861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                        newParams.get(CameraParameters::KEY_FOCUS_MODE));
12656861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                return BAD_VALUE;
12666861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            } else if (focusMode != Parameters::FOCUS_MODE_INFINITY) {
12676861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                camera_metadata_entry_t availableFocusModes =
12686861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    staticInfo(ANDROID_CONTROL_AF_AVAILABLE_MODES);
12696861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                for (i = 0; i < availableFocusModes.count; i++) {
12706861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    if (focusMode == availableFocusModes.data.u8[i]) break;
12716861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                }
12726861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                if (i == availableFocusModes.count) {
12736861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    ALOGE("%s: Requested focus mode \"%s\" is not supported",
12746861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                            __FUNCTION__,
12756861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                            newParams.get(CameraParameters::KEY_FOCUS_MODE));
12766861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    return BAD_VALUE;
12776861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                }
12786861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            }
12796861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
12806861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
12816861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
12826861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // FOCUS_AREAS
12836861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    Vector<Parameters::Area> focusingAreas;
12846861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    res = parseAreas(newParams.get(CameraParameters::KEY_FOCUS_AREAS),
12856861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            &focusingAreas);
12866861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    size_t max3aRegions =
12876861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        (size_t)staticInfo(ANDROID_CONTROL_MAX_REGIONS, 1, 1).data.i32[0];
12886861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    if (res == OK) res = validateAreas(focusingAreas, max3aRegions);
12896861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    if (res != OK) {
12906861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        ALOGE("%s: Requested focus areas are malformed: %s",
12916861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                __FUNCTION__, newParams.get(CameraParameters::KEY_FOCUS_AREAS));
12926861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        return BAD_VALUE;
12936861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
12946861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
12956861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // EXPOSURE_COMPENSATION
12966861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    int exposureCompensation =
12976861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        newParams.getInt(CameraParameters::KEY_EXPOSURE_COMPENSATION);
12986861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    camera_metadata_entry_t exposureCompensationRange =
12996861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        staticInfo(ANDROID_CONTROL_AE_EXP_COMPENSATION_RANGE);
13006861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    if (exposureCompensation < exposureCompensationRange.data.i32[0] ||
13016861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            exposureCompensation > exposureCompensationRange.data.i32[1]) {
13026861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        ALOGE("%s: Requested exposure compensation index is out of bounds: %d",
13036861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                __FUNCTION__, exposureCompensation);
13046861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        return BAD_VALUE;
13056861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
13066861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
13076861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // AUTO_EXPOSURE_LOCK (always supported)
13086861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    bool autoExposureLock = boolFromString(
13096861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        newParams.get(CameraParameters::KEY_AUTO_EXPOSURE_LOCK));
13106861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
13116861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // AUTO_WHITEBALANCE_LOCK (always supported)
13126861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    bool autoWhiteBalanceLock = boolFromString(
13136861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        newParams.get(CameraParameters::KEY_AUTO_WHITEBALANCE_LOCK));
13146861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
13156861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // METERING_AREAS
13166861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    Vector<Parameters::Area> meteringAreas;
13176861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    res = parseAreas(newParams.get(CameraParameters::KEY_METERING_AREAS),
13186861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            &meteringAreas);
13196861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    if (res == OK) res = validateAreas(focusingAreas, max3aRegions);
13206861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    if (res != OK) {
13216861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        ALOGE("%s: Requested metering areas are malformed: %s",
13226861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                __FUNCTION__,
13236861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                newParams.get(CameraParameters::KEY_METERING_AREAS));
13246861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        return BAD_VALUE;
13256861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
13266861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
13276861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // ZOOM
13286861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    int zoom = newParams.getInt(CameraParameters::KEY_ZOOM);
13296861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    if (zoom < 0 || zoom > (int)NUM_ZOOM_STEPS) {
13306861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        ALOGE("%s: Requested zoom level %d is not supported",
13316861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                __FUNCTION__, zoom);
13326861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        return BAD_VALUE;
13336861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
13346861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
13356861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // VIDEO_SIZE
13366861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    int videoWidth, videoHeight;
13376861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    newParams.getVideoSize(&videoWidth, &videoHeight);
1338836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (videoWidth != k.mParameters.videoWidth ||
1339836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            videoHeight != k.mParameters.videoHeight) {
13406861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (mState == RECORD) {
13416861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Video size cannot be updated when recording is active!",
13426861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    __FUNCTION__);
13436861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
13446861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
13456861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        camera_metadata_entry_t availableVideoSizes =
13466861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            staticInfo(ANDROID_SCALER_AVAILABLE_PROCESSED_SIZES);
13476861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        for (i = 0; i < availableVideoSizes.count; i += 2 ) {
13486861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            if (availableVideoSizes.data.i32[i] == videoWidth &&
13496861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    availableVideoSizes.data.i32[i+1] == videoHeight)  break;
13506861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
13516861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (i == availableVideoSizes.count) {
13526861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ALOGE("%s: Requested video size %d x %d is not supported",
13536861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                    __FUNCTION__, videoWidth, videoHeight);
13546861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return BAD_VALUE;
13556861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
13566861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
13576861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
13586861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // RECORDING_HINT (always supported)
13596861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    bool recordingHint = boolFromString(
13606861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        newParams.get(CameraParameters::KEY_RECORDING_HINT) );
13616861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
13626861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // VIDEO_STABILIZATION
13636861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    bool videoStabilization = boolFromString(
13646861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        newParams.get(CameraParameters::KEY_VIDEO_STABILIZATION) );
13656861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    camera_metadata_entry_t availableVideoStabilizationModes =
13666861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        staticInfo(ANDROID_CONTROL_AVAILABLE_VIDEO_STABILIZATION_MODES);
13676861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    if (videoStabilization && availableVideoStabilizationModes.count == 1) {
13686861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        ALOGE("%s: Video stabilization not supported", __FUNCTION__);
13696861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
13706861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
13716861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    /** Update internal parameters */
13729cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
1373836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.previewWidth = previewWidth;
1374836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.previewHeight = previewHeight;
1375836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.previewFpsRange[0] = previewFpsRange[0];
1376836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.previewFpsRange[1] = previewFpsRange[1];
1377836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.previewFps = previewFps;
1378836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.previewFormat = previewFormat;
1379836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala
1380836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.pictureWidth = pictureWidth;
1381836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.pictureHeight = pictureHeight;
1382836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala
1383836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.jpegThumbSize[0] = jpegThumbSize[0];
1384836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.jpegThumbSize[1] = jpegThumbSize[1];
1385836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.jpegQuality = jpegQuality;
1386836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.jpegThumbQuality = jpegThumbQuality;
1387836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala
1388836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.gpsEnabled = gpsEnabled;
1389836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.gpsCoordinates[0] = gpsCoordinates[0];
1390836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.gpsCoordinates[1] = gpsCoordinates[1];
1391836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.gpsCoordinates[2] = gpsCoordinates[2];
1392836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.gpsTimestamp = gpsTimestamp;
1393836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.gpsProcessingMethod = gpsProcessingMethod;
1394836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala
1395836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.wbMode = wbMode;
1396836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.effectMode = effectMode;
1397836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.antibandingMode = antibandingMode;
1398836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.sceneMode = sceneMode;
1399836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala
1400836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.flashMode = flashMode;
1401836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.focusMode = focusMode;
1402836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala
1403836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.focusingAreas = focusingAreas;
1404836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.exposureCompensation = exposureCompensation;
1405836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.autoExposureLock = autoExposureLock;
1406836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.autoWhiteBalanceLock = autoWhiteBalanceLock;
1407836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.meteringAreas = meteringAreas;
1408836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.zoom = zoom;
1409836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala
1410836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.videoWidth = videoWidth;
1411836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.videoHeight = videoHeight;
1412836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala
1413836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.recordingHint = recordingHint;
1414836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.videoStabilization = videoStabilization;
1415836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala
1416836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    res = updatePreviewRequest(k.mParameters);
1417be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) {
1418be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        ALOGE("%s: Camera %d: Unable to update preview request: %s (%d)",
1419be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                __FUNCTION__, mCameraId, strerror(-res), res);
1420be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        return res;
1421be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
1422836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    res = updateCaptureRequest(k.mParameters);
1423be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) {
1424be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        ALOGE("%s: Camera %d: Unable to update capture request: %s (%d)",
1425be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                __FUNCTION__, mCameraId, strerror(-res), res);
1426be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        return res;
1427be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
1428be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
1429836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    res = updateRecordingRequest(k.mParameters);
14309cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (res != OK) {
14319cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        ALOGE("%s: Camera %d: Unable to update recording request: %s (%d)",
14329cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                __FUNCTION__, mCameraId, strerror(-res), res);
14339cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        return res;
14349cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
14359cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
1436be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (mState == PREVIEW) {
1437be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        res = mDevice->setStreamingRequest(mPreviewRequest);
1438be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        if (res != OK) {
1439be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ALOGE("%s: Camera %d: Error streaming new preview request: %s (%d)",
1440be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                    __FUNCTION__, mCameraId, strerror(-res), res);
1441be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            return res;
1442be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        }
14439cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    } else if (mState == RECORD || mState == VIDEO_SNAPSHOT) {
14449cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        res = mDevice->setStreamingRequest(mRecordingRequest);
14459cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        if (res != OK) {
14469cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            ALOGE("%s: Camera %d: Error streaming new record request: %s (%d)",
14479cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    __FUNCTION__, mCameraId, strerror(-res), res);
14489cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            return res;
14499cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        }
1450be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
14516861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
1452836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.paramsFlattened = params;
14539cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
14546db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    return OK;
145561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
1456f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
145761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville TalvalaString8 Camera2Client::getParameters() const {
1458a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
1459ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
1460ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala
1461836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    LockedParameters::ReadKey k(mParameters);
1462ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala
14633cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    // TODO: Deal with focus distances
1464836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    return k.mParameters.paramsFlattened;
146561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
146661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
146761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::sendCommand(int32_t cmd, int32_t arg1, int32_t arg2) {
1468a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
1469ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala    Mutex::Autolock icl(mICameraLock);
1470c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala
1471c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala    ALOGV("%s: Camera %d: Command %d (%d, %d)", __FUNCTION__, mCameraId,
1472c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala            cmd, arg1, arg2);
1473c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala
1474c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala    if (cmd == CAMERA_CMD_SET_DISPLAY_ORIENTATION) {
1475836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        LockedParameters::Key k(mParameters);
1476c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala        int transform = degToTransform(arg1,
1477c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala                mCameraFacing == CAMERA_FACING_FRONT);
1478c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala        if (transform == -1) {
1479c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala            ALOGE("%s: Camera %d: Error setting %d as display orientation value",
1480c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala                    __FUNCTION__, mCameraId, arg1);
1481c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala            return BAD_VALUE;
1482c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala        }
1483836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        if (transform != k.mParameters.previewTransform &&
1484c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala                mPreviewStreamId != NO_STREAM) {
1485c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala            mDevice->setStreamTransform(mPreviewStreamId, transform);
1486c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala        }
1487836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        k.mParameters.previewTransform = transform;
1488c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala        return OK;
1489c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala    }
1490c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala
1491c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala    ALOGE("%s: Camera %d: Unimplemented command %d (%d, %d)", __FUNCTION__,
1492c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala            mCameraId, cmd, arg1, arg2);
1493c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala
14946db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    return OK;
149561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala}
149661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
14973cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala/** Device-related methods */
14983cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
1499d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvalavoid Camera2Client::onCaptureAvailable() {
1500d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    ATRACE_CALL();
1501d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    status_t res;
1502d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    sp<ICameraClient> currentClient;
15039cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    ALOGV("%s: Camera %d: Still capture available", __FUNCTION__, mCameraId);
15049cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
1505d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    CpuConsumer::LockedBuffer imgBuffer;
1506d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    {
1507d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        Mutex::Autolock icl(mICameraLock);
1508d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
1509d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        // TODO: Signal errors here upstream
1510d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        if (mState != STILL_CAPTURE && mState != VIDEO_SNAPSHOT) {
1511d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            ALOGE("%s: Camera %d: Still image produced unexpectedly!",
1512d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                    __FUNCTION__, mCameraId);
1513d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            return;
1514d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        }
1515d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
1516d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        res = mCaptureConsumer->lockNextBuffer(&imgBuffer);
1517d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        if (res != OK) {
1518d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            ALOGE("%s: Camera %d: Error receiving still image buffer: %s (%d)",
1519d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                    __FUNCTION__, mCameraId, strerror(-res), res);
1520d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            return;
1521d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        }
1522d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
1523d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        if (imgBuffer.format != HAL_PIXEL_FORMAT_BLOB) {
1524d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            ALOGE("%s: Camera %d: Unexpected format for still image: "
1525d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                    "%x, expected %x", __FUNCTION__, mCameraId,
1526d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                    imgBuffer.format,
1527d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                    HAL_PIXEL_FORMAT_BLOB);
1528d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            mCaptureConsumer->unlockBuffer(imgBuffer);
1529d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            return;
1530d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        }
1531d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
1532d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        // TODO: Optimize this to avoid memcopy
15339cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        void* captureMemory = mCaptureHeap->mHeap->getBase();
15349cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        size_t size = mCaptureHeap->mHeap->getSize();
1535d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        memcpy(captureMemory, imgBuffer.data, size);
1536d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
1537d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        mCaptureConsumer->unlockBuffer(imgBuffer);
1538d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
1539d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        currentClient = mCameraClient;
1540d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        switch (mState) {
1541d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            case STILL_CAPTURE:
1542d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                mState = STOPPED;
1543d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                break;
1544d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            case VIDEO_SNAPSHOT:
1545d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                mState = RECORD;
1546d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                break;
1547d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            default:
1548d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                ALOGE("%s: Camera %d: Unexpected state %d", __FUNCTION__,
1549d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                        mCameraId, mState);
1550d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                break;
1551d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        }
1552d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    }
1553d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    // Call outside mICameraLock to allow re-entrancy from notification
1554d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    if (currentClient != 0) {
1555d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        currentClient->dataCallback(CAMERA_MSG_COMPRESSED_IMAGE,
15569cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                mCaptureHeap->mBuffers[0], NULL);
15579cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
15589cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala}
15599cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
15609cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvalavoid Camera2Client::onRecordingFrameAvailable() {
15619cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    ATRACE_CALL();
15629cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    status_t res;
15639cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    sp<ICameraClient> currentClient;
15649cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    size_t heapIdx = 0;
15659cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    nsecs_t timestamp;
15669cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    {
15679cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        Mutex::Autolock icl(mICameraLock);
15689cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        // TODO: Signal errors here upstream
1569898a9a9b867e5d209671feee4c92266f90a55aa3Eino-Ville Talvala        bool discardData = false;
15709cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        if (mState != RECORD && mState != VIDEO_SNAPSHOT) {
1571898a9a9b867e5d209671feee4c92266f90a55aa3Eino-Ville Talvala            ALOGV("%s: Camera %d: Discarding recording image buffers received after "
1572898a9a9b867e5d209671feee4c92266f90a55aa3Eino-Ville Talvala                    "recording done",
15739cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    __FUNCTION__, mCameraId);
1574898a9a9b867e5d209671feee4c92266f90a55aa3Eino-Ville Talvala            discardData = true;
15759cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        }
15769cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
157778822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        buffer_handle_t imgBuffer;
157878822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        res = mRecordingConsumer->getNextBuffer(&imgBuffer, &timestamp);
15799cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        if (res != OK) {
15809cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            ALOGE("%s: Camera %d: Error receiving recording buffer: %s (%d)",
15819cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    __FUNCTION__, mCameraId, strerror(-res), res);
15829cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            return;
15839cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        }
15849cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
1585898a9a9b867e5d209671feee4c92266f90a55aa3Eino-Ville Talvala        if (discardData) {
158678822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala            mRecordingConsumer->freeBuffer(imgBuffer);
15879cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            return;
15889cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        }
1589898a9a9b867e5d209671feee4c92266f90a55aa3Eino-Ville Talvala
159078822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        if (mRecordingHeap == 0) {
159178822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala            const size_t bufferSize = 4 + sizeof(buffer_handle_t);
15929cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            ALOGV("%s: Camera %d: Creating recording heap with %d buffers of "
15939cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    "size %d bytes", __FUNCTION__, mCameraId,
15949cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    kRecordingHeapCount, bufferSize);
15959cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            if (mRecordingHeap != 0) {
15969cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                ALOGV("%s: Camera %d: Previous heap has size %d "
15979cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                        "(new will be %d) bytes", __FUNCTION__, mCameraId,
15989cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                        mRecordingHeap->mHeap->getSize(),
15999cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                        bufferSize * kRecordingHeapCount);
16009cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            }
16019cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            // Need to allocate memory for heap
16029cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            mRecordingHeap.clear();
16039cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
16049cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            mRecordingHeap = new Camera2Heap(bufferSize, kRecordingHeapCount,
16059cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    "Camera2Client::RecordingHeap");
16069cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            if (mRecordingHeap->mHeap->getSize() == 0) {
16079cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                ALOGE("%s: Camera %d: Unable to allocate memory for recording",
16089cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                        __FUNCTION__, mCameraId);
160978822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala                mRecordingConsumer->freeBuffer(imgBuffer);
16109cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                return;
16119cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            }
16129cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            mRecordingHeapHead = 0;
16139cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            mRecordingHeapFree = kRecordingHeapCount;
16149cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        }
16159cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
16169cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        if ( mRecordingHeapFree == 0) {
16179cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            ALOGE("%s: Camera %d: No free recording buffers, dropping frame",
16189cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    __FUNCTION__, mCameraId);
161978822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala            mRecordingConsumer->freeBuffer(imgBuffer);
16209cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            return;
16219cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        }
16229cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        heapIdx = mRecordingHeapHead;
16239cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        mRecordingHeapHead = (mRecordingHeapHead + 1) % kRecordingHeapCount;
16249cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        mRecordingHeapFree--;
16259cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
16269cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        ALOGV("%s: Camera %d: Timestamp %lld",
16279cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                __FUNCTION__, mCameraId, timestamp);
16289cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
16299cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        ssize_t offset;
16309cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        size_t size;
16319cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        sp<IMemoryHeap> heap =
16329cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                mRecordingHeap->mBuffers[heapIdx]->getMemory(&offset,
16339cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                        &size);
16349cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
163578822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        uint8_t *data = (uint8_t*)heap->getBase() + offset;
163678822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        uint32_t type = kMetadataBufferTypeGrallocSource;
163778822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        memcpy(data, &type, 4);
163878822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        memcpy(data + 4, &imgBuffer, sizeof(buffer_handle_t));
163978822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala        ALOGV("%s: Camera %d: Sending out buffer_handle_t %p",
1640803cbf6190f16f7b2c43cbc51d0df21ec888abddEino-Ville Talvala                __FUNCTION__, mCameraId, imgBuffer);
16419cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        currentClient = mCameraClient;
16429cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
16439cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    // Call outside mICameraLock to allow re-entrancy from notification
16449cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (currentClient != 0) {
16459cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        currentClient->dataCallbackTimestamp(timestamp,
16469cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                CAMERA_MSG_VIDEO_FRAME,
16479cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                mRecordingHeap->mBuffers[heapIdx]);
1648d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    }
1649d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala}
1650d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
16513cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvalacamera_metadata_entry_t Camera2Client::staticInfo(uint32_t tag,
16523cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        size_t minCount, size_t maxCount) {
16533cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    status_t res;
16543cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t entry;
16553cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    res = find_camera_metadata_entry(mDevice->info(),
16563cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            tag,
16573cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            &entry);
16583cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (CC_UNLIKELY( res != OK )) {
16593cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        const char* tagSection = get_camera_metadata_section_name(tag);
16603cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        if (tagSection == NULL) tagSection = "<unknown>";
16613cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        const char* tagName = get_camera_metadata_tag_name(tag);
16623cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        if (tagName == NULL) tagName = "<unknown>";
16633cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
16643cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        ALOGE("Error finding static metadata entry '%s.%s' (%x): %s (%d)",
16653cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala                tagSection, tagName, tag, strerror(-res), res);
16663cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        entry.count = 0;
16673cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        entry.data.u8 = NULL;
16683cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    } else if (CC_UNLIKELY(
16693cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            (minCount != 0 && entry.count < minCount) ||
16703cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            (maxCount != 0 && entry.count > maxCount) ) ) {
16713cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        const char* tagSection = get_camera_metadata_section_name(tag);
16723cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        if (tagSection == NULL) tagSection = "<unknown>";
16733cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        const char* tagName = get_camera_metadata_tag_name(tag);
16743cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        if (tagName == NULL) tagName = "<unknown>";
16753cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        ALOGE("Malformed static metadata entry '%s.%s' (%x):"
16763cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala                "Expected between %d and %d values, but got %d values",
16773cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala                tagSection, tagName, tag, minCount, maxCount, entry.count);
16783cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        entry.count = 0;
16793cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        entry.data.u8 = NULL;
16803cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    }
16813cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
16823cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    return entry;
16833cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala}
16843cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
16853cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala/** Utility methods */
16863cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
1687f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
1688f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvalastatus_t Camera2Client::buildDefaultParameters() {
1689a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
1690836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    LockedParameters::Key k(mParameters);
1691ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala
1692f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    status_t res;
16933cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    CameraParameters params;
1694f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
16953cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t availableProcessedSizes =
16963cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_SCALER_AVAILABLE_PROCESSED_SIZES, 2);
16973cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!availableProcessedSizes.count) return NO_INIT;
1698f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
1699f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    // TODO: Pick more intelligently
1700836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.previewWidth = availableProcessedSizes.data.i32[0];
1701836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.previewHeight = availableProcessedSizes.data.i32[1];
1702836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.videoWidth = k.mParameters.previewWidth;
1703836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.videoHeight = k.mParameters.previewHeight;
17043cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
1705836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    params.setPreviewSize(k.mParameters.previewWidth, k.mParameters.previewHeight);
1706836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    params.setVideoSize(k.mParameters.videoWidth, k.mParameters.videoHeight);
17073cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_PREFERRED_PREVIEW_SIZE_FOR_VIDEO,
17083cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            String8::format("%dx%d",
1709836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                    k.mParameters.previewWidth, k.mParameters.previewHeight));
1710f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    {
1711f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        String8 supportedPreviewSizes;
1712f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        for (size_t i=0; i < availableProcessedSizes.count; i += 2) {
1713f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            if (i != 0) supportedPreviewSizes += ",";
1714f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            supportedPreviewSizes += String8::format("%dx%d",
1715f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    availableProcessedSizes.data.i32[i],
1716f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    availableProcessedSizes.data.i32[i+1]);
1717f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        }
17183cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_SUPPORTED_PREVIEW_SIZES,
1719f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                supportedPreviewSizes);
17203cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_SUPPORTED_VIDEO_SIZES,
1721f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                supportedPreviewSizes);
1722f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
1723f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
17243cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t availableFpsRanges =
17253cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_CONTROL_AE_AVAILABLE_TARGET_FPS_RANGES, 2);
17263cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!availableFpsRanges.count) return NO_INIT;
1727f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
1728836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.previewFpsRange[0] = availableFpsRanges.data.i32[0];
1729836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.previewFpsRange[1] = availableFpsRanges.data.i32[1];
1730f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
17313cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_PREVIEW_FPS_RANGE,
17323cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            String8::format("%d,%d",
1733836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                    k.mParameters.previewFpsRange[0],
1734836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                    k.mParameters.previewFpsRange[1]));
1735f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
1736f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    {
1737f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        String8 supportedPreviewFpsRange;
1738f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        for (size_t i=0; i < availableFpsRanges.count; i += 2) {
1739f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            if (i != 0) supportedPreviewFpsRange += ",";
1740f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            supportedPreviewFpsRange += String8::format("(%d,%d)",
1741f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    availableFpsRanges.data.i32[i],
1742f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    availableFpsRanges.data.i32[i+1]);
1743f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        }
17443cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_SUPPORTED_PREVIEW_FPS_RANGE,
1745f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                supportedPreviewFpsRange);
1746f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
1747f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
1748836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.previewFormat = HAL_PIXEL_FORMAT_YCrCb_420_SP;
17493cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_PREVIEW_FORMAT,
1750836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            formatEnumToString(k.mParameters.previewFormat)); // NV21
17513cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
1752836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.previewTransform = degToTransform(0,
1753c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala            mCameraFacing == CAMERA_FACING_FRONT);
1754c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala
17553cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t availableFormats =
17563cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_SCALER_AVAILABLE_FORMATS);
1757f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
1758f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    {
1759f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        String8 supportedPreviewFormats;
1760f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        bool addComma = false;
1761f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        for (size_t i=0; i < availableFormats.count; i++) {
1762f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            if (addComma) supportedPreviewFormats += ",";
1763f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            addComma = true;
1764f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            switch (availableFormats.data.i32[i]) {
1765f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            case HAL_PIXEL_FORMAT_YCbCr_422_SP:
1766bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                supportedPreviewFormats +=
1767bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    CameraParameters::PIXEL_FORMAT_YUV422SP;
1768f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
1769f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            case HAL_PIXEL_FORMAT_YCrCb_420_SP:
1770bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                supportedPreviewFormats +=
1771bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    CameraParameters::PIXEL_FORMAT_YUV420SP;
1772f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
1773f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            case HAL_PIXEL_FORMAT_YCbCr_422_I:
1774bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                supportedPreviewFormats +=
1775bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    CameraParameters::PIXEL_FORMAT_YUV422I;
1776f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
1777f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            case HAL_PIXEL_FORMAT_YV12:
1778bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                supportedPreviewFormats +=
1779bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    CameraParameters::PIXEL_FORMAT_YUV420P;
1780f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
1781f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            case HAL_PIXEL_FORMAT_RGB_565:
1782bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                supportedPreviewFormats +=
1783bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    CameraParameters::PIXEL_FORMAT_RGB565;
1784f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
178511b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala            case HAL_PIXEL_FORMAT_RGBA_8888:
178611b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala                supportedPreviewFormats +=
178711b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala                    CameraParameters::PIXEL_FORMAT_RGBA8888;
178811b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala                break;
178911b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala            // Not advertizing JPEG, RAW_SENSOR, etc, for preview formats
1790f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            case HAL_PIXEL_FORMAT_RAW_SENSOR:
179111b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala            case HAL_PIXEL_FORMAT_BLOB:
1792f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                addComma = false;
1793f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
179411b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala
1795f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            default:
1796f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                ALOGW("%s: Camera %d: Unknown preview format: %x",
1797f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                        __FUNCTION__, mCameraId, availableFormats.data.i32[i]);
1798f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                addComma = false;
1799f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
1800f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            }
1801f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        }
18023cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_SUPPORTED_PREVIEW_FORMATS,
1803f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                supportedPreviewFormats);
1804f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
1805f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
1806f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    // PREVIEW_FRAME_RATE / SUPPORTED_PREVIEW_FRAME_RATES are deprecated, but
1807f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    // still have to do something sane for them
1808f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
18093cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_PREVIEW_FRAME_RATE,
1810836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            k.mParameters.previewFpsRange[0]);
1811f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
1812f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    {
1813f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        String8 supportedPreviewFrameRates;
1814f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        for (size_t i=0; i < availableFpsRanges.count; i += 2) {
1815f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            if (i != 0) supportedPreviewFrameRates += ",";
1816f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            supportedPreviewFrameRates += String8::format("%d",
1817f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    availableFpsRanges.data.i32[i]);
1818f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        }
18193cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_SUPPORTED_PREVIEW_FRAME_RATES,
1820f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                supportedPreviewFrameRates);
1821f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
1822f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
18233cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t availableJpegSizes =
18243cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_SCALER_AVAILABLE_JPEG_SIZES, 2);
18253cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!availableJpegSizes.count) return NO_INIT;
1826f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
1827f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    // TODO: Pick maximum
1828836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.pictureWidth = availableJpegSizes.data.i32[0];
1829836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.pictureHeight = availableJpegSizes.data.i32[1];
1830f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
1831836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    params.setPictureSize(k.mParameters.pictureWidth,
1832836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            k.mParameters.pictureHeight);
1833f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
1834f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    {
1835f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        String8 supportedPictureSizes;
1836f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        for (size_t i=0; i < availableJpegSizes.count; i += 2) {
1837f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            if (i != 0) supportedPictureSizes += ",";
1838f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            supportedPictureSizes += String8::format("%dx%d",
1839f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    availableJpegSizes.data.i32[i],
1840f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    availableJpegSizes.data.i32[i+1]);
1841f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        }
18423cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_SUPPORTED_PICTURE_SIZES,
1843f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                supportedPictureSizes);
1844f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
1845f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
18463cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.setPictureFormat(CameraParameters::PIXEL_FORMAT_JPEG);
18473cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_SUPPORTED_PICTURE_FORMATS,
18483cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            CameraParameters::PIXEL_FORMAT_JPEG);
1849f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
18503cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t availableJpegThumbnailSizes =
18513cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_JPEG_AVAILABLE_THUMBNAIL_SIZES, 2);
18523cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!availableJpegThumbnailSizes.count) return NO_INIT;
1853f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
1854f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    // TODO: Pick default thumbnail size sensibly
1855836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.jpegThumbSize[0] = availableJpegThumbnailSizes.data.i32[0];
1856836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.jpegThumbSize[1] = availableJpegThumbnailSizes.data.i32[1];
1857f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
18583cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_JPEG_THUMBNAIL_WIDTH,
1859836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            k.mParameters.jpegThumbSize[0]);
18603cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_JPEG_THUMBNAIL_HEIGHT,
1861836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            k.mParameters.jpegThumbSize[1]);
1862f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
1863f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    {
1864f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        String8 supportedJpegThumbSizes;
1865f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        for (size_t i=0; i < availableJpegThumbnailSizes.count; i += 2) {
1866f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            if (i != 0) supportedJpegThumbSizes += ",";
1867f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            supportedJpegThumbSizes += String8::format("%dx%d",
1868f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    availableJpegThumbnailSizes.data.i32[i],
1869f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    availableJpegThumbnailSizes.data.i32[i+1]);
1870f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        }
18713cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_SUPPORTED_JPEG_THUMBNAIL_SIZES,
1872f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                supportedJpegThumbSizes);
1873f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
1874f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
1875836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.jpegThumbQuality = 90;
18763cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_JPEG_THUMBNAIL_QUALITY,
1877836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            k.mParameters.jpegThumbQuality);
1878836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.jpegQuality = 90;
18793cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_JPEG_QUALITY,
1880836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            k.mParameters.jpegQuality);
1881836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.jpegRotation = 0;
18823cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_ROTATION,
1883836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            k.mParameters.jpegRotation);
18843cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
1885836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.gpsEnabled = false;
1886836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.gpsProcessingMethod = "unknown";
18873cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    // GPS fields in CameraParameters are not set by implementation
18883cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
1889836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.wbMode = ANDROID_CONTROL_AWB_AUTO;
18903cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_WHITE_BALANCE,
18913cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            CameraParameters::WHITE_BALANCE_AUTO);
18923cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
18933cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t availableWhiteBalanceModes =
18943cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_CONTROL_AWB_AVAILABLE_MODES);
1895f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    {
1896f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        String8 supportedWhiteBalance;
1897f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        bool addComma = false;
1898f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        for (size_t i=0; i < availableWhiteBalanceModes.count; i++) {
1899f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            if (addComma) supportedWhiteBalance += ",";
1900f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            addComma = true;
1901f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            switch (availableWhiteBalanceModes.data.u8[i]) {
1902f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            case ANDROID_CONTROL_AWB_AUTO:
1903bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                supportedWhiteBalance +=
1904bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    CameraParameters::WHITE_BALANCE_AUTO;
1905f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
1906f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            case ANDROID_CONTROL_AWB_INCANDESCENT:
1907bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                supportedWhiteBalance +=
1908bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    CameraParameters::WHITE_BALANCE_INCANDESCENT;
1909f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
1910f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            case ANDROID_CONTROL_AWB_FLUORESCENT:
1911bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                supportedWhiteBalance +=
1912bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    CameraParameters::WHITE_BALANCE_FLUORESCENT;
1913f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
1914f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            case ANDROID_CONTROL_AWB_WARM_FLUORESCENT:
1915bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                supportedWhiteBalance +=
1916bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    CameraParameters::WHITE_BALANCE_WARM_FLUORESCENT;
1917f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
1918f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            case ANDROID_CONTROL_AWB_DAYLIGHT:
1919bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                supportedWhiteBalance +=
1920bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    CameraParameters::WHITE_BALANCE_DAYLIGHT;
1921f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
1922f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            case ANDROID_CONTROL_AWB_CLOUDY_DAYLIGHT:
1923bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                supportedWhiteBalance +=
1924bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    CameraParameters::WHITE_BALANCE_CLOUDY_DAYLIGHT;
1925f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
1926f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            case ANDROID_CONTROL_AWB_TWILIGHT:
1927bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                supportedWhiteBalance +=
1928bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    CameraParameters::WHITE_BALANCE_TWILIGHT;
1929f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
1930f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            case ANDROID_CONTROL_AWB_SHADE:
1931bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                supportedWhiteBalance +=
1932bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    CameraParameters::WHITE_BALANCE_SHADE;
1933f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
1934f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            // Skipping values not mappable to v1 API
1935f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            case ANDROID_CONTROL_AWB_OFF:
1936f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                addComma = false;
1937f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
1938f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            default:
1939f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                ALOGW("%s: Camera %d: Unknown white balance value: %d",
1940f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                        __FUNCTION__, mCameraId,
1941f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                        availableWhiteBalanceModes.data.u8[i]);
1942f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                addComma = false;
1943f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
1944f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            }
1945f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        }
19463cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_SUPPORTED_WHITE_BALANCE,
1947f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                supportedWhiteBalance);
1948f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
1949f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
1950836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.effectMode = ANDROID_CONTROL_EFFECT_OFF;
19513cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_EFFECT,
19523cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            CameraParameters::EFFECT_NONE);
19533cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
19543cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t availableEffects =
19553cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_CONTROL_AVAILABLE_EFFECTS);
19563cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!availableEffects.count) return NO_INIT;
1957f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    {
1958f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        String8 supportedEffects;
1959f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        bool addComma = false;
1960f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        for (size_t i=0; i < availableEffects.count; i++) {
1961f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            if (addComma) supportedEffects += ",";
1962f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            addComma = true;
1963f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            switch (availableEffects.data.u8[i]) {
1964f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_EFFECT_OFF:
1965bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedEffects +=
1966bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::EFFECT_NONE;
1967f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
1968f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_EFFECT_MONO:
1969bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedEffects +=
1970bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::EFFECT_MONO;
1971bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    break;
1972f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_EFFECT_NEGATIVE:
1973bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedEffects +=
1974bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::EFFECT_NEGATIVE;
1975f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
1976f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_EFFECT_SOLARIZE:
1977bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedEffects +=
1978bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::EFFECT_SOLARIZE;
1979f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
1980f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_EFFECT_SEPIA:
1981bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedEffects +=
1982bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::EFFECT_SEPIA;
1983f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
1984f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_EFFECT_POSTERIZE:
1985bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedEffects +=
1986bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::EFFECT_POSTERIZE;
1987f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
1988f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_EFFECT_WHITEBOARD:
1989bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedEffects +=
1990bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::EFFECT_WHITEBOARD;
1991f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
1992f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_EFFECT_BLACKBOARD:
1993bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedEffects +=
1994bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::EFFECT_BLACKBOARD;
1995f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
1996f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_EFFECT_AQUA:
1997bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedEffects +=
1998bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::EFFECT_AQUA;
1999f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2000f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                default:
2001f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    ALOGW("%s: Camera %d: Unknown effect value: %d",
2002f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                        __FUNCTION__, mCameraId, availableEffects.data.u8[i]);
2003f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    addComma = false;
2004f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2005f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            }
2006f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        }
20073cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_SUPPORTED_EFFECTS, supportedEffects);
2008f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
2009f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
2010836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.antibandingMode = ANDROID_CONTROL_AE_ANTIBANDING_AUTO;
20113cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_ANTIBANDING,
20123cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            CameraParameters::ANTIBANDING_AUTO);
20133cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
20143cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t availableAntibandingModes =
20153cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_CONTROL_AE_AVAILABLE_ANTIBANDING_MODES);
20163cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!availableAntibandingModes.count) return NO_INIT;
2017f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    {
2018f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        String8 supportedAntibanding;
2019f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        bool addComma = false;
2020f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        for (size_t i=0; i < availableAntibandingModes.count; i++) {
2021f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            if (addComma) supportedAntibanding += ",";
2022f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            addComma = true;
2023f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            switch (availableAntibandingModes.data.u8[i]) {
2024f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_AE_ANTIBANDING_OFF:
2025bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedAntibanding +=
2026bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::ANTIBANDING_OFF;
2027f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2028f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_AE_ANTIBANDING_50HZ:
2029bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedAntibanding +=
2030bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::ANTIBANDING_50HZ;
2031f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2032f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_AE_ANTIBANDING_60HZ:
2033bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedAntibanding +=
2034bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::ANTIBANDING_60HZ;
2035f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2036f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_AE_ANTIBANDING_AUTO:
2037bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedAntibanding +=
2038bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::ANTIBANDING_AUTO;
2039f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2040f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                default:
2041f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    ALOGW("%s: Camera %d: Unknown antibanding value: %d",
2042f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                        __FUNCTION__, mCameraId,
2043f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                            availableAntibandingModes.data.u8[i]);
2044f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    addComma = false;
2045f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2046f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            }
2047f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        }
20483cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_SUPPORTED_ANTIBANDING,
2049f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                supportedAntibanding);
2050f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
2051f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
2052836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.sceneMode = ANDROID_CONTROL_OFF;
20533cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_SCENE_MODE,
20543cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            CameraParameters::SCENE_MODE_AUTO);
20553cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
20563cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t availableSceneModes =
20573cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_CONTROL_AVAILABLE_SCENE_MODES);
20583cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!availableSceneModes.count) return NO_INIT;
2059f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    {
2060bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala        String8 supportedSceneModes(CameraParameters::SCENE_MODE_AUTO);
2061f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        bool addComma = true;
2062f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        bool noSceneModes = false;
2063f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        for (size_t i=0; i < availableSceneModes.count; i++) {
2064f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            if (addComma) supportedSceneModes += ",";
2065f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            addComma = true;
2066f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            switch (availableSceneModes.data.u8[i]) {
2067f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_UNSUPPORTED:
2068f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    noSceneModes = true;
2069f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2070f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_FACE_PRIORITY:
2071f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    // Not in old API
2072f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    addComma = false;
2073f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2074f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_ACTION:
2075bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedSceneModes +=
2076bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::SCENE_MODE_ACTION;
2077f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2078f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_PORTRAIT:
2079bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedSceneModes +=
2080bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::SCENE_MODE_PORTRAIT;
2081f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2082f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_LANDSCAPE:
2083bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedSceneModes +=
2084bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::SCENE_MODE_LANDSCAPE;
2085f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2086f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_NIGHT:
2087bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedSceneModes +=
2088bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::SCENE_MODE_NIGHT;
2089f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2090f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_NIGHT_PORTRAIT:
2091bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedSceneModes +=
2092bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::SCENE_MODE_NIGHT_PORTRAIT;
2093f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2094f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_THEATRE:
2095bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedSceneModes +=
2096bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::SCENE_MODE_THEATRE;
2097f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2098f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_BEACH:
2099bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedSceneModes +=
2100bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::SCENE_MODE_BEACH;
2101f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2102f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_SNOW:
2103bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedSceneModes +=
2104bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::SCENE_MODE_SNOW;
2105f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2106f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_SUNSET:
2107bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedSceneModes +=
2108bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::SCENE_MODE_SUNSET;
2109f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2110f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_STEADYPHOTO:
2111bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedSceneModes +=
2112bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::SCENE_MODE_STEADYPHOTO;
2113f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2114f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_FIREWORKS:
2115bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedSceneModes +=
2116bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::SCENE_MODE_FIREWORKS;
2117f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2118f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_SPORTS:
2119bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedSceneModes +=
2120bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::SCENE_MODE_SPORTS;
2121f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2122f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_PARTY:
2123bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedSceneModes +=
2124bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::SCENE_MODE_PARTY;
2125f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2126f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_CANDLELIGHT:
2127bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedSceneModes +=
2128bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::SCENE_MODE_CANDLELIGHT;
2129f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2130f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_SCENE_MODE_BARCODE:
2131bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedSceneModes +=
2132bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::SCENE_MODE_BARCODE;
2133f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2134f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                default:
2135f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    ALOGW("%s: Camera %d: Unknown scene mode value: %d",
2136bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        __FUNCTION__, mCameraId,
2137bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                            availableSceneModes.data.u8[i]);
2138f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    addComma = false;
2139f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2140f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            }
2141f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        }
2142f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        if (!noSceneModes) {
21433cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            params.set(CameraParameters::KEY_SUPPORTED_SCENE_MODES,
2144f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    supportedSceneModes);
2145f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        }
2146f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
2147f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
21483cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t flashAvailable =
21493cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_FLASH_AVAILABLE, 1, 1);
21503cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!flashAvailable.count) return NO_INIT;
2151f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
21523cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t availableAeModes =
21533cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_CONTROL_AE_AVAILABLE_MODES);
21543cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!availableAeModes.count) return NO_INIT;
2155f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
2156f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    if (flashAvailable.data.u8[0]) {
2157836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        k.mParameters.flashMode = Parameters::FLASH_MODE_AUTO;
21583cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_FLASH_MODE,
21593cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala                CameraParameters::FLASH_MODE_AUTO);
21603cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
21613cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        String8 supportedFlashModes(CameraParameters::FLASH_MODE_OFF);
21623cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        supportedFlashModes = supportedFlashModes +
21633cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            "," + CameraParameters::FLASH_MODE_AUTO +
21643cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            "," + CameraParameters::FLASH_MODE_ON +
21653cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            "," + CameraParameters::FLASH_MODE_TORCH;
2166f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        for (size_t i=0; i < availableAeModes.count; i++) {
2167f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            if (availableAeModes.data.u8[i] ==
2168f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    ANDROID_CONTROL_AE_ON_AUTO_FLASH_REDEYE) {
21693cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala                supportedFlashModes = supportedFlashModes + "," +
21703cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala                    CameraParameters::FLASH_MODE_RED_EYE;
2171f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                break;
2172f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            }
2173f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        }
21743cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_SUPPORTED_FLASH_MODES,
2175f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                supportedFlashModes);
21763cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    } else {
2177836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        k.mParameters.flashMode = Parameters::FLASH_MODE_OFF;
21783cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_FLASH_MODE,
21793cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala                CameraParameters::FLASH_MODE_OFF);
21803cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_SUPPORTED_FLASH_MODES,
21813cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala                CameraParameters::FLASH_MODE_OFF);
2182f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
2183f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
21843cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t minFocusDistance =
21853cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_LENS_MINIMUM_FOCUS_DISTANCE, 1, 1);
21863cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!minFocusDistance.count) return NO_INIT;
21873cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
21883cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t availableAfModes =
21893cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_CONTROL_AF_AVAILABLE_MODES);
21903cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!availableAfModes.count) return NO_INIT;
21913cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
2192f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    if (minFocusDistance.data.f[0] == 0) {
2193f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        // Fixed-focus lens
2194836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        k.mParameters.focusMode = Parameters::FOCUS_MODE_FIXED;
21953cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_FOCUS_MODE,
21963cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala                CameraParameters::FOCUS_MODE_FIXED);
21973cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_SUPPORTED_FOCUS_MODES,
21983cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala                CameraParameters::FOCUS_MODE_FIXED);
2199f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    } else {
2200836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        k.mParameters.focusMode = Parameters::FOCUS_MODE_AUTO;
22013cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_FOCUS_MODE,
22023cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala                CameraParameters::FOCUS_MODE_AUTO);
22033cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        String8 supportedFocusModes(CameraParameters::FOCUS_MODE_FIXED);
22043cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        supportedFocusModes = supportedFocusModes + "," +
22053cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            CameraParameters::FOCUS_MODE_INFINITY;
2206f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        bool addComma = true;
2207bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala
2208f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        for (size_t i=0; i < availableAfModes.count; i++) {
2209f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            if (addComma) supportedFocusModes += ",";
2210f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            addComma = true;
2211f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            switch (availableAfModes.data.u8[i]) {
2212f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_AF_AUTO:
2213bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedFocusModes +=
2214bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::FOCUS_MODE_AUTO;
2215f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2216f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_AF_MACRO:
2217bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedFocusModes +=
2218bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::FOCUS_MODE_MACRO;
2219f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2220f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_AF_CONTINUOUS_VIDEO:
2221bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedFocusModes +=
2222bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::FOCUS_MODE_CONTINUOUS_VIDEO;
2223f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2224f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_AF_CONTINUOUS_PICTURE:
2225bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedFocusModes +=
2226bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::FOCUS_MODE_CONTINUOUS_PICTURE;
2227f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2228f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_AF_EDOF:
2229bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                    supportedFocusModes +=
2230bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                        CameraParameters::FOCUS_MODE_EDOF;
2231f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2232bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala                // Not supported in old API
2233f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                case ANDROID_CONTROL_AF_OFF:
2234f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    addComma = false;
2235f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2236f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                default:
2237f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    ALOGW("%s: Camera %d: Unknown AF mode value: %d",
2238f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                        __FUNCTION__, mCameraId, availableAfModes.data.u8[i]);
2239f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    addComma = false;
2240f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                    break;
2241f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            }
2242f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        }
22433cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_SUPPORTED_FOCUS_MODES,
2244f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala                supportedFocusModes);
2245f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
2246f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
22473cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t max3aRegions =
22483cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_CONTROL_MAX_REGIONS, 1, 1);
22493cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!max3aRegions.count) return NO_INIT;
2250f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
22513cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_MAX_NUM_FOCUS_AREAS,
2252f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            max3aRegions.data.i32[0]);
22533cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_FOCUS_AREAS,
2254f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            "(0,0,0,0,0)");
2255836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.focusingAreas.clear();
2256836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.focusingAreas.add(Parameters::Area(0,0,0,0,0));
22573cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
22583cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t availableFocalLengths =
22593cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_LENS_AVAILABLE_FOCAL_LENGTHS);
22603cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!availableFocalLengths.count) return NO_INIT;
2261f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
2262f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    float minFocalLength = availableFocalLengths.data.f[0];
22633cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.setFloat(CameraParameters::KEY_FOCAL_LENGTH, minFocalLength);
2264f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
22653cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t sensorSize =
22663cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_SENSOR_PHYSICAL_SIZE, 2, 2);
22673cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!sensorSize.count) return NO_INIT;
2268f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
2269f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    // The fields of view here assume infinity focus, maximum wide angle
2270f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    float horizFov = 180 / M_PI *
2271f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            2 * atanf(sensorSize.data.f[0] / (2 * minFocalLength));
2272f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    float vertFov  = 180 / M_PI *
2273f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            2 * atanf(sensorSize.data.f[1] / (2 * minFocalLength));
22743cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.setFloat(CameraParameters::KEY_HORIZONTAL_VIEW_ANGLE, horizFov);
22753cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.setFloat(CameraParameters::KEY_VERTICAL_VIEW_ANGLE, vertFov);
2276f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
2277836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.exposureCompensation = 0;
22783cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_EXPOSURE_COMPENSATION,
2279836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                k.mParameters.exposureCompensation);
2280f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
22813cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t exposureCompensationRange =
22823cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_CONTROL_AE_EXP_COMPENSATION_RANGE, 2, 2);
22833cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!exposureCompensationRange.count) return NO_INIT;
22843cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
22853cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_MAX_EXPOSURE_COMPENSATION,
2286f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            exposureCompensationRange.data.i32[1]);
22873cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_MIN_EXPOSURE_COMPENSATION,
2288f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            exposureCompensationRange.data.i32[0]);
2289f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
22903cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t exposureCompensationStep =
22913cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_CONTROL_AE_EXP_COMPENSATION_STEP, 1, 1);
22923cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!exposureCompensationStep.count) return NO_INIT;
22933cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
22943cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.setFloat(CameraParameters::KEY_EXPOSURE_COMPENSATION_STEP,
2295f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            exposureCompensationStep.data.r[0].numerator /
2296f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            exposureCompensationStep.data.r[0].denominator);
2297f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
2298836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.autoExposureLock = false;
22993cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_AUTO_EXPOSURE_LOCK,
23003cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            CameraParameters::FALSE);
23013cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_AUTO_EXPOSURE_LOCK_SUPPORTED,
23023cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            CameraParameters::TRUE);
2303f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
2304836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.autoWhiteBalanceLock = false;
23053cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_AUTO_WHITEBALANCE_LOCK,
23063cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            CameraParameters::FALSE);
23073cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_AUTO_WHITEBALANCE_LOCK_SUPPORTED,
23083cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            CameraParameters::TRUE);
2309f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
2310836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.meteringAreas.add(Parameters::Area(0, 0, 0, 0, 0));
23113cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_MAX_NUM_METERING_AREAS,
2312f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            max3aRegions.data.i32[0]);
23133cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_METERING_AREAS,
2314f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            "(0,0,0,0,0)");
2315f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
2316836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.zoom = 0;
2317836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    params.set(CameraParameters::KEY_ZOOM, k.mParameters.zoom);
23183cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_MAX_ZOOM, NUM_ZOOM_STEPS - 1);
2319f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
23203cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t maxDigitalZoom =
23213cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_SCALER_AVAILABLE_MAX_ZOOM, 1, 1);
23223cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!maxDigitalZoom.count) return NO_INIT;
2323f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
2324f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    {
2325f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        String8 zoomRatios;
2326f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        float zoom = 1.f;
2327f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        float zoomIncrement = (maxDigitalZoom.data.f[0] - zoom) /
23286db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala                (NUM_ZOOM_STEPS-1);
2329f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        bool addComma = false;
23306db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        for (size_t i=0; i < NUM_ZOOM_STEPS; i++) {
2331f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            if (addComma) zoomRatios += ",";
2332f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            addComma = true;
2333f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            zoomRatios += String8::format("%d", static_cast<int>(zoom * 100));
2334f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            zoom += zoomIncrement;
2335f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala        }
23363cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_ZOOM_RATIOS, zoomRatios);
2337f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
2338f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
23393cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_ZOOM_SUPPORTED,
23403cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            CameraParameters::TRUE);
23413cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_SMOOTH_ZOOM_SUPPORTED,
23423cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            CameraParameters::TRUE);
2343f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
23443cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_FOCUS_DISTANCES,
2345f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            "Infinity,Infinity,Infinity");
2346f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
23473cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t maxFacesDetected =
23483cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_STATS_MAX_FACE_COUNT, 1, 1);
23493cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_MAX_NUM_DETECTED_FACES_HW,
2350f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            maxFacesDetected.data.i32[0]);
23513cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_MAX_NUM_DETECTED_FACES_SW,
2352f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala            0);
2353f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
23543cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_VIDEO_FRAME_FORMAT,
235578822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala            CameraParameters::PIXEL_FORMAT_ANDROID_OPAQUE);
2356f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
23573cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_RECORDING_HINT,
23583cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            CameraParameters::FALSE);
2359f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
23603cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_VIDEO_SNAPSHOT_SUPPORTED,
23613cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            CameraParameters::TRUE);
2362f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
23633cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    params.set(CameraParameters::KEY_VIDEO_STABILIZATION,
23643cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            CameraParameters::FALSE);
23653cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
23663cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    camera_metadata_entry_t availableVideoStabilizationModes =
23673cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        staticInfo(ANDROID_CONTROL_AVAILABLE_VIDEO_STABILIZATION_MODES);
23683cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    if (!availableVideoStabilizationModes.count) return NO_INIT;
2369f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
2370f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    if (availableVideoStabilizationModes.count > 1) {
23713cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_VIDEO_STABILIZATION_SUPPORTED,
23723cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala                CameraParameters::TRUE);
2373f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    } else {
23743cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        params.set(CameraParameters::KEY_VIDEO_STABILIZATION_SUPPORTED,
23753cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala                CameraParameters::FALSE);
2376f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    }
2377f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala
237878822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala    // Always use metadata mode for recording
2379836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.storeMetadataInBuffers = true;
238078822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala
2381836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    k.mParameters.paramsFlattened = params.flatten();
23823cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala
2383f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala    return OK;
2384f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala}
238561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala
2386836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvalastatus_t Camera2Client::updatePreviewStream(const Parameters &params) {
2387be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    ATRACE_CALL();
2388be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    status_t res;
2389836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala
2390be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (mPreviewStreamId != NO_STREAM) {
2391be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        // Check if stream parameters have to change
2392be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        uint32_t currentWidth, currentHeight;
2393be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        res = mDevice->getStreamInfo(mPreviewStreamId,
2394be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                &currentWidth, &currentHeight, 0);
2395be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        if (res != OK) {
2396be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ALOGE("%s: Camera %d: Error querying preview stream info: "
2397be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                    "%s (%d)", __FUNCTION__, mCameraId, strerror(-res), res);
2398be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            return res;
2399be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        }
2400836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        if (currentWidth != (uint32_t)params.previewWidth ||
2401836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                currentHeight != (uint32_t)params.previewHeight) {
24029e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala            ALOGV("%s: Camera %d: Preview size switch: %d x %d -> %d x %d",
24039e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala                    __FUNCTION__, mCameraId, currentWidth, currentHeight,
2404836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                    params.previewWidth, params.previewHeight);
2405be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            res = mDevice->waitUntilDrained();
2406be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            if (res != OK) {
2407be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                ALOGE("%s: Camera %d: Error waiting for preview to drain: "
2408be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                        "%s (%d)", __FUNCTION__, mCameraId, strerror(-res), res);
2409be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                return res;
2410be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            }
2411be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            res = mDevice->deleteStream(mPreviewStreamId);
2412be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            if (res != OK) {
2413be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                ALOGE("%s: Camera %d: Unable to delete old output stream "
2414be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                        "for preview: %s (%d)", __FUNCTION__, mCameraId,
2415be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                        strerror(-res), res);
2416be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                return res;
2417be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            }
2418be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            mPreviewStreamId = NO_STREAM;
2419be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        }
2420be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
2421be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2422be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (mPreviewStreamId == NO_STREAM) {
2423be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        res = mDevice->createStream(mPreviewWindow,
2424836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                params.previewWidth, params.previewHeight,
2425be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                CAMERA2_HAL_PIXEL_FORMAT_OPAQUE, 0,
2426be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                &mPreviewStreamId);
2427be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        if (res != OK) {
2428be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ALOGE("%s: Camera %d: Unable to create preview stream: %s (%d)",
2429be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                    __FUNCTION__, mCameraId, strerror(-res), res);
2430be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            return res;
2431be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        }
2432be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
2433be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2434c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala    res = mDevice->setStreamTransform(mPreviewStreamId,
2435836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            params.previewTransform);
2436c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala    if (res != OK) {
2437c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala        ALOGE("%s: Camera %d: Unable to set preview stream transform: "
2438c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala                "%s (%d)", __FUNCTION__, mCameraId, strerror(-res), res);
2439c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala        return res;
2440c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala    }
2441c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala
2442be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    return OK;
2443be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala}
2444be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2445836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvalastatus_t Camera2Client::updatePreviewRequest(const Parameters &params) {
2446a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala    ATRACE_CALL();
24476db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    status_t res;
24486db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    if (mPreviewRequest == NULL) {
24496db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        res = mDevice->createDefaultRequest(CAMERA2_TEMPLATE_PREVIEW,
24506db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala                &mPreviewRequest);
24516db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        if (res != OK) {
24526db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala            ALOGE("%s: Camera %d: Unable to create default preview request: "
24536db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala                    "%s (%d)", __FUNCTION__, mCameraId, strerror(-res), res);
24546db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala            return res;
24556db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala        }
24566db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    }
2457be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2458836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    res = updateRequestCommon(mPreviewRequest, params);
2459be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) {
2460be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        ALOGE("%s: Camera %d: Unable to update common entries of preview "
2461be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                "request: %s (%d)", __FUNCTION__, mCameraId,
2462be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                strerror(-res), res);
2463be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        return res;
2464be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
2465be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
24666db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala    return OK;
24676db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala}
24686db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala
2469836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvalastatus_t Camera2Client::updateCaptureStream(const Parameters &params) {
2470be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    ATRACE_CALL();
2471d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    status_t res;
2472d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    // Find out buffer size for JPEG
2473d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    camera_metadata_entry_t maxJpegSize =
2474d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            staticInfo(ANDROID_JPEG_MAX_SIZE);
2475d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    if (maxJpegSize.count == 0) {
2476d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        ALOGE("%s: Camera %d: Can't find ANDROID_JPEG_MAX_SIZE!",
2477d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                __FUNCTION__, mCameraId);
2478d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        return INVALID_OPERATION;
2479d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    }
2480d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
2481d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    if (mCaptureConsumer == 0) {
2482d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        // Create CPU buffer queue endpoint
2483d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        mCaptureConsumer = new CpuConsumer(1);
2484d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        mCaptureConsumer->setFrameAvailableListener(new CaptureWaiter(this));
2485d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        mCaptureConsumer->setName(String8("Camera2Client::CaptureConsumer"));
2486d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        mCaptureWindow = new SurfaceTextureClient(
2487d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            mCaptureConsumer->getProducerInterface());
2488d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        // Create memory for API consumption
24899cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        mCaptureHeap = new Camera2Heap(maxJpegSize.data.i32[0], 1,
24909cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                                       "Camera2Client::CaptureHeap");
24919cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        if (mCaptureHeap->mHeap->getSize() == 0) {
2492d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            ALOGE("%s: Camera %d: Unable to allocate memory for capture",
2493d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                    __FUNCTION__, mCameraId);
2494d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            return NO_MEMORY;
2495d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        }
2496d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    }
2497d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
2498be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (mCaptureStreamId != NO_STREAM) {
2499d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        // Check if stream parameters have to change
2500d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        uint32_t currentWidth, currentHeight;
2501d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        res = mDevice->getStreamInfo(mCaptureStreamId,
2502d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                &currentWidth, &currentHeight, 0);
2503d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        if (res != OK) {
2504d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            ALOGE("%s: Camera %d: Error querying capture output stream info: "
2505d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                    "%s (%d)", __FUNCTION__, mCameraId, strerror(-res), res);
2506d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            return res;
2507d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        }
2508836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        if (currentWidth != (uint32_t)params.pictureWidth ||
2509836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                currentHeight != (uint32_t)params.pictureHeight) {
2510d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            res = mDevice->deleteStream(mCaptureStreamId);
2511d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            if (res != OK) {
2512d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                ALOGE("%s: Camera %d: Unable to delete old output stream "
2513d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                        "for capture: %s (%d)", __FUNCTION__, mCameraId,
2514d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                        strerror(-res), res);
2515d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                return res;
2516d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            }
2517d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            mCaptureStreamId = NO_STREAM;
2518d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        }
2519d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    }
2520be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2521be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (mCaptureStreamId == NO_STREAM) {
2522be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        // Create stream for HAL production
2523be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        res = mDevice->createStream(mCaptureWindow,
2524836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                params.pictureWidth, params.pictureHeight,
2525be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                HAL_PIXEL_FORMAT_BLOB, maxJpegSize.data.i32[0],
2526be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                &mCaptureStreamId);
2527be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        if (res != OK) {
2528be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ALOGE("%s: Camera %d: Can't create output stream for capture: "
2529be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                    "%s (%d)", __FUNCTION__, mCameraId, strerror(-res), res);
2530be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            return res;
2531be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        }
2532be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2533be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
2534d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    return OK;
2535d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala}
2536be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2537836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvalastatus_t Camera2Client::updateCaptureRequest(const Parameters &params) {
2538d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    ATRACE_CALL();
2539d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    status_t res;
2540d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    if (mCaptureRequest == NULL) {
2541d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        res = mDevice->createDefaultRequest(CAMERA2_TEMPLATE_STILL_CAPTURE,
2542d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                &mCaptureRequest);
2543d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        if (res != OK) {
2544d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            ALOGE("%s: Camera %d: Unable to create default still image request:"
2545d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala                    " %s (%d)", __FUNCTION__, mCameraId, strerror(-res), res);
2546d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala            return res;
2547d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala        }
2548d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    }
2549be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2550836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    res = updateRequestCommon(mCaptureRequest, params);
2551be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) {
2552be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        ALOGE("%s: Camera %d: Unable to update common entries of capture "
2553be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                "request: %s (%d)", __FUNCTION__, mCameraId,
2554be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                strerror(-res), res);
2555be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        return res;
2556be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
2557be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2558be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(mCaptureRequest,
2559be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_JPEG_THUMBNAIL_SIZE,
2560836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            params.jpegThumbSize, 2);
2561be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2562be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(mCaptureRequest,
2563be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_JPEG_THUMBNAIL_QUALITY,
2564836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            &params.jpegThumbQuality, 1);
2565be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2566be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(mCaptureRequest,
2567be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_JPEG_QUALITY,
2568836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            &params.jpegQuality, 1);
2569be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2570be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(mCaptureRequest,
2571be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_JPEG_ORIENTATION,
2572836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            &params.jpegRotation, 1);
2573be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2574be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2575836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (params.gpsEnabled) {
2576be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        res = updateEntry(mCaptureRequest,
2577be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                ANDROID_JPEG_GPS_COORDINATES,
2578836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                params.gpsCoordinates, 3);
2579be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        if (res != OK) return res;
2580be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        res = updateEntry(mCaptureRequest,
2581be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                ANDROID_JPEG_GPS_TIMESTAMP,
2582836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                &params.gpsTimestamp, 1);
2583be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        if (res != OK) return res;
2584be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        res = updateEntry(mCaptureRequest,
2585be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                ANDROID_JPEG_GPS_PROCESSING_METHOD,
2586836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                params.gpsProcessingMethod.string(),
2587836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                params.gpsProcessingMethod.size());
2588be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        if (res != OK) return res;
2589be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    } else {
2590be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        res = deleteEntry(mCaptureRequest,
2591be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                ANDROID_JPEG_GPS_COORDINATES);
2592be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        if (res != OK) return res;
2593be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        res = deleteEntry(mCaptureRequest,
2594be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                ANDROID_JPEG_GPS_TIMESTAMP);
2595be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        if (res != OK) return res;
2596be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        res = deleteEntry(mCaptureRequest,
2597be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                ANDROID_JPEG_GPS_PROCESSING_METHOD);
2598be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        if (res != OK) return res;
2599be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
2600be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2601d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala    return OK;
2602d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala}
2603d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala
2604836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvalastatus_t Camera2Client::updateRecordingRequest(const Parameters &params) {
26059cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    ATRACE_CALL();
26069cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    status_t res;
26079cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (mRecordingRequest == NULL) {
26089cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        res = mDevice->createDefaultRequest(CAMERA2_TEMPLATE_VIDEO_RECORD,
26099cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                &mRecordingRequest);
26109cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        if (res != OK) {
26119cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            ALOGE("%s: Camera %d: Unable to create default recording request:"
26129cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    " %s (%d)", __FUNCTION__, mCameraId, strerror(-res), res);
26139cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            return res;
26149cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        }
26159cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
26169cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
2617836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    res = updateRequestCommon(mRecordingRequest, params);
26189cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (res != OK) {
26199cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        ALOGE("%s: Camera %d: Unable to update common entries of recording "
26209cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                "request: %s (%d)", __FUNCTION__, mCameraId,
26219cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                strerror(-res), res);
26229cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        return res;
26239cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
26249cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
26259cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    return OK;
26269cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala}
26279cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
2628836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvalastatus_t Camera2Client::updateRecordingStream(const Parameters &params) {
26299cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    status_t res;
26309cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
26319cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (mRecordingConsumer == 0) {
26329cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        // Create CPU buffer queue endpoint
2633803cbf6190f16f7b2c43cbc51d0df21ec888abddEino-Ville Talvala        mRecordingConsumer = new MediaConsumer(kRecordingHeapCount);
26349cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        mRecordingConsumer->setFrameAvailableListener(new RecordingWaiter(this));
26359cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        mRecordingConsumer->setName(String8("Camera2Client::RecordingConsumer"));
26369cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        mRecordingWindow = new SurfaceTextureClient(
26379cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            mRecordingConsumer->getProducerInterface());
26389cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        // Allocate memory later, since we don't know buffer size until receipt
26399cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
26409cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
26419cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (mRecordingStreamId != NO_STREAM) {
26429cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        // Check if stream parameters have to change
26439cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        uint32_t currentWidth, currentHeight;
26449cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        res = mDevice->getStreamInfo(mRecordingStreamId,
26459cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                &currentWidth, &currentHeight, 0);
26469cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        if (res != OK) {
26479cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            ALOGE("%s: Camera %d: Error querying recording output stream info: "
26489cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    "%s (%d)", __FUNCTION__, mCameraId, strerror(-res), res);
26499cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            return res;
26509cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        }
2651836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        if (currentWidth != (uint32_t)params.videoWidth ||
2652836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                currentHeight != (uint32_t)params.videoHeight) {
26539cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            // TODO: Should wait to be sure previous recording has finished
26549cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            res = mDevice->deleteStream(mRecordingStreamId);
26559cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            if (res != OK) {
26569cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                ALOGE("%s: Camera %d: Unable to delete old output stream "
26579cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                        "for recording: %s (%d)", __FUNCTION__, mCameraId,
26589cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                        strerror(-res), res);
26599cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                return res;
26609cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            }
26619cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            mRecordingStreamId = NO_STREAM;
26629cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        }
26639cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
26649cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
26659cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    if (mRecordingStreamId == NO_STREAM) {
26669cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        res = mDevice->createStream(mRecordingWindow,
2667836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                params.videoWidth, params.videoHeight,
266878822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala                CAMERA2_HAL_PIXEL_FORMAT_OPAQUE, 0, &mRecordingStreamId);
26699cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        if (res != OK) {
26709cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            ALOGE("%s: Camera %d: Can't create output stream for recording: "
26719cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala                    "%s (%d)", __FUNCTION__, mCameraId, strerror(-res), res);
26729cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala            return res;
26739cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala        }
26749cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    }
26759cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
26769cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala    return OK;
26779cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala}
26789cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala
2679836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvalastatus_t Camera2Client::updateRequestCommon(camera_metadata_t *request,
2680836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        const Parameters &params) {
2681be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    ATRACE_CALL();
2682be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    status_t res;
2683be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(request,
2684836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            ANDROID_CONTROL_AE_TARGET_FPS_RANGE, params.previewFpsRange, 2);
2685be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2686be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2687836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    uint8_t wbMode = params.autoWhiteBalanceLock ?
2688836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            ANDROID_CONTROL_AWB_LOCKED : params.wbMode;
2689be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(request,
2690be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_CONTROL_AWB_MODE, &wbMode, 1);
2691be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2692be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(request,
2693836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            ANDROID_CONTROL_EFFECT_MODE, &params.effectMode, 1);
2694be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2695be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(request,
2696be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_CONTROL_AE_ANTIBANDING_MODE,
2697836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            &params.antibandingMode, 1);
2698be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2699be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2700be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    uint8_t controlMode =
2701836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            (params.sceneMode == ANDROID_CONTROL_SCENE_MODE_UNSUPPORTED) ?
2702be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_CONTROL_AUTO : ANDROID_CONTROL_USE_SCENE_MODE;
2703be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(request,
2704be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_CONTROL_MODE, &controlMode, 1);
2705be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2706be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (controlMode == ANDROID_CONTROL_USE_SCENE_MODE) {
2707be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        res = updateEntry(request,
2708be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                ANDROID_CONTROL_SCENE_MODE,
2709836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                &params.sceneMode, 1);
2710be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        if (res != OK) return res;
2711be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
2712be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2713be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    uint8_t flashMode = ANDROID_FLASH_OFF;
2714be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    uint8_t aeMode;
2715836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    switch (params.flashMode) {
2716be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        case Parameters::FLASH_MODE_OFF:
2717be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            aeMode = ANDROID_CONTROL_AE_ON; break;
2718be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        case Parameters::FLASH_MODE_AUTO:
2719be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            aeMode = ANDROID_CONTROL_AE_ON_AUTO_FLASH; break;
2720be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        case Parameters::FLASH_MODE_ON:
2721be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            aeMode = ANDROID_CONTROL_AE_ON_ALWAYS_FLASH; break;
2722be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        case Parameters::FLASH_MODE_TORCH:
2723be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            aeMode = ANDROID_CONTROL_AE_ON;
2724be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            flashMode = ANDROID_FLASH_TORCH;
2725be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            break;
2726be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        case Parameters::FLASH_MODE_RED_EYE:
2727be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            aeMode = ANDROID_CONTROL_AE_ON_AUTO_FLASH_REDEYE; break;
2728be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        default:
2729be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ALOGE("%s: Camera %d: Unknown flash mode %d", __FUNCTION__,
2730836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                    mCameraId, params.flashMode);
2731be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            return BAD_VALUE;
2732be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
2733836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (params.autoExposureLock) aeMode = ANDROID_CONTROL_AE_LOCKED;
2734be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2735be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(request,
2736be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_FLASH_MODE, &flashMode, 1);
2737be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2738be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(request,
2739be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_CONTROL_AE_MODE, &aeMode, 1);
2740be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2741be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2742be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    float focusDistance = 0; // infinity focus in diopters
2743be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    uint8_t focusMode;
2744836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    switch (params.focusMode) {
2745be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        case Parameters::FOCUS_MODE_AUTO:
2746be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        case Parameters::FOCUS_MODE_MACRO:
2747be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        case Parameters::FOCUS_MODE_CONTINUOUS_VIDEO:
2748be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        case Parameters::FOCUS_MODE_CONTINUOUS_PICTURE:
2749be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        case Parameters::FOCUS_MODE_EDOF:
2750836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            focusMode = params.focusMode;
2751be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            break;
2752be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        case Parameters::FOCUS_MODE_INFINITY:
2753be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        case Parameters::FOCUS_MODE_FIXED:
2754be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            focusMode = ANDROID_CONTROL_AF_OFF;
2755be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            break;
2756be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        default:
2757be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ALOGE("%s: Camera %d: Unknown focus mode %d", __FUNCTION__,
2758836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                    mCameraId, params.focusMode);
2759be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            return BAD_VALUE;
2760be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
2761be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(request,
2762be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_LENS_FOCUS_DISTANCE, &focusDistance, 1);
2763be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2764be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(request,
2765be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_CONTROL_AF_MODE, &focusMode, 1);
2766be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2767be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2768836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    size_t focusingAreasSize = params.focusingAreas.size() * 5;
2769be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    int32_t *focusingAreas = new int32_t[focusingAreasSize];
2770be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    for (size_t i = 0; i < focusingAreasSize; i += 5) {
2771836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        focusingAreas[i + 0] = params.focusingAreas[i].left;
2772836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        focusingAreas[i + 1] = params.focusingAreas[i].top;
2773836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        focusingAreas[i + 2] = params.focusingAreas[i].right;
2774836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        focusingAreas[i + 3] = params.focusingAreas[i].bottom;
2775836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        focusingAreas[i + 4] = params.focusingAreas[i].weight;
2776be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
2777be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(request,
2778be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_CONTROL_AF_REGIONS, focusingAreas,focusingAreasSize);
2779be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2780be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    delete[] focusingAreas;
2781be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2782be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(request,
2783be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_CONTROL_AE_EXP_COMPENSATION,
2784836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala            &params.exposureCompensation, 1);
2785be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2786be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2787836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    size_t meteringAreasSize = params.meteringAreas.size() * 5;
2788be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    int32_t *meteringAreas = new int32_t[meteringAreasSize];
2789be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    for (size_t i = 0; i < meteringAreasSize; i += 5) {
2790836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        meteringAreas[i + 0] = params.meteringAreas[i].left;
2791836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        meteringAreas[i + 1] = params.meteringAreas[i].top;
2792836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        meteringAreas[i + 2] = params.meteringAreas[i].right;
2793836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        meteringAreas[i + 3] = params.meteringAreas[i].bottom;
2794836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala        meteringAreas[i + 4] = params.meteringAreas[i].weight;
2795be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
2796be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(request,
2797be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_CONTROL_AE_REGIONS, meteringAreas, meteringAreasSize);
2798be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2799be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2800be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(request,
2801be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_CONTROL_AWB_REGIONS, meteringAreas, meteringAreasSize);
2802be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2803be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    delete[] meteringAreas;
2804be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2805be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    // Need to convert zoom index into a crop rectangle. The rectangle is
2806be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    // chosen to maximize its area on the sensor
2807be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2808be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    camera_metadata_entry_t maxDigitalZoom =
2809be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            staticInfo(ANDROID_SCALER_AVAILABLE_MAX_ZOOM);
2810be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    float zoomIncrement = (maxDigitalZoom.data.f[0] - 1) /
2811be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            (NUM_ZOOM_STEPS-1);
2812836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    float zoomRatio = 1 + zoomIncrement * params.zoom;
2813be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2814be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    camera_metadata_entry_t activePixelArraySize =
2815be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            staticInfo(ANDROID_SENSOR_ACTIVE_ARRAY_SIZE, 2, 2);
2816be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    int32_t arrayWidth = activePixelArraySize.data.i32[0];
2817be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    int32_t arrayHeight = activePixelArraySize.data.i32[1];
2818be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    float zoomLeft, zoomTop, zoomWidth, zoomHeight;
2819836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    if (params.previewWidth >= params.previewHeight) {
2820be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        zoomWidth =  arrayWidth / zoomRatio;
2821be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        zoomHeight = zoomWidth *
2822836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                params.previewHeight / params.previewWidth;
2823be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    } else {
2824be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        zoomHeight = arrayHeight / zoomRatio;
2825be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        zoomWidth = zoomHeight *
2826836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala                params.previewWidth / params.previewHeight;
2827be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
2828be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    zoomLeft = (arrayWidth - zoomWidth) / 2;
2829be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    zoomTop = (arrayHeight - zoomHeight) / 2;
2830be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2831be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    int32_t cropRegion[3] = { zoomLeft, zoomTop, zoomWidth };
2832be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(request,
2833be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_SCALER_CROP_REGION, cropRegion, 3);
2834be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2835be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2836be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    // TODO: Decide how to map recordingHint, or whether just to ignore it
2837be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2838836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala    uint8_t vstabMode = params.videoStabilization ?
2839be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_CONTROL_VIDEO_STABILIZATION_ON :
2840be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_CONTROL_VIDEO_STABILIZATION_OFF;
2841be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = updateEntry(request,
2842be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            ANDROID_CONTROL_VIDEO_STABILIZATION_MODE,
2843be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala            &vstabMode, 1);
2844be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) return res;
2845be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2846be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    return OK;
2847be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala}
2848be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2849be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvalastatus_t Camera2Client::updateEntry(camera_metadata_t *buffer,
2850be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        uint32_t tag, const void *data, size_t data_count) {
2851be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    camera_metadata_entry_t entry;
2852be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    status_t res;
2853be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = find_camera_metadata_entry(buffer, tag, &entry);
2854be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res == NAME_NOT_FOUND) {
2855be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        res = add_camera_metadata_entry(buffer,
2856be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                tag, data, data_count);
2857be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    } else if (res == OK) {
2858be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        res = update_camera_metadata_entry(buffer,
2859be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                entry.index, data, data_count, NULL);
2860be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
2861be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2862be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) {
2863be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        ALOGE("%s: Unable to update metadata entry %s.%s (%x): %s (%d)",
2864be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                __FUNCTION__, get_camera_metadata_section_name(tag),
2865be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                get_camera_metadata_tag_name(tag), tag, strerror(-res), res);
2866be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
2867be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    return res;
2868be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala}
2869be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala
2870be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvalastatus_t Camera2Client::deleteEntry(camera_metadata_t *buffer, uint32_t tag) {
2871be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    camera_metadata_entry_t entry;
2872be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    status_t res;
2873be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = find_camera_metadata_entry(buffer, tag, &entry);
2874be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res == NAME_NOT_FOUND) {
2875be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        return OK;
2876be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    } else if (res != OK) {
2877be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        ALOGE("%s: Error looking for entry %s.%s (%x): %s %d",
2878be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                __FUNCTION__,
2879be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                get_camera_metadata_section_name(tag),
2880be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                get_camera_metadata_tag_name(tag), tag, strerror(-res), res);
2881be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        return res;
2882be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
2883be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    res = delete_camera_metadata_entry(buffer, entry.index);
2884be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    if (res != OK) {
2885be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala        ALOGE("%s: Error deleting entry %s.%s (%x): %s %d",
2886be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                __FUNCTION__,
2887be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                get_camera_metadata_section_name(tag),
2888be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala                get_camera_metadata_tag_name(tag), tag, strerror(-res), res);
2889be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    }
2890be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala    return res;
2891be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala}
2892836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala
28936861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvalaint Camera2Client::formatStringToEnum(const char *format) {
28946861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    return
28956861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(format, CameraParameters::PIXEL_FORMAT_YUV422SP) ?
28966861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            HAL_PIXEL_FORMAT_YCbCr_422_SP : // NV16
28976861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(format, CameraParameters::PIXEL_FORMAT_YUV420SP) ?
28986861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            HAL_PIXEL_FORMAT_YCrCb_420_SP : // NV21
28996861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(format, CameraParameters::PIXEL_FORMAT_YUV422I) ?
29006861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            HAL_PIXEL_FORMAT_YCbCr_422_I :  // YUY2
29016861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(format, CameraParameters::PIXEL_FORMAT_YUV420P) ?
29026861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            HAL_PIXEL_FORMAT_YV12 :         // YV12
29036861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(format, CameraParameters::PIXEL_FORMAT_RGB565) ?
29046861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            HAL_PIXEL_FORMAT_RGB_565 :      // RGB565
29056861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(format, CameraParameters::PIXEL_FORMAT_RGBA8888) ?
29066861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            HAL_PIXEL_FORMAT_RGBA_8888 :    // RGB8888
29076861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(format, CameraParameters::PIXEL_FORMAT_BAYER_RGGB) ?
29086861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            HAL_PIXEL_FORMAT_RAW_SENSOR :   // Raw sensor data
29096861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        -1;
29106861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala}
29116861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
29123cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvalaconst char* Camera2Client::formatEnumToString(int format) {
29133cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    const char *fmt;
29143cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    switch(format) {
29153cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        case HAL_PIXEL_FORMAT_YCbCr_422_SP: // NV16
29163cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            fmt = CameraParameters::PIXEL_FORMAT_YUV422SP;
29173cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            break;
29183cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        case HAL_PIXEL_FORMAT_YCrCb_420_SP: // NV21
29193cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            fmt = CameraParameters::PIXEL_FORMAT_YUV420SP;
29203cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            break;
29213cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        case HAL_PIXEL_FORMAT_YCbCr_422_I: // YUY2
29223cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            fmt = CameraParameters::PIXEL_FORMAT_YUV422I;
29233cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            break;
29243cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        case HAL_PIXEL_FORMAT_YV12:        // YV12
29253cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            fmt = CameraParameters::PIXEL_FORMAT_YUV420P;
29263cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            break;
29273cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        case HAL_PIXEL_FORMAT_RGB_565:     // RGB565
29283cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            fmt = CameraParameters::PIXEL_FORMAT_RGB565;
29293cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            break;
29303cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        case HAL_PIXEL_FORMAT_RGBA_8888:   // RGBA8888
29313cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            fmt = CameraParameters::PIXEL_FORMAT_RGBA8888;
29323cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            break;
29333cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        case HAL_PIXEL_FORMAT_RAW_SENSOR:
29343cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            ALOGW("Raw sensor preview format requested.");
29353cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            fmt = CameraParameters::PIXEL_FORMAT_BAYER_RGGB;
29363cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            break;
29373cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala        default:
29383cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            ALOGE("%s: Unknown preview format: %x",
29393cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala                    __FUNCTION__,  format);
29403cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            fmt = NULL;
29413cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala            break;
29423cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    }
29433cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala    return fmt;
29443cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala}
29456861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
29466861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvalaint Camera2Client::wbModeStringToEnum(const char *wbMode) {
29476861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    return
29486861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(wbMode, CameraParameters::WHITE_BALANCE_AUTO) ?
29496861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_AWB_AUTO :
29506861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(wbMode, CameraParameters::WHITE_BALANCE_INCANDESCENT) ?
29516861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_AWB_INCANDESCENT :
29526861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(wbMode, CameraParameters::WHITE_BALANCE_FLUORESCENT) ?
29536861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_AWB_FLUORESCENT :
29546861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(wbMode, CameraParameters::WHITE_BALANCE_WARM_FLUORESCENT) ?
29556861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_AWB_WARM_FLUORESCENT :
29566861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(wbMode, CameraParameters::WHITE_BALANCE_DAYLIGHT) ?
29576861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_AWB_DAYLIGHT :
29586861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(wbMode, CameraParameters::WHITE_BALANCE_CLOUDY_DAYLIGHT) ?
29596861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_AWB_CLOUDY_DAYLIGHT :
29606861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(wbMode, CameraParameters::WHITE_BALANCE_TWILIGHT) ?
29616861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_AWB_TWILIGHT :
29626861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(wbMode, CameraParameters::WHITE_BALANCE_SHADE) ?
29636861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_AWB_SHADE :
29646861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        -1;
29656861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala}
29666861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
29676861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvalaint Camera2Client::effectModeStringToEnum(const char *effectMode) {
29686861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    return
29696861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(effectMode, CameraParameters::EFFECT_NONE) ?
29706861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_EFFECT_OFF :
29716861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(effectMode, CameraParameters::EFFECT_MONO) ?
29726861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_EFFECT_MONO :
29736861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(effectMode, CameraParameters::EFFECT_NEGATIVE) ?
29746861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_EFFECT_NEGATIVE :
29756861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(effectMode, CameraParameters::EFFECT_SOLARIZE) ?
29766861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_EFFECT_SOLARIZE :
29776861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(effectMode, CameraParameters::EFFECT_SEPIA) ?
29786861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_EFFECT_SEPIA :
29796861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(effectMode, CameraParameters::EFFECT_POSTERIZE) ?
29806861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_EFFECT_POSTERIZE :
29816861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(effectMode, CameraParameters::EFFECT_WHITEBOARD) ?
29826861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_EFFECT_WHITEBOARD :
29836861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(effectMode, CameraParameters::EFFECT_BLACKBOARD) ?
29846861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_EFFECT_BLACKBOARD :
29856861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(effectMode, CameraParameters::EFFECT_AQUA) ?
29866861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_EFFECT_AQUA :
29876861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        -1;
29886861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala}
29896861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
29906861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvalaint Camera2Client::abModeStringToEnum(const char *abMode) {
29916861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    return
29926861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(abMode, CameraParameters::ANTIBANDING_AUTO) ?
29936861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_AE_ANTIBANDING_AUTO :
29946861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(abMode, CameraParameters::ANTIBANDING_OFF) ?
29956861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_AE_ANTIBANDING_OFF :
29966861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(abMode, CameraParameters::ANTIBANDING_50HZ) ?
29976861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_AE_ANTIBANDING_50HZ :
29986861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(abMode, CameraParameters::ANTIBANDING_60HZ) ?
29996861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_AE_ANTIBANDING_60HZ :
30006861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        -1;
30016861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala}
30026861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
30036861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvalaint Camera2Client::sceneModeStringToEnum(const char *sceneMode) {
30046861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    return
30056861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(sceneMode, CameraParameters::SCENE_MODE_AUTO) ?
30066861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_SCENE_MODE_UNSUPPORTED :
30076861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(sceneMode, CameraParameters::SCENE_MODE_ACTION) ?
30086861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_SCENE_MODE_ACTION :
30096861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(sceneMode, CameraParameters::SCENE_MODE_PORTRAIT) ?
30106861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_SCENE_MODE_PORTRAIT :
30116861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(sceneMode, CameraParameters::SCENE_MODE_LANDSCAPE) ?
30126861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_SCENE_MODE_LANDSCAPE :
30136861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(sceneMode, CameraParameters::SCENE_MODE_NIGHT) ?
30146861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_SCENE_MODE_NIGHT :
30156861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(sceneMode, CameraParameters::SCENE_MODE_NIGHT_PORTRAIT) ?
30166861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_SCENE_MODE_NIGHT_PORTRAIT :
30176861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(sceneMode, CameraParameters::SCENE_MODE_THEATRE) ?
30186861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_SCENE_MODE_THEATRE :
30196861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(sceneMode, CameraParameters::SCENE_MODE_BEACH) ?
30206861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_SCENE_MODE_BEACH :
30216861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(sceneMode, CameraParameters::SCENE_MODE_SNOW) ?
30226861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_SCENE_MODE_SNOW :
30236861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(sceneMode, CameraParameters::SCENE_MODE_SUNSET) ?
30246861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_SCENE_MODE_SUNSET :
30256861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(sceneMode, CameraParameters::SCENE_MODE_STEADYPHOTO) ?
30266861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_SCENE_MODE_STEADYPHOTO :
30276861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(sceneMode, CameraParameters::SCENE_MODE_FIREWORKS) ?
30286861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_SCENE_MODE_FIREWORKS :
30296861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(sceneMode, CameraParameters::SCENE_MODE_SPORTS) ?
30306861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_SCENE_MODE_SPORTS :
30316861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(sceneMode, CameraParameters::SCENE_MODE_PARTY) ?
30326861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_SCENE_MODE_PARTY :
30336861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(sceneMode, CameraParameters::SCENE_MODE_CANDLELIGHT) ?
30346861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_SCENE_MODE_CANDLELIGHT :
30356861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(sceneMode, CameraParameters::SCENE_MODE_BARCODE) ?
30366861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            ANDROID_CONTROL_SCENE_MODE_BARCODE:
30376861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        -1;
30386861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala}
30396861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
30406861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville TalvalaCamera2Client::Parameters::flashMode_t Camera2Client::flashModeStringToEnum(
30416861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        const char *flashMode) {
30426861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    return
30436861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(flashMode, CameraParameters::FLASH_MODE_OFF) ?
30446861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            Parameters::FLASH_MODE_OFF :
30456861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(flashMode, CameraParameters::FLASH_MODE_AUTO) ?
30466861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            Parameters::FLASH_MODE_AUTO :
30476861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(flashMode, CameraParameters::FLASH_MODE_ON) ?
30486861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            Parameters::FLASH_MODE_ON :
30496861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(flashMode, CameraParameters::FLASH_MODE_RED_EYE) ?
30506861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            Parameters::FLASH_MODE_RED_EYE :
30516861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(flashMode, CameraParameters::FLASH_MODE_TORCH) ?
30526861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            Parameters::FLASH_MODE_TORCH :
30536861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        Parameters::FLASH_MODE_INVALID;
30546861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala}
30556861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
30566861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville TalvalaCamera2Client::Parameters::focusMode_t Camera2Client::focusModeStringToEnum(
30576861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        const char *focusMode) {
30586861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    return
30596861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(focusMode, CameraParameters::FOCUS_MODE_AUTO) ?
30606861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            Parameters::FOCUS_MODE_AUTO :
30616861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(focusMode, CameraParameters::FOCUS_MODE_INFINITY) ?
30626861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            Parameters::FOCUS_MODE_INFINITY :
30636861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(focusMode, CameraParameters::FOCUS_MODE_MACRO) ?
30646861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            Parameters::FOCUS_MODE_MACRO :
30656861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(focusMode, CameraParameters::FOCUS_MODE_FIXED) ?
30666861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            Parameters::FOCUS_MODE_FIXED :
30676861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(focusMode, CameraParameters::FOCUS_MODE_EDOF) ?
30686861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            Parameters::FOCUS_MODE_EDOF :
30696861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(focusMode, CameraParameters::FOCUS_MODE_CONTINUOUS_VIDEO) ?
30706861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            Parameters::FOCUS_MODE_CONTINUOUS_VIDEO :
30716861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(focusMode, CameraParameters::FOCUS_MODE_CONTINUOUS_PICTURE) ?
30726861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            Parameters::FOCUS_MODE_CONTINUOUS_PICTURE :
30736861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        Parameters::FOCUS_MODE_INVALID;
30746861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala}
30756861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
30766861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvalastatus_t Camera2Client::parseAreas(const char *areasCStr,
30776861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        Vector<Parameters::Area> *areas) {
30786861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    static const size_t NUM_FIELDS = 5;
30796861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    areas->clear();
30806861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    if (areasCStr == NULL) {
30816861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        // If no key exists, use default (0,0,0,0,0)
30826861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        areas->push();
30836861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        return OK;
30846861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
30856861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    String8 areasStr(areasCStr);
30866861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    ssize_t areaStart = areasStr.find("(", 0) + 1;
30876861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    while (areaStart != 0) {
30886861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        const char* area = areasStr.string() + areaStart;
30896861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        char *numEnd;
30906861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        int vals[NUM_FIELDS];
30916861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        for (size_t i = 0; i < NUM_FIELDS; i++) {
30926861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            errno = 0;
30936861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            vals[i] = strtol(area, &numEnd, 10);
30946861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            if (errno || numEnd == area) return BAD_VALUE;
30956861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            area = numEnd + 1;
30966861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
30976861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        areas->push(Parameters::Area(
30986861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            vals[0], vals[1], vals[2], vals[3], vals[4]) );
30996861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        areaStart = areasStr.find("(", areaStart) + 1;
31006861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
31016861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    return OK;
31026861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala}
31036861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
31046861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvalastatus_t Camera2Client::validateAreas(const Vector<Parameters::Area> &areas,
31056861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                                      size_t maxRegions) {
31066861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // Definition of valid area can be found in
31076861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    // include/camera/CameraParameters.h
31086861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    if (areas.size() == 0) return BAD_VALUE;
31096861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    if (areas.size() == 1) {
31106861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (areas[0].left == 0 &&
31116861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                areas[0].top == 0 &&
31126861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                areas[0].right == 0 &&
31136861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                areas[0].bottom == 0 &&
31146861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                areas[0].weight == 0) {
31156861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            // Single (0,0,0,0,0) entry is always valid (== driver decides)
31166861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala            return OK;
31176861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        }
31186861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
31196861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    if (areas.size() > maxRegions) {
31206861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        ALOGE("%s: Too many areas requested: %d",
31216861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala                __FUNCTION__, areas.size());
31226861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        return BAD_VALUE;
31236861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
31246861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
31256861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    for (Vector<Parameters::Area>::const_iterator a = areas.begin();
31266861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala         a != areas.end(); a++) {
31276861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (a->weight < 1 || a->weight > 1000) return BAD_VALUE;
31286861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (a->left < -1000 || a->left > 1000) return BAD_VALUE;
31296861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (a->top < -1000 || a->top > 1000) return BAD_VALUE;
31306861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (a->right < -1000 || a->right > 1000) return BAD_VALUE;
31316861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (a->bottom < -1000 || a->bottom > 1000) return BAD_VALUE;
31326861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (a->left >= a->right) return BAD_VALUE;
31336861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        if (a->top >= a->bottom) return BAD_VALUE;
31346861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    }
31356861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    return OK;
31366861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala}
31376861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
31386861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvalabool Camera2Client::boolFromString(const char *boolStr) {
31396861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala    return !boolStr ? false :
31406861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        !strcmp(boolStr, CameraParameters::TRUE) ? true :
31416861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala        false;
31426861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala}
31436861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
3144c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvalaint Camera2Client::degToTransform(int degrees, bool mirror) {
3145c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala    if (!mirror) {
3146c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala        if (degrees == 0) return 0;
3147c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala        else if (degrees == 90) return HAL_TRANSFORM_ROT_90;
3148c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala        else if (degrees == 180) return HAL_TRANSFORM_ROT_180;
3149c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala        else if (degrees == 270) return HAL_TRANSFORM_ROT_270;
3150c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala    } else {  // Do mirror (horizontal flip)
3151c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala        if (degrees == 0) {           // FLIP_H and ROT_0
3152c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala            return HAL_TRANSFORM_FLIP_H;
3153c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala        } else if (degrees == 90) {   // FLIP_H and ROT_90
3154c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala            return HAL_TRANSFORM_FLIP_H | HAL_TRANSFORM_ROT_90;
3155c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala        } else if (degrees == 180) {  // FLIP_H and ROT_180
3156c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala            return HAL_TRANSFORM_FLIP_V;
3157c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala        } else if (degrees == 270) {  // FLIP_H and ROT_270
3158c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala            return HAL_TRANSFORM_FLIP_V | HAL_TRANSFORM_ROT_90;
3159c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala        }
3160c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala    }
3161c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala    ALOGE("%s: Bad input: %d", __FUNCTION__, degrees);
3162c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala    return -1;
3163c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala}
31646861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala
316561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} // namespace android
3166