xref: /aosp_15_r20/hardware/interfaces/camera/device/3.3/default/CameraDeviceSession.cpp (revision 4d7e907c777eeecc4c5bd7cf640a754fac206ff7)
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