1*4d7e907cSAndroid Build Coastguard Worker /*
2*4d7e907cSAndroid Build Coastguard Worker * Copyright (C) 2017 The Android Open Source Project
3*4d7e907cSAndroid Build Coastguard Worker *
4*4d7e907cSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License");
5*4d7e907cSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License.
6*4d7e907cSAndroid Build Coastguard Worker * You may obtain a copy of the License at
7*4d7e907cSAndroid Build Coastguard Worker *
8*4d7e907cSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0
9*4d7e907cSAndroid Build Coastguard Worker *
10*4d7e907cSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software
11*4d7e907cSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS,
12*4d7e907cSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13*4d7e907cSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and
14*4d7e907cSAndroid Build Coastguard Worker * limitations under the License.
15*4d7e907cSAndroid Build Coastguard Worker */
16*4d7e907cSAndroid Build Coastguard Worker
17*4d7e907cSAndroid Build Coastguard Worker #define LOG_TAG "[email protected]"
18*4d7e907cSAndroid Build Coastguard Worker #include <android/log.h>
19*4d7e907cSAndroid Build Coastguard Worker
20*4d7e907cSAndroid Build Coastguard Worker #include <set>
21*4d7e907cSAndroid Build Coastguard Worker #include <utils/Trace.h>
22*4d7e907cSAndroid Build Coastguard Worker #include <hardware/gralloc.h>
23*4d7e907cSAndroid Build Coastguard Worker #include <hardware/gralloc1.h>
24*4d7e907cSAndroid Build Coastguard Worker #include "CameraDeviceSession.h"
25*4d7e907cSAndroid Build Coastguard Worker
26*4d7e907cSAndroid Build Coastguard Worker namespace android {
27*4d7e907cSAndroid Build Coastguard Worker namespace hardware {
28*4d7e907cSAndroid Build Coastguard Worker namespace camera {
29*4d7e907cSAndroid Build Coastguard Worker namespace device {
30*4d7e907cSAndroid Build Coastguard Worker namespace V3_3 {
31*4d7e907cSAndroid Build Coastguard Worker namespace implementation {
32*4d7e907cSAndroid Build Coastguard Worker
CameraDeviceSession(camera3_device_t * device,const camera_metadata_t * deviceInfo,const sp<V3_2::ICameraDeviceCallback> & callback)33*4d7e907cSAndroid Build Coastguard Worker CameraDeviceSession::CameraDeviceSession(
34*4d7e907cSAndroid Build Coastguard Worker camera3_device_t* device,
35*4d7e907cSAndroid Build Coastguard Worker const camera_metadata_t* deviceInfo,
36*4d7e907cSAndroid Build Coastguard Worker const sp<V3_2::ICameraDeviceCallback>& callback) :
37*4d7e907cSAndroid Build Coastguard Worker V3_2::implementation::CameraDeviceSession(device, deviceInfo, callback) {
38*4d7e907cSAndroid Build Coastguard Worker }
39*4d7e907cSAndroid Build Coastguard Worker
~CameraDeviceSession()40*4d7e907cSAndroid Build Coastguard Worker CameraDeviceSession::~CameraDeviceSession() {
41*4d7e907cSAndroid Build Coastguard Worker }
42*4d7e907cSAndroid Build Coastguard Worker
configureStreams_3_3(const StreamConfiguration & requestedConfiguration,ICameraDeviceSession::configureStreams_3_3_cb _hidl_cb)43*4d7e907cSAndroid Build Coastguard Worker Return<void> CameraDeviceSession::configureStreams_3_3(
44*4d7e907cSAndroid Build Coastguard Worker const StreamConfiguration& requestedConfiguration,
45*4d7e907cSAndroid Build Coastguard Worker ICameraDeviceSession::configureStreams_3_3_cb _hidl_cb) {
46*4d7e907cSAndroid Build Coastguard Worker Status status = initStatus();
47*4d7e907cSAndroid Build Coastguard Worker HalStreamConfiguration outStreams;
48*4d7e907cSAndroid Build Coastguard Worker
49*4d7e907cSAndroid Build Coastguard Worker // hold the inflight lock for entire configureStreams scope since there must not be any
50*4d7e907cSAndroid Build Coastguard Worker // inflight request/results during stream configuration.
51*4d7e907cSAndroid Build Coastguard Worker Mutex::Autolock _l(mInflightLock);
52*4d7e907cSAndroid Build Coastguard Worker if (!mInflightBuffers.empty()) {
53*4d7e907cSAndroid Build Coastguard Worker ALOGE("%s: trying to configureStreams while there are still %zu inflight buffers!",
54*4d7e907cSAndroid Build Coastguard Worker __FUNCTION__, mInflightBuffers.size());
55*4d7e907cSAndroid Build Coastguard Worker _hidl_cb(Status::INTERNAL_ERROR, outStreams);
56*4d7e907cSAndroid Build Coastguard Worker return Void();
57*4d7e907cSAndroid Build Coastguard Worker }
58*4d7e907cSAndroid Build Coastguard Worker
59*4d7e907cSAndroid Build Coastguard Worker if (!mInflightAETriggerOverrides.empty()) {
60*4d7e907cSAndroid Build Coastguard Worker ALOGE("%s: trying to configureStreams while there are still %zu inflight"
61*4d7e907cSAndroid Build Coastguard Worker " trigger overrides!", __FUNCTION__,
62*4d7e907cSAndroid Build Coastguard Worker mInflightAETriggerOverrides.size());
63*4d7e907cSAndroid Build Coastguard Worker _hidl_cb(Status::INTERNAL_ERROR, outStreams);
64*4d7e907cSAndroid Build Coastguard Worker return Void();
65*4d7e907cSAndroid Build Coastguard Worker }
66*4d7e907cSAndroid Build Coastguard Worker
67*4d7e907cSAndroid Build Coastguard Worker if (!mInflightRawBoostPresent.empty()) {
68*4d7e907cSAndroid Build Coastguard Worker ALOGE("%s: trying to configureStreams while there are still %zu inflight"
69*4d7e907cSAndroid Build Coastguard Worker " boost overrides!", __FUNCTION__,
70*4d7e907cSAndroid Build Coastguard Worker mInflightRawBoostPresent.size());
71*4d7e907cSAndroid Build Coastguard Worker _hidl_cb(Status::INTERNAL_ERROR, outStreams);
72*4d7e907cSAndroid Build Coastguard Worker return Void();
73*4d7e907cSAndroid Build Coastguard Worker }
74*4d7e907cSAndroid Build Coastguard Worker
75*4d7e907cSAndroid Build Coastguard Worker if (status != Status::OK) {
76*4d7e907cSAndroid Build Coastguard Worker _hidl_cb(status, outStreams);
77*4d7e907cSAndroid Build Coastguard Worker return Void();
78*4d7e907cSAndroid Build Coastguard Worker }
79*4d7e907cSAndroid Build Coastguard Worker
80*4d7e907cSAndroid Build Coastguard Worker camera3_stream_configuration_t stream_list{};
81*4d7e907cSAndroid Build Coastguard Worker hidl_vec<camera3_stream_t*> streams;
82*4d7e907cSAndroid Build Coastguard Worker if (!preProcessConfigurationLocked(requestedConfiguration, &stream_list, &streams)) {
83*4d7e907cSAndroid Build Coastguard Worker _hidl_cb(Status::INTERNAL_ERROR, outStreams);
84*4d7e907cSAndroid Build Coastguard Worker return Void();
85*4d7e907cSAndroid Build Coastguard Worker }
86*4d7e907cSAndroid Build Coastguard Worker
87*4d7e907cSAndroid Build Coastguard Worker ATRACE_BEGIN("camera3->configure_streams");
88*4d7e907cSAndroid Build Coastguard Worker status_t ret = mDevice->ops->configure_streams(mDevice, &stream_list);
89*4d7e907cSAndroid Build Coastguard Worker ATRACE_END();
90*4d7e907cSAndroid Build Coastguard Worker
91*4d7e907cSAndroid Build Coastguard Worker // In case Hal returns error most likely it was not able to release
92*4d7e907cSAndroid Build Coastguard Worker // the corresponding resources of the deleted streams.
93*4d7e907cSAndroid Build Coastguard Worker if (ret == OK) {
94*4d7e907cSAndroid Build Coastguard Worker postProcessConfigurationLocked(requestedConfiguration);
95*4d7e907cSAndroid Build Coastguard Worker } else {
96*4d7e907cSAndroid Build Coastguard Worker postProcessConfigurationFailureLocked(requestedConfiguration);
97*4d7e907cSAndroid Build Coastguard Worker }
98*4d7e907cSAndroid Build Coastguard Worker
99*4d7e907cSAndroid Build Coastguard Worker if (ret == -EINVAL) {
100*4d7e907cSAndroid Build Coastguard Worker status = Status::ILLEGAL_ARGUMENT;
101*4d7e907cSAndroid Build Coastguard Worker } else if (ret != OK) {
102*4d7e907cSAndroid Build Coastguard Worker status = Status::INTERNAL_ERROR;
103*4d7e907cSAndroid Build Coastguard Worker } else {
104*4d7e907cSAndroid Build Coastguard Worker convertToHidl(stream_list, &outStreams);
105*4d7e907cSAndroid Build Coastguard Worker mFirstRequest = true;
106*4d7e907cSAndroid Build Coastguard Worker }
107*4d7e907cSAndroid Build Coastguard Worker
108*4d7e907cSAndroid Build Coastguard Worker _hidl_cb(status, outStreams);
109*4d7e907cSAndroid Build Coastguard Worker return Void();
110*4d7e907cSAndroid Build Coastguard Worker }
111*4d7e907cSAndroid Build Coastguard Worker
112*4d7e907cSAndroid Build Coastguard Worker } // namespace implementation
113*4d7e907cSAndroid Build Coastguard Worker } // namespace V3_3
114*4d7e907cSAndroid Build Coastguard Worker } // namespace device
115*4d7e907cSAndroid Build Coastguard Worker } // namespace camera
116*4d7e907cSAndroid Build Coastguard Worker } // namespace hardware
117*4d7e907cSAndroid Build Coastguard Worker } // namespace android
118