Camera2Client.cpp revision 4ad28ea0a76c7ecdfcc5b96af2b0afcb0c3e5120
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 174bb8118816874c696d9f1adab48490df1da365f7Eino-Ville Talvala#define LOG_TAG "Camera2" 18a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala#define ATRACE_TAG ATRACE_TAG_CAMERA 1961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala//#define LOG_NDEBUG 0 20a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala 21f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala#include <utils/Log.h> 22a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala#include <utils/Trace.h> 2361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 2461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#include <cutils/properties.h> 2561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#include <gui/Surface.h> 2661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 277b82efe7a376c882f8f938e1c41b8311a8cdda4aEino-Ville Talvala#include "api1/Camera2Client.h" 287b82efe7a376c882f8f938e1c41b8311a8cdda4aEino-Ville Talvala 297b82efe7a376c882f8f938e1c41b8311a8cdda4aEino-Ville Talvala#include "api1/client2/StreamingProcessor.h" 307b82efe7a376c882f8f938e1c41b8311a8cdda4aEino-Ville Talvala#include "api1/client2/JpegProcessor.h" 317b82efe7a376c882f8f938e1c41b8311a8cdda4aEino-Ville Talvala#include "api1/client2/CaptureSequencer.h" 327b82efe7a376c882f8f938e1c41b8311a8cdda4aEino-Ville Talvala#include "api1/client2/CallbackProcessor.h" 337b82efe7a376c882f8f938e1c41b8311a8cdda4aEino-Ville Talvala#include "api1/client2/ZslProcessor.h" 347b82efe7a376c882f8f938e1c41b8311a8cdda4aEino-Ville Talvala#include "api1/client2/ZslProcessor3.h" 35ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin 3661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#define ALOG1(...) ALOGD_IF(gLogLevel >= 1, __VA_ARGS__); 3761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#define ALOG2(...) ALOGD_IF(gLogLevel >= 2, __VA_ARGS__); 3861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 392e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvalanamespace android { 402e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvalausing namespace camera2; 412e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala 4261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatic int getCallingPid() { 4361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala return IPCThreadState::self()->getCallingPid(); 4461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 4561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 4661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala// Interface used by CameraService 4761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 4861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville TalvalaCamera2Client::Camera2Client(const sp<CameraService>& cameraService, 4961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala const sp<ICameraClient>& cameraClient, 50ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala const String16& clientPackageName, 5161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala int cameraId, 5261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala int cameraFacing, 53ecf17e82505fdb60d59e00b6dd59036df93de655Igor Murashkin int clientPid, 54ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala uid_t clientUid, 55b99c5b8eebb35133a08c46b015624bd4c4a6c477Eino-Ville Talvala int servicePid, 56b99c5b8eebb35133a08c46b015624bd4c4a6c477Eino-Ville Talvala int deviceVersion): 5744cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Camera2ClientBase(cameraService, cameraClient, clientPackageName, 58ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala cameraId, cameraFacing, clientPid, clientUid, servicePid), 59ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin mParameters(cameraId, cameraFacing), 60ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin mDeviceVersion(deviceVersion) 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; 66f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala} 67f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 68f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvalastatus_t Camera2Client::initialize(camera_module_t *module) 69f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala{ 70a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 71c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala ALOGV("%s: Initializing client for camera %d", __FUNCTION__, mCameraId); 72f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala status_t res; 73f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 74e6800cea0678dbc0bf697b44c3e4548b0253085cIgor Murashkin res = Camera2ClientBase::initialize(module); 75ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala if (res != OK) { 76ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala return res; 77ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala } 78ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala 792e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 802e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala 812e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala res = l.mParameters.initialize(&(mDevice->info())); 82f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala if (res != OK) { 83f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala ALOGE("%s: Camera %d: unable to build defaults: %s (%d)", 84f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 85f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala return NO_INIT; 86f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala } 873cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala 88da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala String8 threadName; 89da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 9073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor = new StreamingProcessor(this); 91254446a80cb13d5beb606bfc3e60a17473869478Eino-Ville Talvala threadName = String8::format("C2-%d-StreamProc", 92254446a80cb13d5beb606bfc3e60a17473869478Eino-Ville Talvala mCameraId); 93254446a80cb13d5beb606bfc3e60a17473869478Eino-Ville Talvala mStreamingProcessor->run(threadName.string()); 9473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala 95ce124da179775a81ad7dcc3f33315eca451e66f2Igor Murashkin mFrameProcessor = new FrameProcessor(mDevice, this); 964bb8118816874c696d9f1adab48490df1da365f7Eino-Ville Talvala threadName = String8::format("C2-%d-FrameProc", 97da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCameraId); 98da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mFrameProcessor->run(threadName.string()); 99da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 100da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCaptureSequencer = new CaptureSequencer(this); 1014bb8118816874c696d9f1adab48490df1da365f7Eino-Ville Talvala threadName = String8::format("C2-%d-CaptureSeq", 102da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCameraId); 103da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCaptureSequencer->run(threadName.string()); 104da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 105da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mJpegProcessor = new JpegProcessor(this, mCaptureSequencer); 1064bb8118816874c696d9f1adab48490df1da365f7Eino-Ville Talvala threadName = String8::format("C2-%d-JpegProc", 107ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala mCameraId); 108da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mJpegProcessor->run(threadName.string()); 109ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala 110ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin switch (mDeviceVersion) { 111ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin case CAMERA_DEVICE_API_VERSION_2_0: { 112ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin sp<ZslProcessor> zslProc = 113ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin new ZslProcessor(this, mCaptureSequencer); 114ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin mZslProcessor = zslProc; 115ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin mZslProcessorThread = zslProc; 116ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin break; 117ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin } 118ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin case CAMERA_DEVICE_API_VERSION_3_0:{ 119ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin sp<ZslProcessor3> zslProc = 120ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin new ZslProcessor3(this, mCaptureSequencer); 121ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin mZslProcessor = zslProc; 122ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin mZslProcessorThread = zslProc; 123ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin break; 124ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin } 125ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin default: 126ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin break; 127ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin } 1284bb8118816874c696d9f1adab48490df1da365f7Eino-Ville Talvala threadName = String8::format("C2-%d-ZslProc", 129da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCameraId); 130ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin mZslProcessorThread->run(threadName.string()); 131ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala 132d86a6880fe86bda21a9b53b240996fc410a512a5Eino-Ville Talvala mCallbackProcessor = new CallbackProcessor(this); 1334bb8118816874c696d9f1adab48490df1da365f7Eino-Ville Talvala threadName = String8::format("C2-%d-CallbkProc", 134da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCameraId); 135da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCallbackProcessor->run(threadName.string()); 136d86a6880fe86bda21a9b53b240996fc410a512a5Eino-Ville Talvala 137f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala if (gLogLevel >= 1) { 138f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala ALOGD("%s: Default parameters converted from camera %d:", __FUNCTION__, 139f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala mCameraId); 1402e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala ALOGD("%s", l.mParameters.paramsFlattened.string()); 141f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala } 142f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 143f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala return OK; 14461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 14561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 14661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville TalvalaCamera2Client::~Camera2Client() { 147a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 148d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala ALOGV("~Camera2Client"); 1494ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala 150f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala mDestructionStarted = true; 151f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 152c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala disconnect(); 153c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala 154da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala ALOGI("Camera %d: Closed", mCameraId); 15561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 15661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 15761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::dump(int fd, const Vector<String16>& args) { 158611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala String8 result; 159d0158c38ad82c1c3033a6dd5806435def3727784Eino-Ville Talvala result.appendFormat("Client2[%d] (%p) Client: %s PID: %d, dump:\n", 160611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala mCameraId, 16144cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin getRemoteCallback()->asBinder().get(), 162d0158c38ad82c1c3033a6dd5806435def3727784Eino-Ville Talvala String8(mClientPackageName).string(), 163611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala mClientPid); 1647f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" State: "); 1657f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala#define CASE_APPEND_ENUM(x) case x: result.append(#x "\n"); break; 1667f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 1672e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala const Parameters& p = mParameters.unsafeAccess(); 168836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala 1692e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala result.append(Parameters::getStateName(p.state)); 1707f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 1714ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala result.append("\n Current parameters:\n"); 1727f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Preview size: %d x %d\n", 173836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.previewWidth, p.previewHeight); 1747f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Preview FPS range: %d - %d\n", 175836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.previewFpsRange[0], p.previewFpsRange[1]); 1767f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Preview HAL pixel format: 0x%x\n", 177836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.previewFormat); 17811b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala result.appendFormat(" Preview transform: %x\n", 179836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.previewTransform); 1807f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Picture size: %d x %d\n", 181836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.pictureWidth, p.pictureHeight); 1827f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Jpeg thumbnail size: %d x %d\n", 183836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.jpegThumbSize[0], p.jpegThumbSize[1]); 1847f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Jpeg quality: %d, thumbnail quality: %d\n", 185836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.jpegQuality, p.jpegThumbQuality); 186836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala result.appendFormat(" Jpeg rotation: %d\n", p.jpegRotation); 1877f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" GPS tags %s\n", 188836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.gpsEnabled ? "enabled" : "disabled"); 189836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala if (p.gpsEnabled) { 1907f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" GPS lat x long x alt: %f x %f x %f\n", 191836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.gpsCoordinates[0], p.gpsCoordinates[1], 192836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.gpsCoordinates[2]); 1937f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" GPS timestamp: %lld\n", 194836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.gpsTimestamp); 1957f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" GPS processing method: %s\n", 196836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.gpsProcessingMethod.string()); 1977f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 1987f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 1997f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" White balance mode: "); 200836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.wbMode) { 201d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_AUTO) 202d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_INCANDESCENT) 203d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_FLUORESCENT) 204d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_WARM_FLUORESCENT) 205d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_DAYLIGHT) 206d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_CLOUDY_DAYLIGHT) 207d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_TWILIGHT) 208d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_SHADE) 2097f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2107f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2117f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2127f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Effect mode: "); 213836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.effectMode) { 214d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_OFF) 215d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_MONO) 216d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_NEGATIVE) 217d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_SOLARIZE) 218d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_SEPIA) 219d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_POSTERIZE) 220d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_WHITEBOARD) 221d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_BLACKBOARD) 222d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_AQUA) 2237f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2247f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2257f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2267f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Antibanding mode: "); 227836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.antibandingMode) { 228d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AE_ANTIBANDING_MODE_AUTO) 229d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AE_ANTIBANDING_MODE_OFF) 230d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AE_ANTIBANDING_MODE_50HZ) 231d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AE_ANTIBANDING_MODE_60HZ) 2327f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2337f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2347f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2357f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Scene mode: "); 236836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.sceneMode) { 2377f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala case ANDROID_CONTROL_SCENE_MODE_UNSUPPORTED: 2387f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append("AUTO\n"); break; 2397f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_ACTION) 2407f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_PORTRAIT) 2417f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_LANDSCAPE) 2427f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_NIGHT) 2437f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_NIGHT_PORTRAIT) 2447f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_THEATRE) 2457f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_BEACH) 2467f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_SNOW) 2477f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_SUNSET) 2487f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_STEADYPHOTO) 2497f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_FIREWORKS) 2507f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_SPORTS) 2517f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_PARTY) 2527f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_CANDLELIGHT) 2537f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_BARCODE) 2547f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2557f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2567f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2577f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Flash mode: "); 258836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.flashMode) { 2597f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_OFF) 2607f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_AUTO) 2617f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_ON) 2627f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_TORCH) 2637f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_RED_EYE) 2647f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_INVALID) 2657f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2667f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2677f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2687f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Focus mode: "); 269836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.focusMode) { 2707f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_AUTO) 2717f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_MACRO) 2727f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_CONTINUOUS_VIDEO) 2737f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_CONTINUOUS_PICTURE) 2747f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_EDOF) 2757f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_INFINITY) 2767f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_FIXED) 2777f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_INVALID) 2787f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2797f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2807f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 281d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala result.append(" Focus state: "); 282d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala switch (p.focusState) { 283d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_INACTIVE) 284d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_PASSIVE_SCAN) 285d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_PASSIVE_FOCUSED) 2864ad28ea0a76c7ecdfcc5b96af2b0afcb0c3e5120Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_PASSIVE_UNFOCUSED) 287d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_ACTIVE_SCAN) 288d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_FOCUSED_LOCKED) 289d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_NOT_FOCUSED_LOCKED) 290d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala default: result.append("UNKNOWN\n"); 291d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala } 292d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala 2937f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Focusing areas:\n"); 294836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala for (size_t i = 0; i < p.focusingAreas.size(); i++) { 2957f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" [ (%d, %d, %d, %d), weight %d ]\n", 296836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.focusingAreas[i].left, 297836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.focusingAreas[i].top, 298836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.focusingAreas[i].right, 299836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.focusingAreas[i].bottom, 300836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.focusingAreas[i].weight); 3017f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 3027f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3037f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Exposure compensation index: %d\n", 304836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.exposureCompensation); 3057f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3067f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" AE lock %s, AWB lock %s\n", 307836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.autoExposureLock ? "enabled" : "disabled", 308836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.autoWhiteBalanceLock ? "enabled" : "disabled" ); 3097f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3107f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Metering areas:\n"); 311836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala for (size_t i = 0; i < p.meteringAreas.size(); i++) { 3127f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" [ (%d, %d, %d, %d), weight %d ]\n", 313836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.meteringAreas[i].left, 314836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.meteringAreas[i].top, 315836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.meteringAreas[i].right, 316836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.meteringAreas[i].bottom, 317836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.meteringAreas[i].weight); 3187f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 3197f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 320836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala result.appendFormat(" Zoom index: %d\n", p.zoom); 321836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala result.appendFormat(" Video size: %d x %d\n", p.videoWidth, 322836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.videoHeight); 3237f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3243297daae9681004775012faba9181d65e097e00cEino-Ville Talvala result.appendFormat(" Recording hint is %s\n", 325836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.recordingHint ? "set" : "not set"); 3267f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3273297daae9681004775012faba9181d65e097e00cEino-Ville Talvala result.appendFormat(" Video stabilization is %s\n", 328836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.videoStabilization ? "enabled" : "disabled"); 3297f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3303297daae9681004775012faba9181d65e097e00cEino-Ville Talvala result.append(" Current streams:\n"); 331da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala result.appendFormat(" Preview stream ID: %d\n", 332da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala getPreviewStreamId()); 333ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala result.appendFormat(" Capture stream ID: %d\n", 334da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala getCaptureStreamId()); 335da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala result.appendFormat(" Recording stream ID: %d\n", 336da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala getRecordingStreamId()); 337e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala 338e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala result.append(" Quirks for this camera:\n"); 339e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala bool haveQuirk = false; 340e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala if (p.quirks.triggerAfWithAuto) { 341e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala result.appendFormat(" triggerAfWithAuto\n"); 342e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala haveQuirk = true; 343e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala } 344e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala if (p.quirks.useZslFormat) { 345e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala result.appendFormat(" useZslFormat\n"); 346e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala haveQuirk = true; 347e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala } 3487373cbe85e617345f7002256a4be389fe62af913Igor Murashkin if (p.quirks.meteringCropRegion) { 3497373cbe85e617345f7002256a4be389fe62af913Igor Murashkin result.appendFormat(" meteringCropRegion\n"); 3507373cbe85e617345f7002256a4be389fe62af913Igor Murashkin haveQuirk = true; 3517373cbe85e617345f7002256a4be389fe62af913Igor Murashkin } 352e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala if (!haveQuirk) { 353e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala result.appendFormat(" none\n"); 354e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala } 355e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala 35673bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala write(fd, result.string(), result.size()); 3573297daae9681004775012faba9181d65e097e00cEino-Ville Talvala 35873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor->dump(fd, args); 359428b77a2b94b74665a47375b3fdb893b98d71269Eino-Ville Talvala 360da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCaptureSequencer->dump(fd, args); 361da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 362c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala mFrameProcessor->dump(fd, args); 363c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala 36497b38a81ac989ccba02d726011a82541f14166dfEino-Ville Talvala mZslProcessor->dump(fd, args); 36597b38a81ac989ccba02d726011a82541f14166dfEino-Ville Talvala 36644cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin return dumpDevice(fd, args); 3677f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala#undef CASE_APPEND_ENUM 36861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 36961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 37061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala// ICamera interface 37161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 37261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::disconnect() { 373a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 37444cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 375c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala 376c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala // Allow both client and the media server to disconnect at all times 377c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala int callingPid = getCallingPid(); 378c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala if (callingPid != mClientPid && callingPid != mServicePid) return; 379ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 380f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala if (mDevice == 0) return; 381f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 38298bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala ALOGV("Camera %d: Shutting down", mCameraId); 38398bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 384d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala /** 385d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala * disconnect() cannot call any methods that might need to promote a 386d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala * wp<Camera2Client>, since disconnect can be called from the destructor, at 387d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala * which point all such promotions will fail. 388d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala */ 389d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala 390d5087f91357a9218580596b466926ab750bc8ea7Eino-Ville Talvala stopPreviewL(); 3916db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 39298bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala { 39398bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala SharedParameters::Lock l(mParameters); 394c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala if (l.mParameters.state == Parameters::DISCONNECTED) return; 39598bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala l.mParameters.state = Parameters::DISCONNECTED; 39698bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala } 39798bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 39873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor->deletePreviewStream(); 39973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor->deleteRecordingStream(); 400da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mJpegProcessor->deleteStream(); 401d86a6880fe86bda21a9b53b240996fc410a512a5Eino-Ville Talvala mCallbackProcessor->deleteStream(); 402cf70d3469332445dc3ffd09729da3538612b1bb2Eino-Ville Talvala mZslProcessor->deleteStream(); 403cf70d3469332445dc3ffd09729da3538612b1bb2Eino-Ville Talvala 404254446a80cb13d5beb606bfc3e60a17473869478Eino-Ville Talvala mStreamingProcessor->requestExit(); 40598bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mFrameProcessor->requestExit(); 40698bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mCaptureSequencer->requestExit(); 40798bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mJpegProcessor->requestExit(); 408ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin mZslProcessorThread->requestExit(); 40998bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mCallbackProcessor->requestExit(); 41098bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 41198bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala ALOGV("Camera %d: Waiting for threads", mCameraId); 41298bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 413254446a80cb13d5beb606bfc3e60a17473869478Eino-Ville Talvala mStreamingProcessor->join(); 41498bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mFrameProcessor->join(); 41598bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mCaptureSequencer->join(); 41698bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mJpegProcessor->join(); 417ae500e53efa1d26eb7c13e62d0ecc8d75db2473aIgor Murashkin mZslProcessorThread->join(); 41898bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mCallbackProcessor->join(); 41998bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 42098bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala ALOGV("Camera %d: Disconnecting device", mCameraId); 42198bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 42298bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mDevice->disconnect(); 42398bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 4243a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala mDevice.clear(); 4258ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 42661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala CameraService::Client::disconnect(); 42761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 42861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 42961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::connect(const sp<ICameraClient>& client) { 430a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 4319e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 43244cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 433ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 4349cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (mClientPid != 0 && getCallingPid() != mClientPid) { 4359cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Connection attempt from pid %d; " 4369cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala "current locked to pid %d", __FUNCTION__, 4379cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala mCameraId, getCallingPid(), mClientPid); 4389cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return BAD_VALUE; 4399cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 4409cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 4419cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala mClientPid = getCallingPid(); 4428ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 44344cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin mRemoteCallback = client; 44444cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin mSharedCameraCallbacks = client; 4459cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 4469cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return OK; 44761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 44861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 44961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::lock() { 450a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 4519e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 45244cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 4539cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGV("%s: Camera %d: Lock call from pid %d; current client pid %d", 4549cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, getCallingPid(), mClientPid); 455ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 4569cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (mClientPid == 0) { 4579cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala mClientPid = getCallingPid(); 4589cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return OK; 4599cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 4609cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 4619cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (mClientPid != getCallingPid()) { 4629cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Lock call from pid %d; currently locked to pid %d", 4639cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, getCallingPid(), mClientPid); 4649cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return EBUSY; 4659cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 4669cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 4679cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return OK; 46861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 46961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 47061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::unlock() { 471a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 4729e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 47344cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 4749cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGV("%s: Camera %d: Unlock call from pid %d; current client pid %d", 4759cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, getCallingPid(), mClientPid); 476ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 4779cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (mClientPid == getCallingPid()) { 478907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala SharedParameters::Lock l(mParameters); 479907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala if (l.mParameters.state == Parameters::RECORD || 480907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala l.mParameters.state == Parameters::VIDEO_SNAPSHOT) { 481907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala ALOGD("Not allowed to unlock camera during recording."); 482907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala return INVALID_OPERATION; 483907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala } 4849cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala mClientPid = 0; 48544cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin mRemoteCallback.clear(); 48644cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin mSharedCameraCallbacks.clear(); 4879cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return OK; 4889cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 4899cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 4909cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Unlock call from pid %d; currently locked to pid %d", 4919cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, getCallingPid(), mClientPid); 4929cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return EBUSY; 49361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 49461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 4951ce7c34e67c2cf58dd88c31f36f4bd62e375f7f0Eino-Ville Talvalastatus_t Camera2Client::setPreviewTarget( 4968ba01021b573889802e67e029225a96f0dfa471aAndy McFadden const sp<IGraphicBufferProducer>& bufferProducer) { 497a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 4989e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 49944cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 5003a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 5013a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 502ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 5036db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala sp<IBinder> binder; 5046db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala sp<ANativeWindow> window; 5058ba01021b573889802e67e029225a96f0dfa471aAndy McFadden if (bufferProducer != 0) { 5068ba01021b573889802e67e029225a96f0dfa471aAndy McFadden binder = bufferProducer->asBinder(); 5071ce7c34e67c2cf58dd88c31f36f4bd62e375f7f0Eino-Ville Talvala // Using controlledByApp flag to ensure that the buffer queue remains in 5081ce7c34e67c2cf58dd88c31f36f4bd62e375f7f0Eino-Ville Talvala // async mode for the old camera API, where many applications depend 5091ce7c34e67c2cf58dd88c31f36f4bd62e375f7f0Eino-Ville Talvala // on that behavior. 5101ce7c34e67c2cf58dd88c31f36f4bd62e375f7f0Eino-Ville Talvala window = new Surface(bufferProducer, /*controlledByApp*/ true); 5116db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 51236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return setPreviewWindowL(binder, window); 5136db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala} 5146db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 51536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::setPreviewWindowL(const sp<IBinder>& binder, 516be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala sp<ANativeWindow> window) { 517a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 5186db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala status_t res; 5196db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 5206db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala if (binder == mPreviewSurface) { 5219e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: Camera %d: New window is same as old window", 5229e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala __FUNCTION__, mCameraId); 5236db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return NO_ERROR; 5246db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 5256db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 526f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala Parameters::State state; 527f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala { 528f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala SharedParameters::Lock l(mParameters); 529f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala state = l.mParameters.state; 530f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala } 531f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala switch (state) { 5322e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::DISCONNECTED: 5332e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 5342e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STILL_CAPTURE: 5352e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 5369cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Cannot set preview display while in state %s", 5372e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala __FUNCTION__, mCameraId, 538f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala Parameters::getStateName(state)); 5399cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return INVALID_OPERATION; 5402e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STOPPED: 5412e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::WAITING_FOR_PREVIEW_WINDOW: 5429cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala // OK 5439cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 5442e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 5459cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala // Already running preview - need to stop and create a new stream 546d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala res = stopStream(); 547d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala if (res != OK) { 548d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala ALOGE("%s: Unable to stop preview to swap windows: %s (%d)", 549d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala __FUNCTION__, strerror(-res), res); 550d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala return res; 551d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala } 552f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala state = Parameters::WAITING_FOR_PREVIEW_WINDOW; 5539cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 5549cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 5559cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 556bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala mPreviewSurface = binder; 55773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->setPreviewWindow(window); 55873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (res != OK) { 55973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Unable to set new preview window: %s (%d)", 56073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala __FUNCTION__, strerror(-res), res); 56173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return res; 56273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala } 563bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala 564f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala if (state == Parameters::WAITING_FOR_PREVIEW_WINDOW) { 565f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala SharedParameters::Lock l(mParameters); 566f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala l.mParameters.state = state; 5672e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return startPreviewL(l.mParameters, false); 5686db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 5696db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 5706db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return OK; 57161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 57261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 57361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::setPreviewCallbackFlag(int flag) { 574a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 575228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala ALOGV("%s: Camera %d: Flag 0x%x", __FUNCTION__, mCameraId, flag); 57644cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 577ddf3c5025e2f6f35a4c188c19f30142c64a092c4Igor Murashkin 578228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if ( checkPid(__FUNCTION__) != OK) return; 579228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 5802e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 5812e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala setPreviewCallbackFlagL(l.mParameters, flag); 582228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala} 583228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 584228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvalavoid Camera2Client::setPreviewCallbackFlagL(Parameters ¶ms, int flag) { 585228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala status_t res = OK; 586a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala 587a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala switch(params.state) { 588a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala case Parameters::STOPPED: 589a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala case Parameters::WAITING_FOR_PREVIEW_WINDOW: 590a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala case Parameters::PREVIEW: 591a2520db02bead68d4980783c41500ae96511bdf8Zhijun He case Parameters::STILL_CAPTURE: 592a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala // OK 593a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala break; 594a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala default: 595a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (flag & CAMERA_FRAME_CALLBACK_FLAG_ENABLE_MASK) { 596a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGE("%s: Camera %d: Can't use preview callbacks " 597a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala "in state %d", __FUNCTION__, mCameraId, params.state); 598a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala return; 599a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 600a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 601a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala 602228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (flag & CAMERA_FRAME_CALLBACK_FLAG_ONE_SHOT_MASK) { 603228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala ALOGV("%s: setting oneshot", __FUNCTION__); 604228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala params.previewCallbackOneShot = true; 605228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 606228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (params.previewCallbackFlags != (uint32_t)flag) { 6073ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 608527748abf04c0060894fd7aace54959a2c343435Zhijun He if (params.previewCallbackSurface && flag != CAMERA_FRAME_CALLBACK_FLAG_NOOP) { 6093ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala // Disable any existing preview callback window when enabling 6103ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala // preview callback flags 6113ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala res = mCallbackProcessor->setCallbackWindow(NULL); 6123ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala if (res != OK) { 6133ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to clear preview callback surface:" 6143ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala " %s (%d)", __FUNCTION__, mCameraId, strerror(-res), res); 6153ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala return; 6163ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } 6173ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala params.previewCallbackSurface = false; 6183ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } 6193ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 620228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala params.previewCallbackFlags = flag; 6213ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 622a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (params.state == Parameters::PREVIEW) { 623228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala res = startPreviewL(params, true); 624a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (res != OK) { 625a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to refresh request in state %s", 626a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala __FUNCTION__, mCameraId, 627a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala Parameters::getStateName(params.state)); 628a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 6293ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } 6303ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } 6313ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala} 6323ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 6333ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvalastatus_t Camera2Client::setPreviewCallbackTarget( 6343ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala const sp<IGraphicBufferProducer>& callbackProducer) { 6353ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala ATRACE_CALL(); 6363ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 6373ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala Mutex::Autolock icl(mBinderSerializationLock); 6383ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala status_t res; 6393ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 6403ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 6413ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala sp<ANativeWindow> window; 6423ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala if (callbackProducer != 0) { 6433ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala window = new Surface(callbackProducer); 6443ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } 6453ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 6463ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala res = mCallbackProcessor->setCallbackWindow(window); 6473ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala if (res != OK) { 6483ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to set preview callback surface: %s (%d)", 6493ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 6503ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala return res; 6513ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } 6523ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 6533ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala SharedParameters::Lock l(mParameters); 6543ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 6553ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala if (window != NULL) { 6563ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala // Disable traditional callbacks when a valid callback target is given 6573ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala l.mParameters.previewCallbackFlags = CAMERA_FRAME_CALLBACK_FLAG_NOOP; 6583ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala l.mParameters.previewCallbackOneShot = false; 6593ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala l.mParameters.previewCallbackSurface = true; 6603ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } else { 6613ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala // Disable callback target if given a NULL interface. 6623ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala l.mParameters.previewCallbackSurface = false; 6633ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } 6643ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 6653ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala switch(l.mParameters.state) { 6662e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 6673ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala res = startPreviewL(l.mParameters, true); 668228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala break; 6692e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 6702e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 6713ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala res = startRecordingL(l.mParameters, true); 672228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala break; 673228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala default: 674228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala break; 6753ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala } 6763ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala if (res != OK) { 6773ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to refresh request in state %s", 6783ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala __FUNCTION__, mCameraId, 6793ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala Parameters::getStateName(l.mParameters.state)); 680228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 681228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 6823ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala return OK; 68361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 68461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 6853ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 68661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::startPreview() { 687a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 6889e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 68944cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 6903a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 6913a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 6922e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 6932e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return startPreviewL(l.mParameters, false); 694d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala} 695ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 696228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvalastatus_t Camera2Client::startPreviewL(Parameters ¶ms, bool restart) { 697d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala ATRACE_CALL(); 6986db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala status_t res; 69922d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin 70022d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin ALOGV("%s: state == %d, restart = %d", __FUNCTION__, params.state, restart); 70122d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin 702a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala if ( (params.state == Parameters::PREVIEW || 703a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala params.state == Parameters::RECORD || 704a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala params.state == Parameters::VIDEO_SNAPSHOT) 705a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala && !restart) { 706a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala // Succeed attempt to re-enter a streaming state 707a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala ALOGI("%s: Camera %d: Preview already active, ignoring restart", 708a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala __FUNCTION__, mCameraId); 70977449ada4b5ca73a948aa4fef9aafe3079a66d61Alex Ray return OK; 71077449ada4b5ca73a948aa4fef9aafe3079a66d61Alex Ray } 71177449ada4b5ca73a948aa4fef9aafe3079a66d61Alex Ray if (params.state > Parameters::PREVIEW && !restart) { 7124ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala ALOGE("%s: Can't start preview in state %s", 7132e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala __FUNCTION__, 7142e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala Parameters::getStateName(params.state)); 7154ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala return INVALID_OPERATION; 7164ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala } 7176db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 71873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (!mStreamingProcessor->haveValidPreviewWindow()) { 7192e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala params.state = Parameters::WAITING_FOR_PREVIEW_WINDOW; 7206db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return OK; 7216db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 7222e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala params.state = Parameters::STOPPED; 7239cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 72473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->updatePreviewStream(params); 725be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala if (res != OK) { 726be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala ALOGE("%s: Camera %d: Unable to update preview stream: %s (%d)", 727be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 728be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala return res; 7296db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 73073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala 731a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala // We could wait to create the JPEG output stream until first actual use 732a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala // (first takePicture call). However, this would substantially increase the 733a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala // first capture latency on HAL3 devices, and potentially on some HAL2 734a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala // devices. So create it unconditionally at preview start. As a drawback, 735a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala // this increases gralloc memory consumption for applications that don't 736a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala // ever take a picture. 737a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala // TODO: Find a better compromise, though this likely would involve HAL 738a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala // changes. 739a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala res = updateProcessorStream(mJpegProcessor, params); 740a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala if (res != OK) { 741a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala ALOGE("%s: Camera %d: Can't pre-configure still image " 742a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala "stream: %s (%d)", 743a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 744a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala return res; 745a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala } 746a9c64a9398ac2e6173f99e252f305808a34cab1cEino-Ville Talvala 747d1d6467d3bcbc1305eeba0176a2edf04925c368eZhijun He Vector<int32_t> outputStreams; 7483ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala bool callbacksEnabled = (params.previewCallbackFlags & 7493ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala CAMERA_FRAME_CALLBACK_FLAG_ENABLE_MASK) || 7503ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala params.previewCallbackSurface; 7513ee3550a2f529cbf56d87d8503f59a8f45dccf32Eino-Ville Talvala 752228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (callbacksEnabled) { 753a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala // Can't have recording stream hanging around when enabling callbacks, 754a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala // since it exceeds the max stream count on some devices. 755a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (mStreamingProcessor->getRecordingStreamId() != NO_STREAM) { 756a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGV("%s: Camera %d: Clearing out recording stream before " 757a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala "creating callback stream", __FUNCTION__, mCameraId); 758a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala res = mStreamingProcessor->stopStream(); 759a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (res != OK) { 760a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGE("%s: Camera %d: Can't stop streaming to delete " 761a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala "recording stream", __FUNCTION__, mCameraId); 762a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala return res; 763a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 764a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala res = mStreamingProcessor->deleteRecordingStream(); 765a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (res != OK) { 766a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to delete recording stream before " 767a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala "enabling callbacks: %s (%d)", __FUNCTION__, mCameraId, 768a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala strerror(-res), res); 769a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala return res; 770a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 771a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 772a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala 773d86a6880fe86bda21a9b53b240996fc410a512a5Eino-Ville Talvala res = mCallbackProcessor->updateStream(params); 774228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (res != OK) { 775228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to update callback stream: %s (%d)", 776228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 777228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return res; 778228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 77973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams.push(getCallbackStreamId()); 780228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 7815a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala if (params.zslMode && !params.recordingHint) { 782dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin res = updateProcessorStream(mZslProcessor, params); 783da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala if (res != OK) { 784da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to update ZSL stream: %s (%d)", 785da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 786da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala return res; 787da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala } 78873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams.push(getZslStreamId()); 789da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala } 7906db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 79173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams.push(getPreviewStreamId()); 79273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala 7935a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala if (!params.recordingHint) { 79473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (!restart) { 79573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->updatePreviewRequest(params); 7965a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala if (res != OK) { 79773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Camera %d: Can't set up preview request: " 79873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala "%s (%d)", __FUNCTION__, mCameraId, 79973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala strerror(-res), res); 8005a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala return res; 8015a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala } 8025a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala } 80373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->startStream(StreamingProcessor::PREVIEW, 80473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams); 8055a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala } else { 80673bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (!restart) { 80773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->updateRecordingRequest(params); 80873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (res != OK) { 80973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Camera %d: Can't set up preview request with " 81073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala "record hint: %s (%d)", __FUNCTION__, mCameraId, 81173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala strerror(-res), res); 81273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return res; 81373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala } 81473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala } 81573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->startStream(StreamingProcessor::RECORD, 81673bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams); 817be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala } 818be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala if (res != OK) { 81973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Camera %d: Unable to start streaming preview: %s (%d)", 820be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 8216db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return res; 8226db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 8236db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 8242e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala params.state = Parameters::PREVIEW; 8256db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return OK; 82661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 82761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 82861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::stopPreview() { 829a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 8309e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 83144cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 8323a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 8333a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return; 83436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala stopPreviewL(); 835ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala} 836ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 83736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalavoid Camera2Client::stopPreviewL() { 838ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala ATRACE_CALL(); 8394865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala status_t res; 840d5087f91357a9218580596b466926ab750bc8ea7Eino-Ville Talvala const nsecs_t kStopCaptureTimeout = 3000000000LL; // 3 seconds 8412e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala Parameters::State state; 842228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala { 8432e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 8442e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala state = l.mParameters.state; 845228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 846228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 847228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala switch (state) { 8482e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::DISCONNECTED: 849ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala // Nothing to do. 850d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala break; 8512e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STOPPED: 852d5087f91357a9218580596b466926ab750bc8ea7Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 8532e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STILL_CAPTURE: 854d5087f91357a9218580596b466926ab750bc8ea7Eino-Ville Talvala mCaptureSequencer->waitUntilIdle(kStopCaptureTimeout); 855d5087f91357a9218580596b466926ab750bc8ea7Eino-Ville Talvala // no break 8562e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 8572e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 858a27c4aa222c8dd1712617dad954c5f3aa68d5427Ruben Brunk syncWithDevice(); 859d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala res = stopStream(); 860d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala if (res != OK) { 861d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala ALOGE("%s: Camera %d: Can't stop streaming: %s (%d)", 862d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 863d09801b99503b57c35e321ad9afa7e861e012813Eino-Ville Talvala } 8644865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala res = mDevice->waitUntilDrained(); 8654865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala if (res != OK) { 8664865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala ALOGE("%s: Camera %d: Waiting to stop streaming failed: %s (%d)", 8674865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 8684865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala } 869228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala // no break 8702e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::WAITING_FOR_PREVIEW_WINDOW: { 8712e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 8722e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.state = Parameters::STOPPED; 8732e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala commandStopFaceDetectionL(l.mParameters); 874d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala break; 875228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 876d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala default: 877d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala ALOGE("%s: Camera %d: Unknown state %d", __FUNCTION__, mCameraId, 878228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala state); 879d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala } 88061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 88161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 88261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalabool Camera2Client::previewEnabled() { 883a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 88444cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 8853a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 8863a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return false; 8873a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 8882e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 8892e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return l.mParameters.state == Parameters::PREVIEW; 89061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 89161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 89261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::storeMetaDataInBuffers(bool enabled) { 893a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 89444cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 8953a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 8963a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 8973a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 8982e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 8992e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala switch (l.mParameters.state) { 9002e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 9012e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 90278822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala ALOGE("%s: Camera %d: Can't be called in state %s", 9032e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala __FUNCTION__, mCameraId, 9042e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala Parameters::getStateName(l.mParameters.state)); 90578822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala return INVALID_OPERATION; 90678822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala default: 90778822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala // OK 90878822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala break; 90978822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala } 91078822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala 9112e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.storeMetadataInBuffers = enabled; 91278822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala 91378822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala return OK; 91461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 91561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 91661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::startRecording() { 917a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 9189e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 91944cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 9209cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala status_t res; 9213a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 9222e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 923228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 9242e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return startRecordingL(l.mParameters, false); 925228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala} 9263a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 927228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvalastatus_t Camera2Client::startRecordingL(Parameters ¶ms, bool restart) { 928228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala status_t res; 92922d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin 93022d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin ALOGV("%s: state == %d, restart = %d", __FUNCTION__, params.state, restart); 93122d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin 932228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala switch (params.state) { 9332e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STOPPED: 934228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala res = startPreviewL(params, false); 9359cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (res != OK) return res; 9369cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 9372e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 9389cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala // Ready to go 9399cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 9402e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 9412e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 942228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala // OK to call this when recording is already on, just skip unless 943228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala // we're looking to restart 944228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (!restart) return OK; 9459cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 9469cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala default: 9479cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Can't start recording in state %s", 9482e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala __FUNCTION__, mCameraId, 9492e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala Parameters::getStateName(params.state)); 9509cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return INVALID_OPERATION; 9519cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala }; 9529cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 953228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (!params.storeMetadataInBuffers) { 95478822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala ALOGE("%s: Camera %d: Recording only supported in metadata mode, but " 95578822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala "non-metadata recording mode requested!", __FUNCTION__, 95678822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala mCameraId); 95778822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala return INVALID_OPERATION; 95878822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala } 95978822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala 96073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (!restart) { 96173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mCameraService->playSound(CameraService::SOUND_RECORDING); 96273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor->updateRecordingRequest(params); 96373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (res != OK) { 96473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Camera %d: Unable to update recording request: %s (%d)", 96573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 96673bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return res; 96773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala } 96873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala } 969609acc0c96bc2aedd42246862b537e045f5184b6Eino-Ville Talvala 970a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala // Not all devices can support a preview callback stream and a recording 971a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala // stream at the same time, so assume none of them can. 972a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (mCallbackProcessor->getStreamId() != NO_STREAM) { 973a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGV("%s: Camera %d: Clearing out callback stream before " 974a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala "creating recording stream", __FUNCTION__, mCameraId); 975a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala res = mStreamingProcessor->stopStream(); 976a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (res != OK) { 977a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGE("%s: Camera %d: Can't stop streaming to delete callback stream", 978a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala __FUNCTION__, mCameraId); 979a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala return res; 980a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 981a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala res = mCallbackProcessor->deleteStream(); 982a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala if (res != OK) { 983a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to delete callback stream before " 984a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala "record: %s (%d)", __FUNCTION__, mCameraId, 985a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala strerror(-res), res); 986a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala return res; 987a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 988a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala } 989a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala // Disable callbacks if they're enabled; can't record and use callbacks, 990a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala // and we can't fail record start without stagefright asserting. 991a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala params.previewCallbackFlags = 0; 992a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala 99382db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin res = updateProcessorStream< 99482db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin StreamingProcessor, 99582db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin &StreamingProcessor::updateRecordingStream>(mStreamingProcessor, 99682db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin params); 9979cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (res != OK) { 9989cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Unable to update recording stream: %s (%d)", 9999cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 10009cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return res; 10019cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 100273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala 1003d1d6467d3bcbc1305eeba0176a2edf04925c368eZhijun He Vector<int32_t> outputStreams; 100473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams.push(getPreviewStreamId()); 100573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams.push(getRecordingStreamId()); 10069cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 100773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->startStream(StreamingProcessor::RECORD, 100873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams); 10099cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (res != OK) { 101073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Camera %d: Unable to start recording stream: %s (%d)", 10119cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 10129cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return res; 10139cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 10149cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 10152e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (params.state < Parameters::RECORD) { 10162e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala params.state = Parameters::RECORD; 1017228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 10189cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 10199cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return OK; 102061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 102161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 102261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::stopRecording() { 1023a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 10249e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 102544cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 10262e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 1027228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 10289cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala status_t res; 10293a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return; 10303a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 10312e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala switch (l.mParameters.state) { 10322e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 10339cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala // OK to stop 10349cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 10352e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STOPPED: 10362e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 10372e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STILL_CAPTURE: 10382e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 10399cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala default: 10409cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Can't stop recording in state %s", 10412e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala __FUNCTION__, mCameraId, 10422e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala Parameters::getStateName(l.mParameters.state)); 10439cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return; 10449cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala }; 10459cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 1046609acc0c96bc2aedd42246862b537e045f5184b6Eino-Ville Talvala mCameraService->playSound(CameraService::SOUND_RECORDING); 1047609acc0c96bc2aedd42246862b537e045f5184b6Eino-Ville Talvala 10485a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala res = startPreviewL(l.mParameters, true); 10499cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (res != OK) { 10505a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to return to preview", 10515a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala __FUNCTION__, mCameraId); 10529cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 105361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 105461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 105561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalabool Camera2Client::recordingEnabled() { 1056a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 105744cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 10588da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong 10593a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( checkPid(__FUNCTION__) != OK) return false; 10603a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 10618da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong return recordingEnabledL(); 10628da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong} 10638da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong 10648da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dongbool Camera2Client::recordingEnabledL() { 10658da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong ATRACE_CALL(); 10662e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 10678da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong 10682e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return (l.mParameters.state == Parameters::RECORD 10692e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala || l.mParameters.state == Parameters::VIDEO_SNAPSHOT); 107061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 107161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 107261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::releaseRecordingFrame(const sp<IMemory>& mem) { 1073a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 107444cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 10753a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( checkPid(__FUNCTION__) != OK) return; 107630e65e7e2ec01e13e45b5e38552a34d2fbb3f866Eino-Ville Talvala 107773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor->releaseRecordingFrame(mem); 107861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 107961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 108061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::autoFocus() { 1081a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 108244cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 10838a42dd8cd1a245d844f96cfd67dc342d7937e353Eino-Ville Talvala ALOGV("%s: Camera %d", __FUNCTION__, mCameraId); 10843a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 10853a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 10863a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 1087174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala int triggerId; 1088d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala bool notifyImmediately = false; 1089d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala bool notifySuccess = false; 1090174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala { 10912e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 10924865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala if (l.mParameters.state < Parameters::PREVIEW) { 10934865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return INVALID_OPERATION; 10944865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala } 10954865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 10965f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin /** 10975f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin * If the camera does not support auto-focus, it is a no-op and 10985f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin * onAutoFocus(boolean, Camera) callback will be called immediately 10995f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin * with a fake value of success set to true. 11009454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala * 11019454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala * Similarly, if focus mode is set to INFINITY, there's no reason to 11029454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala * bother the HAL. 11035f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin */ 11049454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala if (l.mParameters.focusMode == Parameters::FOCUS_MODE_FIXED || 11059454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala l.mParameters.focusMode == Parameters::FOCUS_MODE_INFINITY) { 1106d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala notifyImmediately = true; 1107d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala notifySuccess = true; 1108d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala } 1109d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala /** 1110d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala * If we're in CAF mode, and AF has already been locked, just fire back 1111d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala * the callback right away; the HAL would not send a notification since 1112d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala * no state change would happen on a AF trigger. 1113d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala */ 1114d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala if ( (l.mParameters.focusMode == Parameters::FOCUS_MODE_CONTINUOUS_PICTURE || 1115d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala l.mParameters.focusMode == Parameters::FOCUS_MODE_CONTINUOUS_VIDEO) && 1116d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala l.mParameters.focusState == ANDROID_CONTROL_AF_STATE_FOCUSED_LOCKED ) { 1117d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala notifyImmediately = true; 1118d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala notifySuccess = true; 1119d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala } 1120d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala /** 1121d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala * Send immediate notification back to client 1122d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala */ 1123d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala if (notifyImmediately) { 112444cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin SharedCameraCallbacks::Lock l(mSharedCameraCallbacks); 112544cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin if (l.mRemoteCallback != 0) { 112644cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin l.mRemoteCallback->notifyCallback(CAMERA_MSG_FOCUS, 1127d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala notifySuccess ? 1 : 0, 0); 11285f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin } 11295f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin return OK; 11305f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin } 1131d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala /** 1132d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala * Handle quirk mode for AF in scene modes 1133d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala */ 113495069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala if (l.mParameters.quirks.triggerAfWithAuto && 113595069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.sceneMode != ANDROID_CONTROL_SCENE_MODE_UNSUPPORTED && 1136ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala l.mParameters.focusMode != Parameters::FOCUS_MODE_AUTO && 1137ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala !l.mParameters.focusingAreas[0].isEmpty()) { 113895069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala ALOGV("%s: Quirk: Switching from focusMode %d to AUTO", 113995069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala __FUNCTION__, l.mParameters.focusMode); 114095069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.shadowFocusMode = l.mParameters.focusMode; 114195069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.focusMode = Parameters::FOCUS_MODE_AUTO; 114295069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala updateRequests(l.mParameters); 114395069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala } 114495069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala 11452e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.currentAfTriggerId = ++l.mParameters.afTriggerCounter; 11462e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala triggerId = l.mParameters.currentAfTriggerId; 1147174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 11484865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala syncWithDevice(); 1149174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 1150174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala mDevice->triggerAutofocus(triggerId); 1151174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 11526db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return OK; 115361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 115461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 115561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::cancelAutoFocus() { 1156a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 115744cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 11588a42dd8cd1a245d844f96cfd67dc342d7937e353Eino-Ville Talvala ALOGV("%s: Camera %d", __FUNCTION__, mCameraId); 11593a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 11603a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 11613a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 1162174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala int triggerId; 1163174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala { 11642e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 11659454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala // Canceling does nothing in FIXED or INFINITY modes 11669454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala if (l.mParameters.focusMode == Parameters::FOCUS_MODE_FIXED || 11679454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala l.mParameters.focusMode == Parameters::FOCUS_MODE_INFINITY) { 11689454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala return OK; 11699454a9710b13c7d9262fe1cbd910235a3cd35f20Eino-Ville Talvala } 11702e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala triggerId = ++l.mParameters.afTriggerCounter; 117195069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala 117295069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala // When using triggerAfWithAuto quirk, may need to reset focus mode to 1173ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala // the real state at this point. No need to cancel explicitly if 1174ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala // changing the AF mode. 117595069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala if (l.mParameters.shadowFocusMode != Parameters::FOCUS_MODE_INVALID) { 117695069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala ALOGV("%s: Quirk: Restoring focus mode to %d", __FUNCTION__, 117795069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.shadowFocusMode); 117895069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.focusMode = l.mParameters.shadowFocusMode; 117995069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.shadowFocusMode = Parameters::FOCUS_MODE_INVALID; 118095069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala updateRequests(l.mParameters); 1181ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala 1182ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala return OK; 118395069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala } 1184174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 11854865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala syncWithDevice(); 1186174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 1187174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala mDevice->triggerCancelAutofocus(triggerId); 1188174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 11896db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return OK; 119061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 119161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 1192ff82370c7c04340d50673d425f48acafd00f2bc9Ben Murdochstatus_t Camera2Client::takePicture(int msgType) { 1193a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 119444cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 1195d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala status_t res; 11963a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 1197d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala 1198b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala { 1199b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala SharedParameters::Lock l(mParameters); 1200b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala switch (l.mParameters.state) { 1201b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::DISCONNECTED: 1202b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::STOPPED: 1203b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::WAITING_FOR_PREVIEW_WINDOW: 1204b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala ALOGE("%s: Camera %d: Cannot take picture without preview enabled", 1205da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala __FUNCTION__, mCameraId); 1206b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala return INVALID_OPERATION; 1207b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::PREVIEW: 1208b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala // Good to go for takePicture 1209b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala res = commandStopFaceDetectionL(l.mParameters); 1210b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala if (res != OK) { 1211b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala ALOGE("%s: Camera %d: Unable to stop face detection for still capture", 1212b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala __FUNCTION__, mCameraId); 1213b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala return res; 1214b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala } 1215b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala l.mParameters.state = Parameters::STILL_CAPTURE; 1216b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala break; 1217b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::RECORD: 1218b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala // Good to go for video snapshot 1219b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala l.mParameters.state = Parameters::VIDEO_SNAPSHOT; 1220b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala break; 1221b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::STILL_CAPTURE: 1222b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 1223b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala ALOGE("%s: Camera %d: Already taking a picture", 1224b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala __FUNCTION__, mCameraId); 1225b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala return INVALID_OPERATION; 1226b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala } 1227d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala 1228b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala ALOGV("%s: Camera %d: Starting picture capture", __FUNCTION__, mCameraId); 1229d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala 1230dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin res = updateProcessorStream(mJpegProcessor, l.mParameters); 1231b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala if (res != OK) { 1232b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala ALOGE("%s: Camera %d: Can't set up still image stream: %s (%d)", 1233b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 1234b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala return res; 1235b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala } 1236228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 12378ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 12384865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala // Need HAL to have correct settings before (possibly) triggering precapture 12394865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala syncWithDevice(); 12404865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 1241aa9e3e01b86bd9bfb5ac36c0f360d5fe478cbb2dIgor Murashkin res = mCaptureSequencer->startCapture(msgType); 1242d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala if (res != OK) { 1243da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to start capture: %s (%d)", 1244d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 1245d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala } 1246d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala 1247da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala return res; 124861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 124961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 125061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::setParameters(const String8& params) { 1251a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 12528a42dd8cd1a245d844f96cfd67dc342d7937e353Eino-Ville Talvala ALOGV("%s: Camera %d", __FUNCTION__, mCameraId); 125344cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 12546861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala status_t res; 12553a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 12563a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 12572e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 12586861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala 12592e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala res = l.mParameters.set(params); 12602e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (res != OK) return res; 12619cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 12622e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala res = updateRequests(l.mParameters); 12638ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 12648ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 126561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 1266f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 126761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville TalvalaString8 Camera2Client::getParameters() const { 1268a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 12698a42dd8cd1a245d844f96cfd67dc342d7937e353Eino-Ville Talvala ALOGV("%s: Camera %d", __FUNCTION__, mCameraId); 127044cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 12713a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( checkPid(__FUNCTION__) != OK) return String8(); 1272ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 12732e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::ReadLock l(mParameters); 1274ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 12758a42dd8cd1a245d844f96cfd67dc342d7937e353Eino-Ville Talvala return l.mParameters.get(); 127661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 127761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 127861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::sendCommand(int32_t cmd, int32_t arg1, int32_t arg2) { 1279a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 128044cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin Mutex::Autolock icl(mBinderSerializationLock); 12813a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 12823a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 1283c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala 1284c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala ALOGV("%s: Camera %d: Command %d (%d, %d)", __FUNCTION__, mCameraId, 1285c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala cmd, arg1, arg2); 1286c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala 128736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala switch (cmd) { 128836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_START_SMOOTH_ZOOM: 128936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandStartSmoothZoomL(); 129036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_STOP_SMOOTH_ZOOM: 129136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandStopSmoothZoomL(); 129236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_SET_DISPLAY_ORIENTATION: 129336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandSetDisplayOrientationL(arg1); 129436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_ENABLE_SHUTTER_SOUND: 129536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandEnableShutterSoundL(arg1 == 1); 129636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_PLAY_RECORDING_SOUND: 129736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandPlayRecordingSoundL(); 129836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_START_FACE_DETECTION: 129936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandStartFaceDetectionL(arg1); 1300228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case CAMERA_CMD_STOP_FACE_DETECTION: { 13012e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 13022e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return commandStopFaceDetectionL(l.mParameters); 1303228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 130436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_ENABLE_FOCUS_MOVE_MSG: 130536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandEnableFocusMoveMsgL(arg1 == 1); 130636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_PING: 130736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandPingL(); 130836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_SET_VIDEO_BUFFER_COUNT: 130936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandSetVideoBufferCountL(arg1); 131036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala default: 131136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("%s: Unknown command %d (arguments %d, %d)", 131236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala __FUNCTION__, cmd, arg1, arg2); 1313c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala return BAD_VALUE; 131436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 131536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 131636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 131736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandStartSmoothZoomL() { 131836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("%s: Unimplemented!", __FUNCTION__); 131936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 132036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 132136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 132236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandStopSmoothZoomL() { 132336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("%s: Unimplemented!", __FUNCTION__); 132436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 132536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 132636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 132736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandSetDisplayOrientationL(int degrees) { 13282e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala int transform = Parameters::degToTransform(degrees, 132936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala mCameraFacing == CAMERA_FACING_FRONT); 133036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala if (transform == -1) { 133136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("%s: Camera %d: Error setting %d as display orientation value", 133236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala __FUNCTION__, mCameraId, degrees); 133336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return BAD_VALUE; 133436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 13352e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 13362e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (transform != l.mParameters.previewTransform && 133773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala getPreviewStreamId() != NO_STREAM) { 133873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mDevice->setStreamTransform(getPreviewStreamId(), transform); 133936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 13402e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.previewTransform = transform; 134136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 134236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 134336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 134436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandEnableShutterSoundL(bool enable) { 13452e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 134636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala if (enable) { 13472e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.playShutterSound = true; 1348c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala return OK; 134936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 1350983cf231ab2d176a14595cdae46ff1b0c239af47James Dong 135136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala // Disabling shutter sound may not be allowed. In that case only 135236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala // allow the mediaserver process to disable the sound. 135336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala char value[PROPERTY_VALUE_MAX]; 135436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala property_get("ro.camera.sound.forced", value, "0"); 135536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala if (strncmp(value, "0", 2) != 0) { 135636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala // Disabling shutter sound is not allowed. Deny if the current 135736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala // process is not mediaserver. 135836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala if (getCallingPid() != getpid()) { 135936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("Failed to disable shutter sound. Permission denied (pid %d)", 136036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala getCallingPid()); 136136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return PERMISSION_DENIED; 1362983cf231ab2d176a14595cdae46ff1b0c239af47James Dong } 136336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 1364983cf231ab2d176a14595cdae46ff1b0c239af47James Dong 13652e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.playShutterSound = false; 136636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 136736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 1368983cf231ab2d176a14595cdae46ff1b0c239af47James Dong 136936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandPlayRecordingSoundL() { 137036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala mCameraService->playSound(CameraService::SOUND_RECORDING); 137136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 137236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 137336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 1374ddf3c5025e2f6f35a4c188c19f30142c64a092c4Igor Murashkinstatus_t Camera2Client::commandStartFaceDetectionL(int /*type*/) { 13758ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGV("%s: Camera %d: Starting face detection", 13768ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId); 13778ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala status_t res; 13782e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 13792e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala switch (l.mParameters.state) { 13802e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::DISCONNECTED: 13812e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STOPPED: 13822e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::WAITING_FOR_PREVIEW_WINDOW: 13832e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STILL_CAPTURE: 13848ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Cannot start face detection without preview active", 13858ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId); 13868ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return INVALID_OPERATION; 13872e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 13882e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 13892e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 13908ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala // Good to go for starting face detect 13918ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala break; 13928ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 13938ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala // Ignoring type 13942e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.fastInfo.bestFaceDetectMode == 1395d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin ANDROID_STATISTICS_FACE_DETECT_MODE_OFF) { 13968ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Face detection not supported", 13978ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId); 1398caf3a9c1447f602c658f558025b90413d1b4114dZiv Hendel return BAD_VALUE; 13998ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 14002e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.enableFaceDetect) return OK; 14018ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 14022e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.enableFaceDetect = true; 14038ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 14042e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala res = updateRequests(l.mParameters); 14058ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 14068ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 140736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 140836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 1409228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvalastatus_t Camera2Client::commandStopFaceDetectionL(Parameters ¶ms) { 14108ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala status_t res = OK; 14118ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGV("%s: Camera %d: Stopping face detection", 14128ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId); 14138ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 1414228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (!params.enableFaceDetect) return OK; 14158ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 1416228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala params.enableFaceDetect = false; 14178ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 14182e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (params.state == Parameters::PREVIEW 14192e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala || params.state == Parameters::RECORD 14202e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala || params.state == Parameters::VIDEO_SNAPSHOT) { 1421228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala res = updateRequests(params); 14228ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 14238ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 14248ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 142536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 142636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 142736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandEnableFocusMoveMsgL(bool enable) { 14282e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 14292e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.enableFocusMoveMessages = enable; 1430174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 143136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 143236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 143336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 143436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandPingL() { 143536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala // Always ping back if access is proper and device is alive 14362e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 14372e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.state != Parameters::DISCONNECTED) { 1438983cf231ab2d176a14595cdae46ff1b0c239af47James Dong return OK; 143936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } else { 144036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return NO_INIT; 144136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 144236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 144336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 144436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandSetVideoBufferCountL(size_t count) { 14458da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong if (recordingEnabledL()) { 144636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("%s: Camera %d: Error setting video buffer count after " 144736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala "recording was started", __FUNCTION__, mCameraId); 144836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return INVALID_OPERATION; 1449c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala } 1450c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala 145173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return mStreamingProcessor->setRecordingBufferCount(count); 145261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 145361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 14543cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala/** Device-related methods */ 1455160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvalavoid Camera2Client::notifyAutoFocus(uint8_t newState, int triggerId) { 1456160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala ALOGV("%s: Autofocus state now %d, last trigger %d", 1457160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala __FUNCTION__, newState, triggerId); 1458174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala bool sendCompletedMessage = false; 1459174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala bool sendMovingMessage = false; 1460174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 1461174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala bool success = false; 1462174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala bool afInMotion = false; 1463174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala { 14642e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 1465d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala l.mParameters.focusState = newState; 14662e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala switch (l.mParameters.focusMode) { 1467174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_AUTO: 1468174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_MACRO: 1469174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Don't send notifications upstream if they're not for the current AF 1470174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // trigger. For example, if cancel was called in between, or if we 1471174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // already sent a notification about this AF call. 14722e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (triggerId != l.mParameters.currentAfTriggerId) break; 1473174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala switch (newState) { 1474174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_FOCUSED_LOCKED: 1475174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala success = true; 1476174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // no break 1477174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_NOT_FOCUSED_LOCKED: 1478174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala sendCompletedMessage = true; 14792e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.currentAfTriggerId = -1; 1480174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1481174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_ACTIVE_SCAN: 1482174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Just starting focusing, ignore 1483174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1484174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_INACTIVE: 1485174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_PASSIVE_SCAN: 1486174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_PASSIVE_FOCUSED: 14874ad28ea0a76c7ecdfcc5b96af2b0afcb0c3e5120Eino-Ville Talvala case ANDROID_CONTROL_AF_STATE_PASSIVE_UNFOCUSED: 1488174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala default: 1489174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Unexpected in AUTO/MACRO mode 1490174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala ALOGE("%s: Unexpected AF state transition in AUTO/MACRO mode: %d", 1491174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala __FUNCTION__, newState); 1492174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1493174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1494174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1495174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_CONTINUOUS_VIDEO: 1496174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_CONTINUOUS_PICTURE: 1497174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala switch (newState) { 1498174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_FOCUSED_LOCKED: 1499174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala success = true; 1500174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // no break 1501174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_NOT_FOCUSED_LOCKED: 1502174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Don't send notifications upstream if they're not for 1503174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // the current AF trigger. For example, if cancel was 1504174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // called in between, or if we already sent a 1505174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // notification about this AF call. 1506174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Send both a 'AF done' callback and a 'AF move' callback 15072e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (triggerId != l.mParameters.currentAfTriggerId) break; 1508174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala sendCompletedMessage = true; 1509174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala afInMotion = false; 15102e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.enableFocusMoveMessages && 15112e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.afInMotion) { 1512174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala sendMovingMessage = true; 1513174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 15142e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.currentAfTriggerId = -1; 1515174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1516174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_INACTIVE: 1517174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Cancel was called, or we switched state; care if 1518174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // currently moving 1519174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala afInMotion = false; 15202e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.enableFocusMoveMessages && 15212e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.afInMotion) { 1522174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala sendMovingMessage = true; 1523174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1524174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1525174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_PASSIVE_SCAN: 1526174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Start passive scan, inform upstream 1527174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala afInMotion = true; 1528174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // no break 1529174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_PASSIVE_FOCUSED: 15304ad28ea0a76c7ecdfcc5b96af2b0afcb0c3e5120Eino-Ville Talvala case ANDROID_CONTROL_AF_STATE_PASSIVE_UNFOCUSED: 1531174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Stop passive scan, inform upstream 15322e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.enableFocusMoveMessages) { 1533174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala sendMovingMessage = true; 1534174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1535174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1536174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 15372e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.afInMotion = afInMotion; 1538174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1539174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_EDOF: 1540174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_INFINITY: 1541174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_FIXED: 1542174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala default: 1543174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala if (newState != ANDROID_CONTROL_AF_STATE_INACTIVE) { 1544a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala ALOGE("%s: Unexpected AF state change %d " 1545a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala "(ID %d) in focus mode %d", 1546a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala __FUNCTION__, newState, triggerId, 1547a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala l.mParameters.focusMode); 1548174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1549174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1550174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1551174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala if (sendMovingMessage) { 155244cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin SharedCameraCallbacks::Lock l(mSharedCameraCallbacks); 155344cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin if (l.mRemoteCallback != 0) { 155444cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin l.mRemoteCallback->notifyCallback(CAMERA_MSG_FOCUS_MOVE, 15558ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala afInMotion ? 1 : 0, 0); 15568ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 1557174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1558603b12efa16e7afb4e6c75f6b353216c83e8e135Eino-Ville Talvala if (sendCompletedMessage) { 155944cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin SharedCameraCallbacks::Lock l(mSharedCameraCallbacks); 156044cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin if (l.mRemoteCallback != 0) { 156144cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin l.mRemoteCallback->notifyCallback(CAMERA_MSG_FOCUS, 1562a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala success ? 1 : 0, 0); 15638ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 1564603b12efa16e7afb4e6c75f6b353216c83e8e135Eino-Ville Talvala } 1565160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala} 1566160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala 1567160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvalavoid Camera2Client::notifyAutoExposure(uint8_t newState, int triggerId) { 1568160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala ALOGV("%s: Autoexposure state now %d, last trigger %d", 1569160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala __FUNCTION__, newState, triggerId); 1570da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCaptureSequencer->notifyAutoExposure(newState, triggerId); 1571160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala} 1572160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala 1573a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvalacamera2::SharedParameters& Camera2Client::getParameters() { 1574a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala return mParameters; 1575c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala} 1576c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala 1577da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvalaint Camera2Client::getPreviewStreamId() const { 157873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return mStreamingProcessor->getPreviewStreamId(); 1579da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1580da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 1581da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvalaint Camera2Client::getCaptureStreamId() const { 1582da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala return mJpegProcessor->getStreamId(); 1583da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1584da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 1585da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvalaint Camera2Client::getCallbackStreamId() const { 1586da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala return mCallbackProcessor->getStreamId(); 1587da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1588da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 1589da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvalaint Camera2Client::getRecordingStreamId() const { 159073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return mStreamingProcessor->getRecordingStreamId(); 1591da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1592da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 1593da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvalaint Camera2Client::getZslStreamId() const { 1594da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala return mZslProcessor->getStreamId(); 1595da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1596da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 15974865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalastatus_t Camera2Client::registerFrameListener(int32_t minId, int32_t maxId, 15984865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala wp<camera2::FrameProcessor::FilteredListener> listener) { 15994865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return mFrameProcessor->registerListener(minId, maxId, listener); 16004865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala} 16014865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 16024865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalastatus_t Camera2Client::removeFrameListener(int32_t minId, int32_t maxId, 1603da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala wp<camera2::FrameProcessor::FilteredListener> listener) { 16044865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return mFrameProcessor->removeListener(minId, maxId, listener); 1605da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1606da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 16074865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalastatus_t Camera2Client::stopStream() { 16084865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return mStreamingProcessor->stopStream(); 1609da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1610da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 16114865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kPreviewRequestIdStart; 16124865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kPreviewRequestIdEnd; 16134865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kRecordingRequestIdStart; 16144865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kRecordingRequestIdEnd; 16154865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kCaptureRequestIdStart; 16164865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kCaptureRequestIdEnd; 1617da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 16183cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala/** Utility methods */ 16193cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala 16205a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvalastatus_t Camera2Client::updateRequests(Parameters ¶ms) { 16218ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala status_t res; 16228ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 162322d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin ALOGV("%s: Camera %d: state = %d", __FUNCTION__, getCameraId(), params.state); 162422d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin 16254865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala res = mStreamingProcessor->incrementStreamingIds(); 16264865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala if (res != OK) { 16274865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala ALOGE("%s: Camera %d: Unable to increment request IDs: %s (%d)", 16284865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 16294865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return res; 16304865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala } 16314865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 163273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->updatePreviewRequest(params); 16338ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala if (res != OK) { 16348ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to update preview request: %s (%d)", 16358ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 16368ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 16378ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 163873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->updateRecordingRequest(params); 16398ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala if (res != OK) { 16408ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to update recording request: %s (%d)", 16418ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 16428ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 16438ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 16448ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 16452e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (params.state == Parameters::PREVIEW) { 16465a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala res = startPreviewL(params, true); 16478ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala if (res != OK) { 16488ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Error streaming new preview request: %s (%d)", 16498ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 16508ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 16518ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 16522e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala } else if (params.state == Parameters::RECORD || 16532e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala params.state == Parameters::VIDEO_SNAPSHOT) { 165473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = startRecordingL(params, true); 16558ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala if (res != OK) { 16568ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Error streaming new record request: %s (%d)", 16578ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 16588ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 16598ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 16608ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 16618ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 16628ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala} 16638ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 16649cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 1665228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvalasize_t Camera2Client::calculateBufferSize(int width, int height, 1666228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala int format, int stride) { 1667228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala switch (format) { 1668228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_YCbCr_422_SP: // NV16 1669228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 2; 1670228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_YCrCb_420_SP: // NV21 1671228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 3 / 2; 1672228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_YCbCr_422_I: // YUY2 1673228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 2; 1674228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_YV12: { // YV12 1675228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala size_t ySize = stride * height; 1676f17b6cf6aa7548ca82e7fed96d71db7821103e57Eino-Ville Talvala size_t uvStride = (stride / 2 + 0xF) & ~0xF; 1677228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala size_t uvSize = uvStride * height / 2; 1678228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return ySize + uvSize * 2; 1679228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 1680228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_RGB_565: 1681228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 2; 1682228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_RGBA_8888: 1683228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 4; 1684228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_RAW_SENSOR: 1685228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 2; 1686228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala default: 1687228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala ALOGE("%s: Unknown preview format: %x", 1688228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala __FUNCTION__, format); 1689228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return 0; 1690228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 1691228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala} 16928ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 16934865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalastatus_t Camera2Client::syncWithDevice() { 16944865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala ATRACE_CALL(); 169543b7ac6bd1a949ecb8ffc7e50d0a2f01a6258034Eino-Ville Talvala const nsecs_t kMaxSyncTimeout = 500000000; // 500 ms 16964865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala status_t res; 16974865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 16984865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala int32_t activeRequestId = mStreamingProcessor->getActiveRequestId(); 16994865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala if (activeRequestId == 0) return OK; 17004865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 17014865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala res = mDevice->waitUntilRequestReceived(activeRequestId, kMaxSyncTimeout); 17024865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala if (res == TIMED_OUT) { 17034865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala ALOGE("%s: Camera %d: Timed out waiting sync with HAL", 17044865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala __FUNCTION__, mCameraId); 17054865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala } else if (res != OK) { 17064865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala ALOGE("%s: Camera %d: Error while waiting to sync with HAL", 17074865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala __FUNCTION__, mCameraId); 17084865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala } 17094865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return res; 17104865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala} 17114865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 1712dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkintemplate <typename ProcessorT> 1713dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkinstatus_t Camera2Client::updateProcessorStream(sp<ProcessorT> processor, 1714dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin camera2::Parameters params) { 171582db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin // No default template arguments until C++11, so we need this overload 171682db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin return updateProcessorStream<ProcessorT, &ProcessorT::updateStream>( 171782db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin processor, params); 171882db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin} 171982db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin 172082db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkintemplate <typename ProcessorT, 172182db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin status_t (ProcessorT::*updateStreamF)(const Parameters &)> 172282db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkinstatus_t Camera2Client::updateProcessorStream(sp<ProcessorT> processor, 172382db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin Parameters params) { 1724dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin status_t res; 1725dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin 172682db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin // Get raw pointer since sp<T> doesn't have operator->* 172782db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin ProcessorT *processorPtr = processor.get(); 172882db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin res = (processorPtr->*updateStreamF)(params); 1729dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin 1730dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin /** 1731dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin * Can't update the stream if it's busy? 1732dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin * 1733dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin * Then we need to stop the device (by temporarily clearing the request 1734dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin * queue) and then try again. Resume streaming once we're done. 1735dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin */ 1736dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin if (res == -EBUSY) { 1737a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala ALOGV("%s: Camera %d: Pausing to update stream", __FUNCTION__, 1738a691ff3c03e38e148bbefed35ebb15e552a12613Eino-Ville Talvala mCameraId); 1739dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin res = mStreamingProcessor->togglePauseStream(/*pause*/true); 1740dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin if (res != OK) { 1741dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin ALOGE("%s: Camera %d: Can't pause streaming: %s (%d)", 1742dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin __FUNCTION__, mCameraId, strerror(-res), res); 1743dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin } 1744dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin 1745dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin res = mDevice->waitUntilDrained(); 1746dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin if (res != OK) { 1747dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin ALOGE("%s: Camera %d: Waiting to stop streaming failed: %s (%d)", 1748dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin __FUNCTION__, mCameraId, strerror(-res), res); 1749dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin } 1750dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin 175182db9e6126812dd2ee74e33e4c475cae2c7e48f6Igor Murashkin res = (processorPtr->*updateStreamF)(params); 1752dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin if (res != OK) { 1753dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin ALOGE("%s: Camera %d: Failed to update processing stream " 1754dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin " despite having halted streaming first: %s (%d)", 1755dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin __FUNCTION__, mCameraId, strerror(-res), res); 1756dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin } 1757dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin 1758dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin res = mStreamingProcessor->togglePauseStream(/*pause*/false); 1759dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin if (res != OK) { 1760dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin ALOGE("%s: Camera %d: Can't unpause streaming: %s (%d)", 1761dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin __FUNCTION__, mCameraId, strerror(-res), res); 1762dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin } 1763dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin } 1764dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin 1765dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin return res; 1766dca254aef0c09867e50fe6613c6fad405de72842Igor Murashkin} 176744cfcf00b9008c1c04f4c8277c6c06af039fd976Igor Murashkin 176861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} // namespace android 1769