Camera2Client.cpp revision ceb388d6c03c38b96dc41c0ea4804b749aa077c4
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> 26e538206d15282afbc5b168d60b1026a5dfcd13c0James Painter#include "camera2/Parameters.h" 2710894e509f777c6bd7e408a57f5cf21ee2b36a96James Painter#include "Camera2Client.h" 2861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 2961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#define ALOG1(...) ALOGD_IF(gLogLevel >= 1, __VA_ARGS__); 3061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala#define ALOG2(...) ALOGD_IF(gLogLevel >= 2, __VA_ARGS__); 3161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 322e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvalanamespace android { 332e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvalausing namespace camera2; 342e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala 3561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatic int getCallingPid() { 3661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala return IPCThreadState::self()->getCallingPid(); 3761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 3861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 3961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala// Interface used by CameraService 4061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 4161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville TalvalaCamera2Client::Camera2Client(const sp<CameraService>& cameraService, 4261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala const sp<ICameraClient>& cameraClient, 43ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala const String16& clientPackageName, 4461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala int cameraId, 4561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala int cameraFacing, 46ecf17e82505fdb60d59e00b6dd59036df93de655Igor Murashkin int clientPid, 47ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala uid_t clientUid, 48ecf17e82505fdb60d59e00b6dd59036df93de655Igor Murashkin int servicePid): 49ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala Client(cameraService, cameraClient, clientPackageName, 50ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala cameraId, cameraFacing, clientPid, clientUid, servicePid), 51ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala mSharedCameraClient(cameraClient), 5273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mParameters(cameraId, cameraFacing) 53f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala{ 54a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 55da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala ALOGI("Camera %d: Opened", cameraId); 5661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 57f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala mDevice = new Camera2Device(cameraId); 58228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 592e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 602e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.state = Parameters::DISCONNECTED; 61f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala} 62f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 633a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvalastatus_t Camera2Client::checkPid(const char* checkLocation) const { 643a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala int callingPid = getCallingPid(); 65c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala if (callingPid == mClientPid) return NO_ERROR; 663a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 673a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala ALOGE("%s: attempt to use a locked camera from a different process" 68c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala " (old pid %d, new pid %d)", checkLocation, mClientPid, callingPid); 693a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala return PERMISSION_DENIED; 703a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala} 713a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 72f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvalastatus_t Camera2Client::initialize(camera_module_t *module) 73f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala{ 74a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 75c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala ALOGV("%s: Initializing client for camera %d", __FUNCTION__, mCameraId); 76f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala status_t res; 77f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 78ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala // Verify ops permissions 79ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala res = startCameraOps(); 80ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala if (res != OK) { 81ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala return res; 82ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala } 83ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala 84f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala res = mDevice->initialize(module); 85f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala if (res != OK) { 86f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala ALOGE("%s: Camera %d: unable to initialize device: %s (%d)", 87f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 88f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala return NO_INIT; 89f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala } 90f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 91174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala res = mDevice->setNotifyCallback(this); 92174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 932e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 942e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala 952e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala res = l.mParameters.initialize(&(mDevice->info())); 96f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala if (res != OK) { 97f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala ALOGE("%s: Camera %d: unable to build defaults: %s (%d)", 98f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 99f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala return NO_INIT; 100f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala } 1013cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala 102da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala String8 threadName; 103da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 10473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor = new StreamingProcessor(this); 10573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala 106ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala mFrameProcessor = new FrameProcessor(this); 1074bb8118816874c696d9f1adab48490df1da365f7Eino-Ville Talvala threadName = String8::format("C2-%d-FrameProc", 108da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCameraId); 109da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mFrameProcessor->run(threadName.string()); 110da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 111da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCaptureSequencer = new CaptureSequencer(this); 1124bb8118816874c696d9f1adab48490df1da365f7Eino-Ville Talvala threadName = String8::format("C2-%d-CaptureSeq", 113da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCameraId); 114da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCaptureSequencer->run(threadName.string()); 115da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 116da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mJpegProcessor = new JpegProcessor(this, mCaptureSequencer); 1174bb8118816874c696d9f1adab48490df1da365f7Eino-Ville Talvala threadName = String8::format("C2-%d-JpegProc", 118ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala mCameraId); 119da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mJpegProcessor->run(threadName.string()); 120ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala 121da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mZslProcessor = new ZslProcessor(this, mCaptureSequencer); 1224bb8118816874c696d9f1adab48490df1da365f7Eino-Ville Talvala threadName = String8::format("C2-%d-ZslProc", 123da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCameraId); 124da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mZslProcessor->run(threadName.string()); 125ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala 126d86a6880fe86bda21a9b53b240996fc410a512a5Eino-Ville Talvala mCallbackProcessor = new CallbackProcessor(this); 1274bb8118816874c696d9f1adab48490df1da365f7Eino-Ville Talvala threadName = String8::format("C2-%d-CallbkProc", 128da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCameraId); 129da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCallbackProcessor->run(threadName.string()); 130d86a6880fe86bda21a9b53b240996fc410a512a5Eino-Ville Talvala 131f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala if (gLogLevel >= 1) { 132f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala ALOGD("%s: Default parameters converted from camera %d:", __FUNCTION__, 133f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala mCameraId); 1342e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala ALOGD("%s", l.mParameters.paramsFlattened.string()); 135f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala } 136f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 137f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala return OK; 13861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 13961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 14061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville TalvalaCamera2Client::~Camera2Client() { 141a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 1424ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala 143f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala mDestructionStarted = true; 144f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 145c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala disconnect(); 146c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala 147da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala ALOGI("Camera %d: Closed", mCameraId); 14861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 14961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 15061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::dump(int fd, const Vector<String16>& args) { 151611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala String8 result; 1523297daae9681004775012faba9181d65e097e00cEino-Ville Talvala result.appendFormat("Client2[%d] (%p) PID: %d, dump:\n", 153611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala mCameraId, 154611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala getCameraClient()->asBinder().get(), 155611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala mClientPid); 1567f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" State: "); 1577f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala#define CASE_APPEND_ENUM(x) case x: result.append(#x "\n"); break; 1587f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 1592e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala const Parameters& p = mParameters.unsafeAccess(); 160836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala 1612e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala result.append(Parameters::getStateName(p.state)); 1627f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 1634ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala result.append("\n Current parameters:\n"); 1647f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Preview size: %d x %d\n", 165836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.previewWidth, p.previewHeight); 1667f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Preview FPS range: %d - %d\n", 167836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.previewFpsRange[0], p.previewFpsRange[1]); 1687f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Preview HAL pixel format: 0x%x\n", 169836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.previewFormat); 17011b7cdef9726f8270f12f6c393600e8fb3c469deEino-Ville Talvala result.appendFormat(" Preview transform: %x\n", 171836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.previewTransform); 1727f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Picture size: %d x %d\n", 173836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.pictureWidth, p.pictureHeight); 1747f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Jpeg thumbnail size: %d x %d\n", 175836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.jpegThumbSize[0], p.jpegThumbSize[1]); 1767f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Jpeg quality: %d, thumbnail quality: %d\n", 177836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.jpegQuality, p.jpegThumbQuality); 178836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala result.appendFormat(" Jpeg rotation: %d\n", p.jpegRotation); 1797f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" GPS tags %s\n", 180836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.gpsEnabled ? "enabled" : "disabled"); 181836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala if (p.gpsEnabled) { 1827f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" GPS lat x long x alt: %f x %f x %f\n", 183836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.gpsCoordinates[0], p.gpsCoordinates[1], 184836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.gpsCoordinates[2]); 1857f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" GPS timestamp: %lld\n", 186836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.gpsTimestamp); 1877f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" GPS processing method: %s\n", 188836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.gpsProcessingMethod.string()); 1897f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 1907f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 1917f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" White balance mode: "); 192836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.wbMode) { 193d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_AUTO) 194d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_INCANDESCENT) 195d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_FLUORESCENT) 196d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_WARM_FLUORESCENT) 197d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_DAYLIGHT) 198d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_CLOUDY_DAYLIGHT) 199d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_TWILIGHT) 200d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AWB_MODE_SHADE) 2017f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2027f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2037f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2047f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Effect mode: "); 205836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.effectMode) { 206d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_OFF) 207d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_MONO) 208d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_NEGATIVE) 209d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_SOLARIZE) 210d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_SEPIA) 211d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_POSTERIZE) 212d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_WHITEBOARD) 213d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_BLACKBOARD) 214d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_EFFECT_MODE_AQUA) 2157f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2167f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2177f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2187f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Antibanding mode: "); 219836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.antibandingMode) { 220d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AE_ANTIBANDING_MODE_AUTO) 221d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AE_ANTIBANDING_MODE_OFF) 222d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AE_ANTIBANDING_MODE_50HZ) 223d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin CASE_APPEND_ENUM(ANDROID_CONTROL_AE_ANTIBANDING_MODE_60HZ) 2247f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2257f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2267f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2277f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Scene mode: "); 228836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.sceneMode) { 2297f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala case ANDROID_CONTROL_SCENE_MODE_UNSUPPORTED: 2307f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append("AUTO\n"); break; 2317f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_ACTION) 2327f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_PORTRAIT) 2337f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_LANDSCAPE) 2347f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_NIGHT) 2357f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_NIGHT_PORTRAIT) 2367f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_THEATRE) 2377f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_BEACH) 2387f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_SNOW) 2397f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_SUNSET) 2407f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_STEADYPHOTO) 2417f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_FIREWORKS) 2427f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_SPORTS) 2437f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_PARTY) 2447f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_CANDLELIGHT) 2457f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_SCENE_MODE_BARCODE) 2467f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2477f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2487f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2497f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Flash mode: "); 250836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.flashMode) { 2517f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_OFF) 2527f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_AUTO) 2537f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_ON) 2547f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_TORCH) 2557f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_RED_EYE) 2567f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FLASH_MODE_INVALID) 2577f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2587f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2597f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2607f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Focus mode: "); 261836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala switch (p.focusMode) { 2627f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_AUTO) 2637f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_MACRO) 2647f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_CONTINUOUS_VIDEO) 2657f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_CONTINUOUS_PICTURE) 2667f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_EDOF) 2677f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_INFINITY) 2687f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_FIXED) 2697f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala CASE_APPEND_ENUM(Parameters::FOCUS_MODE_INVALID) 2707f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala default: result.append("UNKNOWN\n"); 2717f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2727f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 273d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala result.append(" Focus state: "); 274d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala switch (p.focusState) { 275d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_INACTIVE) 276d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_PASSIVE_SCAN) 277d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_PASSIVE_FOCUSED) 278d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_ACTIVE_SCAN) 279d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_FOCUSED_LOCKED) 280d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala CASE_APPEND_ENUM(ANDROID_CONTROL_AF_STATE_NOT_FOCUSED_LOCKED) 281d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala default: result.append("UNKNOWN\n"); 282d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala } 283d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala 2847f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.append(" Focusing areas:\n"); 285836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala for (size_t i = 0; i < p.focusingAreas.size(); i++) { 2867f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" [ (%d, %d, %d, %d), weight %d ]\n", 287836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.focusingAreas[i].left, 288836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.focusingAreas[i].top, 289836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.focusingAreas[i].right, 290836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.focusingAreas[i].bottom, 291836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.focusingAreas[i].weight); 2927f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 2937f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2947f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Exposure compensation index: %d\n", 295836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.exposureCompensation); 2967f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 2977f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" AE lock %s, AWB lock %s\n", 298836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.autoExposureLock ? "enabled" : "disabled", 299836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.autoWhiteBalanceLock ? "enabled" : "disabled" ); 3007f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3017f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" Metering areas:\n"); 302836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala for (size_t i = 0; i < p.meteringAreas.size(); i++) { 3037f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala result.appendFormat(" [ (%d, %d, %d, %d), weight %d ]\n", 304836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.meteringAreas[i].left, 305836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.meteringAreas[i].top, 306836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.meteringAreas[i].right, 307836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.meteringAreas[i].bottom, 308836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.meteringAreas[i].weight); 3097f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala } 3107f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 311836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala result.appendFormat(" Zoom index: %d\n", p.zoom); 312836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala result.appendFormat(" Video size: %d x %d\n", p.videoWidth, 313836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.videoHeight); 3147f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3153297daae9681004775012faba9181d65e097e00cEino-Ville Talvala result.appendFormat(" Recording hint is %s\n", 316836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.recordingHint ? "set" : "not set"); 3177f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3183297daae9681004775012faba9181d65e097e00cEino-Ville Talvala result.appendFormat(" Video stabilization is %s\n", 319836b81f3c5a5bacb800f698f90ded6bd6e6bc5ceEino-Ville Talvala p.videoStabilization ? "enabled" : "disabled"); 3207f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3213297daae9681004775012faba9181d65e097e00cEino-Ville Talvala result.append(" Current streams:\n"); 322da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala result.appendFormat(" Preview stream ID: %d\n", 323da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala getPreviewStreamId()); 324ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala result.appendFormat(" Capture stream ID: %d\n", 325da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala getCaptureStreamId()); 326da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala result.appendFormat(" Recording stream ID: %d\n", 327da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala getRecordingStreamId()); 328e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala 329e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala result.append(" Quirks for this camera:\n"); 330e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala bool haveQuirk = false; 331e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala if (p.quirks.triggerAfWithAuto) { 332e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala result.appendFormat(" triggerAfWithAuto\n"); 333e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala haveQuirk = true; 334e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala } 335e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala if (p.quirks.useZslFormat) { 336e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala result.appendFormat(" useZslFormat\n"); 337e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala haveQuirk = true; 338e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala } 3397373cbe85e617345f7002256a4be389fe62af913Igor Murashkin if (p.quirks.meteringCropRegion) { 3407373cbe85e617345f7002256a4be389fe62af913Igor Murashkin result.appendFormat(" meteringCropRegion\n"); 3417373cbe85e617345f7002256a4be389fe62af913Igor Murashkin haveQuirk = true; 3427373cbe85e617345f7002256a4be389fe62af913Igor Murashkin } 343e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala if (!haveQuirk) { 344e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala result.appendFormat(" none\n"); 345e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala } 346e382ee28709b83264a46b09e8f766c5ef42efa35Eino-Ville Talvala 34773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala write(fd, result.string(), result.size()); 3483297daae9681004775012faba9181d65e097e00cEino-Ville Talvala 34973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor->dump(fd, args); 350428b77a2b94b74665a47375b3fdb893b98d71269Eino-Ville Talvala 351da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCaptureSequencer->dump(fd, args); 352da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 353c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala mFrameProcessor->dump(fd, args); 354c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala 35597b38a81ac989ccba02d726011a82541f14166dfEino-Ville Talvala mZslProcessor->dump(fd, args); 35697b38a81ac989ccba02d726011a82541f14166dfEino-Ville Talvala 3573297daae9681004775012faba9181d65e097e00cEino-Ville Talvala result = " Device dump:\n"; 358611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala write(fd, result.string(), result.size()); 3597f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3603297daae9681004775012faba9181d65e097e00cEino-Ville Talvala status_t res = mDevice->dump(fd, args); 3613297daae9681004775012faba9181d65e097e00cEino-Ville Talvala if (res != OK) { 3623297daae9681004775012faba9181d65e097e00cEino-Ville Talvala result = String8::format(" Error dumping device: %s (%d)", 3633297daae9681004775012faba9181d65e097e00cEino-Ville Talvala strerror(-res), res); 3643297daae9681004775012faba9181d65e097e00cEino-Ville Talvala write(fd, result.string(), result.size()); 3653297daae9681004775012faba9181d65e097e00cEino-Ville Talvala } 3667f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala 3677f61084a428a5c7afbeff2fa9e9839baf9018020Eino-Ville Talvala#undef CASE_APPEND_ENUM 368611f61998863d3a3ffae4e5f2b723b7319c59ddfEino-Ville Talvala return NO_ERROR; 36961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 37061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 37161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala// ICamera interface 37261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 37361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::disconnect() { 374a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 375ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 376c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala 377c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala // Allow both client and the media server to disconnect at all times 378c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala int callingPid = getCallingPid(); 379c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala if (callingPid != mClientPid && callingPid != mServicePid) return; 380ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 381f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala if (mDevice == 0) return; 382f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 38398bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala ALOGV("Camera %d: Shutting down", mCameraId); 38498bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 385d5087f91357a9218580596b466926ab750bc8ea7Eino-Ville Talvala stopPreviewL(); 3866db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 38798bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala { 38898bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala SharedParameters::Lock l(mParameters); 389c03792041b9dd6f7f54abd6c82bd6c755a336cd8Eino-Ville Talvala if (l.mParameters.state == Parameters::DISCONNECTED) return; 39098bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala l.mParameters.state = Parameters::DISCONNECTED; 39198bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala } 39298bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 39373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor->deletePreviewStream(); 39473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor->deleteRecordingStream(); 395da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mJpegProcessor->deleteStream(); 396d86a6880fe86bda21a9b53b240996fc410a512a5Eino-Ville Talvala mCallbackProcessor->deleteStream(); 397cf70d3469332445dc3ffd09729da3538612b1bb2Eino-Ville Talvala mZslProcessor->deleteStream(); 398cf70d3469332445dc3ffd09729da3538612b1bb2Eino-Ville Talvala 39998bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mFrameProcessor->requestExit(); 40098bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mCaptureSequencer->requestExit(); 40198bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mJpegProcessor->requestExit(); 40298bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mZslProcessor->requestExit(); 40398bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mCallbackProcessor->requestExit(); 40498bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 40598bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala ALOGV("Camera %d: Waiting for threads", mCameraId); 40698bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 40798bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mFrameProcessor->join(); 40898bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mCaptureSequencer->join(); 40998bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mJpegProcessor->join(); 41098bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mZslProcessor->join(); 41198bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mCallbackProcessor->join(); 41298bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 41398bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala ALOGV("Camera %d: Disconnecting device", mCameraId); 41498bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 41598bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala mDevice->disconnect(); 41698bb82d1bf7c94240956426812de6593801faad4Eino-Ville Talvala 4173a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala mDevice.clear(); 4188ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 41961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala CameraService::Client::disconnect(); 42061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 42161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 42261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::connect(const sp<ICameraClient>& client) { 423a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 4249e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 425ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 426ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 4279cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (mClientPid != 0 && getCallingPid() != mClientPid) { 4289cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Connection attempt from pid %d; " 4299cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala "current locked to pid %d", __FUNCTION__, 4309cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala mCameraId, getCallingPid(), mClientPid); 4319cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return BAD_VALUE; 4329cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 4339cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 4349cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala mClientPid = getCallingPid(); 4358ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 4369cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala mCameraClient = client; 437a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala mSharedCameraClient = client; 4389cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 4399cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return OK; 44061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 44161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 44261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::lock() { 443a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 4449e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 445ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 4469cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGV("%s: Camera %d: Lock call from pid %d; current client pid %d", 4479cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, getCallingPid(), mClientPid); 448ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 4499cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (mClientPid == 0) { 4509cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala mClientPid = getCallingPid(); 4519cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return OK; 4529cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 4539cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 4549cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (mClientPid != getCallingPid()) { 4559cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Lock call from pid %d; currently locked to pid %d", 4569cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, getCallingPid(), mClientPid); 4579cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return EBUSY; 4589cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 4599cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 4609cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return OK; 46161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 46261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 46361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::unlock() { 464a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 4659e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 466ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 4679cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGV("%s: Camera %d: Unlock call from pid %d; current client pid %d", 4689cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, getCallingPid(), mClientPid); 469ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 4709cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (mClientPid == getCallingPid()) { 471907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala SharedParameters::Lock l(mParameters); 472907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala if (l.mParameters.state == Parameters::RECORD || 473907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala l.mParameters.state == Parameters::VIDEO_SNAPSHOT) { 474907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala ALOGD("Not allowed to unlock camera during recording."); 475907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala return INVALID_OPERATION; 476907e5651c18d0e25073743a49a685fe1a385939aEino-Ville Talvala } 4779cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala mClientPid = 0; 4789cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala mCameraClient.clear(); 479a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala mSharedCameraClient.clear(); 4809cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return OK; 4819cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 4829cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 4839cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Unlock call from pid %d; currently locked to pid %d", 4849cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, getCallingPid(), mClientPid); 4859cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return EBUSY; 48661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 48761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 4886db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvalastatus_t Camera2Client::setPreviewDisplay( 4896db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala const sp<Surface>& surface) { 490a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 4919e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 492ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 4933a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 4943a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 495ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 4966db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala sp<IBinder> binder; 4976db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala sp<ANativeWindow> window; 4986db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala if (surface != 0) { 4999e1cdea45d40fa8cf95dd080943053856009054fMathias Agopian binder = surface->getIGraphicBufferProducer()->asBinder(); 5006db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala window = surface; 5016db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 5026db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 50336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return setPreviewWindowL(binder,window); 50461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 50561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 5066db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvalastatus_t Camera2Client::setPreviewTexture( 5078ba01021b573889802e67e029225a96f0dfa471aAndy McFadden const sp<IGraphicBufferProducer>& bufferProducer) { 508a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 5099e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 510ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 5113a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 5123a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 513ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 5146db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala sp<IBinder> binder; 5156db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala sp<ANativeWindow> window; 5168ba01021b573889802e67e029225a96f0dfa471aAndy McFadden if (bufferProducer != 0) { 5178ba01021b573889802e67e029225a96f0dfa471aAndy McFadden binder = bufferProducer->asBinder(); 5181a2952aee048ca7b1765e2bc09ebe9aeddaeafa3Mathias Agopian window = new Surface(bufferProducer); 5196db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 52036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return setPreviewWindowL(binder, window); 5216db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala} 5226db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 52336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::setPreviewWindowL(const sp<IBinder>& binder, 524be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala sp<ANativeWindow> window) { 525a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 5266db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala status_t res; 5276db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 5286db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala if (binder == mPreviewSurface) { 5299e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: Camera %d: New window is same as old window", 5309e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala __FUNCTION__, mCameraId); 5316db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return NO_ERROR; 5326db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 5336db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 534f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala Parameters::State state; 535f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala { 536f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala SharedParameters::Lock l(mParameters); 537f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala state = l.mParameters.state; 538f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala } 539f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala switch (state) { 5402e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::DISCONNECTED: 5412e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 5422e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STILL_CAPTURE: 5432e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 5449cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Cannot set preview display while in state %s", 5452e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala __FUNCTION__, mCameraId, 546f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala Parameters::getStateName(state)); 5479cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return INVALID_OPERATION; 5482e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STOPPED: 5492e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::WAITING_FOR_PREVIEW_WINDOW: 5509cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala // OK 5519cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 5522e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 5539cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala // Already running preview - need to stop and create a new stream 5544865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala mStreamingProcessor->stopStream(); 555f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala state = Parameters::WAITING_FOR_PREVIEW_WINDOW; 5569cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 5579cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 5589cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 559bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala mPreviewSurface = binder; 56073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->setPreviewWindow(window); 56173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (res != OK) { 56273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Unable to set new preview window: %s (%d)", 56373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala __FUNCTION__, strerror(-res), res); 56473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return res; 56573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala } 566bd47b7bcfe7f5a97fef81143f4282c41590626feEino-Ville Talvala 567f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala if (state == Parameters::WAITING_FOR_PREVIEW_WINDOW) { 568f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala SharedParameters::Lock l(mParameters); 569f1945f0435e431fab2e6b83337a1ffe71a8df28cEino-Ville Talvala l.mParameters.state = state; 5702e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return startPreviewL(l.mParameters, false); 5716db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 5726db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 5736db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return OK; 57461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 57561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 57661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::setPreviewCallbackFlag(int flag) { 577a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 578228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala ALOGV("%s: Camera %d: Flag 0x%x", __FUNCTION__, mCameraId, flag); 579ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 580ddf3c5025e2f6f35a4c188c19f30142c64a092c4Igor Murashkin 581228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if ( checkPid(__FUNCTION__) != OK) return; 582228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 5832e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 5842e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala setPreviewCallbackFlagL(l.mParameters, flag); 585228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala} 586228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 587228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvalavoid Camera2Client::setPreviewCallbackFlagL(Parameters ¶ms, int flag) { 588228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala status_t res = OK; 589228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (flag & CAMERA_FRAME_CALLBACK_FLAG_ONE_SHOT_MASK) { 590228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala ALOGV("%s: setting oneshot", __FUNCTION__); 591228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala params.previewCallbackOneShot = true; 592228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 593228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (params.previewCallbackFlags != (uint32_t)flag) { 594228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala params.previewCallbackFlags = flag; 595228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala switch(params.state) { 5962e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 597228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala res = startPreviewL(params, true); 598228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala break; 5992e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 6002e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 601228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala res = startRecordingL(params, true); 602228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala break; 603228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala default: 604228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala break; 605228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 606228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (res != OK) { 607228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to refresh request in state %s", 6082e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala __FUNCTION__, mCameraId, 6092e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala Parameters::getStateName(params.state)); 610228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 611228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 612228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 61361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 61461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 61561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::startPreview() { 616a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 6179e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 618ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 6193a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 6203a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 6212e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 6222e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return startPreviewL(l.mParameters, false); 623d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala} 624ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 625228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvalastatus_t Camera2Client::startPreviewL(Parameters ¶ms, bool restart) { 626d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala ATRACE_CALL(); 6276db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala status_t res; 62822d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin 62922d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin ALOGV("%s: state == %d, restart = %d", __FUNCTION__, params.state, restart); 63022d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin 631a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala if ( (params.state == Parameters::PREVIEW || 632a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala params.state == Parameters::RECORD || 633a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala params.state == Parameters::VIDEO_SNAPSHOT) 634a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala && !restart) { 635a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala // Succeed attempt to re-enter a streaming state 636a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala ALOGI("%s: Camera %d: Preview already active, ignoring restart", 637a14be59340219c47639ec77a352d2af362551a6fEino-Ville Talvala __FUNCTION__, mCameraId); 63877449ada4b5ca73a948aa4fef9aafe3079a66d61Alex Ray return OK; 63977449ada4b5ca73a948aa4fef9aafe3079a66d61Alex Ray } 64077449ada4b5ca73a948aa4fef9aafe3079a66d61Alex Ray if (params.state > Parameters::PREVIEW && !restart) { 6414ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala ALOGE("%s: Can't start preview in state %s", 6422e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala __FUNCTION__, 6432e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala Parameters::getStateName(params.state)); 6444ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala return INVALID_OPERATION; 6454ecfec32aca8749baeb634f7c961f804cb1e8f3eEino-Ville Talvala } 6466db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 64773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (!mStreamingProcessor->haveValidPreviewWindow()) { 6482e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala params.state = Parameters::WAITING_FOR_PREVIEW_WINDOW; 6496db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return OK; 6506db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 6512e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala params.state = Parameters::STOPPED; 6529cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 65373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->updatePreviewStream(params); 654be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala if (res != OK) { 655be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala ALOGE("%s: Camera %d: Unable to update preview stream: %s (%d)", 656be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 657be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala return res; 6586db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 65973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala 66073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala Vector<uint8_t> outputStreams; 661228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala bool callbacksEnabled = params.previewCallbackFlags & 662228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala CAMERA_FRAME_CALLBACK_FLAG_ENABLE_MASK; 663228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (callbacksEnabled) { 664d86a6880fe86bda21a9b53b240996fc410a512a5Eino-Ville Talvala res = mCallbackProcessor->updateStream(params); 665228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (res != OK) { 666228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to update callback stream: %s (%d)", 667228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 668228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return res; 669228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 67073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams.push(getCallbackStreamId()); 671228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 6725a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala if (params.zslMode && !params.recordingHint) { 673da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala res = mZslProcessor->updateStream(params); 674da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala if (res != OK) { 675da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to update ZSL stream: %s (%d)", 676da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 677da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala return res; 678da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala } 67973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams.push(getZslStreamId()); 680da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala } 6816db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 68273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams.push(getPreviewStreamId()); 68373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala 6845a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala if (!params.recordingHint) { 68573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (!restart) { 68673bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->updatePreviewRequest(params); 6875a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala if (res != OK) { 68873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Camera %d: Can't set up preview request: " 68973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala "%s (%d)", __FUNCTION__, mCameraId, 69073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala strerror(-res), res); 6915a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala return res; 6925a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala } 6935a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala } 69473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->startStream(StreamingProcessor::PREVIEW, 69573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams); 6965a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala } else { 6975a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala // With recording hint set, we're going to be operating under the 6985a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala // assumption that the user will record video. To optimize recording 6995a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala // startup time, create the necessary output streams for recording and 7005a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala // video snapshot now if they don't already exist. 7015a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala res = mJpegProcessor->updateStream(params); 7025a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala if (res != OK) { 7035a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala ALOGE("%s: Camera %d: Can't pre-configure still image " 7045a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala "stream: %s (%d)", 705be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 706be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala return res; 707be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala } 708da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 70973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (!restart) { 71073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->updateRecordingRequest(params); 71173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (res != OK) { 71273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Camera %d: Can't set up preview request with " 71373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala "record hint: %s (%d)", __FUNCTION__, mCameraId, 71473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala strerror(-res), res); 71573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return res; 71673bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala } 71773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala } 71873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->startStream(StreamingProcessor::RECORD, 71973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams); 720be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala } 721be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala if (res != OK) { 72273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Camera %d: Unable to start streaming preview: %s (%d)", 723be0573b93e2d6fa133579c885583af9ed16bc29dEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 7246db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return res; 7256db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala } 7266db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala 7272e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala params.state = Parameters::PREVIEW; 7286db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return OK; 72961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 73061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 73161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::stopPreview() { 732a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 7339e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 734ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 7353a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 7363a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return; 73736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala stopPreviewL(); 738ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala} 739ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 74036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalavoid Camera2Client::stopPreviewL() { 741ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala ATRACE_CALL(); 7424865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala status_t res; 743d5087f91357a9218580596b466926ab750bc8ea7Eino-Ville Talvala const nsecs_t kStopCaptureTimeout = 3000000000LL; // 3 seconds 7442e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala Parameters::State state; 745228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala { 7462e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 7472e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala state = l.mParameters.state; 748228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 749228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 750228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala switch (state) { 7512e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::DISCONNECTED: 752ceb388d6c03c38b96dc41c0ea4804b749aa077c4Eino-Ville Talvala // Nothing to do. 753d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala break; 7542e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STOPPED: 755d5087f91357a9218580596b466926ab750bc8ea7Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 7562e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STILL_CAPTURE: 757d5087f91357a9218580596b466926ab750bc8ea7Eino-Ville Talvala mCaptureSequencer->waitUntilIdle(kStopCaptureTimeout); 758d5087f91357a9218580596b466926ab750bc8ea7Eino-Ville Talvala // no break 7592e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 7602e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 76173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor->stopStream(); 7624865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala res = mDevice->waitUntilDrained(); 7634865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala if (res != OK) { 7644865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala ALOGE("%s: Camera %d: Waiting to stop streaming failed: %s (%d)", 7654865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 7664865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala } 767228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala // no break 7682e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::WAITING_FOR_PREVIEW_WINDOW: { 7692e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 7702e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.state = Parameters::STOPPED; 7712e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala commandStopFaceDetectionL(l.mParameters); 772d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala break; 773228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 774d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala default: 775d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala ALOGE("%s: Camera %d: Unknown state %d", __FUNCTION__, mCameraId, 776228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala state); 777d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala } 77861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 77961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 78061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalabool Camera2Client::previewEnabled() { 781a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 782ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 7833a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 7843a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return false; 7853a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 7862e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 7872e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return l.mParameters.state == Parameters::PREVIEW; 78861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 78961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 79061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::storeMetaDataInBuffers(bool enabled) { 791a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 792ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 7933a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 7943a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 7953a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 7962e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 7972e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala switch (l.mParameters.state) { 7982e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 7992e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 80078822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala ALOGE("%s: Camera %d: Can't be called in state %s", 8012e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala __FUNCTION__, mCameraId, 8022e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala Parameters::getStateName(l.mParameters.state)); 80378822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala return INVALID_OPERATION; 80478822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala default: 80578822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala // OK 80678822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala break; 80778822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala } 80878822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala 8092e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.storeMetadataInBuffers = enabled; 81078822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala 81178822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala return OK; 81261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 81361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 81461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::startRecording() { 815a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 8169e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 817ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 8189cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala status_t res; 8193a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 8202e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 821228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 8222e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return startRecordingL(l.mParameters, false); 823228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala} 8243a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 825228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvalastatus_t Camera2Client::startRecordingL(Parameters ¶ms, bool restart) { 826228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala status_t res; 82722d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin 82822d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin ALOGV("%s: state == %d, restart = %d", __FUNCTION__, params.state, restart); 82922d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin 830228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala switch (params.state) { 8312e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STOPPED: 832228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala res = startPreviewL(params, false); 8339cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (res != OK) return res; 8349cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 8352e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 8369cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala // Ready to go 8379cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 8382e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 8392e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 840228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala // OK to call this when recording is already on, just skip unless 841228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala // we're looking to restart 842228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (!restart) return OK; 8439cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 8449cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala default: 8459cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Can't start recording in state %s", 8462e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala __FUNCTION__, mCameraId, 8472e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala Parameters::getStateName(params.state)); 8489cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return INVALID_OPERATION; 8499cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala }; 8509cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 851228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (!params.storeMetadataInBuffers) { 85278822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala ALOGE("%s: Camera %d: Recording only supported in metadata mode, but " 85378822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala "non-metadata recording mode requested!", __FUNCTION__, 85478822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala mCameraId); 85578822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala return INVALID_OPERATION; 85678822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala } 85778822d73af1e7f6b8b297fc7f98ef7f8257cc10aEino-Ville Talvala 85873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (!restart) { 85973bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mCameraService->playSound(CameraService::SOUND_RECORDING); 86073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor->updateRecordingRequest(params); 86173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala if (res != OK) { 86273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Camera %d: Unable to update recording request: %s (%d)", 86373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 86473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return res; 86573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala } 86673bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala } 867609acc0c96bc2aedd42246862b537e045f5184b6Eino-Ville Talvala 86873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->updateRecordingStream(params); 8699cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (res != OK) { 8709cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Unable to update recording stream: %s (%d)", 8719cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 8729cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return res; 8739cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 87473bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala 87573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala Vector<uint8_t> outputStreams; 876228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala bool callbacksEnabled = params.previewCallbackFlags & 877228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala CAMERA_FRAME_CALLBACK_FLAG_ENABLE_MASK; 878228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (callbacksEnabled) { 879d86a6880fe86bda21a9b53b240996fc410a512a5Eino-Ville Talvala res = mCallbackProcessor->updateStream(params); 880228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (res != OK) { 881228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to update callback stream: %s (%d)", 882228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 883228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return res; 884228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 88573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams.push(getCallbackStreamId()); 886228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 88773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams.push(getPreviewStreamId()); 88873bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams.push(getRecordingStreamId()); 8899cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 89073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->startStream(StreamingProcessor::RECORD, 89173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala outputStreams); 8929cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (res != OK) { 89373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala ALOGE("%s: Camera %d: Unable to start recording stream: %s (%d)", 8949cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 8959cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return res; 8969cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 8979cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 8982e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (params.state < Parameters::RECORD) { 8992e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala params.state = Parameters::RECORD; 900228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 9019cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 9029cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return OK; 90361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 90461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 90561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::stopRecording() { 906a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 9079e4c3db01ba4eb1e5acbed113f78a31374900df6Eino-Ville Talvala ALOGV("%s: E", __FUNCTION__); 908ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 9092e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 910228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala 9119cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala status_t res; 9123a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return; 9133a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 9142e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala switch (l.mParameters.state) { 9152e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 9169cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala // OK to stop 9179cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala break; 9182e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STOPPED: 9192e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 9202e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STILL_CAPTURE: 9212e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 9229cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala default: 9239cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala ALOGE("%s: Camera %d: Can't stop recording in state %s", 9242e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala __FUNCTION__, mCameraId, 9252e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala Parameters::getStateName(l.mParameters.state)); 9269cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala return; 9279cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala }; 9289cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 929609acc0c96bc2aedd42246862b537e045f5184b6Eino-Ville Talvala mCameraService->playSound(CameraService::SOUND_RECORDING); 930609acc0c96bc2aedd42246862b537e045f5184b6Eino-Ville Talvala 9315a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala res = startPreviewL(l.mParameters, true); 9329cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala if (res != OK) { 9335a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to return to preview", 9345a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala __FUNCTION__, mCameraId); 9359cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala } 93661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 93761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 93861ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalabool Camera2Client::recordingEnabled() { 939a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 940ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 9418da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong 9423a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( checkPid(__FUNCTION__) != OK) return false; 9433a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 9448da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong return recordingEnabledL(); 9458da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong} 9468da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong 9478da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dongbool Camera2Client::recordingEnabledL() { 9488da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong ATRACE_CALL(); 9492e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 9508da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong 9512e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return (l.mParameters.state == Parameters::RECORD 9522e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala || l.mParameters.state == Parameters::VIDEO_SNAPSHOT); 95361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 95461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 95561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalavoid Camera2Client::releaseRecordingFrame(const sp<IMemory>& mem) { 956a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 957ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 9583a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( checkPid(__FUNCTION__) != OK) return; 95930e65e7e2ec01e13e45b5e38552a34d2fbb3f866Eino-Ville Talvala 96073bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mStreamingProcessor->releaseRecordingFrame(mem); 96161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 96261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 96361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::autoFocus() { 964a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 965ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 9668a42dd8cd1a245d844f96cfd67dc342d7937e353Eino-Ville Talvala ALOGV("%s: Camera %d", __FUNCTION__, mCameraId); 9673a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 9683a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 9693a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 970174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala int triggerId; 971d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala bool notifyImmediately = false; 972d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala bool notifySuccess = false; 973174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala { 9742e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 9754865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala if (l.mParameters.state < Parameters::PREVIEW) { 9764865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return INVALID_OPERATION; 9774865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala } 9784865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 9795f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin /** 9805f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin * If the camera does not support auto-focus, it is a no-op and 9815f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin * onAutoFocus(boolean, Camera) callback will be called immediately 9825f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin * with a fake value of success set to true. 9835f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin */ 9845f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin if (l.mParameters.focusMode == Parameters::FOCUS_MODE_FIXED) { 985d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala notifyImmediately = true; 986d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala notifySuccess = true; 987d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala } 988d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala /** 989d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala * If we're in CAF mode, and AF has already been locked, just fire back 990d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala * the callback right away; the HAL would not send a notification since 991d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala * no state change would happen on a AF trigger. 992d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala */ 993d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala if ( (l.mParameters.focusMode == Parameters::FOCUS_MODE_CONTINUOUS_PICTURE || 994d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala l.mParameters.focusMode == Parameters::FOCUS_MODE_CONTINUOUS_VIDEO) && 995d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala l.mParameters.focusState == ANDROID_CONTROL_AF_STATE_FOCUSED_LOCKED ) { 996d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala notifyImmediately = true; 997d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala notifySuccess = true; 998d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala } 999d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala /** 1000d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala * Send immediate notification back to client 1001d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala */ 1002d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala if (notifyImmediately) { 10035f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin SharedCameraClient::Lock l(mSharedCameraClient); 10045f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin if (l.mCameraClient != 0) { 10055f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin l.mCameraClient->notifyCallback(CAMERA_MSG_FOCUS, 1006d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala notifySuccess ? 1 : 0, 0); 10075f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin } 10085f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin return OK; 10095f0714eb039c07554bef6ec289c70ed1164fdf52Igor Murashkin } 1010d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala /** 1011d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala * Handle quirk mode for AF in scene modes 1012d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala */ 101395069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala if (l.mParameters.quirks.triggerAfWithAuto && 101495069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.sceneMode != ANDROID_CONTROL_SCENE_MODE_UNSUPPORTED && 1015ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala l.mParameters.focusMode != Parameters::FOCUS_MODE_AUTO && 1016ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala !l.mParameters.focusingAreas[0].isEmpty()) { 101795069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala ALOGV("%s: Quirk: Switching from focusMode %d to AUTO", 101895069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala __FUNCTION__, l.mParameters.focusMode); 101995069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.shadowFocusMode = l.mParameters.focusMode; 102095069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.focusMode = Parameters::FOCUS_MODE_AUTO; 102195069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala updateRequests(l.mParameters); 102295069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala } 102395069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala 10242e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.currentAfTriggerId = ++l.mParameters.afTriggerCounter; 10252e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala triggerId = l.mParameters.currentAfTriggerId; 1026174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 10274865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala syncWithDevice(); 1028174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 1029174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala mDevice->triggerAutofocus(triggerId); 1030174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 10316db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return OK; 103261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 103361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 103461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::cancelAutoFocus() { 1035a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 1036ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 10378a42dd8cd1a245d844f96cfd67dc342d7937e353Eino-Ville Talvala ALOGV("%s: Camera %d", __FUNCTION__, mCameraId); 10383a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 10393a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 10403a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 1041174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala int triggerId; 1042174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala { 10432e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 10442e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala triggerId = ++l.mParameters.afTriggerCounter; 104595069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala 104695069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala // When using triggerAfWithAuto quirk, may need to reset focus mode to 1047ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala // the real state at this point. No need to cancel explicitly if 1048ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala // changing the AF mode. 104995069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala if (l.mParameters.shadowFocusMode != Parameters::FOCUS_MODE_INVALID) { 105095069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala ALOGV("%s: Quirk: Restoring focus mode to %d", __FUNCTION__, 105195069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.shadowFocusMode); 105295069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.focusMode = l.mParameters.shadowFocusMode; 105395069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala l.mParameters.shadowFocusMode = Parameters::FOCUS_MODE_INVALID; 105495069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala updateRequests(l.mParameters); 1055ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala 1056ac0cd56627b121081308213d5a327cfbae410f4dEino-Ville Talvala return OK; 105795069fefbdf54d87a624c2ac73727fce1c38545eEino-Ville Talvala } 1058174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 10594865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala syncWithDevice(); 1060174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 1061174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala mDevice->triggerCancelAutofocus(triggerId); 1062174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 10636db981c45a964f0d9df4c3451f064dff7954d78eEino-Ville Talvala return OK; 106461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 106561ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 1066ff82370c7c04340d50673d425f48acafd00f2bc9Ben Murdochstatus_t Camera2Client::takePicture(int msgType) { 1067a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 1068ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 1069d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala status_t res; 10703a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 1071d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala 1072b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala { 1073b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala SharedParameters::Lock l(mParameters); 1074b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala switch (l.mParameters.state) { 1075b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::DISCONNECTED: 1076b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::STOPPED: 1077b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::WAITING_FOR_PREVIEW_WINDOW: 1078b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala ALOGE("%s: Camera %d: Cannot take picture without preview enabled", 1079da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala __FUNCTION__, mCameraId); 1080b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala return INVALID_OPERATION; 1081b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::PREVIEW: 1082b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala // Good to go for takePicture 1083b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala res = commandStopFaceDetectionL(l.mParameters); 1084b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala if (res != OK) { 1085b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala ALOGE("%s: Camera %d: Unable to stop face detection for still capture", 1086b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala __FUNCTION__, mCameraId); 1087b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala return res; 1088b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala } 1089b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala l.mParameters.state = Parameters::STILL_CAPTURE; 1090b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala break; 1091b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::RECORD: 1092b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala // Good to go for video snapshot 1093b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala l.mParameters.state = Parameters::VIDEO_SNAPSHOT; 1094b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala break; 1095b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::STILL_CAPTURE: 1096b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 1097b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala ALOGE("%s: Camera %d: Already taking a picture", 1098b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala __FUNCTION__, mCameraId); 1099b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala return INVALID_OPERATION; 1100b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala } 1101d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala 1102b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala ALOGV("%s: Camera %d: Starting picture capture", __FUNCTION__, mCameraId); 1103d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala 1104b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala res = mJpegProcessor->updateStream(l.mParameters); 1105b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala if (res != OK) { 1106b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala ALOGE("%s: Camera %d: Can't set up still image stream: %s (%d)", 1107b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 1108b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala return res; 1109b8d6efba8b87e6eeb049651cb67f9827198e658eEino-Ville Talvala } 1110228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 11118ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 11124865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala // Need HAL to have correct settings before (possibly) triggering precapture 11134865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala syncWithDevice(); 11144865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 1115aa9e3e01b86bd9bfb5ac36c0f360d5fe478cbb2dIgor Murashkin res = mCaptureSequencer->startCapture(msgType); 1116d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala if (res != OK) { 1117da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to start capture: %s (%d)", 1118d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 1119d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala } 1120d4bcfde6bf3e7b28e36f6ec66e6d9e5adebfa949Eino-Ville Talvala 1121da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala return res; 112261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 112361ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 112461ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::setParameters(const String8& params) { 1125a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 11268a42dd8cd1a245d844f96cfd67dc342d7937e353Eino-Ville Talvala ALOGV("%s: Camera %d", __FUNCTION__, mCameraId); 1127ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 11286861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala status_t res; 11293a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 11303a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala 11312e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 11326861a4e9f929c2cb4a3131244e01e676c5b28f55Eino-Ville Talvala 11332e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala res = l.mParameters.set(params); 11342e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (res != OK) return res; 11359cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 11362e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala res = updateRequests(l.mParameters); 11378ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 11388ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 113961ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 1140f69c70ded4316ea3ee504ac779bd024433ed4ef7Eino-Ville Talvala 114161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville TalvalaString8 Camera2Client::getParameters() const { 1142a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 11438a42dd8cd1a245d844f96cfd67dc342d7937e353Eino-Ville Talvala ALOGV("%s: Camera %d", __FUNCTION__, mCameraId); 1144ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 11453a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( checkPid(__FUNCTION__) != OK) return String8(); 1146ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 11472e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::ReadLock l(mParameters); 1148ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala 11498a42dd8cd1a245d844f96cfd67dc342d7937e353Eino-Ville Talvala return l.mParameters.get(); 115061ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 115161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 115261ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvalastatus_t Camera2Client::sendCommand(int32_t cmd, int32_t arg1, int32_t arg2) { 1153a189097d0c96fac9afa86e644312ffbb0027b124Eino-Ville Talvala ATRACE_CALL(); 1154ac45eb3dfa7347f7b8c98be1111b2a5f9e344c46Eino-Ville Talvala Mutex::Autolock icl(mICameraLock); 11553a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala status_t res; 11563a609147811105d40766f8f8f5904bf71cb123cbEino-Ville Talvala if ( (res = checkPid(__FUNCTION__) ) != OK) return res; 1157c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala 1158c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala ALOGV("%s: Camera %d: Command %d (%d, %d)", __FUNCTION__, mCameraId, 1159c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala cmd, arg1, arg2); 1160c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala 116136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala switch (cmd) { 116236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_START_SMOOTH_ZOOM: 116336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandStartSmoothZoomL(); 116436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_STOP_SMOOTH_ZOOM: 116536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandStopSmoothZoomL(); 116636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_SET_DISPLAY_ORIENTATION: 116736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandSetDisplayOrientationL(arg1); 116836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_ENABLE_SHUTTER_SOUND: 116936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandEnableShutterSoundL(arg1 == 1); 117036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_PLAY_RECORDING_SOUND: 117136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandPlayRecordingSoundL(); 117236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_START_FACE_DETECTION: 117336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandStartFaceDetectionL(arg1); 1174228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case CAMERA_CMD_STOP_FACE_DETECTION: { 11752e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 11762e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala return commandStopFaceDetectionL(l.mParameters); 1177228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 117836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_ENABLE_FOCUS_MOVE_MSG: 117936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandEnableFocusMoveMsgL(arg1 == 1); 118036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_PING: 118136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandPingL(); 118236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala case CAMERA_CMD_SET_VIDEO_BUFFER_COUNT: 118336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return commandSetVideoBufferCountL(arg1); 118436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala default: 118536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("%s: Unknown command %d (arguments %d, %d)", 118636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala __FUNCTION__, cmd, arg1, arg2); 1187c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala return BAD_VALUE; 118836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 118936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 119036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 119136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandStartSmoothZoomL() { 119236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("%s: Unimplemented!", __FUNCTION__); 119336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 119436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 119536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 119636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandStopSmoothZoomL() { 119736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("%s: Unimplemented!", __FUNCTION__); 119836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 119936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 120036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 120136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandSetDisplayOrientationL(int degrees) { 12022e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala int transform = Parameters::degToTransform(degrees, 120336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala mCameraFacing == CAMERA_FACING_FRONT); 120436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala if (transform == -1) { 120536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("%s: Camera %d: Error setting %d as display orientation value", 120636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala __FUNCTION__, mCameraId, degrees); 120736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return BAD_VALUE; 120836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 12092e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 12102e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (transform != l.mParameters.previewTransform && 121173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala getPreviewStreamId() != NO_STREAM) { 121273bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala mDevice->setStreamTransform(getPreviewStreamId(), transform); 121336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 12142e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.previewTransform = transform; 121536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 121636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 121736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 121836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandEnableShutterSoundL(bool enable) { 12192e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 122036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala if (enable) { 12212e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.playShutterSound = true; 1222c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala return OK; 122336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 1224983cf231ab2d176a14595cdae46ff1b0c239af47James Dong 122536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala // Disabling shutter sound may not be allowed. In that case only 122636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala // allow the mediaserver process to disable the sound. 122736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala char value[PROPERTY_VALUE_MAX]; 122836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala property_get("ro.camera.sound.forced", value, "0"); 122936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala if (strncmp(value, "0", 2) != 0) { 123036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala // Disabling shutter sound is not allowed. Deny if the current 123136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala // process is not mediaserver. 123236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala if (getCallingPid() != getpid()) { 123336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("Failed to disable shutter sound. Permission denied (pid %d)", 123436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala getCallingPid()); 123536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return PERMISSION_DENIED; 1236983cf231ab2d176a14595cdae46ff1b0c239af47James Dong } 123736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 1238983cf231ab2d176a14595cdae46ff1b0c239af47James Dong 12392e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.playShutterSound = false; 124036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 124136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 1242983cf231ab2d176a14595cdae46ff1b0c239af47James Dong 124336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandPlayRecordingSoundL() { 124436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala mCameraService->playSound(CameraService::SOUND_RECORDING); 124536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 124636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 124736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 1248ddf3c5025e2f6f35a4c188c19f30142c64a092c4Igor Murashkinstatus_t Camera2Client::commandStartFaceDetectionL(int /*type*/) { 12498ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGV("%s: Camera %d: Starting face detection", 12508ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId); 12518ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala status_t res; 12522e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 12532e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala switch (l.mParameters.state) { 12542e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::DISCONNECTED: 12552e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STOPPED: 12562e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::WAITING_FOR_PREVIEW_WINDOW: 12572e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::STILL_CAPTURE: 12588ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Cannot start face detection without preview active", 12598ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId); 12608ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return INVALID_OPERATION; 12612e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::PREVIEW: 12622e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::RECORD: 12632e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala case Parameters::VIDEO_SNAPSHOT: 12648ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala // Good to go for starting face detect 12658ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala break; 12668ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 12678ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala // Ignoring type 12682e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.fastInfo.bestFaceDetectMode == 1269d32b99b1a87497280add6efc0e99bd383e402de1Igor Murashkin ANDROID_STATISTICS_FACE_DETECT_MODE_OFF) { 12708ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Face detection not supported", 12718ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId); 12728ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return INVALID_OPERATION; 12738ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 12742e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.enableFaceDetect) return OK; 12758ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 12762e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.enableFaceDetect = true; 12778ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 12782e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala res = updateRequests(l.mParameters); 12798ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 12808ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 128136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 128236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 1283228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvalastatus_t Camera2Client::commandStopFaceDetectionL(Parameters ¶ms) { 12848ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala status_t res = OK; 12858ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGV("%s: Camera %d: Stopping face detection", 12868ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId); 12878ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 1288228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala if (!params.enableFaceDetect) return OK; 12898ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 1290228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala params.enableFaceDetect = false; 12918ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 12922e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (params.state == Parameters::PREVIEW 12932e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala || params.state == Parameters::RECORD 12942e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala || params.state == Parameters::VIDEO_SNAPSHOT) { 1295228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala res = updateRequests(params); 12968ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 12978ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 12988ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 129936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 130036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 130136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandEnableFocusMoveMsgL(bool enable) { 13022e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 13032e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.enableFocusMoveMessages = enable; 1304174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 130536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return OK; 130636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 130736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 130836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandPingL() { 130936cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala // Always ping back if access is proper and device is alive 13102e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 13112e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.state != Parameters::DISCONNECTED) { 1312983cf231ab2d176a14595cdae46ff1b0c239af47James Dong return OK; 131336cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } else { 131436cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return NO_INIT; 131536cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala } 131636cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala} 131736cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala 131836cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvalastatus_t Camera2Client::commandSetVideoBufferCountL(size_t count) { 13198da4cd7d706d9f551bf2d08cd8b61907a10cd38dJames Dong if (recordingEnabledL()) { 132036cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala ALOGE("%s: Camera %d: Error setting video buffer count after " 132136cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala "recording was started", __FUNCTION__, mCameraId); 132236cdfb185877a7f573621d19ed2b2e1cac13d62eEino-Ville Talvala return INVALID_OPERATION; 1323c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala } 1324c94cd19694ea0befe2eb22735c50b00070f006d9Eino-Ville Talvala 132573bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return mStreamingProcessor->setRecordingBufferCount(count); 132661ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} 132761ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala 13283cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala/** Device-related methods */ 13293cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala 1330160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvalavoid Camera2Client::notifyError(int errorCode, int arg1, int arg2) { 1331160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala ALOGE("Error condition %d reported by HAL, arguments %d, %d", errorCode, arg1, arg2); 1332160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala} 1333160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala 1334160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvalavoid Camera2Client::notifyShutter(int frameNumber, nsecs_t timestamp) { 1335ddf3c5025e2f6f35a4c188c19f30142c64a092c4Igor Murashkin (void)frameNumber; 1336ddf3c5025e2f6f35a4c188c19f30142c64a092c4Igor Murashkin (void)timestamp; 1337160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala ALOGV("%s: Shutter notification for frame %d at time %lld", __FUNCTION__, 1338160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala frameNumber, timestamp); 1339160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala} 1340160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala 1341160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvalavoid Camera2Client::notifyAutoFocus(uint8_t newState, int triggerId) { 1342160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala ALOGV("%s: Autofocus state now %d, last trigger %d", 1343160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala __FUNCTION__, newState, triggerId); 1344174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala bool sendCompletedMessage = false; 1345174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala bool sendMovingMessage = false; 1346174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala 1347174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala bool success = false; 1348174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala bool afInMotion = false; 1349174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala { 13502e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala SharedParameters::Lock l(mParameters); 1351d6cc4a62f3d94cad4dd36bd0a844ba8764177d26Eino-Ville Talvala l.mParameters.focusState = newState; 13522e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala switch (l.mParameters.focusMode) { 1353174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_AUTO: 1354174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_MACRO: 1355174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Don't send notifications upstream if they're not for the current AF 1356174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // trigger. For example, if cancel was called in between, or if we 1357174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // already sent a notification about this AF call. 13582e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (triggerId != l.mParameters.currentAfTriggerId) break; 1359174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala switch (newState) { 1360174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_FOCUSED_LOCKED: 1361174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala success = true; 1362174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // no break 1363174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_NOT_FOCUSED_LOCKED: 1364174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala sendCompletedMessage = true; 13652e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.currentAfTriggerId = -1; 1366174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1367174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_ACTIVE_SCAN: 1368174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Just starting focusing, ignore 1369174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1370174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_INACTIVE: 1371174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_PASSIVE_SCAN: 1372174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_PASSIVE_FOCUSED: 1373174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala default: 1374174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Unexpected in AUTO/MACRO mode 1375174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala ALOGE("%s: Unexpected AF state transition in AUTO/MACRO mode: %d", 1376174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala __FUNCTION__, newState); 1377174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1378174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1379174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1380174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_CONTINUOUS_VIDEO: 1381174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_CONTINUOUS_PICTURE: 1382174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala switch (newState) { 1383174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_FOCUSED_LOCKED: 1384174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala success = true; 1385174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // no break 1386174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_NOT_FOCUSED_LOCKED: 1387174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Don't send notifications upstream if they're not for 1388174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // the current AF trigger. For example, if cancel was 1389174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // called in between, or if we already sent a 1390174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // notification about this AF call. 1391174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Send both a 'AF done' callback and a 'AF move' callback 13922e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (triggerId != l.mParameters.currentAfTriggerId) break; 1393174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala sendCompletedMessage = true; 1394174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala afInMotion = false; 13952e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.enableFocusMoveMessages && 13962e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.afInMotion) { 1397174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala sendMovingMessage = true; 1398174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 13992e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.currentAfTriggerId = -1; 1400174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1401174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_INACTIVE: 1402174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Cancel was called, or we switched state; care if 1403174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // currently moving 1404174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala afInMotion = false; 14052e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.enableFocusMoveMessages && 14062e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.afInMotion) { 1407174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala sendMovingMessage = true; 1408174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1409174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1410174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_PASSIVE_SCAN: 1411174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Start passive scan, inform upstream 1412174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala afInMotion = true; 1413174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // no break 1414174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case ANDROID_CONTROL_AF_STATE_PASSIVE_FOCUSED: 1415174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala // Stop passive scan, inform upstream 14162e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (l.mParameters.enableFocusMoveMessages) { 1417174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala sendMovingMessage = true; 1418174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1419174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1420174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 14212e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala l.mParameters.afInMotion = afInMotion; 1422174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala break; 1423174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_EDOF: 1424174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_INFINITY: 1425174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala case Parameters::FOCUS_MODE_FIXED: 1426174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala default: 1427174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala if (newState != ANDROID_CONTROL_AF_STATE_INACTIVE) { 1428a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala ALOGE("%s: Unexpected AF state change %d " 1429a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala "(ID %d) in focus mode %d", 1430a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala __FUNCTION__, newState, triggerId, 1431a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala l.mParameters.focusMode); 1432174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1433174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1434174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1435174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala if (sendMovingMessage) { 1436a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala SharedCameraClient::Lock l(mSharedCameraClient); 1437a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala if (l.mCameraClient != 0) { 1438a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala l.mCameraClient->notifyCallback(CAMERA_MSG_FOCUS_MOVE, 14398ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala afInMotion ? 1 : 0, 0); 14408ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 1441174181eec57c963a2a17bd156d81c3f18b3ba75cEino-Ville Talvala } 1442603b12efa16e7afb4e6c75f6b353216c83e8e135Eino-Ville Talvala if (sendCompletedMessage) { 1443a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala SharedCameraClient::Lock l(mSharedCameraClient); 1444a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala if (l.mCameraClient != 0) { 1445a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala l.mCameraClient->notifyCallback(CAMERA_MSG_FOCUS, 1446a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala success ? 1 : 0, 0); 14478ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 1448603b12efa16e7afb4e6c75f6b353216c83e8e135Eino-Ville Talvala } 1449160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala} 1450160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala 1451160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvalavoid Camera2Client::notifyAutoExposure(uint8_t newState, int triggerId) { 1452160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala ALOGV("%s: Autoexposure state now %d, last trigger %d", 1453160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala __FUNCTION__, newState, triggerId); 1454da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala mCaptureSequencer->notifyAutoExposure(newState, triggerId); 1455160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala} 1456160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala 1457160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvalavoid Camera2Client::notifyAutoWhitebalance(uint8_t newState, int triggerId) { 1458ddf3c5025e2f6f35a4c188c19f30142c64a092c4Igor Murashkin (void)newState; 1459ddf3c5025e2f6f35a4c188c19f30142c64a092c4Igor Murashkin (void)triggerId; 1460160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala ALOGV("%s: Auto-whitebalance state now %d, last trigger %d", 1461160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala __FUNCTION__, newState, triggerId); 1462160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala} 1463160d4af9d933fe9461bb213e5876fc5c8c2178c2Eino-Ville Talvala 1464da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvalaint Camera2Client::getCameraId() const { 1465a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala return mCameraId; 1466c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala} 1467c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala 1468a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvalaconst sp<Camera2Device>& Camera2Client::getCameraDevice() { 1469a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala return mDevice; 1470c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala} 1471c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala 1472609acc0c96bc2aedd42246862b537e045f5184b6Eino-Ville Talvalaconst sp<CameraService>& Camera2Client::getCameraService() { 1473609acc0c96bc2aedd42246862b537e045f5184b6Eino-Ville Talvala return mCameraService; 1474609acc0c96bc2aedd42246862b537e045f5184b6Eino-Ville Talvala} 1475609acc0c96bc2aedd42246862b537e045f5184b6Eino-Ville Talvala 1476a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvalacamera2::SharedParameters& Camera2Client::getParameters() { 1477a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala return mParameters; 1478c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala} 1479c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala 1480da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvalaint Camera2Client::getPreviewStreamId() const { 148173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return mStreamingProcessor->getPreviewStreamId(); 1482da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1483da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 1484da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvalaint Camera2Client::getCaptureStreamId() const { 1485da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala return mJpegProcessor->getStreamId(); 1486da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1487da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 1488da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvalaint Camera2Client::getCallbackStreamId() const { 1489da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala return mCallbackProcessor->getStreamId(); 1490da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1491da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 1492da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvalaint Camera2Client::getRecordingStreamId() const { 149373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala return mStreamingProcessor->getRecordingStreamId(); 1494da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1495da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 1496da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvalaint Camera2Client::getZslStreamId() const { 1497da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala return mZslProcessor->getStreamId(); 1498da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1499da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 15004865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalastatus_t Camera2Client::registerFrameListener(int32_t minId, int32_t maxId, 15014865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala wp<camera2::FrameProcessor::FilteredListener> listener) { 15024865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return mFrameProcessor->registerListener(minId, maxId, listener); 15034865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala} 15044865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 15054865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalastatus_t Camera2Client::removeFrameListener(int32_t minId, int32_t maxId, 1506da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala wp<camera2::FrameProcessor::FilteredListener> listener) { 15074865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return mFrameProcessor->removeListener(minId, maxId, listener); 1508da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1509da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 15104865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalastatus_t Camera2Client::stopStream() { 15114865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return mStreamingProcessor->stopStream(); 1512da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala} 1513da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 1514a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville TalvalaCamera2Client::SharedCameraClient::Lock::Lock(SharedCameraClient &client): 1515a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala mCameraClient(client.mCameraClient), 1516a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala mSharedClient(client) { 1517a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala mSharedClient.mCameraClientLock.lock(); 1518c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala} 1519c8474b68e435cd840ba66791fb09e3da59f1d93cEino-Ville Talvala 1520a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville TalvalaCamera2Client::SharedCameraClient::Lock::~Lock() { 1521a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala mSharedClient.mCameraClientLock.unlock(); 15228ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala} 15238ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 1524ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville TalvalaCamera2Client::SharedCameraClient::SharedCameraClient(const sp<ICameraClient>&client): 1525ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala mCameraClient(client) { 1526ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala} 1527ea0d51b5ed0b474433b02414f9133b835f972569Eino-Ville Talvala 1528a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville TalvalaCamera2Client::SharedCameraClient& Camera2Client::SharedCameraClient::operator=( 1529a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala const sp<ICameraClient>&client) { 1530a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala Mutex::Autolock l(mCameraClientLock); 1531a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala mCameraClient = client; 1532a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala return *this; 1533a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala} 15342e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala 1535a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvalavoid Camera2Client::SharedCameraClient::clear() { 1536a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala Mutex::Autolock l(mCameraClientLock); 1537a16733eeb9c40db4793bec408f29b4204e5f23b1Eino-Ville Talvala mCameraClient.clear(); 15388ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala} 15398ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 15404865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kPreviewRequestIdStart; 15414865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kPreviewRequestIdEnd; 15424865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kRecordingRequestIdStart; 15434865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kRecordingRequestIdEnd; 15444865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kCaptureRequestIdStart; 15454865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalaconst int32_t Camera2Client::kCaptureRequestIdEnd; 1546da6665cbd06ca58d3357c3002b7366d13e23f152Eino-Ville Talvala 15473cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala/** Utility methods */ 15483cca136b73b0f4d058019230eb2070cc23e2bbb0Eino-Ville Talvala 15495a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvalastatus_t Camera2Client::updateRequests(Parameters ¶ms) { 15508ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala status_t res; 15518ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 155222d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin ALOGV("%s: Camera %d: state = %d", __FUNCTION__, getCameraId(), params.state); 155322d58d37db6b5f48a10b3a19f69ffda09943c125Igor Murashkin 15544865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala res = mStreamingProcessor->incrementStreamingIds(); 15554865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala if (res != OK) { 15564865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala ALOGE("%s: Camera %d: Unable to increment request IDs: %s (%d)", 15574865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 15584865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return res; 15594865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala } 15604865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 156173bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->updatePreviewRequest(params); 15628ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala if (res != OK) { 15638ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to update preview request: %s (%d)", 15648ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 15658ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 15668ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 156773bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = mStreamingProcessor->updateRecordingRequest(params); 15688ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala if (res != OK) { 15698ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Unable to update recording request: %s (%d)", 15708ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 15718ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 15728ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 15738ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 15742e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala if (params.state == Parameters::PREVIEW) { 15755a4f93eaaab7518fd734fdc9f0f686d632f31a59Eino-Ville Talvala res = startPreviewL(params, true); 15768ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala if (res != OK) { 15778ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Error streaming new preview request: %s (%d)", 15788ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 15798ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 15808ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 15812e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala } else if (params.state == Parameters::RECORD || 15822e19c3c02957208371cdd491e6342ea7ddb440d9Eino-Ville Talvala params.state == Parameters::VIDEO_SNAPSHOT) { 158373bbd1f1c493835f191ea2b0b72439292496b40aEino-Ville Talvala res = startRecordingL(params, true); 15848ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala if (res != OK) { 15858ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala ALOGE("%s: Camera %d: Error streaming new record request: %s (%d)", 15868ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala __FUNCTION__, mCameraId, strerror(-res), res); 15878ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 15888ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 15898ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala } 15908ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala return res; 15918ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala} 15928ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 15939cca4c6d976d2d4127286e9eaa54d1b99880c25cEino-Ville Talvala 1594228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvalasize_t Camera2Client::calculateBufferSize(int width, int height, 1595228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala int format, int stride) { 1596228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala switch (format) { 1597228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_YCbCr_422_SP: // NV16 1598228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 2; 1599228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_YCrCb_420_SP: // NV21 1600228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 3 / 2; 1601228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_YCbCr_422_I: // YUY2 1602228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 2; 1603228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_YV12: { // YV12 1604228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala size_t ySize = stride * height; 1605f17b6cf6aa7548ca82e7fed96d71db7821103e57Eino-Ville Talvala size_t uvStride = (stride / 2 + 0xF) & ~0xF; 1606228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala size_t uvSize = uvStride * height / 2; 1607228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return ySize + uvSize * 2; 1608228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 1609228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_RGB_565: 1610228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 2; 1611228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_RGBA_8888: 1612228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 4; 1613228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala case HAL_PIXEL_FORMAT_RAW_SENSOR: 1614228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return width * height * 2; 1615228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala default: 1616228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala ALOGE("%s: Unknown preview format: %x", 1617228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala __FUNCTION__, format); 1618228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala return 0; 1619228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala } 1620228a53805808a24cb19fcf13b1f0bdc2ed89bbe1Eino-Ville Talvala} 16218ce89d9e2b132bf58a030acec88acf0a998926a1Eino-Ville Talvala 16224865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvalastatus_t Camera2Client::syncWithDevice() { 16234865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala ATRACE_CALL(); 162443b7ac6bd1a949ecb8ffc7e50d0a2f01a6258034Eino-Ville Talvala const nsecs_t kMaxSyncTimeout = 500000000; // 500 ms 16254865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala status_t res; 16264865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 16274865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala int32_t activeRequestId = mStreamingProcessor->getActiveRequestId(); 16284865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala if (activeRequestId == 0) return OK; 16294865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 16304865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala res = mDevice->waitUntilRequestReceived(activeRequestId, kMaxSyncTimeout); 16314865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala if (res == TIMED_OUT) { 16324865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala ALOGE("%s: Camera %d: Timed out waiting sync with HAL", 16334865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala __FUNCTION__, mCameraId); 16344865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala } else if (res != OK) { 16354865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala ALOGE("%s: Camera %d: Error while waiting to sync with HAL", 16364865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala __FUNCTION__, mCameraId); 16374865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala } 16384865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala return res; 16394865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala} 16404865c526e681366481b0ab242ffa1ead57bb02ccEino-Ville Talvala 164161ab9f93315ea817cd1ac110e2a95da4dab6b4d1Eino-Ville Talvala} // namespace android 1642