blob: 48a733886ecccedf78076ea504734240850bbf44 [file] [log] [blame]
Yin-Chia Yehb97babb2015-03-12 13:42:44 -07001/*
2**
Shuzhen Wangc28189a2017-11-27 23:05:10 -08003** Copyright 2015-2018, The Android Open Source Project
Yin-Chia Yehb97babb2015-03-12 13:42:44 -07004**
5** Licensed under the Apache License, Version 2.0 (the "License");
6** you may not use this file except in compliance with the License.
7** You may obtain a copy of the License at
8**
9** http://www.apache.org/licenses/LICENSE-2.0
10**
11** Unless required by applicable law or agreed to in writing, software
12** distributed under the License is distributed on an "AS IS" BASIS,
13** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14** See the License for the specific language governing permissions and
15** limitations under the License.
16*/
17
18#define LOG_TAG "OutputConfiguration"
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -080019//#define LOG_NDEBUG 0
20
Yin-Chia Yehb97babb2015-03-12 13:42:44 -070021#include <utils/Log.h>
22
23#include <camera/camera2/OutputConfiguration.h>
Austin Borger71d8f672023-06-01 16:51:35 -070024#include <camera/StringUtils.h>
Shuzhen Wang38df0ca2024-10-09 11:33:44 -070025#include <com_android_internal_camera_flags.h>
Yin-Chia Yehb97babb2015-03-12 13:42:44 -070026#include <binder/Parcel.h>
Mathias Agopian032845c2017-02-08 17:05:02 -080027#include <gui/view/Surface.h>
Emilian Peev2295df72021-11-12 18:14:10 -080028#include <system/camera_metadata.h>
Shuzhen Wang0709c282024-02-12 09:09:32 -080029#include <system/graphics.h>
Brian Andersonf6753562016-10-11 14:51:05 -070030#include <utils/String8.h>
Yin-Chia Yehb97babb2015-03-12 13:42:44 -070031
Shuzhen Wang38df0ca2024-10-09 11:33:44 -070032namespace flags = com::android::internal::camera::flags;
Yin-Chia Yehb97babb2015-03-12 13:42:44 -070033
Austin Borger9e2b27c2022-07-15 11:27:24 -070034namespace android {
Yin-Chia Yehb97babb2015-03-12 13:42:44 -070035
36const int OutputConfiguration::INVALID_ROTATION = -1;
Zhijun He018107a2016-01-18 15:32:50 -080037const int OutputConfiguration::INVALID_SET_ID = -1;
Yin-Chia Yehb97babb2015-03-12 13:42:44 -070038
Shuzhen Wang0129d522016-10-30 22:43:41 -070039const std::vector<sp<IGraphicBufferProducer>>&
40 OutputConfiguration::getGraphicBufferProducers() const {
41 return mGbps;
Yin-Chia Yehb97babb2015-03-12 13:42:44 -070042}
43
44int OutputConfiguration::getRotation() const {
45 return mRotation;
46}
47
Zhijun He018107a2016-01-18 15:32:50 -080048int OutputConfiguration::getSurfaceSetID() const {
49 return mSurfaceSetID;
50}
51
Zhijun He5d677d12016-05-29 16:52:39 -070052int OutputConfiguration::getSurfaceType() const {
53 return mSurfaceType;
54}
55
56int OutputConfiguration::getWidth() const {
57 return mWidth;
58}
59
60int OutputConfiguration::getHeight() const {
61 return mHeight;
62}
63
Shuzhen Wang758c2152017-01-10 18:26:18 -080064bool OutputConfiguration::isDeferred() const {
65 return mIsDeferred;
66}
67
68bool OutputConfiguration::isShared() const {
69 return mIsShared;
70}
71
Austin Borger71d8f672023-06-01 16:51:35 -070072std::string OutputConfiguration::getPhysicalCameraId() const {
Shuzhen Wangc28189a2017-11-27 23:05:10 -080073 return mPhysicalCameraId;
74}
75
Shuzhen Wang83bff122020-11-20 15:51:39 -080076bool OutputConfiguration::isMultiResolution() const {
77 return mIsMultiResolution;
78}
79
Jayant Chowdhary13f9b2f2020-12-02 22:46:15 -080080const std::vector<int32_t> &OutputConfiguration::getSensorPixelModesUsed() const {
81 return mSensorPixelModesUsed;
82}
83
Emilian Peevc81a7592022-02-14 17:38:18 -080084int64_t OutputConfiguration::getDynamicRangeProfile() const {
Emilian Peev2295df72021-11-12 18:14:10 -080085 return mDynamicRangeProfile;
86}
87
Austin Borger9e2b27c2022-07-15 11:27:24 -070088int32_t OutputConfiguration::getColorSpace() const {
89 return mColorSpace;
90}
91
Shuzhen Wang8ed1e872022-03-08 16:34:33 -080092int64_t OutputConfiguration::getStreamUseCase() const {
Shuzhen Wangc8ab4522021-12-14 20:12:42 -080093 return mStreamUseCase;
94}
95
Shuzhen Wange4208922022-02-01 16:52:48 -080096int OutputConfiguration::getTimestampBase() const {
97 return mTimestampBase;
98}
99
Shuzhen Wang38df0ca2024-10-09 11:33:44 -0700100int OutputConfiguration::getMirrorMode(sp<IGraphicBufferProducer> surface) const {
101 if (!flags::mirror_mode_shared_surfaces()) {
102 return mMirrorMode;
103 }
104
105 // Use per-producer mirror mode if available.
106 for (size_t i = 0; i < mGbps.size(); i++) {
107 if (mGbps[i] == surface) {
108 return mMirrorModeForProducers[i];
109 }
110 }
111
112 // For surface that doesn't belong to this output configuration, use
113 // mMirrorMode as default.
114 ALOGW("%s: Surface doesn't belong to this OutputConfiguration!", __FUNCTION__);
Shuzhen Wang610d7b82022-02-08 14:37:22 -0800115 return mMirrorMode;
116}
117
Shuzhen Wangbce53db2022-12-03 00:38:20 +0000118bool OutputConfiguration::useReadoutTimestamp() const {
119 return mUseReadoutTimestamp;
120}
121
Shuzhen Wang0709c282024-02-12 09:09:32 -0800122int OutputConfiguration::getFormat() const {
123 return mFormat;
124}
125
126int OutputConfiguration::getDataspace() const {
127 return mDataspace;
128}
129
130int64_t OutputConfiguration::getUsage() const {
131 return mUsage;
132}
133
134bool OutputConfiguration::isComplete() const {
135 return !((mSurfaceType == SURFACE_TYPE_MEDIA_RECORDER ||
136 mSurfaceType == SURFACE_TYPE_MEDIA_CODEC ||
137 mSurfaceType == SURFACE_TYPE_IMAGE_READER) &&
138 mGbps.empty());
139}
140
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800141OutputConfiguration::OutputConfiguration() :
142 mRotation(INVALID_ROTATION),
Zhijun He5d677d12016-05-29 16:52:39 -0700143 mSurfaceSetID(INVALID_SET_ID),
144 mSurfaceType(SURFACE_TYPE_UNKNOWN),
145 mWidth(0),
Shuzhen Wang758c2152017-01-10 18:26:18 -0800146 mHeight(0),
147 mIsDeferred(false),
Shuzhen Wang83bff122020-11-20 15:51:39 -0800148 mIsShared(false),
Emilian Peev2295df72021-11-12 18:14:10 -0800149 mIsMultiResolution(false),
Shuzhen Wangc8ab4522021-12-14 20:12:42 -0800150 mDynamicRangeProfile(ANDROID_REQUEST_AVAILABLE_DYNAMIC_RANGE_PROFILES_MAP_STANDARD),
Austin Borger9e2b27c2022-07-15 11:27:24 -0700151 mColorSpace(ANDROID_REQUEST_AVAILABLE_COLOR_SPACE_PROFILES_MAP_UNSPECIFIED),
Shuzhen Wange4208922022-02-01 16:52:48 -0800152 mStreamUseCase(ANDROID_SCALER_AVAILABLE_STREAM_USE_CASES_DEFAULT),
Shuzhen Wang610d7b82022-02-08 14:37:22 -0800153 mTimestampBase(TIMESTAMP_BASE_DEFAULT),
Shuzhen Wangbce53db2022-12-03 00:38:20 +0000154 mMirrorMode(MIRROR_MODE_AUTO),
Shuzhen Wang0709c282024-02-12 09:09:32 -0800155 mUseReadoutTimestamp(false),
156 mFormat(HAL_PIXEL_FORMAT_IMPLEMENTATION_DEFINED),
157 mDataspace(0),
158 mUsage(0) {
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800159}
160
Eino-Ville Talvalaf51fca22016-12-13 11:25:55 -0800161OutputConfiguration::OutputConfiguration(const android::Parcel& parcel) :
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800162 mRotation(INVALID_ROTATION),
163 mSurfaceSetID(INVALID_SET_ID) {
164 readFromParcel(&parcel);
165}
166
Eino-Ville Talvalaf51fca22016-12-13 11:25:55 -0800167status_t OutputConfiguration::readFromParcel(const android::Parcel* parcel) {
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800168 status_t err = OK;
Yin-Chia Yehb97babb2015-03-12 13:42:44 -0700169 int rotation = 0;
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800170
171 if (parcel == nullptr) return BAD_VALUE;
172
173 if ((err = parcel->readInt32(&rotation)) != OK) {
Yin-Chia Yehb97babb2015-03-12 13:42:44 -0700174 ALOGE("%s: Failed to read rotation from parcel", __FUNCTION__);
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800175 return err;
Yin-Chia Yehb97babb2015-03-12 13:42:44 -0700176 }
177
Zhijun He018107a2016-01-18 15:32:50 -0800178 int setID = INVALID_SET_ID;
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800179 if ((err = parcel->readInt32(&setID)) != OK) {
Zhijun He018107a2016-01-18 15:32:50 -0800180 ALOGE("%s: Failed to read surface set ID from parcel", __FUNCTION__);
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800181 return err;
Zhijun He018107a2016-01-18 15:32:50 -0800182 }
183
Zhijun He5d677d12016-05-29 16:52:39 -0700184 int surfaceType = SURFACE_TYPE_UNKNOWN;
185 if ((err = parcel->readInt32(&surfaceType)) != OK) {
186 ALOGE("%s: Failed to read surface type from parcel", __FUNCTION__);
187 return err;
188 }
189
190 int width = 0;
191 if ((err = parcel->readInt32(&width)) != OK) {
192 ALOGE("%s: Failed to read surface width from parcel", __FUNCTION__);
193 return err;
194 }
195
196 int height = 0;
197 if ((err = parcel->readInt32(&height)) != OK) {
198 ALOGE("%s: Failed to read surface height from parcel", __FUNCTION__);
199 return err;
200 }
201
Shuzhen Wang758c2152017-01-10 18:26:18 -0800202 int isDeferred = 0;
203 if ((err = parcel->readInt32(&isDeferred)) != OK) {
204 ALOGE("%s: Failed to read surface isDeferred flag from parcel", __FUNCTION__);
Shuzhen Wang0129d522016-10-30 22:43:41 -0700205 return err;
206 }
Shuzhen Wang758c2152017-01-10 18:26:18 -0800207
208 int isShared = 0;
209 if ((err = parcel->readInt32(&isShared)) != OK) {
210 ALOGE("%s: Failed to read surface isShared flag from parcel", __FUNCTION__);
211 return err;
212 }
213
214 if (isDeferred && surfaceType != SURFACE_TYPE_SURFACE_VIEW &&
215 surfaceType != SURFACE_TYPE_SURFACE_TEXTURE) {
216 ALOGE("%s: Invalid surface type for deferred configuration", __FUNCTION__);
Shuzhen Wang0129d522016-10-30 22:43:41 -0700217 return BAD_VALUE;
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800218 }
219
Shuzhen Wang758c2152017-01-10 18:26:18 -0800220 std::vector<view::Surface> surfaceShims;
221 if ((err = parcel->readParcelableVector(&surfaceShims)) != OK) {
222 ALOGE("%s: Failed to read surface(s) from parcel", __FUNCTION__);
223 return err;
Shuzhen Wang0129d522016-10-30 22:43:41 -0700224 }
225
Austin Borger71d8f672023-06-01 16:51:35 -0700226 String16 physicalCameraId;
227 parcel->readString16(&physicalCameraId);
228 mPhysicalCameraId = toStdString(physicalCameraId);
Shuzhen Wangc28189a2017-11-27 23:05:10 -0800229
Shuzhen Wang83bff122020-11-20 15:51:39 -0800230 int isMultiResolution = 0;
231 if ((err = parcel->readInt32(&isMultiResolution)) != OK) {
232 ALOGE("%s: Failed to read surface isMultiResolution flag from parcel", __FUNCTION__);
233 return err;
234 }
235
Jayant Chowdhary13f9b2f2020-12-02 22:46:15 -0800236 std::vector<int32_t> sensorPixelModesUsed;
Jayant Chowdhary84df28c2021-05-26 22:32:21 -0700237 if ((err = parcel->readInt32Vector(&sensorPixelModesUsed)) != OK) {
Jayant Chowdhary13f9b2f2020-12-02 22:46:15 -0800238 ALOGE("%s: Failed to read sensor pixel mode(s) from parcel", __FUNCTION__);
239 return err;
240 }
Emilian Peevc81a7592022-02-14 17:38:18 -0800241 int64_t dynamicProfile;
242 if ((err = parcel->readInt64(&dynamicProfile)) != OK) {
Emilian Peev2295df72021-11-12 18:14:10 -0800243 ALOGE("%s: Failed to read surface dynamic range profile flag from parcel", __FUNCTION__);
244 return err;
245 }
Austin Borger9e2b27c2022-07-15 11:27:24 -0700246 int32_t colorSpace;
247 if ((err = parcel->readInt32(&colorSpace)) != OK) {
248 ALOGE("%s: Failed to read surface color space flag from parcel", __FUNCTION__);
249 return err;
250 }
Emilian Peev2295df72021-11-12 18:14:10 -0800251
Shuzhen Wang8ed1e872022-03-08 16:34:33 -0800252 int64_t streamUseCase = ANDROID_SCALER_AVAILABLE_STREAM_USE_CASES_DEFAULT;
253 if ((err = parcel->readInt64(&streamUseCase)) != OK) {
Shuzhen Wangc8ab4522021-12-14 20:12:42 -0800254 ALOGE("%s: Failed to read stream use case from parcel", __FUNCTION__);
255 return err;
256 }
257
Shuzhen Wange4208922022-02-01 16:52:48 -0800258 int timestampBase = TIMESTAMP_BASE_DEFAULT;
259 if ((err = parcel->readInt32(&timestampBase)) != OK) {
260 ALOGE("%s: Failed to read timestamp base from parcel", __FUNCTION__);
261 return err;
262 }
263
Shuzhen Wang610d7b82022-02-08 14:37:22 -0800264 int mirrorMode = MIRROR_MODE_AUTO;
265 if ((err = parcel->readInt32(&mirrorMode)) != OK) {
266 ALOGE("%s: Failed to read mirroring mode from parcel", __FUNCTION__);
267 return err;
268 }
269
Shuzhen Wang38df0ca2024-10-09 11:33:44 -0700270 std::vector<int> mirrorModeForProducers;
271 if ((err = parcel->readInt32Vector(&mirrorModeForProducers)) != OK) {
272 ALOGE("%s: Failed to read mirroring mode for surfaces from parcel", __FUNCTION__);
273 return err;
274 }
275
Shuzhen Wangbce53db2022-12-03 00:38:20 +0000276 int useReadoutTimestamp = 0;
277 if ((err = parcel->readInt32(&useReadoutTimestamp)) != OK) {
278 ALOGE("%s: Failed to read useReadoutTimestamp flag from parcel", __FUNCTION__);
279 return err;
280 }
281
Shuzhen Wang0709c282024-02-12 09:09:32 -0800282 int format = HAL_PIXEL_FORMAT_IMPLEMENTATION_DEFINED;
283 if ((err = parcel->readInt32(&format)) != OK) {
284 ALOGE("%s: Failed to read format from parcel", __FUNCTION__);
285 return err;
286 }
287
288 int dataspace = 0;
289 if ((err = parcel->readInt32(&dataspace)) != OK) {
290 ALOGE("%s: Failed to read dataspace from parcel", __FUNCTION__);
291 return err;
292 }
293
294 int64_t usage = 0;
295 if ((err = parcel->readInt64(&usage)) != OK) {
296 ALOGE("%s: Failed to read usage flag from parcel", __FUNCTION__);
297 return err;
298 }
299
Yin-Chia Yehb97babb2015-03-12 13:42:44 -0700300 mRotation = rotation;
Zhijun He018107a2016-01-18 15:32:50 -0800301 mSurfaceSetID = setID;
Zhijun He5d677d12016-05-29 16:52:39 -0700302 mSurfaceType = surfaceType;
303 mWidth = width;
304 mHeight = height;
Shuzhen Wang758c2152017-01-10 18:26:18 -0800305 mIsDeferred = isDeferred != 0;
306 mIsShared = isShared != 0;
Shuzhen Wang83bff122020-11-20 15:51:39 -0800307 mIsMultiResolution = isMultiResolution != 0;
Shuzhen Wangc8ab4522021-12-14 20:12:42 -0800308 mStreamUseCase = streamUseCase;
Shuzhen Wange4208922022-02-01 16:52:48 -0800309 mTimestampBase = timestampBase;
Shuzhen Wang610d7b82022-02-08 14:37:22 -0800310 mMirrorMode = mirrorMode;
Shuzhen Wang38df0ca2024-10-09 11:33:44 -0700311 mMirrorModeForProducers = std::move(mirrorModeForProducers);
Shuzhen Wangbce53db2022-12-03 00:38:20 +0000312 mUseReadoutTimestamp = useReadoutTimestamp != 0;
Shuzhen Wang758c2152017-01-10 18:26:18 -0800313 for (auto& surface : surfaceShims) {
314 ALOGV("%s: OutputConfiguration: %p, name %s", __FUNCTION__,
315 surface.graphicBufferProducer.get(),
Tomasz Wasilczyk12b04a52023-08-11 15:52:22 +0000316 toString8(surface.name).c_str());
Shuzhen Wang758c2152017-01-10 18:26:18 -0800317 mGbps.push_back(surface.graphicBufferProducer);
318 }
Yin-Chia Yehb97babb2015-03-12 13:42:44 -0700319
Jayant Chowdhary13f9b2f2020-12-02 22:46:15 -0800320 mSensorPixelModesUsed = std::move(sensorPixelModesUsed);
Emilian Peev2295df72021-11-12 18:14:10 -0800321 mDynamicRangeProfile = dynamicProfile;
Austin Borger9e2b27c2022-07-15 11:27:24 -0700322 mColorSpace = colorSpace;
Shuzhen Wang0709c282024-02-12 09:09:32 -0800323 mFormat = format;
324 mDataspace = dataspace;
325 mUsage = usage;
Jayant Chowdhary13f9b2f2020-12-02 22:46:15 -0800326
Shuzhen Wangc28189a2017-11-27 23:05:10 -0800327 ALOGV("%s: OutputConfiguration: rotation = %d, setId = %d, surfaceType = %d,"
Shuzhen Wang8ed1e872022-03-08 16:34:33 -0800328 " physicalCameraId = %s, isMultiResolution = %d, streamUseCase = %" PRId64
Shuzhen Wang0709c282024-02-12 09:09:32 -0800329 ", timestampBase = %d, mirrorMode = %d, useReadoutTimestamp = %d, format = %d, "
330 "dataspace = %d, usage = %" PRId64,
Shuzhen Wange4208922022-02-01 16:52:48 -0800331 __FUNCTION__, mRotation, mSurfaceSetID, mSurfaceType,
Austin Borger71d8f672023-06-01 16:51:35 -0700332 mPhysicalCameraId.c_str(), mIsMultiResolution, mStreamUseCase, timestampBase,
Shuzhen Wang0709c282024-02-12 09:09:32 -0800333 mMirrorMode, mUseReadoutTimestamp, mFormat, mDataspace, mUsage);
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800334
335 return err;
Yin-Chia Yehb97babb2015-03-12 13:42:44 -0700336}
337
Zhijun He018107a2016-01-18 15:32:50 -0800338OutputConfiguration::OutputConfiguration(sp<IGraphicBufferProducer>& gbp, int rotation,
Austin Borger71d8f672023-06-01 16:51:35 -0700339 const std::string& physicalId,
Emilian Peev40ead602017-09-26 15:46:36 +0100340 int surfaceSetID, bool isShared) {
Shuzhen Wang0129d522016-10-30 22:43:41 -0700341 mGbps.push_back(gbp);
Ruben Brunk3450ba72015-06-16 11:00:37 -0700342 mRotation = rotation;
Zhijun He018107a2016-01-18 15:32:50 -0800343 mSurfaceSetID = surfaceSetID;
Shuzhen Wang758c2152017-01-10 18:26:18 -0800344 mIsDeferred = false;
Emilian Peev40ead602017-09-26 15:46:36 +0100345 mIsShared = isShared;
Shuzhen Wang0ff9ae32018-12-05 18:06:12 -0800346 mPhysicalCameraId = physicalId;
Shuzhen Wang83bff122020-11-20 15:51:39 -0800347 mIsMultiResolution = false;
Emilian Peev2295df72021-11-12 18:14:10 -0800348 mDynamicRangeProfile = ANDROID_REQUEST_AVAILABLE_DYNAMIC_RANGE_PROFILES_MAP_STANDARD;
Austin Borger9e2b27c2022-07-15 11:27:24 -0700349 mColorSpace = ANDROID_REQUEST_AVAILABLE_COLOR_SPACE_PROFILES_MAP_UNSPECIFIED;
Shuzhen Wangc8ab4522021-12-14 20:12:42 -0800350 mStreamUseCase = ANDROID_SCALER_AVAILABLE_STREAM_USE_CASES_DEFAULT;
Shuzhen Wange4208922022-02-01 16:52:48 -0800351 mTimestampBase = TIMESTAMP_BASE_DEFAULT;
Shuzhen Wang610d7b82022-02-08 14:37:22 -0800352 mMirrorMode = MIRROR_MODE_AUTO;
Shuzhen Wangbce53db2022-12-03 00:38:20 +0000353 mUseReadoutTimestamp = false;
Shuzhen Wang0709c282024-02-12 09:09:32 -0800354 mFormat = HAL_PIXEL_FORMAT_IMPLEMENTATION_DEFINED;
355 mDataspace = 0;
356 mUsage = 0;
Ruben Brunk3450ba72015-06-16 11:00:37 -0700357}
358
Jayant Chowdharybe543d42018-08-15 13:16:14 -0700359OutputConfiguration::OutputConfiguration(
360 const std::vector<sp<IGraphicBufferProducer>>& gbps,
Austin Borger71d8f672023-06-01 16:51:35 -0700361 int rotation, const std::string& physicalCameraId, int surfaceSetID, int surfaceType,
Shuzhen Wang0ff9ae32018-12-05 18:06:12 -0800362 int width, int height, bool isShared)
Jayant Chowdharybe543d42018-08-15 13:16:14 -0700363 : mGbps(gbps), mRotation(rotation), mSurfaceSetID(surfaceSetID), mSurfaceType(surfaceType),
Shuzhen Wang0ff9ae32018-12-05 18:06:12 -0800364 mWidth(width), mHeight(height), mIsDeferred(false), mIsShared(isShared),
Emilian Peev2295df72021-11-12 18:14:10 -0800365 mPhysicalCameraId(physicalCameraId), mIsMultiResolution(false),
Shuzhen Wangc8ab4522021-12-14 20:12:42 -0800366 mDynamicRangeProfile(ANDROID_REQUEST_AVAILABLE_DYNAMIC_RANGE_PROFILES_MAP_STANDARD),
Austin Borger9e2b27c2022-07-15 11:27:24 -0700367 mColorSpace(ANDROID_REQUEST_AVAILABLE_COLOR_SPACE_PROFILES_MAP_UNSPECIFIED),
Shuzhen Wange4208922022-02-01 16:52:48 -0800368 mStreamUseCase(ANDROID_SCALER_AVAILABLE_STREAM_USE_CASES_DEFAULT),
Shuzhen Wang610d7b82022-02-08 14:37:22 -0800369 mTimestampBase(TIMESTAMP_BASE_DEFAULT),
Shuzhen Wang0709c282024-02-12 09:09:32 -0800370 mMirrorMode(MIRROR_MODE_AUTO), mUseReadoutTimestamp(false),
371 mFormat(HAL_PIXEL_FORMAT_IMPLEMENTATION_DEFINED), mDataspace(0),
372 mUsage(0) { }
Jayant Chowdharybe543d42018-08-15 13:16:14 -0700373
Eino-Ville Talvalaf51fca22016-12-13 11:25:55 -0800374status_t OutputConfiguration::writeToParcel(android::Parcel* parcel) const {
Yin-Chia Yehb97babb2015-03-12 13:42:44 -0700375
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800376 if (parcel == nullptr) return BAD_VALUE;
377 status_t err = OK;
378
379 err = parcel->writeInt32(mRotation);
380 if (err != OK) return err;
381
382 err = parcel->writeInt32(mSurfaceSetID);
383 if (err != OK) return err;
384
Zhijun He5d677d12016-05-29 16:52:39 -0700385 err = parcel->writeInt32(mSurfaceType);
386 if (err != OK) return err;
387
388 err = parcel->writeInt32(mWidth);
389 if (err != OK) return err;
390
391 err = parcel->writeInt32(mHeight);
392 if (err != OK) return err;
393
Shuzhen Wang758c2152017-01-10 18:26:18 -0800394 err = parcel->writeInt32(mIsDeferred ? 1 : 0);
Eino-Ville Talvalad56db1d2015-12-17 16:50:35 -0800395 if (err != OK) return err;
Yin-Chia Yehb97babb2015-03-12 13:42:44 -0700396
Shuzhen Wang758c2152017-01-10 18:26:18 -0800397 err = parcel->writeInt32(mIsShared ? 1 : 0);
398 if (err != OK) return err;
399
400 std::vector<view::Surface> surfaceShims;
401 for (auto& gbp : mGbps) {
Shuzhen Wang0129d522016-10-30 22:43:41 -0700402 view::Surface surfaceShim;
403 surfaceShim.name = String16("unknown_name"); // name of surface
Shuzhen Wang758c2152017-01-10 18:26:18 -0800404 surfaceShim.graphicBufferProducer = gbp;
405 surfaceShims.push_back(surfaceShim);
Shuzhen Wang0129d522016-10-30 22:43:41 -0700406 }
Shuzhen Wang758c2152017-01-10 18:26:18 -0800407 err = parcel->writeParcelableVector(surfaceShims);
408 if (err != OK) return err;
Shuzhen Wang0129d522016-10-30 22:43:41 -0700409
Austin Borger71d8f672023-06-01 16:51:35 -0700410 String16 physicalCameraId = toString16(mPhysicalCameraId);
411 err = parcel->writeString16(physicalCameraId);
Shuzhen Wangc28189a2017-11-27 23:05:10 -0800412 if (err != OK) return err;
413
Shuzhen Wang83bff122020-11-20 15:51:39 -0800414 err = parcel->writeInt32(mIsMultiResolution ? 1 : 0);
415 if (err != OK) return err;
416
Jayant Chowdhary13f9b2f2020-12-02 22:46:15 -0800417 err = parcel->writeParcelableVector(mSensorPixelModesUsed);
418 if (err != OK) return err;
419
Emilian Peevc81a7592022-02-14 17:38:18 -0800420 err = parcel->writeInt64(mDynamicRangeProfile);
Emilian Peev2295df72021-11-12 18:14:10 -0800421 if (err != OK) return err;
422
Austin Borger9e2b27c2022-07-15 11:27:24 -0700423 err = parcel->writeInt32(mColorSpace);
424 if (err != OK) return err;
425
Shuzhen Wang8ed1e872022-03-08 16:34:33 -0800426 err = parcel->writeInt64(mStreamUseCase);
Shuzhen Wangc8ab4522021-12-14 20:12:42 -0800427 if (err != OK) return err;
428
Shuzhen Wange4208922022-02-01 16:52:48 -0800429 err = parcel->writeInt32(mTimestampBase);
430 if (err != OK) return err;
431
Shuzhen Wang610d7b82022-02-08 14:37:22 -0800432 err = parcel->writeInt32(mMirrorMode);
433 if (err != OK) return err;
434
Shuzhen Wang38df0ca2024-10-09 11:33:44 -0700435 err = parcel->writeInt32Vector(mMirrorModeForProducers);
436 if (err != OK) return err;
437
Shuzhen Wangbce53db2022-12-03 00:38:20 +0000438 err = parcel->writeInt32(mUseReadoutTimestamp ? 1 : 0);
439 if (err != OK) return err;
440
Shuzhen Wang0709c282024-02-12 09:09:32 -0800441 err = parcel->writeInt32(mFormat);
442 if (err != OK) return err;
443
444 err = parcel->writeInt32(mDataspace);
445 if (err != OK) return err;
446
447 err = parcel->writeInt64(mUsage);
448 if (err != OK) return err;
449
Yin-Chia Yehb97babb2015-03-12 13:42:44 -0700450 return OK;
451}
452
Jayant Chowdhary13f9b2f2020-12-02 22:46:15 -0800453template <typename T>
454static bool simpleVectorsEqual(T first, T second) {
455 if (first.size() != second.size()) {
456 return false;
457 }
458
459 for (size_t i = 0; i < first.size(); i++) {
460 if (first[i] != second[i]) {
461 return false;
462 }
463 }
464 return true;
465}
466
Shuzhen Wang38df0ca2024-10-09 11:33:44 -0700467template <typename T>
468static bool simpleVectorsLessThan(T first, T second) {
469 if (first.size() != second.size()) {
470 return first.size() < second.size();
471 }
472
473 for (size_t i = 0; i < first.size(); i++) {
474 if (first[i] != second[i]) {
475 return first[i] < second[i];
476 }
477 }
478 return false;
479}
480
Shuzhen Wang0129d522016-10-30 22:43:41 -0700481bool OutputConfiguration::gbpsEqual(const OutputConfiguration& other) const {
482 const std::vector<sp<IGraphicBufferProducer> >& otherGbps =
483 other.getGraphicBufferProducers();
Jayant Chowdhary13f9b2f2020-12-02 22:46:15 -0800484 return simpleVectorsEqual(otherGbps, mGbps);
485}
Shuzhen Wang0129d522016-10-30 22:43:41 -0700486
Jayant Chowdhary13f9b2f2020-12-02 22:46:15 -0800487bool OutputConfiguration::sensorPixelModesUsedEqual(const OutputConfiguration& other) const {
488 const std::vector<int32_t>& othersensorPixelModesUsed = other.getSensorPixelModesUsed();
489 return simpleVectorsEqual(othersensorPixelModesUsed, mSensorPixelModesUsed);
490}
491
Shuzhen Wang38df0ca2024-10-09 11:33:44 -0700492bool OutputConfiguration::mirrorModesEqual(const OutputConfiguration& other) const {
493 const std::vector<int>& otherMirrorModes = other.getMirrorModes();
494 return simpleVectorsEqual(otherMirrorModes, mMirrorModeForProducers);
495
496}
497
Jayant Chowdhary13f9b2f2020-12-02 22:46:15 -0800498bool OutputConfiguration::sensorPixelModesUsedLessThan(const OutputConfiguration& other) const {
499 const std::vector<int32_t>& spms = other.getSensorPixelModesUsed();
Shuzhen Wang38df0ca2024-10-09 11:33:44 -0700500 return simpleVectorsLessThan(mSensorPixelModesUsed, spms);
501}
Jayant Chowdhary13f9b2f2020-12-02 22:46:15 -0800502
Shuzhen Wang38df0ca2024-10-09 11:33:44 -0700503bool OutputConfiguration::mirrorModesLessThan(const OutputConfiguration& other) const {
504 const std::vector<int>& otherMirrorModes = other.getMirrorModes();
505 return simpleVectorsLessThan(mMirrorModeForProducers, otherMirrorModes);
Shuzhen Wang0129d522016-10-30 22:43:41 -0700506}
507
508bool OutputConfiguration::gbpsLessThan(const OutputConfiguration& other) const {
509 const std::vector<sp<IGraphicBufferProducer> >& otherGbps =
510 other.getGraphicBufferProducers();
511
512 if (mGbps.size() != otherGbps.size()) {
513 return mGbps.size() < otherGbps.size();
514 }
515
516 for (size_t i = 0; i < mGbps.size(); i++) {
517 if (mGbps[i] != otherGbps[i]) {
518 return mGbps[i] < otherGbps[i];
519 }
520 }
521
522 return false;
523}
Yin-Chia Yehb97babb2015-03-12 13:42:44 -0700524}; // namespace android