Camera2Client.cpp revision a53021f776d0c82271727e5817388936513feb92
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 17cc27e117ed01c9a2b4def5a9c7a3103af83ee47eZhijun He#define LOG_TAG "Camera2Client" 18a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala#define ATRACE_TAG ATRACE_TAG_CAMERA 1961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala//#define LOG_NDEBUG 0 20a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala 21377b2ec9a2885f9b6405b07ba900a9e3f4349c38Kévin PETIT#include <inttypes.h> 22f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala#include <utils/Log.h> 23a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala#include <utils/Trace.h> 2461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 2561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#include <cutils/properties.h> 2661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#include <gui/Surface.h> 2761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 287b82efe7a376c882f8f938e1c41b8311a8cdda4aEino-Ville Talvala#include "api1/Camera2Client.h" 297b82efe7a376c882f8f938e1c41b8311a8cdda4aEino-Ville Talvala 307b82efe7a376c882f8f938e1c41b8311a8cdda4aEino-Ville Talvala#include "api1/client2/StreamingProcessor.h" 317b82efe7a376c882f8f938e1c41b8311a8cdda4aEino-Ville Talvala#include "api1/client2/JpegProcessor.h" 327b82efe7a376c882f8f938e1c41b8311a8cdda4aEino-Ville Talvala#include "api1/client2/CaptureSequencer.h" 337b82efe7a376c882f8f938e1c41b8311a8cdda4aEino-Ville Talvala#include "api1/client2/CallbackProcessor.h" 347b82efe7a376c882f8f938e1c41b8311a8cdda4aEino-Ville Talvala#include "api1/client2/ZslProcessor.h" 357b82efe7a376c882f8f938e1c41b8311a8cdda4aEino-Ville Talvala#include "api1/client2/ZslProcessor3.h" 36ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin 3761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#define ALOG1(...) ALOGD_IF(gLogLevel >= 1, __VA_ARGS__); 3861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#define ALOG2(...) ALOGD_IF(gLogLevel >= 2, __VA_ARGS__); 3961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 402e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvalanamespace android { 412e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvalausing namespace camera2; 422e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala 4361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatic int getCallingPid() { 4461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala return IPCThreadState::self()->getCallingPid(); 4561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 4661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 4761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala// Interface used by CameraService 4861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 4961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville TalvalaCamera2Client::Camera2Client(const sp<CameraService>& cameraService, 5061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala const sp<ICameraClient>& cameraClient, 51ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala const String16& clientPackageName, 5261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala int cameraId, 5361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala int cameraFacing, 54ecf17e82505fdb60d59e00b6dd59036df93de655Igor Murashkin int clientPid, 55ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala uid_t clientUid, 56a858ea0495c887621a2fd9c0afc13780deccb597Igor Murashkin int servicePid, 57a858ea0495c887621a2fd9c0afc13780deccb597Igor Murashkin bool legacyMode): 5844cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Camera2ClientBase(cameraService, cameraClient, clientPackageName, 59ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala cameraId, cameraFacing, clientPid, clientUid, servicePid), 60cd8fce8fbe0f515e53a0ea0f50b739cf42ee57a4Yin-Chia Yeh mParameters(cameraId, cameraFacing) 61f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala{ 62a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 63228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 642e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 652e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.state = Parameters::DISCONNECTED; 66a858ea0495c887621a2fd9c0afc13780deccb597Igor Murashkin 67a858ea0495c887621a2fd9c0afc13780deccb597Igor Murashkin mLegacyMode = legacyMode; 68f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala} 69f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 70f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvalastatus_t Camera2Client::initialize(camera_module_t *module) 71f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala{ 72a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 73c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala ALOGV("%s: Initializing client for camera %d", __FUNCTION__, mCameraId); 74f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala status_t res; 75f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 76e6800cea0678dbc0bf697b44c3e4548b0253085cIgor Murashkin res = Camera2ClientBase::initialize(module); 77ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala if (res != OK) { 78ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala return res; 79ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala } 80ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala 81fd6ecdd39bd83ea020f78b425e96310380d66c35Eino-Ville Talvala { 82fd6ecdd39bd83ea020f78b425e96310380d66c35Eino-Ville Talvala SharedParameters::Lock l(mParameters); 83fd6ecdd39bd83ea020f78b425e96310380d66c35Eino-Ville Talvala 84cd8fce8fbe0f515e53a0ea0f50b739cf42ee57a4Yin-Chia Yeh res = l.mParameters.initialize(&(mDevice->info()), mDeviceVersion); 85fd6ecdd39bd83ea020f78b425e96310380d66c35Eino-Ville Talvala if (res != OK) { 86fd6ecdd39bd83ea020f78b425e96310380d66c35Eino-Ville Talvala ALOGE("%s: Camera %d: unable to build defaults: %s (%d)", 87fd6ecdd39bd83ea020f78b425e96310380d66c35Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 88fd6ecdd39bd83ea020f78b425e96310380d66c35Eino-Ville Talvala return NO_INIT; 89fd6ecdd39bd83ea020f78b425e96310380d66c35Eino-Ville Talvala } 90f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala } 913cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala 92da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala String8 threadName; 93da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 9473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor = new StreamingProcessor(this); 95254446a80cb13d5beb606bfc3e60a17473869478Eino-Ville Talvala threadName = String8::format("C2-%d-StreamProc", 96254446a80cb13d5beb606bfc3e60a17473869478Eino-Ville Talvala mCameraId); 97254446a80cb13d5beb606bfc3e60a17473869478Eino-Ville Talvala mStreamingProcessor->run(threadName.string()); 9873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala 99ce124da179775a81ad7dcc3f33315eca451e66f2Igor Murashkin mFrameProcessor = new FrameProcessor(mDevice, this); 1004bb8118816874c696d9f1adab48490df1da365f7Eino-Ville Talvala threadName = String8::format("C2-%d-FrameProc", 101da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCameraId); 102da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mFrameProcessor->run(threadName.string()); 103da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 104da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCaptureSequencer = new CaptureSequencer(this); 1054bb8118816874c696d9f1adab48490df1da365f7Eino-Ville Talvala threadName = String8::format("C2-%d-CaptureSeq", 106da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCameraId); 107da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCaptureSequencer->run(threadName.string()); 108da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 109da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mJpegProcessor = new JpegProcessor(this, mCaptureSequencer); 1104bb8118816874c696d9f1adab48490df1da365f7Eino-Ville Talvala threadName = String8::format("C2-%d-JpegProc", 111ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala mCameraId); 112da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mJpegProcessor->run(threadName.string()); 113ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala 114ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin switch (mDeviceVersion) { 115ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin case CAMERA_DEVICE_API_VERSION_2_0: { 116ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin sp<ZslProcessor> zslProc = 117ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin new ZslProcessor(this, mCaptureSequencer); 118ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin mZslProcessor = zslProc; 119ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin mZslProcessorThread = zslProc; 120ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin break; 121ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin } 12295dd5ba5bf83716f2eed5fe72366c4212464d710Zhijun He case CAMERA_DEVICE_API_VERSION_3_0: 12395dd5ba5bf83716f2eed5fe72366c4212464d710Zhijun He case CAMERA_DEVICE_API_VERSION_3_1: 12495dd5ba5bf83716f2eed5fe72366c4212464d710Zhijun He case CAMERA_DEVICE_API_VERSION_3_2: { 125ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin sp<ZslProcessor3> zslProc = 126ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin new ZslProcessor3(this, mCaptureSequencer); 127ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin mZslProcessor = zslProc; 128ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin mZslProcessorThread = zslProc; 129ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin break; 130ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin } 131ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin default: 132ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin break; 133ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin } 1344bb8118816874c696d9f1adab48490df1da365f7Eino-Ville Talvala threadName = String8::format("C2-%d-ZslProc", 135da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCameraId); 136ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin mZslProcessorThread->run(threadName.string()); 137ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala 138d86a6880fe86bda21a9b53b240996fc410a512a5Eino-Ville Talvala mCallbackProcessor = new CallbackProcessor(this); 1394bb8118816874c696d9f1adab48490df1da365f7Eino-Ville Talvala threadName = String8::format("C2-%d-CallbkProc", 140da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCameraId); 141da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCallbackProcessor->run(threadName.string()); 142d86a6880fe86bda21a9b53b240996fc410a512a5Eino-Ville Talvala 143f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala if (gLogLevel >= 1) { 144fd6ecdd39bd83ea020f78b425e96310380d66c35Eino-Ville Talvala SharedParameters::Lock l(mParameters); 145f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala ALOGD("%s: Default parameters converted from camera %d:", __FUNCTION__, 146f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala mCameraId); 1472e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala ALOGD("%s", l.mParameters.paramsFlattened.string()); 148f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala } 149f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 150f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala return OK; 15161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 15261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 15361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville TalvalaCamera2Client::~Camera2Client() { 154a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 155d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala ALOGV("~Camera2Client"); 1564ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala 157f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala mDestructionStarted = true; 158f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 159c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala disconnect(); 160c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala 161da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala ALOGI("Camera %d: Closed", mCameraId); 16261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 16361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 16461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::dump(int fd, const Vector<String16>& args) { 165611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala String8 result; 166d0158c38ad82c1c3033a6dd5806435def3727784Eino-Ville Talvala result.appendFormat("Client2[%d] (%p) Client: %s PID: %d, dump:\n", 167611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala mCameraId, 16844cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin getRemoteCallback()->asBinder().get(), 169d0158c38ad82c1c3033a6dd5806435def3727784Eino-Ville Talvala String8(mClientPackageName).string(), 170611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala mClientPid); 1717f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" State: "); 1727f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala#define CASE_APPEND_ENUM(x) case x: result.append(#x "\n"); break; 1737f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 1742e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala const Parameters& p = mParameters.unsafeAccess(); 175836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala 1762e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala result.append(Parameters::getStateName(p.state)); 1777f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 1784ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala result.append("\n Current parameters:\n"); 1797f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Preview size: %d x %d\n", 180836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.previewWidth, p.previewHeight); 1817f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Preview FPS range: %d - %d\n", 182836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.previewFpsRange[0], p.previewFpsRange[1]); 1837f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Preview HAL pixel format: 0x%x\n", 184836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.previewFormat); 18511b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala result.appendFormat(" Preview transform: %x\n", 186836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.previewTransform); 1877f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Picture size: %d x %d\n", 188836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.pictureWidth, p.pictureHeight); 1897f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Jpeg thumbnail size: %d x %d\n", 190836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.jpegThumbSize[0], p.jpegThumbSize[1]); 1917f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Jpeg quality: %d, thumbnail quality: %d\n", 192836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.jpegQuality, p.jpegThumbQuality); 193836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala result.appendFormat(" Jpeg rotation: %d\n", p.jpegRotation); 1947f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" GPS tags %s\n", 195836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.gpsEnabled ? "enabled" : "disabled"); 196836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala if (p.gpsEnabled) { 1977f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" GPS lat x long x alt: %f x %f x %f\n", 198836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.gpsCoordinates[0], p.gpsCoordinates[1], 199836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.gpsCoordinates[2]); 200377b2ec9a2885f9b6405b07ba900a9e3f4349c38Kévin PETIT result.appendFormat(" GPS timestamp: %" PRId64 "\n", 201836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.gpsTimestamp); 2027f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" GPS processing method: %s\n", 203836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.gpsProcessingMethod.string()); 2047f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2057f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2067f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" White balance mode: "); 207836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.wbMode) { 208d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_AUTO) 209d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_INCANDESCENT) 210d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_FLUORESCENT) 211d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_WARM_FLUORESCENT) 212d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_DAYLIGHT) 213d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_CLOUDY_DAYLIGHT) 214d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_TWILIGHT) 215d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_SHADE) 2167f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2177f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2187f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2197f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Effect mode: "); 220836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.effectMode) { 221d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_OFF) 222d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_MONO) 223d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_NEGATIVE) 224d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_SOLARIZE) 225d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_SEPIA) 226d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_POSTERIZE) 227d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_WHITEBOARD) 228d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_BLACKBOARD) 229d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_AQUA) 2307f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2317f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2327f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2337f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Antibanding mode: "); 234836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.antibandingMode) { 235d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AE_ANTIBANDING_MODE_AUTO) 236d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AE_ANTIBANDING_MODE_OFF) 237d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AE_ANTIBANDING_MODE_50HZ) 238d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AE_ANTIBANDING_MODE_60HZ) 2397f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2407f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2417f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2427f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Scene mode: "); 243836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.sceneMode) { 244c69b91ceae6255e41c5413796fb0ed4f7af45b15Ruben Brunk case ANDROID_CONTROL_SCENE_MODE_DISABLED: 2457f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append("AUTO\n"); break; 2467f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_ACTION) 2477f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_PORTRAIT) 2487f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_LANDSCAPE) 2497f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_NIGHT) 2507f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_NIGHT_PORTRAIT) 2517f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_THEATRE) 2527f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_BEACH) 2537f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_SNOW) 2547f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_SUNSET) 2557f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_STEADYPHOTO) 2567f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_FIREWORKS) 2577f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_SPORTS) 2587f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_PARTY) 2597f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_CANDLELIGHT) 2607f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_BARCODE) 2617f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2627f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2637f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2647f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Flash mode: "); 265836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.flashMode) { 2667f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_OFF) 2677f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_AUTO) 2687f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_ON) 2697f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_TORCH) 2707f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_RED_EYE) 2717f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_INVALID) 2727f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2737f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2747f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2757f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Focus mode: "); 276836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.focusMode) { 2777f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_AUTO) 2787f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_MACRO) 2797f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_CONTINUOUS_VIDEO) 2807f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_CONTINUOUS_PICTURE) 2817f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_EDOF) 2827f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_INFINITY) 2837f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_FIXED) 2847f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_INVALID) 2857f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2867f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2877f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 288d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala result.append(" Focus state: "); 289d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala switch (p.focusState) { 290d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_INACTIVE) 291d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_PASSIVE_SCAN) 292d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_PASSIVE_FOCUSED) 2934ad28ea0a76c7ecdfcc5b96af2b0afcb0c3e5120Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_PASSIVE_UNFOCUSED) 294d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_ACTIVE_SCAN) 295d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_FOCUSED_LOCKED) 296d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_NOT_FOCUSED_LOCKED) 297d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala default: result.append("UNKNOWN\n"); 298d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala } 299d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala 3007f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Focusing areas:\n"); 301836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala for (size_t i = 0; i < p.focusingAreas.size(); i++) { 3027f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" [ (%d, %d, %d, %d), weight %d ]\n", 303836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.focusingAreas[i].left, 304836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.focusingAreas[i].top, 305836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.focusingAreas[i].right, 306836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.focusingAreas[i].bottom, 307836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.focusingAreas[i].weight); 3087f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 3097f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3107f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Exposure compensation index: %d\n", 311836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.exposureCompensation); 3127f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3137f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" AE lock %s, AWB lock %s\n", 314836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.autoExposureLock ? "enabled" : "disabled", 315836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.autoWhiteBalanceLock ? "enabled" : "disabled" ); 3167f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3177f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Metering areas:\n"); 318836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala for (size_t i = 0; i < p.meteringAreas.size(); i++) { 3197f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" [ (%d, %d, %d, %d), weight %d ]\n", 320836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.meteringAreas[i].left, 321836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.meteringAreas[i].top, 322836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.meteringAreas[i].right, 323836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.meteringAreas[i].bottom, 324836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.meteringAreas[i].weight); 3257f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 3267f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 327836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala result.appendFormat(" Zoom index: %d\n", p.zoom); 328836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala result.appendFormat(" Video size: %d x %d\n", p.videoWidth, 329836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.videoHeight); 3307f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3313297daae9681004775012faba9181d65e097e00cEino-Ville Talvala result.appendFormat(" Recording hint is %s\n", 332836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.recordingHint ? "set" : "not set"); 3337f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3343297daae9681004775012faba9181d65e097e00cEino-Ville Talvala result.appendFormat(" Video stabilization is %s\n", 335836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.videoStabilization ? "enabled" : "disabled"); 3367f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3370181fde7bd20238cb13ae2665f0e5bfe7c2d9ac8Eino-Ville Talvala result.appendFormat(" Selected still capture FPS range: %d - %d\n", 3380181fde7bd20238cb13ae2665f0e5bfe7c2d9ac8Eino-Ville Talvala p.fastInfo.bestStillCaptureFpsRange[0], 3390181fde7bd20238cb13ae2665f0e5bfe7c2d9ac8Eino-Ville Talvala p.fastInfo.bestStillCaptureFpsRange[1]); 3400181fde7bd20238cb13ae2665f0e5bfe7c2d9ac8Eino-Ville Talvala 3413297daae9681004775012faba9181d65e097e00cEino-Ville Talvala result.append(" Current streams:\n"); 342da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala result.appendFormat(" Preview stream ID: %d\n", 343da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala getPreviewStreamId()); 344ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala result.appendFormat(" Capture stream ID: %d\n", 345da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala getCaptureStreamId()); 346da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala result.appendFormat(" Recording stream ID: %d\n", 347da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala getRecordingStreamId()); 348e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala 349e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala result.append(" Quirks for this camera:\n"); 350e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala bool haveQuirk = false; 351e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala if (p.quirks.triggerAfWithAuto) { 352e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala result.appendFormat(" triggerAfWithAuto\n"); 353e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala haveQuirk = true; 354e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala } 355e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala if (p.quirks.useZslFormat) { 356e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala result.appendFormat(" useZslFormat\n"); 357e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala haveQuirk = true; 358e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala } 3597373cbe85e617345f7002256a4be389fe62af913Igor Murashkin if (p.quirks.meteringCropRegion) { 3607373cbe85e617345f7002256a4be389fe62af913Igor Murashkin result.appendFormat(" meteringCropRegion\n"); 3617373cbe85e617345f7002256a4be389fe62af913Igor Murashkin haveQuirk = true; 3627373cbe85e617345f7002256a4be389fe62af913Igor Murashkin } 363fd6ecdd39bd83ea020f78b425e96310380d66c35Eino-Ville Talvala if (p.quirks.partialResults) { 364fd6ecdd39bd83ea020f78b425e96310380d66c35Eino-Ville Talvala result.appendFormat(" usePartialResult\n"); 365fd6ecdd39bd83ea020f78b425e96310380d66c35Eino-Ville Talvala haveQuirk = true; 366fd6ecdd39bd83ea020f78b425e96310380d66c35Eino-Ville Talvala } 367e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala if (!haveQuirk) { 368e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala result.appendFormat(" none\n"); 369e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala } 370e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala 37173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala write(fd, result.string(), result.size()); 3723297daae9681004775012faba9181d65e097e00cEino-Ville Talvala 37373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor->dump(fd, args); 374428b77a2b94b74665a47375b3fdb893b98d71269Eino-Ville Talvala 375da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCaptureSequencer->dump(fd, args); 376da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 377c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala mFrameProcessor->dump(fd, args); 378c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala 37997b38a81ac989ccba02d726011a82541f14166dfEino-Ville Talvala mZslProcessor->dump(fd, args); 38097b38a81ac989ccba02d726011a82541f14166dfEino-Ville Talvala 38144cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin return dumpDevice(fd, args); 3827f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala#undef CASE_APPEND_ENUM 38361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 38461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 38561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala// ICamera interface 38661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 38761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::disconnect() { 388a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 38944cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 390c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala 391c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala // Allow both client and the media server to disconnect at all times 392c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala int callingPid = getCallingPid(); 393c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala if (callingPid != mClientPid && callingPid != mServicePid) return; 394ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 395f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala if (mDevice == 0) return; 396f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 39798bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala ALOGV("Camera %d: Shutting down", mCameraId); 39898bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 399d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala /** 400d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala * disconnect() cannot call any methods that might need to promote a 401d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala * wp<Camera2Client>, since disconnect can be called from the destructor, at 402d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala * which point all such promotions will fail. 403d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala */ 404d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala 405d5087f91357a9218580596b466926ab750bc8ea7Eino-Ville Talvala stopPreviewL(); 4066db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 40798bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala { 40898bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala SharedParameters::Lock l(mParameters); 409c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala if (l.mParameters.state == Parameters::DISCONNECTED) return; 41098bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala l.mParameters.state = Parameters::DISCONNECTED; 41198bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala } 41298bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 413254446a80cb13d5beb606bfc3e60a17473869478Eino-Ville Talvala mStreamingProcessor->requestExit(); 41498bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mFrameProcessor->requestExit(); 41598bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mCaptureSequencer->requestExit(); 41698bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mJpegProcessor->requestExit(); 417ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin mZslProcessorThread->requestExit(); 41898bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mCallbackProcessor->requestExit(); 41998bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 42098bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala ALOGV("Camera %d: Waiting for threads", mCameraId); 42198bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 422254446a80cb13d5beb606bfc3e60a17473869478Eino-Ville Talvala mStreamingProcessor->join(); 42398bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mFrameProcessor->join(); 42498bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mCaptureSequencer->join(); 42598bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mJpegProcessor->join(); 426ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin mZslProcessorThread->join(); 42798bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mCallbackProcessor->join(); 42898bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 429dfe715582943b3fc9bab91f88257a3bba6c6deefRuben Brunk ALOGV("Camera %d: Deleting streams", mCameraId); 430dfe715582943b3fc9bab91f88257a3bba6c6deefRuben Brunk 431dfe715582943b3fc9bab91f88257a3bba6c6deefRuben Brunk mStreamingProcessor->deletePreviewStream(); 432dfe715582943b3fc9bab91f88257a3bba6c6deefRuben Brunk mStreamingProcessor->deleteRecordingStream(); 433dfe715582943b3fc9bab91f88257a3bba6c6deefRuben Brunk mJpegProcessor->deleteStream(); 434dfe715582943b3fc9bab91f88257a3bba6c6deefRuben Brunk mCallbackProcessor->deleteStream(); 435dfe715582943b3fc9bab91f88257a3bba6c6deefRuben Brunk mZslProcessor->deleteStream(); 436dfe715582943b3fc9bab91f88257a3bba6c6deefRuben Brunk 4376551e1ede59f4a3043fb141159ca67bd2c85a911Ruben Brunk // Remove all ZSL stream state before disconnect; needed to work around b/15408128. 4386551e1ede59f4a3043fb141159ca67bd2c85a911Ruben Brunk mZslProcessor->disconnect(); 4396551e1ede59f4a3043fb141159ca67bd2c85a911Ruben Brunk 44098bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala ALOGV("Camera %d: Disconnecting device", mCameraId); 44198bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 44298bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mDevice->disconnect(); 44398bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 4443a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala mDevice.clear(); 4458ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 44661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala CameraService::Client::disconnect(); 44761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 44861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 44961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::connect(const sp<ICameraClient>& client) { 450a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 4519e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 45244cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 453ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 4549cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (mClientPid != 0 && getCallingPid() != mClientPid) { 4559cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Connection attempt from pid %d; " 4569cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala "current locked to pid %d", __FUNCTION__, 4579cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala mCameraId, getCallingPid(), mClientPid); 4589cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return BAD_VALUE; 4599cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 4609cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 4619cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala mClientPid = getCallingPid(); 4628ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 46344cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin mRemoteCallback = client; 46444cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin mSharedCameraCallbacks = client; 4659cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 4669cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return OK; 46761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 46861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 46961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::lock() { 470a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 4719e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 47244cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 4739cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGV("%s: Camera %d: Lock call from pid %d; current client pid %d", 4749cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, getCallingPid(), mClientPid); 475ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 4769cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (mClientPid == 0) { 4779cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala mClientPid = getCallingPid(); 4789cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return OK; 4799cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 4809cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 4819cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (mClientPid != getCallingPid()) { 4829cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Lock call from pid %d; currently locked to pid %d", 4839cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, getCallingPid(), mClientPid); 4849cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return EBUSY; 4859cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 4869cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 4879cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return OK; 48861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 48961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 49061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::unlock() { 491a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 4929e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 49344cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 4949cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGV("%s: Camera %d: Unlock call from pid %d; current client pid %d", 4959cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, getCallingPid(), mClientPid); 496ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 4979cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (mClientPid == getCallingPid()) { 498907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala SharedParameters::Lock l(mParameters); 499907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala if (l.mParameters.state == Parameters::RECORD || 500907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala l.mParameters.state == Parameters::VIDEO_SNAPSHOT) { 501907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala ALOGD("Not allowed to unlock camera during recording."); 502907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala return INVALID_OPERATION; 503907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala } 5049cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala mClientPid = 0; 50544cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin mRemoteCallback.clear(); 50644cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin mSharedCameraCallbacks.clear(); 5079cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return OK; 5089cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 5099cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 5109cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Unlock call from pid %d; currently locked to pid %d", 5119cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, getCallingPid(), mClientPid); 5129cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return EBUSY; 51361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 51461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 5151ce7c34e67c2cf58dd88c31f36f4bd62e375f7f0Eino-Ville Talvalastatus_t Camera2Client::setPreviewTarget( 5168ba01021b573889802e67e029225a96f0dfa471aAndy McFadden const sp<IGraphicBufferProducer>& bufferProducer) { 517a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 5189e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 51944cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 5203a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 5213a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 522ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 5236db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala sp<IBinder> binder; 5246db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala sp<ANativeWindow> window; 5258ba01021b573889802e67e029225a96f0dfa471aAndy McFadden if (bufferProducer != 0) { 5268ba01021b573889802e67e029225a96f0dfa471aAndy McFadden binder = bufferProducer->asBinder(); 5271ce7c34e67c2cf58dd88c31f36f4bd62e375f7f0Eino-Ville Talvala // Using controlledByApp flag to ensure that the buffer queue remains in 5281ce7c34e67c2cf58dd88c31f36f4bd62e375f7f0Eino-Ville Talvala // async mode for the old camera API, where many applications depend 5291ce7c34e67c2cf58dd88c31f36f4bd62e375f7f0Eino-Ville Talvala // on that behavior. 5301ce7c34e67c2cf58dd88c31f36f4bd62e375f7f0Eino-Ville Talvala window = new Surface(bufferProducer, /*controlledByApp*/ true); 5316db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 53236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return setPreviewWindowL(binder, window); 5336db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala} 5346db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 53536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::setPreviewWindowL(const sp<IBinder>& binder, 536be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala sp<ANativeWindow> window) { 537a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 5386db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala status_t res; 5396db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 5406db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala if (binder == mPreviewSurface) { 5419e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: Camera %d: New window is same as old window", 5429e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala __FUNCTION__, mCameraId); 5436db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return NO_ERROR; 5446db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 5456db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 546f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala Parameters::State state; 547f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala { 548f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala SharedParameters::Lock l(mParameters); 549f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala state = l.mParameters.state; 550f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala } 551f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala switch (state) { 5522e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::DISCONNECTED: 5532e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 5542e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STILL_CAPTURE: 5552e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 5569cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Cannot set preview display while in state %s", 5572e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala __FUNCTION__, mCameraId, 558f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala Parameters::getStateName(state)); 5599cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return INVALID_OPERATION; 5602e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STOPPED: 5612e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::WAITING_FOR_PREVIEW_WINDOW: 5629cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala // OK 5639cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 5642e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 5659cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala // Already running preview - need to stop and create a new stream 566d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala res = stopStream(); 567d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala if (res != OK) { 568d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala ALOGE("%s: Unable to stop preview to swap windows: %s (%d)", 569d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala __FUNCTION__, strerror(-res), res); 570d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala return res; 571d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala } 572f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala state = Parameters::WAITING_FOR_PREVIEW_WINDOW; 5739cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 5749cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 5759cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 576bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala mPreviewSurface = binder; 57773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->setPreviewWindow(window); 57873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (res != OK) { 57973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Unable to set new preview window: %s (%d)", 58073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala __FUNCTION__, strerror(-res), res); 58173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return res; 58273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala } 583bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala 584f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala if (state == Parameters::WAITING_FOR_PREVIEW_WINDOW) { 585f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala SharedParameters::Lock l(mParameters); 586f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala l.mParameters.state = state; 5872e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return startPreviewL(l.mParameters, false); 5886db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 5896db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 5906db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return OK; 59161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 59261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 59361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::setPreviewCallbackFlag(int flag) { 594a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 595228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala ALOGV("%s: Camera %d: Flag 0x%x", __FUNCTION__, mCameraId, flag); 59644cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 597ddf3c5025e2f6f35a4c188c19f30142c64a092c4Igor Murashkin 598228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if ( checkPid(__FUNCTION__) != OK) return; 599228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 6002e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 6012e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala setPreviewCallbackFlagL(l.mParameters, flag); 602228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala} 603228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 604228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvalavoid Camera2Client::setPreviewCallbackFlagL(Parameters ¶ms, int flag) { 605228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala status_t res = OK; 606a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala 607a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala switch(params.state) { 608a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala case Parameters::STOPPED: 609a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala case Parameters::WAITING_FOR_PREVIEW_WINDOW: 610a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala case Parameters::PREVIEW: 611a2520db02bead68d4980783c41500ae96511bdf8Zhijun He case Parameters::STILL_CAPTURE: 612a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala // OK 613a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala break; 614a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala default: 615a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (flag & CAMERA_FRAME_CALLBACK_FLAG_ENABLE_MASK) { 616a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGE("%s: Camera %d: Can't use preview callbacks " 617a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala "in state %d", __FUNCTION__, mCameraId, params.state); 618a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala return; 619a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 620a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 621a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala 622228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (flag & CAMERA_FRAME_CALLBACK_FLAG_ONE_SHOT_MASK) { 623228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala ALOGV("%s: setting oneshot", __FUNCTION__); 624228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala params.previewCallbackOneShot = true; 625228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 626228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (params.previewCallbackFlags != (uint32_t)flag) { 6273ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 628527748abf04c0060894fd7aace54959a2c343435Zhijun He if (params.previewCallbackSurface && flag != CAMERA_FRAME_CALLBACK_FLAG_NOOP) { 6293ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala // Disable any existing preview callback window when enabling 6303ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala // preview callback flags 6313ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala res = mCallbackProcessor->setCallbackWindow(NULL); 6323ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala if (res != OK) { 6333ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to clear preview callback surface:" 6343ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala " %s (%d)", __FUNCTION__, mCameraId, strerror(-res), res); 6353ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala return; 6363ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } 6373ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala params.previewCallbackSurface = false; 6383ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } 6393ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 640228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala params.previewCallbackFlags = flag; 6413ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 642a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (params.state == Parameters::PREVIEW) { 643228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala res = startPreviewL(params, true); 644a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (res != OK) { 645a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to refresh request in state %s", 646a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala __FUNCTION__, mCameraId, 647a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala Parameters::getStateName(params.state)); 648a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 6493ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } 6503ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } 6513ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala} 6523ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 6533ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvalastatus_t Camera2Client::setPreviewCallbackTarget( 6543ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala const sp<IGraphicBufferProducer>& callbackProducer) { 6553ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala ATRACE_CALL(); 6563ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 6573ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala Mutex::Autolock icl(mBinderSerializationLock); 6583ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala status_t res; 6593ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 6603ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 6613ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala sp<ANativeWindow> window; 6623ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala if (callbackProducer != 0) { 6633ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala window = new Surface(callbackProducer); 6643ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } 6653ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 6663ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala res = mCallbackProcessor->setCallbackWindow(window); 6673ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala if (res != OK) { 6683ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to set preview callback surface: %s (%d)", 6693ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 6703ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala return res; 6713ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } 6723ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 6733ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala SharedParameters::Lock l(mParameters); 6743ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 6753ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala if (window != NULL) { 6763ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala // Disable traditional callbacks when a valid callback target is given 6773ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala l.mParameters.previewCallbackFlags = CAMERA_FRAME_CALLBACK_FLAG_NOOP; 6783ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala l.mParameters.previewCallbackOneShot = false; 6793ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala l.mParameters.previewCallbackSurface = true; 6803ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } else { 6813ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala // Disable callback target if given a NULL interface. 6823ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala l.mParameters.previewCallbackSurface = false; 6833ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } 6843ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 6853ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala switch(l.mParameters.state) { 6862e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 6873ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala res = startPreviewL(l.mParameters, true); 688228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala break; 6892e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 6902e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 6913ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala res = startRecordingL(l.mParameters, true); 692228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala break; 693228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala default: 694228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala break; 6953ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } 6963ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala if (res != OK) { 6973ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to refresh request in state %s", 6983ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala __FUNCTION__, mCameraId, 6993ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala Parameters::getStateName(l.mParameters.state)); 700228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 701228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 7023ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala return OK; 70361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 70461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 7053ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 70661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::startPreview() { 707a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 7089e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 70944cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 7103a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 7113a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 7122e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 7132e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return startPreviewL(l.mParameters, false); 714d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala} 715ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 716228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvalastatus_t Camera2Client::startPreviewL(Parameters ¶ms, bool restart) { 717d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala ATRACE_CALL(); 7186db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala status_t res; 71922d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin 72022d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin ALOGV("%s: state == %d, restart = %d", __FUNCTION__, params.state, restart); 72122d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin 722a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala if ( (params.state == Parameters::PREVIEW || 723a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala params.state == Parameters::RECORD || 724a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala params.state == Parameters::VIDEO_SNAPSHOT) 725a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala && !restart) { 726a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala // Succeed attempt to re-enter a streaming state 727a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala ALOGI("%s: Camera %d: Preview already active, ignoring restart", 728a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala __FUNCTION__, mCameraId); 72977449ada4b5ca73a948aa4fef9aafe3079a66d61Alex Ray return OK; 73077449ada4b5ca73a948aa4fef9aafe3079a66d61Alex Ray } 73177449ada4b5ca73a948aa4fef9aafe3079a66d61Alex Ray if (params.state > Parameters::PREVIEW && !restart) { 7324ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala ALOGE("%s: Can't start preview in state %s", 7332e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala __FUNCTION__, 7342e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala Parameters::getStateName(params.state)); 7354ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala return INVALID_OPERATION; 7364ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala } 7376db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 73873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (!mStreamingProcessor->haveValidPreviewWindow()) { 7392e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala params.state = Parameters::WAITING_FOR_PREVIEW_WINDOW; 7406db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return OK; 7416db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 7422e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala params.state = Parameters::STOPPED; 743c1b7cc4d3eeb55fd03ff77b099b827e7568480e4Zhijun He int lastPreviewStreamId = mStreamingProcessor->getPreviewStreamId(); 7449cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 74573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->updatePreviewStream(params); 746be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala if (res != OK) { 747be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala ALOGE("%s: Camera %d: Unable to update preview stream: %s (%d)", 748be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 749be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala return res; 7506db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 75173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala 752c1b7cc4d3eeb55fd03ff77b099b827e7568480e4Zhijun He bool previewStreamChanged = mStreamingProcessor->getPreviewStreamId() != lastPreviewStreamId; 753c1b7cc4d3eeb55fd03ff77b099b827e7568480e4Zhijun He 754a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala // We could wait to create the JPEG output stream until first actual use 755a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala // (first takePicture call). However, this would substantially increase the 756a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala // first capture latency on HAL3 devices, and potentially on some HAL2 757a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala // devices. So create it unconditionally at preview start. As a drawback, 758a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala // this increases gralloc memory consumption for applications that don't 759a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala // ever take a picture. 760a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala // TODO: Find a better compromise, though this likely would involve HAL 761a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala // changes. 762e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He int lastJpegStreamId = mJpegProcessor->getStreamId(); 763a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala res = updateProcessorStream(mJpegProcessor, params); 764a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala if (res != OK) { 765a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala ALOGE("%s: Camera %d: Can't pre-configure still image " 766a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala "stream: %s (%d)", 767a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 768a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala return res; 769a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala } 770e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He bool jpegStreamChanged = mJpegProcessor->getStreamId() != lastJpegStreamId; 771a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala 772d1d6467d3bcbc1305eeba0176a2edf04925c368eZhijun He Vector<int32_t> outputStreams; 7733ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala bool callbacksEnabled = (params.previewCallbackFlags & 7743ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala CAMERA_FRAME_CALLBACK_FLAG_ENABLE_MASK) || 7753ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala params.previewCallbackSurface; 7763ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 777228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (callbacksEnabled) { 778a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala // Can't have recording stream hanging around when enabling callbacks, 779a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala // since it exceeds the max stream count on some devices. 780a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (mStreamingProcessor->getRecordingStreamId() != NO_STREAM) { 781a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGV("%s: Camera %d: Clearing out recording stream before " 782a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala "creating callback stream", __FUNCTION__, mCameraId); 783a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala res = mStreamingProcessor->stopStream(); 784a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (res != OK) { 785a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGE("%s: Camera %d: Can't stop streaming to delete " 786a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala "recording stream", __FUNCTION__, mCameraId); 787a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala return res; 788a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 789a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala res = mStreamingProcessor->deleteRecordingStream(); 790a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (res != OK) { 791a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to delete recording stream before " 792a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala "enabling callbacks: %s (%d)", __FUNCTION__, mCameraId, 793a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala strerror(-res), res); 794a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala return res; 795a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 796a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 797a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala 798d86a6880fe86bda21a9b53b240996fc410a512a5Eino-Ville Talvala res = mCallbackProcessor->updateStream(params); 799228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (res != OK) { 800228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to update callback stream: %s (%d)", 801228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 802228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return res; 803228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 80473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams.push(getCallbackStreamId()); 805c1b7cc4d3eeb55fd03ff77b099b827e7568480e4Zhijun He } else if (previewStreamChanged && mCallbackProcessor->getStreamId() != NO_STREAM) { 806c1b7cc4d3eeb55fd03ff77b099b827e7568480e4Zhijun He /** 807c1b7cc4d3eeb55fd03ff77b099b827e7568480e4Zhijun He * Delete the unused callback stream when preview stream is changed and 808c1b7cc4d3eeb55fd03ff77b099b827e7568480e4Zhijun He * preview is not enabled. Don't need stop preview stream as preview is in 809c1b7cc4d3eeb55fd03ff77b099b827e7568480e4Zhijun He * STOPPED state now. 810c1b7cc4d3eeb55fd03ff77b099b827e7568480e4Zhijun He */ 811c1b7cc4d3eeb55fd03ff77b099b827e7568480e4Zhijun He ALOGV("%s: Camera %d: Delete unused preview callback stream.", __FUNCTION__, mCameraId); 812c1b7cc4d3eeb55fd03ff77b099b827e7568480e4Zhijun He res = mCallbackProcessor->deleteStream(); 813c1b7cc4d3eeb55fd03ff77b099b827e7568480e4Zhijun He if (res != OK) { 814c1b7cc4d3eeb55fd03ff77b099b827e7568480e4Zhijun He ALOGE("%s: Camera %d: Unable to delete callback stream %s (%d)", 815c1b7cc4d3eeb55fd03ff77b099b827e7568480e4Zhijun He __FUNCTION__, mCameraId, strerror(-res), res); 816c1b7cc4d3eeb55fd03ff77b099b827e7568480e4Zhijun He return res; 817c1b7cc4d3eeb55fd03ff77b099b827e7568480e4Zhijun He } 818228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 819ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh 820ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh if (params.zslMode && !params.recordingHint && 821ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh getRecordingStreamId() == NO_STREAM) { 822dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin res = updateProcessorStream(mZslProcessor, params); 823da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala if (res != OK) { 824da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to update ZSL stream: %s (%d)", 825da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 826da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala return res; 827da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala } 828e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He 829e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He if (jpegStreamChanged) { 830e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He ALOGV("%s: Camera %d: Clear ZSL buffer queue when Jpeg size is changed", 831e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He __FUNCTION__, mCameraId); 832e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He mZslProcessor->clearZslQueue(); 833e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He } 83473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams.push(getZslStreamId()); 835661076292093f82aec488baf8460cdf204a5efd2Zhijun He } else { 836661076292093f82aec488baf8460cdf204a5efd2Zhijun He mZslProcessor->deleteStream(); 837da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala } 8386db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 83973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams.push(getPreviewStreamId()); 84073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala 8415a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala if (!params.recordingHint) { 84273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (!restart) { 84373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->updatePreviewRequest(params); 8445a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala if (res != OK) { 84573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Camera %d: Can't set up preview request: " 84673bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala "%s (%d)", __FUNCTION__, mCameraId, 84773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala strerror(-res), res); 8485a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala return res; 8495a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala } 8505a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala } 85173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->startStream(StreamingProcessor::PREVIEW, 85273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams); 8535a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala } else { 85473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (!restart) { 85573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->updateRecordingRequest(params); 85673bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (res != OK) { 85773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Camera %d: Can't set up preview request with " 85873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala "record hint: %s (%d)", __FUNCTION__, mCameraId, 85973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala strerror(-res), res); 86073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return res; 86173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala } 86273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala } 86373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->startStream(StreamingProcessor::RECORD, 86473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams); 865be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala } 866be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala if (res != OK) { 86773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Camera %d: Unable to start streaming preview: %s (%d)", 868be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 8696db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return res; 8706db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 8716db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 8722e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala params.state = Parameters::PREVIEW; 8736db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return OK; 87461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 87561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 87661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::stopPreview() { 877a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 8789e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 87944cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 8803a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 8813a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return; 88236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala stopPreviewL(); 883ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala} 884ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 88536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalavoid Camera2Client::stopPreviewL() { 886ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala ATRACE_CALL(); 8874865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala status_t res; 888d5087f91357a9218580596b466926ab750bc8ea7Eino-Ville Talvala const nsecs_t kStopCaptureTimeout = 3000000000LL; // 3 seconds 8892e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala Parameters::State state; 890228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala { 8912e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 8922e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala state = l.mParameters.state; 893228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 894228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 895228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala switch (state) { 8962e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::DISCONNECTED: 897ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala // Nothing to do. 898d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala break; 8992e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STOPPED: 900d5087f91357a9218580596b466926ab750bc8ea7Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 9012e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STILL_CAPTURE: 902d5087f91357a9218580596b466926ab750bc8ea7Eino-Ville Talvala mCaptureSequencer->waitUntilIdle(kStopCaptureTimeout); 903d5087f91357a9218580596b466926ab750bc8ea7Eino-Ville Talvala // no break 9042e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 9052e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 906a27c4aa222c8dd1712617dad954c5f3aa68d5427Ruben Brunk syncWithDevice(); 907d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala res = stopStream(); 908d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala if (res != OK) { 909d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala ALOGE("%s: Camera %d: Can't stop streaming: %s (%d)", 910d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 911d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala } 9124865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala res = mDevice->waitUntilDrained(); 9134865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala if (res != OK) { 9144865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala ALOGE("%s: Camera %d: Waiting to stop streaming failed: %s (%d)", 9154865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 9164865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala } 91728d0327bc80e1e424c3db34c62e8f73cd5ffab1eYin-Chia Yeh // Clean up recording stream 91828d0327bc80e1e424c3db34c62e8f73cd5ffab1eYin-Chia Yeh res = mStreamingProcessor->deleteRecordingStream(); 91928d0327bc80e1e424c3db34c62e8f73cd5ffab1eYin-Chia Yeh if (res != OK) { 92028d0327bc80e1e424c3db34c62e8f73cd5ffab1eYin-Chia Yeh ALOGE("%s: Camera %d: Unable to delete recording stream before " 92128d0327bc80e1e424c3db34c62e8f73cd5ffab1eYin-Chia Yeh "stop preview: %s (%d)", 92228d0327bc80e1e424c3db34c62e8f73cd5ffab1eYin-Chia Yeh __FUNCTION__, mCameraId, strerror(-res), res); 92328d0327bc80e1e424c3db34c62e8f73cd5ffab1eYin-Chia Yeh } 924a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh { 925a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh // Ideally we should recover the override after recording stopped, but 926a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh // right now recording stream will live until here, so we are forced to 927a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh // recover here. TODO: find a better way to handle that (b/17495165) 928a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh SharedParameters::Lock l(mParameters); 929a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh l.mParameters.recoverOverriddenJpegSize(); 930a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh } 931228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala // no break 9322e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::WAITING_FOR_PREVIEW_WINDOW: { 9332e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 9342e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.state = Parameters::STOPPED; 9352e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala commandStopFaceDetectionL(l.mParameters); 936d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala break; 937228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 938d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala default: 939d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala ALOGE("%s: Camera %d: Unknown state %d", __FUNCTION__, mCameraId, 940228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala state); 941d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala } 94261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 94361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 94461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalabool Camera2Client::previewEnabled() { 945a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 94644cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 9473a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 9483a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return false; 9493a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 9502e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 9512e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return l.mParameters.state == Parameters::PREVIEW; 95261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 95361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 95461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::storeMetaDataInBuffers(bool enabled) { 955a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 95644cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 9573a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 9583a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 9593a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 9602e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 9612e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala switch (l.mParameters.state) { 9622e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 9632e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 96478822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala ALOGE("%s: Camera %d: Can't be called in state %s", 9652e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala __FUNCTION__, mCameraId, 9662e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala Parameters::getStateName(l.mParameters.state)); 96778822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala return INVALID_OPERATION; 96878822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala default: 96978822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala // OK 97078822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala break; 97178822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala } 97278822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala 9732e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.storeMetadataInBuffers = enabled; 97478822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala 97578822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala return OK; 97661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 97761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 97861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::startRecording() { 979a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 9809e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 98144cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 9829cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala status_t res; 9833a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 9842e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 985228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 9862e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return startRecordingL(l.mParameters, false); 987228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala} 9883a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 989228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvalastatus_t Camera2Client::startRecordingL(Parameters ¶ms, bool restart) { 990228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala status_t res; 99122d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin 99222d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin ALOGV("%s: state == %d, restart = %d", __FUNCTION__, params.state, restart); 99322d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin 994228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala switch (params.state) { 9952e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STOPPED: 996228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala res = startPreviewL(params, false); 9979cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (res != OK) return res; 9989cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 9992e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 10009cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala // Ready to go 10019cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 10022e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 10032e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 1004228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala // OK to call this when recording is already on, just skip unless 1005228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala // we're looking to restart 1006228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (!restart) return OK; 10079cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 10089cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala default: 10099cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Can't start recording in state %s", 10102e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala __FUNCTION__, mCameraId, 10112e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala Parameters::getStateName(params.state)); 10129cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return INVALID_OPERATION; 10139cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala }; 10149cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 1015228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (!params.storeMetadataInBuffers) { 101678822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala ALOGE("%s: Camera %d: Recording only supported in metadata mode, but " 101778822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala "non-metadata recording mode requested!", __FUNCTION__, 101878822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala mCameraId); 101978822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala return INVALID_OPERATION; 102078822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala } 102178822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala 102273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (!restart) { 102373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mCameraService->playSound(CameraService::SOUND_RECORDING); 102473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor->updateRecordingRequest(params); 102573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (res != OK) { 102673bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Camera %d: Unable to update recording request: %s (%d)", 102773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 102873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return res; 102973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala } 103073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala } 1031609acc0c96bc2aedd42246862b537e045f5184b6Eino-Ville Talvala 1032a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala // Not all devices can support a preview callback stream and a recording 1033a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala // stream at the same time, so assume none of them can. 1034a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (mCallbackProcessor->getStreamId() != NO_STREAM) { 1035a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGV("%s: Camera %d: Clearing out callback stream before " 1036a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala "creating recording stream", __FUNCTION__, mCameraId); 1037a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala res = mStreamingProcessor->stopStream(); 1038a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (res != OK) { 1039a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGE("%s: Camera %d: Can't stop streaming to delete callback stream", 1040a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala __FUNCTION__, mCameraId); 1041a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala return res; 1042a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 1043a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala res = mCallbackProcessor->deleteStream(); 1044a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (res != OK) { 1045a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to delete callback stream before " 1046a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala "record: %s (%d)", __FUNCTION__, mCameraId, 1047a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala strerror(-res), res); 1048a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala return res; 1049a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 1050a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 1051ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh 1052ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh if (mZslProcessor->getStreamId() != NO_STREAM) { 1053ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh ALOGV("%s: Camera %d: Clearing out zsl stream before " 1054ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh "creating recording stream", __FUNCTION__, mCameraId); 1055ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh res = mStreamingProcessor->stopStream(); 1056ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh if (res != OK) { 1057ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh ALOGE("%s: Camera %d: Can't stop streaming to delete callback stream", 1058ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh __FUNCTION__, mCameraId); 1059ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh return res; 1060ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh } 1061ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh res = mDevice->waitUntilDrained(); 1062ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh if (res != OK) { 1063ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh ALOGE("%s: Camera %d: Waiting to stop streaming failed: %s (%d)", 1064ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh __FUNCTION__, mCameraId, strerror(-res), res); 1065ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh } 1066ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh res = mZslProcessor->clearZslQueue(); 1067ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh if (res != OK) { 1068ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh ALOGE("%s: Camera %d: Can't clear zsl queue", 1069ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh __FUNCTION__, mCameraId); 1070ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh return res; 1071ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh } 1072ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh res = mZslProcessor->deleteStream(); 1073ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh if (res != OK) { 1074ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh ALOGE("%s: Camera %d: Unable to delete zsl stream before " 1075ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh "record: %s (%d)", __FUNCTION__, mCameraId, 1076ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh strerror(-res), res); 1077ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh return res; 1078ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh } 1079ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh } 1080ca05ebd4c666322e754ac63236c8b329dbb53b00Yin-Chia Yeh 1081a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala // Disable callbacks if they're enabled; can't record and use callbacks, 1082a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala // and we can't fail record start without stagefright asserting. 1083a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala params.previewCallbackFlags = 0; 1084a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala 1085a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh bool recordingStreamNeedsUpdate; 1086a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh res = mStreamingProcessor->recordingStreamNeedsUpdate(params, &recordingStreamNeedsUpdate); 10879cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (res != OK) { 1088a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh ALOGE("%s: Camera %d: Can't query recording stream", 1089a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh __FUNCTION__, mCameraId); 10909cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return res; 10919cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 109273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala 1093a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh if (recordingStreamNeedsUpdate) { 1094a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh // Need to stop stream here in case updateRecordingStream fails 1095a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh // Right now camera device cannot handle configureStream failure gracefully 1096a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh // when device is streaming 1097a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh res = mStreamingProcessor->stopStream(); 1098a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh if (res != OK) { 1099a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh ALOGE("%s: Camera %d: Can't stop streaming to update record stream", 1100a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh __FUNCTION__, mCameraId); 1101a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh return res; 1102a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh } 1103a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh res = mDevice->waitUntilDrained(); 1104a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh if (res != OK) { 1105a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh ALOGE("%s: Camera %d: Waiting to stop streaming failed: %s (%d)", 1106a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh __FUNCTION__, mCameraId, strerror(-res), res); 1107a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh } 1108a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh res = updateProcessorStream< 1109a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh StreamingProcessor, 1110a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh &StreamingProcessor::updateRecordingStream>(mStreamingProcessor, 1111a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh params); 1112a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh 1113a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh // updateRecordingStream might trigger a configureStream call and device might fail 1114a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh // configureStream due to jpeg size > video size. Try again with jpeg size overridden 1115a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh // to video size. 1116a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh // TODO: This may not be needed after we add stop streaming above. Remove that if 1117a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh // it's the case. 1118a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh if (res == BAD_VALUE) { 1119a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh overrideVideoSnapshotSize(params); 1120a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh res = updateProcessorStream< 1121a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh StreamingProcessor, 1122a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh &StreamingProcessor::updateRecordingStream>(mStreamingProcessor, 1123a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh params); 1124a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh } 1125a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh if (res != OK) { 1126a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh ALOGE("%s: Camera %d: Unable to update recording stream: %s (%d)", 1127a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh __FUNCTION__, mCameraId, strerror(-res), res); 1128a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh return res; 1129a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh } 1130a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh } 1131a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh 1132d1d6467d3bcbc1305eeba0176a2edf04925c368eZhijun He Vector<int32_t> outputStreams; 113373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams.push(getPreviewStreamId()); 113473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams.push(getRecordingStreamId()); 11359cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 113673bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->startStream(StreamingProcessor::RECORD, 113773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams); 11383ea3fcd0822b2f43d87f1d8f67d7bf145864b201Yin-Chia Yeh 1139a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh // startStream might trigger a configureStream call and device might fail 1140a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh // configureStream due to jpeg size > video size. Try again with jpeg size overridden 1141a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh // to video size. 1142a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh if (res == BAD_VALUE) { 1143a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh overrideVideoSnapshotSize(params); 11443ea3fcd0822b2f43d87f1d8f67d7bf145864b201Yin-Chia Yeh res = mStreamingProcessor->startStream(StreamingProcessor::RECORD, 11453ea3fcd0822b2f43d87f1d8f67d7bf145864b201Yin-Chia Yeh outputStreams); 11463ea3fcd0822b2f43d87f1d8f67d7bf145864b201Yin-Chia Yeh } 11473ea3fcd0822b2f43d87f1d8f67d7bf145864b201Yin-Chia Yeh 11489cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (res != OK) { 114973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Camera %d: Unable to start recording stream: %s (%d)", 11509cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 11519cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return res; 11529cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 11539cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 11542e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (params.state < Parameters::RECORD) { 11552e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala params.state = Parameters::RECORD; 1156228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 11579cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 11589cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return OK; 115961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 116061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 116161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::stopRecording() { 1162a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 11639e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 116444cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 11652e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 1166228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 11679cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala status_t res; 11683a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return; 11693a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 11702e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala switch (l.mParameters.state) { 11712e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 11729cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala // OK to stop 11739cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 11742e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STOPPED: 11752e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 11762e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STILL_CAPTURE: 11772e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 11789cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala default: 11799cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Can't stop recording in state %s", 11802e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala __FUNCTION__, mCameraId, 11812e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala Parameters::getStateName(l.mParameters.state)); 11829cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return; 11839cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala }; 11849cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 1185609acc0c96bc2aedd42246862b537e045f5184b6Eino-Ville Talvala mCameraService->playSound(CameraService::SOUND_RECORDING); 1186609acc0c96bc2aedd42246862b537e045f5184b6Eino-Ville Talvala 11875a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala res = startPreviewL(l.mParameters, true); 11889cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (res != OK) { 11895a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to return to preview", 11905a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala __FUNCTION__, mCameraId); 11919cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 119261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 119361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 119461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalabool Camera2Client::recordingEnabled() { 1195a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 119644cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 11978da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong 11983a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( checkPid(__FUNCTION__) != OK) return false; 11993a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 12008da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong return recordingEnabledL(); 12018da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong} 12028da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong 12038da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dongbool Camera2Client::recordingEnabledL() { 12048da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong ATRACE_CALL(); 12052e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 12068da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong 12072e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return (l.mParameters.state == Parameters::RECORD 12082e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala || l.mParameters.state == Parameters::VIDEO_SNAPSHOT); 120961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 121061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 121161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::releaseRecordingFrame(const sp<IMemory>& mem) { 1212a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 121344cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 12143a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( checkPid(__FUNCTION__) != OK) return; 121530e65e7e2ec01e13e45b5e38552a34d2fbb3f866Eino-Ville Talvala 121673bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor->releaseRecordingFrame(mem); 121761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 121861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 121961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::autoFocus() { 1220a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 122144cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 12228a42dd8cd1a245d844f96cfd67dc342d7937e353Eino-Ville Talvala ALOGV("%s: Camera %d", __FUNCTION__, mCameraId); 12233a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 12243a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 12253a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 1226174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala int triggerId; 1227d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala bool notifyImmediately = false; 1228d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala bool notifySuccess = false; 1229174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala { 12302e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 12314865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala if (l.mParameters.state < Parameters::PREVIEW) { 12324865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return INVALID_OPERATION; 12334865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala } 12344865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 12355f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin /** 12365f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin * If the camera does not support auto-focus, it is a no-op and 12375f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin * onAutoFocus(boolean, Camera) callback will be called immediately 12385f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin * with a fake value of success set to true. 12399454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala * 12409454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala * Similarly, if focus mode is set to INFINITY, there's no reason to 12419454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala * bother the HAL. 12425f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin */ 12439454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala if (l.mParameters.focusMode == Parameters::FOCUS_MODE_FIXED || 12449454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala l.mParameters.focusMode == Parameters::FOCUS_MODE_INFINITY) { 1245d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala notifyImmediately = true; 1246d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala notifySuccess = true; 1247d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala } 1248d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala /** 1249d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala * If we're in CAF mode, and AF has already been locked, just fire back 1250d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala * the callback right away; the HAL would not send a notification since 1251d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala * no state change would happen on a AF trigger. 1252d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala */ 1253d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala if ( (l.mParameters.focusMode == Parameters::FOCUS_MODE_CONTINUOUS_PICTURE || 1254d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala l.mParameters.focusMode == Parameters::FOCUS_MODE_CONTINUOUS_VIDEO) && 1255d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala l.mParameters.focusState == ANDROID_CONTROL_AF_STATE_FOCUSED_LOCKED ) { 1256d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala notifyImmediately = true; 1257d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala notifySuccess = true; 1258d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala } 1259d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala /** 1260d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala * Send immediate notification back to client 1261d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala */ 1262d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala if (notifyImmediately) { 126344cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin SharedCameraCallbacks::Lock l(mSharedCameraCallbacks); 126444cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin if (l.mRemoteCallback != 0) { 126544cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin l.mRemoteCallback->notifyCallback(CAMERA_MSG_FOCUS, 1266d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala notifySuccess ? 1 : 0, 0); 12675f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin } 12685f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin return OK; 12695f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin } 1270d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala /** 1271d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala * Handle quirk mode for AF in scene modes 1272d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala */ 127395069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala if (l.mParameters.quirks.triggerAfWithAuto && 1274c69b91ceae6255e41c5413796fb0ed4f7af45b15Ruben Brunk l.mParameters.sceneMode != ANDROID_CONTROL_SCENE_MODE_DISABLED && 1275ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala l.mParameters.focusMode != Parameters::FOCUS_MODE_AUTO && 1276ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala !l.mParameters.focusingAreas[0].isEmpty()) { 127795069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala ALOGV("%s: Quirk: Switching from focusMode %d to AUTO", 127895069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala __FUNCTION__, l.mParameters.focusMode); 127995069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.shadowFocusMode = l.mParameters.focusMode; 128095069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.focusMode = Parameters::FOCUS_MODE_AUTO; 128195069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala updateRequests(l.mParameters); 128295069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala } 128395069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala 12842e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.currentAfTriggerId = ++l.mParameters.afTriggerCounter; 12852e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala triggerId = l.mParameters.currentAfTriggerId; 1286174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 12872b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala ATRACE_ASYNC_BEGIN(kAutofocusLabel, triggerId); 12882b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala 12894865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala syncWithDevice(); 1290174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 1291174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala mDevice->triggerAutofocus(triggerId); 1292174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 12936db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return OK; 129461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 129561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 129661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::cancelAutoFocus() { 1297a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 129844cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 12998a42dd8cd1a245d844f96cfd67dc342d7937e353Eino-Ville Talvala ALOGV("%s: Camera %d", __FUNCTION__, mCameraId); 13003a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 13013a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 13023a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 1303174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala int triggerId; 1304174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala { 13052e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 13069454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala // Canceling does nothing in FIXED or INFINITY modes 13079454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala if (l.mParameters.focusMode == Parameters::FOCUS_MODE_FIXED || 13089454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala l.mParameters.focusMode == Parameters::FOCUS_MODE_INFINITY) { 13099454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala return OK; 13109454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala } 13112b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala 13122b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala // An active AF trigger is canceled 13132b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala if (l.mParameters.afTriggerCounter == l.mParameters.currentAfTriggerId) { 13142b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala ATRACE_ASYNC_END(kAutofocusLabel, l.mParameters.currentAfTriggerId); 13152b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala } 13162b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala 13172e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala triggerId = ++l.mParameters.afTriggerCounter; 131895069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala 131995069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala // When using triggerAfWithAuto quirk, may need to reset focus mode to 1320ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala // the real state at this point. No need to cancel explicitly if 1321ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala // changing the AF mode. 132295069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala if (l.mParameters.shadowFocusMode != Parameters::FOCUS_MODE_INVALID) { 132395069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala ALOGV("%s: Quirk: Restoring focus mode to %d", __FUNCTION__, 132495069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.shadowFocusMode); 132595069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.focusMode = l.mParameters.shadowFocusMode; 132695069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.shadowFocusMode = Parameters::FOCUS_MODE_INVALID; 132795069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala updateRequests(l.mParameters); 1328ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala 1329ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala return OK; 133095069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala } 1331dec84fb1c687509c3125acac76e0af80e4e0afbdYin-Chia Yeh if (l.mParameters.zslMode) { 1332dec84fb1c687509c3125acac76e0af80e4e0afbdYin-Chia Yeh mZslProcessor->clearZslQueue(); 1333dec84fb1c687509c3125acac76e0af80e4e0afbdYin-Chia Yeh } 1334174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 13354865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala syncWithDevice(); 1336174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 1337174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala mDevice->triggerCancelAutofocus(triggerId); 1338174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 13396db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return OK; 134061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 134161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 1342ff82370c7c04340d50673d425f48acafd00f2bc9Ben Murdochstatus_t Camera2Client::takePicture(int msgType) { 1343a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 134444cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 1345d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala status_t res; 13463a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 1347d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala 13482b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala int takePictureCounter; 1349b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala { 1350b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala SharedParameters::Lock l(mParameters); 1351b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala switch (l.mParameters.state) { 1352b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::DISCONNECTED: 1353b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::STOPPED: 1354b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::WAITING_FOR_PREVIEW_WINDOW: 1355b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala ALOGE("%s: Camera %d: Cannot take picture without preview enabled", 1356da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala __FUNCTION__, mCameraId); 1357b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala return INVALID_OPERATION; 1358b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::PREVIEW: 1359b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala // Good to go for takePicture 1360b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala res = commandStopFaceDetectionL(l.mParameters); 1361b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala if (res != OK) { 1362b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala ALOGE("%s: Camera %d: Unable to stop face detection for still capture", 1363b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala __FUNCTION__, mCameraId); 1364b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala return res; 1365b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala } 1366b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala l.mParameters.state = Parameters::STILL_CAPTURE; 1367b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala break; 1368b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::RECORD: 1369b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala // Good to go for video snapshot 1370b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala l.mParameters.state = Parameters::VIDEO_SNAPSHOT; 1371b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala break; 1372b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::STILL_CAPTURE: 1373b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 1374b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala ALOGE("%s: Camera %d: Already taking a picture", 1375b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala __FUNCTION__, mCameraId); 1376b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala return INVALID_OPERATION; 1377b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala } 1378d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala 1379b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala ALOGV("%s: Camera %d: Starting picture capture", __FUNCTION__, mCameraId); 1380d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala 1381e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He int lastJpegStreamId = mJpegProcessor->getStreamId(); 1382dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin res = updateProcessorStream(mJpegProcessor, l.mParameters); 1383b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala if (res != OK) { 1384b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala ALOGE("%s: Camera %d: Can't set up still image stream: %s (%d)", 1385b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 1386b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala return res; 1387b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala } 13882b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala takePictureCounter = ++l.mParameters.takePictureCounter; 1389e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He 1390e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He // Clear ZSL buffer queue when Jpeg size is changed. 1391e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He bool jpegStreamChanged = mJpegProcessor->getStreamId() != lastJpegStreamId; 1392e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He if (l.mParameters.zslMode && jpegStreamChanged) { 1393e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He ALOGV("%s: Camera %d: Clear ZSL buffer queue when Jpeg size is changed", 1394e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He __FUNCTION__, mCameraId); 1395e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He mZslProcessor->clearZslQueue(); 1396e2d83756cb088db15fda73616ca097b8d190e1a1Zhijun He } 1397228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 13988ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 13992b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala ATRACE_ASYNC_BEGIN(kTakepictureLabel, takePictureCounter); 14002b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala 14014865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala // Need HAL to have correct settings before (possibly) triggering precapture 14024865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala syncWithDevice(); 14034865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 1404aa9e3e01b86bd9bfb5ac36c0f360d5fe478cbb2dIgor Murashkin res = mCaptureSequencer->startCapture(msgType); 1405d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala if (res != OK) { 1406da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to start capture: %s (%d)", 1407d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 1408d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala } 1409d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala 1410da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala return res; 141161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 141261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 141361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::setParameters(const String8& params) { 1414a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 14158a42dd8cd1a245d844f96cfd67dc342d7937e353Eino-Ville Talvala ALOGV("%s: Camera %d", __FUNCTION__, mCameraId); 141644cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 14176861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala status_t res; 14183a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 14193a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 14202e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 14216861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala 1422dec84fb1c687509c3125acac76e0af80e4e0afbdYin-Chia Yeh Parameters::focusMode_t focusModeBefore = l.mParameters.focusMode; 14232e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala res = l.mParameters.set(params); 14242e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (res != OK) return res; 1425dec84fb1c687509c3125acac76e0af80e4e0afbdYin-Chia Yeh Parameters::focusMode_t focusModeAfter = l.mParameters.focusMode; 1426dec84fb1c687509c3125acac76e0af80e4e0afbdYin-Chia Yeh 1427dec84fb1c687509c3125acac76e0af80e4e0afbdYin-Chia Yeh if (l.mParameters.zslMode && focusModeAfter != focusModeBefore) { 1428dec84fb1c687509c3125acac76e0af80e4e0afbdYin-Chia Yeh mZslProcessor->clearZslQueue(); 1429dec84fb1c687509c3125acac76e0af80e4e0afbdYin-Chia Yeh } 14309cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 14312e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala res = updateRequests(l.mParameters); 14328ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 14338ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 143461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 1435f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 143661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville TalvalaString8 Camera2Client::getParameters() const { 1437a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 14388a42dd8cd1a245d844f96cfd67dc342d7937e353Eino-Ville Talvala ALOGV("%s: Camera %d", __FUNCTION__, mCameraId); 143944cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 1440ebe865b175b3f1b2a9212cea7b008937c919d8f3Igor Murashkin // The camera service can unconditionally get the parameters at all times 1441ebe865b175b3f1b2a9212cea7b008937c919d8f3Igor Murashkin if (getCallingPid() != mServicePid && checkPid(__FUNCTION__) != OK) return String8(); 1442ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 14432e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::ReadLock l(mParameters); 1444ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 14458a42dd8cd1a245d844f96cfd67dc342d7937e353Eino-Ville Talvala return l.mParameters.get(); 144661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 144761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 144861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::sendCommand(int32_t cmd, int32_t arg1, int32_t arg2) { 1449a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 145044cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 14513a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 14523a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 1453c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala 1454c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala ALOGV("%s: Camera %d: Command %d (%d, %d)", __FUNCTION__, mCameraId, 1455c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala cmd, arg1, arg2); 1456c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala 145736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala switch (cmd) { 145836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_START_SMOOTH_ZOOM: 145936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandStartSmoothZoomL(); 146036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_STOP_SMOOTH_ZOOM: 146136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandStopSmoothZoomL(); 146236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_SET_DISPLAY_ORIENTATION: 146336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandSetDisplayOrientationL(arg1); 146436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_ENABLE_SHUTTER_SOUND: 146536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandEnableShutterSoundL(arg1 == 1); 146636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_PLAY_RECORDING_SOUND: 146736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandPlayRecordingSoundL(); 146836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_START_FACE_DETECTION: 146936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandStartFaceDetectionL(arg1); 1470228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case CAMERA_CMD_STOP_FACE_DETECTION: { 14712e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 14722e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return commandStopFaceDetectionL(l.mParameters); 1473228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 147436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_ENABLE_FOCUS_MOVE_MSG: 147536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandEnableFocusMoveMsgL(arg1 == 1); 147636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_PING: 147736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandPingL(); 147836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_SET_VIDEO_BUFFER_COUNT: 147936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandSetVideoBufferCountL(arg1); 148036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala default: 148136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("%s: Unknown command %d (arguments %d, %d)", 148236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala __FUNCTION__, cmd, arg1, arg2); 1483c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala return BAD_VALUE; 148436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 148536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 148636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 148736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandStartSmoothZoomL() { 148836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("%s: Unimplemented!", __FUNCTION__); 148936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 149036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 149136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 149236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandStopSmoothZoomL() { 149336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("%s: Unimplemented!", __FUNCTION__); 149436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 149536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 149636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 149736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandSetDisplayOrientationL(int degrees) { 14982e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala int transform = Parameters::degToTransform(degrees, 149936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala mCameraFacing == CAMERA_FACING_FRONT); 150036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala if (transform == -1) { 150136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("%s: Camera %d: Error setting %d as display orientation value", 150236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala __FUNCTION__, mCameraId, degrees); 150336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return BAD_VALUE; 150436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 15052e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 15062e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (transform != l.mParameters.previewTransform && 150773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala getPreviewStreamId() != NO_STREAM) { 150873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mDevice->setStreamTransform(getPreviewStreamId(), transform); 150936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 15102e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.previewTransform = transform; 151136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 151236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 151336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 151436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandEnableShutterSoundL(bool enable) { 15152e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 151636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala if (enable) { 15172e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.playShutterSound = true; 1518c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala return OK; 151936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 1520983cf231ab2d176a14595cdae46ff1b0c239af47James Dong 1521a858ea0495c887621a2fd9c0afc13780deccb597Igor Murashkin // the camera2 api legacy mode can unconditionally disable the shutter sound 1522a858ea0495c887621a2fd9c0afc13780deccb597Igor Murashkin if (mLegacyMode) { 1523a858ea0495c887621a2fd9c0afc13780deccb597Igor Murashkin ALOGV("%s: Disable shutter sound in legacy mode", __FUNCTION__); 1524a858ea0495c887621a2fd9c0afc13780deccb597Igor Murashkin l.mParameters.playShutterSound = false; 1525a858ea0495c887621a2fd9c0afc13780deccb597Igor Murashkin return OK; 1526a858ea0495c887621a2fd9c0afc13780deccb597Igor Murashkin } 1527a858ea0495c887621a2fd9c0afc13780deccb597Igor Murashkin 152836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala // Disabling shutter sound may not be allowed. In that case only 152936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala // allow the mediaserver process to disable the sound. 153036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala char value[PROPERTY_VALUE_MAX]; 153136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala property_get("ro.camera.sound.forced", value, "0"); 153236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala if (strncmp(value, "0", 2) != 0) { 153336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala // Disabling shutter sound is not allowed. Deny if the current 153436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala // process is not mediaserver. 153536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala if (getCallingPid() != getpid()) { 153636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("Failed to disable shutter sound. Permission denied (pid %d)", 153736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala getCallingPid()); 153836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return PERMISSION_DENIED; 1539983cf231ab2d176a14595cdae46ff1b0c239af47James Dong } 154036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 1541983cf231ab2d176a14595cdae46ff1b0c239af47James Dong 15422e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.playShutterSound = false; 154336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 154436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 1545983cf231ab2d176a14595cdae46ff1b0c239af47James Dong 154636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandPlayRecordingSoundL() { 154736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala mCameraService->playSound(CameraService::SOUND_RECORDING); 154836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 154936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 155036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 1551ddf3c5025e2f6f35a4c188c19f30142c64a092c4Igor Murashkinstatus_t Camera2Client::commandStartFaceDetectionL(int /*type*/) { 15528ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGV("%s: Camera %d: Starting face detection", 15538ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId); 15548ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala status_t res; 15552e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 15562e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala switch (l.mParameters.state) { 15572e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::DISCONNECTED: 15582e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STOPPED: 15592e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::WAITING_FOR_PREVIEW_WINDOW: 15602e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STILL_CAPTURE: 15618ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Cannot start face detection without preview active", 15628ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId); 15638ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return INVALID_OPERATION; 15642e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 15652e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 15662e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 15678ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala // Good to go for starting face detect 15688ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala break; 15698ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 15708ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala // Ignoring type 15712e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.fastInfo.bestFaceDetectMode == 1572d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin ANDROID_STATISTICS_FACE_DETECT_MODE_OFF) { 15738ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Face detection not supported", 15748ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId); 1575caf3a9c1447f602c658f558025b90413d1b4114dZiv Hendel return BAD_VALUE; 15768ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 15772e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.enableFaceDetect) return OK; 15788ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 15792e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.enableFaceDetect = true; 15808ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 15812e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala res = updateRequests(l.mParameters); 15828ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 15838ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 158436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 158536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 1586228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvalastatus_t Camera2Client::commandStopFaceDetectionL(Parameters ¶ms) { 15878ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala status_t res = OK; 15888ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGV("%s: Camera %d: Stopping face detection", 15898ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId); 15908ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 1591228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (!params.enableFaceDetect) return OK; 15928ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 1593228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala params.enableFaceDetect = false; 15948ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 15952e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (params.state == Parameters::PREVIEW 15962e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala || params.state == Parameters::RECORD 15972e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala || params.state == Parameters::VIDEO_SNAPSHOT) { 1598228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala res = updateRequests(params); 15998ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 16008ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 16018ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 160236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 160336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 160436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandEnableFocusMoveMsgL(bool enable) { 16052e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 16062e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.enableFocusMoveMessages = enable; 1607174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 160836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 160936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 161036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 161136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandPingL() { 161236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala // Always ping back if access is proper and device is alive 16132e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 16142e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.state != Parameters::DISCONNECTED) { 1615983cf231ab2d176a14595cdae46ff1b0c239af47James Dong return OK; 161636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } else { 161736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return NO_INIT; 161836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 161936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 162036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 162136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandSetVideoBufferCountL(size_t count) { 16228da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong if (recordingEnabledL()) { 162336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("%s: Camera %d: Error setting video buffer count after " 162436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala "recording was started", __FUNCTION__, mCameraId); 162536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return INVALID_OPERATION; 1626c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala } 1627c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala 162873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return mStreamingProcessor->setRecordingBufferCount(count); 162961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 163061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 16313cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala/** Device-related methods */ 1632160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvalavoid Camera2Client::notifyAutoFocus(uint8_t newState, int triggerId) { 1633160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala ALOGV("%s: Autofocus state now %d, last trigger %d", 1634160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala __FUNCTION__, newState, triggerId); 1635174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala bool sendCompletedMessage = false; 1636174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala bool sendMovingMessage = false; 1637174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 1638174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala bool success = false; 1639174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala bool afInMotion = false; 1640174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala { 16412e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 16422b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala // Trace end of AF state 16432b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala char tmp[32]; 16442b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala if (l.mParameters.afStateCounter > 0) { 16452b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala camera_metadata_enum_snprint( 16462b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala ANDROID_CONTROL_AF_STATE, l.mParameters.focusState, tmp, sizeof(tmp)); 16472b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala ATRACE_ASYNC_END(tmp, l.mParameters.afStateCounter); 16482b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala } 16492b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala 16502b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala // Update state 1651d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala l.mParameters.focusState = newState; 16522b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala l.mParameters.afStateCounter++; 16532b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala 16542b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala // Trace start of AF state 16552b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala 16562b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala camera_metadata_enum_snprint( 16572b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala ANDROID_CONTROL_AF_STATE, l.mParameters.focusState, tmp, sizeof(tmp)); 16582b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala ATRACE_ASYNC_BEGIN(tmp, l.mParameters.afStateCounter); 16592b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala 16602e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala switch (l.mParameters.focusMode) { 1661174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_AUTO: 1662174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_MACRO: 1663174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Don't send notifications upstream if they're not for the current AF 1664174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // trigger. For example, if cancel was called in between, or if we 1665174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // already sent a notification about this AF call. 16662e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (triggerId != l.mParameters.currentAfTriggerId) break; 1667174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala switch (newState) { 1668174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_FOCUSED_LOCKED: 1669174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala success = true; 1670174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // no break 1671174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_NOT_FOCUSED_LOCKED: 1672174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala sendCompletedMessage = true; 16732e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.currentAfTriggerId = -1; 1674174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1675174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_ACTIVE_SCAN: 1676174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Just starting focusing, ignore 1677174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1678174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_INACTIVE: 1679174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_PASSIVE_SCAN: 1680174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_PASSIVE_FOCUSED: 16814ad28ea0a76c7ecdfcc5b96af2b0afcb0c3e5120Eino-Ville Talvala case ANDROID_CONTROL_AF_STATE_PASSIVE_UNFOCUSED: 1682174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala default: 1683174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Unexpected in AUTO/MACRO mode 1684174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala ALOGE("%s: Unexpected AF state transition in AUTO/MACRO mode: %d", 1685174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala __FUNCTION__, newState); 1686174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1687174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1688174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1689174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_CONTINUOUS_VIDEO: 1690174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_CONTINUOUS_PICTURE: 1691174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala switch (newState) { 1692174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_FOCUSED_LOCKED: 1693174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala success = true; 1694174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // no break 1695174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_NOT_FOCUSED_LOCKED: 1696174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Don't send notifications upstream if they're not for 1697174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // the current AF trigger. For example, if cancel was 1698174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // called in between, or if we already sent a 1699174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // notification about this AF call. 1700174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Send both a 'AF done' callback and a 'AF move' callback 17012e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (triggerId != l.mParameters.currentAfTriggerId) break; 1702174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala sendCompletedMessage = true; 1703174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala afInMotion = false; 17042e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.enableFocusMoveMessages && 17052e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.afInMotion) { 1706174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala sendMovingMessage = true; 1707174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 17082e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.currentAfTriggerId = -1; 1709174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1710174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_INACTIVE: 1711174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Cancel was called, or we switched state; care if 1712174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // currently moving 1713174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala afInMotion = false; 17142e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.enableFocusMoveMessages && 17152e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.afInMotion) { 1716174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala sendMovingMessage = true; 1717174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1718174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1719174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_PASSIVE_SCAN: 1720174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Start passive scan, inform upstream 1721174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala afInMotion = true; 1722174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // no break 1723174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_PASSIVE_FOCUSED: 17244ad28ea0a76c7ecdfcc5b96af2b0afcb0c3e5120Eino-Ville Talvala case ANDROID_CONTROL_AF_STATE_PASSIVE_UNFOCUSED: 1725174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Stop passive scan, inform upstream 17262e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.enableFocusMoveMessages) { 1727174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala sendMovingMessage = true; 1728174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1729174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1730174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 17312e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.afInMotion = afInMotion; 1732174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1733174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_EDOF: 1734174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_INFINITY: 1735174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_FIXED: 1736174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala default: 1737174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala if (newState != ANDROID_CONTROL_AF_STATE_INACTIVE) { 1738a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala ALOGE("%s: Unexpected AF state change %d " 1739a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala "(ID %d) in focus mode %d", 1740a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala __FUNCTION__, newState, triggerId, 1741a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala l.mParameters.focusMode); 1742174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1743174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1744174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1745174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala if (sendMovingMessage) { 174644cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin SharedCameraCallbacks::Lock l(mSharedCameraCallbacks); 174744cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin if (l.mRemoteCallback != 0) { 174844cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin l.mRemoteCallback->notifyCallback(CAMERA_MSG_FOCUS_MOVE, 17498ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala afInMotion ? 1 : 0, 0); 17508ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 1751174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1752603b12efa16e7afb4e6c75f6b353216c83e8e135Eino-Ville Talvala if (sendCompletedMessage) { 17532b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala ATRACE_ASYNC_END(kAutofocusLabel, triggerId); 175444cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin SharedCameraCallbacks::Lock l(mSharedCameraCallbacks); 175544cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin if (l.mRemoteCallback != 0) { 175644cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin l.mRemoteCallback->notifyCallback(CAMERA_MSG_FOCUS, 1757a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala success ? 1 : 0, 0); 17588ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 1759603b12efa16e7afb4e6c75f6b353216c83e8e135Eino-Ville Talvala } 1760160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala} 1761160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala 1762160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvalavoid Camera2Client::notifyAutoExposure(uint8_t newState, int triggerId) { 1763160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala ALOGV("%s: Autoexposure state now %d, last trigger %d", 1764160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala __FUNCTION__, newState, triggerId); 1765da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCaptureSequencer->notifyAutoExposure(newState, triggerId); 1766160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala} 1767160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala 1768a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvalacamera2::SharedParameters& Camera2Client::getParameters() { 1769a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala return mParameters; 1770c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala} 1771c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala 1772da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvalaint Camera2Client::getPreviewStreamId() const { 177373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return mStreamingProcessor->getPreviewStreamId(); 1774da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1775da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 1776da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvalaint Camera2Client::getCaptureStreamId() const { 1777da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala return mJpegProcessor->getStreamId(); 1778da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1779da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 1780da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvalaint Camera2Client::getCallbackStreamId() const { 1781da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala return mCallbackProcessor->getStreamId(); 1782da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1783da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 1784da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvalaint Camera2Client::getRecordingStreamId() const { 178573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return mStreamingProcessor->getRecordingStreamId(); 1786da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1787da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 1788da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvalaint Camera2Client::getZslStreamId() const { 1789da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala return mZslProcessor->getStreamId(); 1790da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1791da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 17924865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalastatus_t Camera2Client::registerFrameListener(int32_t minId, int32_t maxId, 179325a0aef19e170d2695f64b4c48296e7914155a88Zhijun He wp<camera2::FrameProcessor::FilteredListener> listener, bool sendPartials) { 179425a0aef19e170d2695f64b4c48296e7914155a88Zhijun He return mFrameProcessor->registerListener(minId, maxId, listener, sendPartials); 17954865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala} 17964865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 17974865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalastatus_t Camera2Client::removeFrameListener(int32_t minId, int32_t maxId, 1798da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala wp<camera2::FrameProcessor::FilteredListener> listener) { 17994865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return mFrameProcessor->removeListener(minId, maxId, listener); 1800da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1801da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 18024865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalastatus_t Camera2Client::stopStream() { 18034865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return mStreamingProcessor->stopStream(); 1804da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1805da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 18064865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kPreviewRequestIdStart; 18074865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kPreviewRequestIdEnd; 18084865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kRecordingRequestIdStart; 18094865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kRecordingRequestIdEnd; 18104865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kCaptureRequestIdStart; 18114865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kCaptureRequestIdEnd; 1812da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 18133cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala/** Utility methods */ 18143cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala 18155a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvalastatus_t Camera2Client::updateRequests(Parameters ¶ms) { 18168ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala status_t res; 18178ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 181822d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin ALOGV("%s: Camera %d: state = %d", __FUNCTION__, getCameraId(), params.state); 181922d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin 18204865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala res = mStreamingProcessor->incrementStreamingIds(); 18214865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala if (res != OK) { 18224865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala ALOGE("%s: Camera %d: Unable to increment request IDs: %s (%d)", 18234865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 18244865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return res; 18254865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala } 18264865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 182773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->updatePreviewRequest(params); 18288ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala if (res != OK) { 18298ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to update preview request: %s (%d)", 18308ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 18318ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 18328ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 183373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->updateRecordingRequest(params); 18348ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala if (res != OK) { 18358ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to update recording request: %s (%d)", 18368ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 18378ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 18388ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 18398ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 18402e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (params.state == Parameters::PREVIEW) { 18415a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala res = startPreviewL(params, true); 18428ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala if (res != OK) { 18438ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Error streaming new preview request: %s (%d)", 18448ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 18458ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 18468ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 18472e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala } else if (params.state == Parameters::RECORD || 18482e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala params.state == Parameters::VIDEO_SNAPSHOT) { 184973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = startRecordingL(params, true); 18508ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala if (res != OK) { 18518ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Error streaming new record request: %s (%d)", 18528ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 18538ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 18548ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 18558ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 18568ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 18578ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala} 18588ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 18599cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 1860228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvalasize_t Camera2Client::calculateBufferSize(int width, int height, 1861228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala int format, int stride) { 1862228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala switch (format) { 1863228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_YCbCr_422_SP: // NV16 1864228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 2; 1865228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_YCrCb_420_SP: // NV21 1866228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 3 / 2; 1867228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_YCbCr_422_I: // YUY2 1868228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 2; 1869228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_YV12: { // YV12 1870228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala size_t ySize = stride * height; 1871f17b6cf6aa7548ca82e7fed96d71db7821103e57Eino-Ville Talvala size_t uvStride = (stride / 2 + 0xF) & ~0xF; 1872228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala size_t uvSize = uvStride * height / 2; 1873228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return ySize + uvSize * 2; 1874228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 1875228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_RGB_565: 1876228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 2; 1877228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_RGBA_8888: 1878228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 4; 1879228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_RAW_SENSOR: 1880228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 2; 1881228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala default: 1882228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala ALOGE("%s: Unknown preview format: %x", 1883228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala __FUNCTION__, format); 1884228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return 0; 1885228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 1886228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala} 18878ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 18884865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalastatus_t Camera2Client::syncWithDevice() { 18894865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala ATRACE_CALL(); 189043b7ac6bd1a949ecb8ffc7e50d0a2f01a6258034Eino-Ville Talvala const nsecs_t kMaxSyncTimeout = 500000000; // 500 ms 18914865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala status_t res; 18924865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 18934865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala int32_t activeRequestId = mStreamingProcessor->getActiveRequestId(); 18944865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala if (activeRequestId == 0) return OK; 18954865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 18964865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala res = mDevice->waitUntilRequestReceived(activeRequestId, kMaxSyncTimeout); 18974865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala if (res == TIMED_OUT) { 18984865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala ALOGE("%s: Camera %d: Timed out waiting sync with HAL", 18994865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala __FUNCTION__, mCameraId); 19004865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala } else if (res != OK) { 19014865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala ALOGE("%s: Camera %d: Error while waiting to sync with HAL", 19024865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala __FUNCTION__, mCameraId); 19034865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala } 19044865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return res; 19054865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala} 19064865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 1907dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkintemplate <typename ProcessorT> 1908dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkinstatus_t Camera2Client::updateProcessorStream(sp<ProcessorT> processor, 1909dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin camera2::Parameters params) { 191082db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin // No default template arguments until C++11, so we need this overload 191182db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin return updateProcessorStream<ProcessorT, &ProcessorT::updateStream>( 191282db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin processor, params); 191382db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin} 191482db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin 191582db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkintemplate <typename ProcessorT, 191682db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin status_t (ProcessorT::*updateStreamF)(const Parameters &)> 191782db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkinstatus_t Camera2Client::updateProcessorStream(sp<ProcessorT> processor, 191882db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin Parameters params) { 1919dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin status_t res; 1920dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin 192182db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin // Get raw pointer since sp<T> doesn't have operator->* 192282db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin ProcessorT *processorPtr = processor.get(); 192382db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin res = (processorPtr->*updateStreamF)(params); 1924dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin 1925dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin /** 1926dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin * Can't update the stream if it's busy? 1927dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin * 1928dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin * Then we need to stop the device (by temporarily clearing the request 1929dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin * queue) and then try again. Resume streaming once we're done. 1930dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin */ 1931dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin if (res == -EBUSY) { 1932a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGV("%s: Camera %d: Pausing to update stream", __FUNCTION__, 1933a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala mCameraId); 1934dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin res = mStreamingProcessor->togglePauseStream(/*pause*/true); 1935dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin if (res != OK) { 1936dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin ALOGE("%s: Camera %d: Can't pause streaming: %s (%d)", 1937dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin __FUNCTION__, mCameraId, strerror(-res), res); 1938dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin } 1939dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin 1940dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin res = mDevice->waitUntilDrained(); 1941dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin if (res != OK) { 1942dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin ALOGE("%s: Camera %d: Waiting to stop streaming failed: %s (%d)", 1943dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin __FUNCTION__, mCameraId, strerror(-res), res); 1944dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin } 1945dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin 194682db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin res = (processorPtr->*updateStreamF)(params); 1947dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin if (res != OK) { 1948dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin ALOGE("%s: Camera %d: Failed to update processing stream " 1949dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin " despite having halted streaming first: %s (%d)", 1950dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin __FUNCTION__, mCameraId, strerror(-res), res); 1951dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin } 1952dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin 1953dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin res = mStreamingProcessor->togglePauseStream(/*pause*/false); 1954dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin if (res != OK) { 1955dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin ALOGE("%s: Camera %d: Can't unpause streaming: %s (%d)", 1956dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin __FUNCTION__, mCameraId, strerror(-res), res); 1957dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin } 1958dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin } 1959dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin 1960dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin return res; 1961dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin} 196244cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin 1963a53021f776d0c82271727e5817388936513feb92Yin-Chia Yehstatus_t Camera2Client::overrideVideoSnapshotSize(Parameters ¶ms) { 1964a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh ALOGV("%s: Camera %d: configure still size to video size before recording" 1965a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh , __FUNCTION__, mCameraId); 1966a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh params.overrideJpegSizeByVideoSize(); 1967a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh status_t res = updateProcessorStream(mJpegProcessor, params); 1968a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh if (res != OK) { 1969a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh ALOGE("%s: Camera %d: Can't override video snapshot size to video size: %s (%d)", 1970a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh __FUNCTION__, mCameraId, strerror(-res), res); 1971a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh } 1972a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh return res; 1973a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh} 1974a53021f776d0c82271727e5817388936513feb92Yin-Chia Yeh 19752b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvalaconst char* Camera2Client::kAutofocusLabel = "autofocus"; 19762b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvalaconst char* Camera2Client::kTakepictureLabel = "take_picture"; 19772b07e0207da44d7b3cc63c369fd10c9f12a5e2cdEino-Ville Talvala 197861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} // namespace android 1979